changeset 615:184d6d3f0cd9 draft

remove uncessary Task Name definision
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Sat, 14 Nov 2009 18:21:14 +0900
parents a8a825ca5945
children 350b9b8c985f
files Renderer/Engine/Func.h Renderer/Engine/show_time.cc Renderer/Engine/spe/DrawSpan.cc Renderer/Engine/spe/spe-main.cc Renderer/Engine/task/DrawSpan.cc Renderer/Engine/task/task_init.cc Renderer/Engine/viewer.cc TaskManager/ChangeLog TaskManager/kernel/schedule/Scheduler.h
diffstat 9 files changed, 137 insertions(+), 85 deletions(-) [+]
line wrap: on
line diff
--- a/Renderer/Engine/Func.h	Thu Nov 12 17:06:49 2009 +0900
+++ b/Renderer/Engine/Func.h	Sat Nov 14 18:21:14 2009 +0900
@@ -1,38 +1,39 @@
 enum {
+
      INIT,
      SDL_INIT,
      FINISH,
-     VIEWER_RUN_INIT,
-     VIEWER_RUN_LOOP,
-     VIEWER_RUN_DRAW,
-     VIEWER_RUN_FINISH,
+
+     Create_SGP,
+     Update_SGP,
+     CreatePolygon,
+     CreatePolygonFromSceneGraph,
+     CreateSpan,
+
+     DrawSpan,
+     DrawSpanEnd,
+     DrawBack,
+
+     LoadTexture,
+     SetTexture,
 
-     TASK_INIT_TEXTURE, 
-     TASK_CREATE_SGP,
-     TASK_UPDATE_SGP,
-     TASK_CREATE_PP,
-     TASK_CREATE_PP2,
-     TASK_CREATE_SPAN,
-     TASK_CS_START,
-     TASK_CS_RUN,
-     TASK_DRAW_SPAN,
-     TASK_DRAW_SPAN_END,
-     TASK_DRAW_BACK,
-     TASK_SET_TEXTURE,
-     TASK_MOVE,
-     TASK_DRAW,
-     TASK_DUMMY,
+     Move,
+     Draw,
+
+     Dummy,
 
-     CHAINCAL_TASK,
-     CHAININIT_TASK,
+     UpdateKey,
+     InitKey,
+
+     ShowTime,
+     Switch,
+
+     ChainMove,
+
+
      RUN_FINISH,
 
-     TASK_SWITCH,
-     SHOW_TIME,
-     UPDATE_KEY,
-     INIT_KEY_TASK,
 
-     CHAIN_MOVE,
 };
 
 #define DATA_ID 0
