changeset 187:e9b5dcdae38d draft

fix
author gongo@localhost.localdomain
date Thu, 08 Jan 2009 13:46:57 +0900
parents 06cdf8baa989
children fe854a6ee9e2
files TaskManager/Cell/spe/SchedNop2Ready.cc TaskManager/Cell/spe/SchedTask.cc TaskManager/Cell/spe/Scheduler.cc TaskManager/Test/test_render/spe/DrawSpanRenew.cpp TaskManager/kernel/schedule/SchedNop2Ready.cc TaskManager/kernel/schedule/SchedTask.cc TaskManager/kernel/schedule/Scheduler.cc include/TaskManager/Scheduler.h
diffstat 8 files changed, 87 insertions(+), 54 deletions(-) [+]
line wrap: on
line diff
--- a/TaskManager/Cell/spe/SchedNop2Ready.cc	Tue Jan 06 16:18:37 2009 +0900
+++ b/TaskManager/Cell/spe/SchedNop2Ready.cc	Thu Jan 08 13:46:57 2009 +0900
@@ -26,7 +26,7 @@
     
     delete p;
 
-    nextSched = scheduler->get_nextRenewTaskList(NULL, 0);
+    nextSched = scheduler->get_nextRenewTaskList();
 	
     // RenewTask がある
     if (nextSched) {
--- a/TaskManager/Cell/spe/SchedTask.cc	Tue Jan 06 16:18:37 2009 +0900
+++ b/TaskManager/Cell/spe/SchedTask.cc	Thu Jan 08 13:46:57 2009 +0900
@@ -303,25 +303,20 @@
     if (__cur_index < __list->length) {
 	SchedTaskBase *nextSched;
 
-	nextSched = __scheduler->get_nextRenewTaskList(__list, __cur_index);
+	nextSched = __scheduler->get_nextRenewTaskList();
 	
 	// RenewTask がある
 	if (nextSched) {
+	    __scheduler->set_backupTaskList(__list);
+	    __scheduler->set_backupTaskListIndex(__cur_index);
 	    return nextSched;
 	} else {
-	    TaskPtr nextTask
-		= &__list->tasks[__cur_index++];
+	    TaskPtr nextTask = &__list->tasks[__cur_index++];
 	    nextSched = createSchedTask(nextTask);
 	    ((SchedTask*)nextSched)->__init__(__list, nextTask, __cur_index,
 					      __scheduler->get_curReadBuf(),
 					      __scheduler->get_curWriteBuf(),
 					      __scheduler);
-
-	    /**
-	     * この理由は SchedTask:~SchedTask() で
-	     */
-	    __list = NULL;
-
 	    return nextSched;
 	}
     } else {
@@ -362,14 +357,18 @@
 	__list = NULL;
 	return nextSched;
     } else {
-	uint32 nextList = (uint32)__list->next;
+	SchedTaskBase *nextList;
+	
+	nextList = __scheduler->get_nextRenewTaskList();
 	
-	if (nextList == 0) {
+	if (nextList) {
+	    return nextList;
+	} else {
 	    TaskListPtr nextList = __scheduler->get_backupTaskList();
 
-	    // 中断した TaskList
+	    // 中断した TaskList がある
 	    if (nextList) {
-		__cur_index = __scheduler->bakIndex_taskList;
+		__cur_index = __scheduler->get_backupTaskListIndex();
 		
 		nextTask = &nextList->tasks[__cur_index++];
 		nextSched = createSchedTask(nextTask);
@@ -382,11 +381,6 @@
 	    } else {
 		return new SchedNop2Ready(__scheduler);
 	    }
-	} else {
-	    __scheduler->renewTop_taskList
-		= __scheduler->renewTop_taskList->next;
-	    return createSchedTaskList(nextList, __scheduler,
-				       SCHED_TASKLIST_RENEW);
 	}
     }
 }
--- a/TaskManager/Cell/spe/Scheduler.cc	Tue Jan 06 16:18:37 2009 +0900
+++ b/TaskManager/Cell/spe/Scheduler.cc	Thu Jan 08 13:46:57 2009 +0900
@@ -145,17 +145,14 @@
  * @return next RenewTaskList
  */
 SchedTaskList*
-Scheduler::get_nextRenewTaskList(TaskListPtr curList, int curIndex)
+Scheduler::get_nextRenewTaskList(void)
 {
     if (renewTop_taskList) {
 	TaskListPtr list  = renewTop_taskList;
 	renewTop_taskList = renewTop_taskList->next;
 	renewCur_taskList = NULL;
-	
-	bak_curTaskList = curList;
-	bakIndex_taskList = curIndex;
-	
-	//list->next = NULL;
+		
+	list->next = NULL;
 	SchedTaskList *sched
 	    = createSchedTaskList((uint32)list, this, SCHED_TASKLIST_RENEW);
 	return sched;
@@ -164,6 +161,18 @@
     }
 }
 
+void
+Scheduler::set_backupTaskList(TaskListPtr cur_taskList)
+{
+    bak_curTaskList = cur_taskList;
+}
+
+void
+Scheduler::set_backupTaskListIndex(int cur_index)
+{
+    bakIndex_taskList = cur_index;
+}
+
 /**
  * RenewTaskList 実行前に中断した TaskList を返す
  * NULL の場合、中断した TaskList は無い。
@@ -173,7 +182,19 @@
 TaskListPtr
 Scheduler::get_backupTaskList(void)
 {
-    return bak_curTaskList;
+    TaskListPtr ret = bak_curTaskList;
+    
+    bak_curTaskList = NULL;
+    return ret;
+}
+
+int
+Scheduler::get_backupTaskListIndex(void)
+{
+    int ret = bakIndex_taskList;
+
+    bakIndex_taskList = 0;
+    return ret;
 }
 
 void
--- a/TaskManager/Test/test_render/spe/DrawSpanRenew.cpp	Tue Jan 06 16:18:37 2009 +0900
+++ b/TaskManager/Test/test_render/spe/DrawSpanRenew.cpp	Thu Jan 08 13:46:57 2009 +0900
@@ -159,7 +159,7 @@
 					   span->tex_width, span->tex_addr);
 			tex_localx = tex_xpos % TEXTURE_SPLIT_PIXEL;
 			tex_localy = tex_ypos % TEXTURE_SPLIT_PIXEL;
-
+			goto FINISH;
 			if (!isAvailableTile(tex_addr)) {
 			    spack->info.start = t;
 			    set_rgb(tex_addr);
--- a/TaskManager/kernel/schedule/SchedNop2Ready.cc	Tue Jan 06 16:18:37 2009 +0900
+++ b/TaskManager/kernel/schedule/SchedNop2Ready.cc	Thu Jan 08 13:46:57 2009 +0900
@@ -26,7 +26,7 @@
     
     delete p;
 
-    nextSched = scheduler->get_nextRenewTaskList(NULL, 0);
+    nextSched = scheduler->get_nextRenewTaskList();
 	
     // RenewTask がある
     if (nextSched) {
--- a/TaskManager/kernel/schedule/SchedTask.cc	Tue Jan 06 16:18:37 2009 +0900
+++ b/TaskManager/kernel/schedule/SchedTask.cc	Thu Jan 08 13:46:57 2009 +0900
@@ -303,25 +303,20 @@
     if (__cur_index < __list->length) {
 	SchedTaskBase *nextSched;
 
-	nextSched = __scheduler->get_nextRenewTaskList(__list, __cur_index);
+	nextSched = __scheduler->get_nextRenewTaskList();
 	
 	// RenewTask がある
 	if (nextSched) {
+	    __scheduler->set_backupTaskList(__list);
+	    __scheduler->set_backupTaskListIndex(__cur_index);
 	    return nextSched;
 	} else {
-	    TaskPtr nextTask
-		= &__list->tasks[__cur_index++];
+	    TaskPtr nextTask = &__list->tasks[__cur_index++];
 	    nextSched = createSchedTask(nextTask);
 	    ((SchedTask*)nextSched)->__init__(__list, nextTask, __cur_index,
 					      __scheduler->get_curReadBuf(),
 					      __scheduler->get_curWriteBuf(),
 					      __scheduler);
-
-	    /**
-	     * この理由は SchedTask:~SchedTask() で
-	     */
-	    __list = NULL;
-
 	    return nextSched;
 	}
     } else {
@@ -362,14 +357,18 @@
 	__list = NULL;
 	return nextSched;
     } else {
-	uint32 nextList = (uint32)__list->next;
+	SchedTaskBase *nextList;
+	
+	nextList = __scheduler->get_nextRenewTaskList();
 	
-	if (nextList == 0) {
+	if (nextList) {
+	    return nextList;
+	} else {
 	    TaskListPtr nextList = __scheduler->get_backupTaskList();
 
-	    // 中断した TaskList
+	    // 中断した TaskList がある
 	    if (nextList) {
-		__cur_index = __scheduler->bakIndex_taskList;
+		__cur_index = __scheduler->get_backupTaskListIndex();
 		
 		nextTask = &nextList->tasks[__cur_index++];
 		nextSched = createSchedTask(nextTask);
@@ -382,11 +381,6 @@
 	    } else {
 		return new SchedNop2Ready(__scheduler);
 	    }
-	} else {
-	    __scheduler->renewTop_taskList
-		= __scheduler->renewTop_taskList->next;
-	    return createSchedTaskList(nextList, __scheduler,
-				       SCHED_TASKLIST_RENEW);
 	}
     }
 }