--- a/Renderer/Engine/show_time.cc	Thu Nov 12 17:06:49 2009 +0900
+++ b/Renderer/Engine/show_time.cc	Sat Nov 14 18:21:14 2009 +0900
@@ -10,19 +10,19 @@
     HTaskPtr pre_show;
     */
     /*
-    show = manager->create_task(SHOW_TIME);
+    show = manager->create_task(ShowTime);
     show->set_cpu(SPE_0);
     show->spawn();
     printf("testですよ\n");
     */
 
     /*
-    pre_show = manager->create_task(SHOW_TIME);
+    pre_show = manager->create_task(ShowTime);
     pre_show->set_cpu((CPU_TYPE)((int)SPE_0));    
     pre_show->spawn();
 
     for (int i = 1; i < 6; i++) {        
-	show = manager->create_task(SHOW_TIME);
+	show = manager->create_task(ShowTime);
 	show->set_cpu((CPU_TYPE)((int)SPE_0 + i));
 	show->wait_for(pre_show);
 	show->spawn();
--- a/Renderer/Engine/spe/DrawSpan.cc	Thu Nov 12 17:06:49 2009 +0900
+++ b/Renderer/Engine/spe/DrawSpan.cc	Sat Nov 14 18:21:14 2009 +0900
@@ -485,7 +485,7 @@
 
     free(free_spack);
 
-    TaskPtr nextTask = smanager->create_task(TASK_DRAW_SPAN_END);
+    TaskPtr nextTask = smanager->create_task(DrawSpanEnd);
     nextTask->add_param((int)g);
     smanager->wait_task(nextTask);
 
--- a/Renderer/Engine/spe/spe-main.cc	Thu Nov 12 17:06:49 2009 +0900
+++ b/Renderer/Engine/spe/spe-main.cc	Sat Nov 14 18:21:14 2009 +0900
@@ -22,23 +22,23 @@
 void
 task_init(Scheduler *s)
 {
-    SchedRegisterTask(TASK_INIT_TEXTURE, LoadTexture);
-    SchedRegisterTask(TASK_SET_TEXTURE, SetTexture);
-    SchedRegisterTask(TASK_DRAW_SPAN, DrawSpan);
-    SchedRegisterTask(TASK_DRAW_SPAN_END, DrawSpanEnd);
+    SchedRegister( LoadTexture);
+    SchedRegister( SetTexture);
+    SchedRegister( DrawSpan);
+    SchedRegister( DrawSpanEnd);
 
-    SchedRegisterTask(CHAINCAL_TASK, ChainCal);
-    SchedRegisterTask(CHAININIT_TASK, ChainInit);
+    SchedRegister( ChainCal);
+    SchedRegister( ChainInit);
 #if 0
-    SchedRegisterTask(TASK_DRAW_SPAN2, DrawSpanRenew);
+    SchedRegister( DrawSpanRenew);
 #endif
-    SchedRegisterTask(TASK_DRAW_BACK, DrawBack);
+    SchedRegister( DrawBack);
 
-    SchedRegisterTask(TASK_CREATE_SPAN, CreateSpan);
-    //SchedRegisterTask(TASK_CREATE_PP, CreatePolygon);
+    SchedRegister( CreateSpan);
+    //SchedRegister( CreatePolygon);
 
-    SchedRegisterTask(SHOW_TIME, ShowTime);
+    SchedRegister( ShowTime);
 
-	SchedRegisterTask(INIT_KEY_TASK, InitKey);
-	SchedRegisterTask(UPDATE_KEY, UpdateKey);
+	SchedRegister( InitKey);
+	SchedRegister( UpdateKey);
 }
--- a/Renderer/Engine/task/DrawSpan.cc	Thu Nov 12 17:06:49 2009 +0900
+++ b/Renderer/Engine/task/DrawSpan.cc	Sat Nov 14 18:21:14 2009 +0900
@@ -481,7 +481,7 @@
 
     free(free_spack);
 
-    TaskPtr nextTask = smanager->create_task(TASK_DRAW_SPAN_END);
+    TaskPtr nextTask = smanager->create_task(DrawSpanEnd);
     nextTask->add_param((memaddr)g);
     smanager->wait_task(nextTask);
 
--- a/Renderer/Engine/task/task_init.cc	Thu Nov 12 17:06:49 2009 +0900
+++ b/Renderer/Engine/task/task_init.cc	Sat Nov 14 18:21:14 2009 +0900
@@ -36,31 +36,62 @@
 void
 task_initialize()
 {
-    SchedRegisterTask(TASK_CREATE_SGP, Create_SGP);
-    SchedRegisterTask(TASK_UPDATE_SGP, Update_SGP);
-    SchedRegisterTask(TASK_CREATE_PP,  CreatePolygon);
-    SchedRegisterTask(TASK_CREATE_PP2,  CreatePolygonFromSceneGraph);
-    SchedRegisterTask(TASK_CREATE_SPAN, CreateSpan);
+#if 0
+    SchedRegister(TASK_CREATE_SGP, Create_SGP);
+    SchedRegister(TASK_UPDATE_SGP, Update_SGP);
+    SchedRegister(TASK_CREATE_PP,  CreatePolygon);
+    SchedRegister(TASK_CREATE_PP2,  CreatePolygonFromSceneGraph);
+    SchedRegister(TASK_CREATE_SPAN, CreateSpan);
 
-    SchedRegisterTask(TASK_DRAW_SPAN, DrawSpan);
-    SchedRegisterTask(TASK_DRAW_SPAN_END, DrawSpanEnd);
-//    SchedRegisterTask(TASK_DRAW_SPAN2, DrawSpanRenew);
-    SchedRegisterTask(TASK_DRAW_BACK, DrawBack);
+    SchedRegister(TASK_DRAW_SPAN, DrawSpan);
+    SchedRegister(TASK_DRAW_SPAN_END, DrawSpanEnd);
+//    SchedRegister(TASK_DRAW_SPAN2, DrawSpanRenew);
+    SchedRegister(TASK_DRAW_BACK, DrawBack);
 
-    SchedRegisterTask(TASK_INIT_TEXTURE, LoadTexture);
-    SchedRegisterTask(TASK_SET_TEXTURE, SetTexture);
+    SchedRegister(TASK_INIT_TEXTURE, LoadTexture);
+    SchedRegister(TASK_SET_TEXTURE, SetTexture);
 
-    SchedRegisterTask(TASK_MOVE, Move);
-    SchedRegisterTask(TASK_DRAW, Draw);
+    SchedRegister(TASK_MOVE, Move);
+    SchedRegister(TASK_DRAW, Draw);
 
-    SchedRegisterTask(TASK_DUMMY, Dummy);
+    SchedRegister(TASK_DUMMY, Dummy);
 
-    SchedRegisterTask(UPDATE_KEY, UpdateKey);
-    SchedRegisterTask(INIT_KEY_TASK, InitKey);
+    SchedRegister(UPDATE_KEY, UpdateKey);
+    SchedRegister(INIT_KEY_TASK, InitKey);
 
-    SchedRegisterTask(SHOW_TIME, ShowTime);
-    SchedRegisterTask(TASK_SWITCH, Switch);
+    SchedRegister(SHOW_TIME, ShowTime);
+    SchedRegister(TASK_SWITCH, Switch);
 
     // usr
-    SchedRegisterTask(CHAIN_MOVE, ChainMove);
+    SchedRegister(CHAIN_MOVE, ChainMove);
+#else
+    SchedRegister( Create_SGP);
+    SchedRegister( Update_SGP);
+    SchedRegister(  CreatePolygon);
+    SchedRegister(CreatePolygonFromSceneGraph);
+    SchedRegister( CreateSpan);
+
+    SchedRegister( DrawSpan);
+    SchedRegister( DrawSpanEnd);
+//    SchedRegister(DrawSpanRenew);
+    SchedRegister( DrawBack);
+
+    SchedRegister( LoadTexture);
+    SchedRegister( SetTexture);
+
+    SchedRegister( Move);
+    SchedRegister( Draw);
+
+    SchedRegister( Dummy);
+
+    SchedRegister( UpdateKey);
+    SchedRegister( InitKey);
+
+    SchedRegister( ShowTime);
+    SchedRegister( Switch);
+
+    // usr
+    SchedRegister( ChainMove);
+#endif
+
 }
--- a/Renderer/Engine/viewer.cc	Thu Nov 12 17:06:49 2009 +0900
+++ b/Renderer/Engine/viewer.cc	Sat Nov 14 18:21:14 2009 +0900
@@ -146,10 +146,10 @@
         spackList[i-1].init(i*split_screen_h);
     }
 
-    task_next = manager->create_task(TASK_DUMMY);
+    task_next = manager->create_task(Dummy);
     
     for (int i = 0; i < spe_num; i++) {
-        task_tex = manager->create_task(TASK_INIT_TEXTURE);
+        task_tex = manager->create_task(LoadTexture);
         /*
          * ここはもう少しわかりやすい使い方がいいかもしれぬ。こんなもん?
 		 */