--- a/TaskManager/kernel/schedule/Scheduler.cc	Tue Jan 06 16:18:37 2009 +0900
+++ b/TaskManager/kernel/schedule/Scheduler.cc	Thu Jan 08 13:46:57 2009 +0900
@@ -145,17 +145,14 @@
  * @return next RenewTaskList
  */
 SchedTaskList*
-Scheduler::get_nextRenewTaskList(TaskListPtr curList, int curIndex)
+Scheduler::get_nextRenewTaskList(void)
 {
     if (renewTop_taskList) {
 	TaskListPtr list  = renewTop_taskList;
 	renewTop_taskList = renewTop_taskList->next;
 	renewCur_taskList = NULL;
-	
-	bak_curTaskList = curList;
-	bakIndex_taskList = curIndex;
-	
-	//list->next = NULL;
+		
+	list->next = NULL;
 	SchedTaskList *sched
 	    = createSchedTaskList((uint32)list, this, SCHED_TASKLIST_RENEW);
 	return sched;
@@ -164,6 +161,18 @@
     }
 }
 
+void
+Scheduler::set_backupTaskList(TaskListPtr cur_taskList)
+{
+    bak_curTaskList = cur_taskList;
+}
+
+void
+Scheduler::set_backupTaskListIndex(int cur_index)
+{
+    bakIndex_taskList = cur_index;
+}
+
 /**
  * RenewTaskList 実行前に中断した TaskList を返す
  * NULL の場合、中断した TaskList は無い。
@@ -173,7 +182,19 @@
 TaskListPtr
 Scheduler::get_backupTaskList(void)
 {
-    return bak_curTaskList;
+    TaskListPtr ret = bak_curTaskList;
+    
+    bak_curTaskList = NULL;
+    return ret;
+}
+
+int
+Scheduler::get_backupTaskListIndex(void)
+{
+    int ret = bakIndex_taskList;
+
+    bakIndex_taskList = 0;
+    return ret;
 }
 
 void
--- a/include/TaskManager/Scheduler.h	Tue Jan 06 16:18:37 2009 +0900
+++ b/include/TaskManager/Scheduler.h	Thu Jan 08 13:46:57 2009 +0900
@@ -129,8 +129,11 @@
     ListDataPtr get_curWriteBuf(void);
     TaskListPtr get_renewListBuf(void);
 
-    SchedTaskList* get_nextRenewTaskList(TaskListPtr curList, int curIndex);
+    void set_backupTaskList(TaskListPtr cur_taskList);
+    void set_backupTaskListIndex(int cur_index);
+    SchedTaskList* get_nextRenewTaskList(void);
     TaskListPtr get_backupTaskList(void);
+    int get_backupTaskListIndex(void);
 
     // なんか名前が変だが。。。
     /* TaskGroup */