@@ -167,7 +167,7 @@
 {
     HTaskPtr task_next = initLoop();
     // key の情報を格納する領域を確保する (global_alloc(KEY_STATUS))
-    HTaskPtr init_key_task = manager->create_task(INIT_KEY_TASK);
+    HTaskPtr init_key_task = manager->create_task(InitKey);
 	init_key_task->set_cpu(SPE_0);
     init_key_task->spawn();
     
@@ -182,7 +182,7 @@
 
     /* test */
    
-    HTaskPtr task_switch = manager->create_task(TASK_SWITCH);
+    HTaskPtr task_switch = manager->create_task(Switch);
     task_switch->wait_for(task_next);
     task_switch->set_post(post2runMoveDrawLoop, (void*)this, 0);
     task_switch->spawn();
@@ -239,27 +239,27 @@
     Viewer *viewer = (Viewer*)viewer_;
     
     // 同じ PPE 上なので sgroot(ポインタ) を add_param で送る。 
-    //HTaskPtr send_key_task = viewer->manager->create_task(SEND_KEY);
+    //HTaskPtr send_key_task = viewer->manager->create_task(SendKey);
     //send_key_task->add_param((int)sgroot);
     // set input data -> viewer keyPtr
     viewer->getKey();
-    HTaskPtr update_key = viewer->manager->create_task(UPDATE_KEY);
+    HTaskPtr update_key = viewer->manager->create_task(UpdateKey);
     update_key->add_inData(viewer->keyPtr, sizeof(key_stat));
     update_key->set_cpu(SPE_0);
     update_key->spawn();
     
     /* TASK_MOVE は外から引数で取ってくるべき */
     //HTaskPtr move_task = viewer->manager->create_task(viewer->app->move_taskid);    
-    HTaskPtr move_task = viewer->manager->create_task(TASK_MOVE);
+    HTaskPtr move_task = viewer->manager->create_task(Move);
     //move_task->add_param(sgroot);
 
-    //HTaskPtr draw_task = viewer->manager->create_task(TASK_DRAW);
+    //HTaskPtr draw_task = viewer->manager->create_task(Draw);
 
     /* rendering task test */
-    HTaskPtr draw_task = viewer->manager->create_task(TASK_DUMMY);
-    HTaskPtr draw_dummy = viewer->manager->create_task(TASK_DUMMY);
+    HTaskPtr draw_task = viewer->manager->create_task(Dummy);
+    HTaskPtr draw_dummy = viewer->manager->create_task(Dummy);
 
-    HTaskPtr switch_task = viewer->manager->create_task(TASK_SWITCH);
+    HTaskPtr switch_task = viewer->manager->create_task(Switch);
     viewer->draw_dummy = draw_dummy;
     switch_task->wait_for(draw_dummy);
     draw_task->set_post(post2speRendering, (void*)viewer, 0);
@@ -279,7 +279,7 @@
 post2speRunLoop(void *viewer_)
 {
     Viewer *viewer = (Viewer *)viewer_;
-    HTaskPtr task_next = viewer->manager->create_task(TASK_DUMMY);
+    HTaskPtr task_next = viewer->manager->create_task(Dummy);
     viewer->run_move(task_next);
 }
 #endif
@@ -298,7 +298,7 @@
 post2runMove(void *viewer_)
 {
     Viewer *viewer = (Viewer*)viewer_;
-    HTaskPtr task_next = viewer->manager->create_task(TASK_DUMMY);
+    HTaskPtr task_next = viewer->manager->create_task(Dummy);
     viewer->run_move(task_next);
 }
 #endif
@@ -320,7 +320,7 @@
 post2rendering(SchedTask *s, void *viewer_, void *arg)
 {
     Viewer *viewer = (Viewer *)viewer_;
-    HTaskPtr task_next = viewer->manager->create_task(TASK_DUMMY);
+    HTaskPtr task_next = viewer->manager->create_task(Dummy);
     viewer->rendering(task_next);
 }
 
@@ -341,7 +341,7 @@
 post2runLoop(SchedTask *s, void *viewer_, void *arg)
 {
     Viewer *viewer = (Viewer*)viewer_;
-    HTaskPtr task_next = viewer->manager->create_task(TASK_DUMMY);
+    HTaskPtr task_next = viewer->manager->create_task(Dummy);
     viewer->run_loop(task_next);
 
     psx_sync_n();
@@ -377,7 +377,7 @@
 post2runDraw(SchedTask *s, void *viewer_, void *arg)
 {
     Viewer *viewer = (Viewer*)viewer_;
-    HTaskPtr task_next = viewer->manager->create_task(TASK_DUMMY);
+    HTaskPtr task_next = viewer->manager->create_task(Dummy);
     viewer->run_draw(task_next);
 
 }
@@ -410,7 +410,7 @@
 post2speRendering(SchedTask *s, void *viewer_, void *arg)
 {
     Viewer *viewer = (Viewer*)viewer_;
-    HTaskPtr task_next = viewer->manager->create_task(TASK_DUMMY);
+    HTaskPtr task_next = viewer->manager->create_task(Dummy);
     viewer->spe_rendering(task_next);
 }
 
@@ -429,7 +429,7 @@
 post2speDraw(SchedTask *s, void *viewer_, void *arg)
 {
     Viewer *viewer = (Viewer*)viewer_;
-    HTaskPtr task_next = viewer->manager->create_task(TASK_DUMMY);
+    HTaskPtr task_next = viewer->manager->create_task(Dummy);
     viewer->spe_draw(task_next);
 }
 
@@ -448,7 +448,7 @@
 void
 Viewer::common_rendering(HTaskPtr task_next)
 {
-    HTaskPtr task_create_pp = manager->create_task(TASK_CREATE_PP2);
+    HTaskPtr task_create_pp = manager->create_task(CreatePolygonFromSceneGraph);
     
     // SceneGraph(木構造) -> PolygonPack
 
@@ -466,7 +466,7 @@
         int index_end = (index_start + range >= spackList_length)
             ? spackList_length : index_start + range;
 
-		HTaskPtr task_create_sp = manager->create_task(TASK_CREATE_SPAN);
+		HTaskPtr task_create_sp = manager->create_task(CreateSpan);
         task_create_sp->add_inData(ppack, sizeof(PolygonPack));
         task_create_sp->add_inData(spackList_ptr,
                                    sizeof(SpanPack*)*spackList_length_align);
@@ -501,7 +501,7 @@
 {
     HTaskPtr task_draw;
 
-    //task_next = manager->create_task(TASK_DUMMY);
+    //task_next = manager->create_task(Dummy);
     //task_next->set_post(post2runLoop, (void*)this);
 
     ppack->clear();
@@ -518,7 +518,7 @@
         while (startx < this->width) {
             if (spack->info.size > 0) {
                 // Draw SpanPack
-                task_draw = manager->create_task(TASK_DRAW_SPAN);
+                task_draw = manager->create_task(DrawSpan);
                 task_draw->add_inData(spack, sizeof(SpanPack));
 
                 task_draw->add_param(
--- a/TaskManager/ChangeLog	Thu Nov 12 17:06:49 2009 +0900
+++ b/TaskManager/ChangeLog	Sat Nov 14 18:21:14 2009 +0900
@@ -1,3 +1,18 @@
+2009-11-14 Shinji KONO <kono@ie.u-ryukyu.ac.jp>
+
+    要するに、SPE task 側から addOutData できればよい。
+    でも、別に、PPE側から計算してもよいはずだけどね。
+    そうすれば、renew task は取り外せる。
+
+	SchedDefineTask1(DrawSpanEnd,draw_span_end);
+    で、名前を指定させておいて、さらに、
+        SchedExternTask(DrawSpanEnd);
+        SchedRegisterTask(TASK_DRAW_SPAN_END, DrawSpanEnd);
+    で、新しく名前を要求するのって、なんとかならんの? 読みづらいんだよ。
+    DrawSpanEnd を、そのまま使ってもよさそうだけど?
+
+    せっかく、renew task を外したのに、HD crash で失ってしまいました。
+
 2009-10-11 Shinji KONO <kono@ie.u-ryukyu.ac.jp>
 
     単純な、rbuf, wbuf + write return size の task のAPI
--- a/TaskManager/kernel/schedule/Scheduler.h	Thu Nov 12 17:06:49 2009 +0900
+++ b/TaskManager/kernel/schedule/Scheduler.h	Sat Nov 14 18:21:14 2009 +0900
@@ -210,6 +210,9 @@
 #define SchedRegisterTask(cmd, str)             \
     register_task(cmd, runTask_##str);
 
+#define SchedRegister(str)             \
+    register_task(str, runTask_##str);
+
 #define SchedDefineDynamicTask(str,segment)                             \
     SchedDefineTask(str)
 
@@ -231,8 +234,10 @@
 		     _ovly_table[segment].size, \
                     runTask_##str, \
 	runTask_##str##_offset);
+#define SchedRegisterDynamic(str, segment) SchedRegisterDynamicTask(str, str, segment)                    
 #else
 #define SchedRegisterDynamicTask(cmd, str, segment) SchedRegisterTask(cmd, str)
+#define SchedRegisterDynamic(str, segment) SchedRegisterDynamicTask(str, str, segment)                    
 #endif