changeset 468:796f72cb21d9 draft

test_nogl on Mac OS X worked.
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Fri, 02 Oct 2009 16:40:43 +0900
parents 839e34d0cc3c
children f785f63ae940
files TaskManager/ChangeLog TaskManager/Test/test_render/Func.h TaskManager/Test/test_render/task/ChainMove.cc TaskManager/Test/test_render/task/CreateSpan.cc TaskManager/Test/test_render/task/DrawSpan.cc TaskManager/Test/test_render/task/DrawSpan.h TaskManager/Test/test_render/task/Set_Texture.cc TaskManager/Test/test_render/task/task_init.cc TaskManager/Test/test_render/task/update_sgp.cc TaskManager/Test/test_render/viewer.cc TaskManager/kernel/schedule/SchedTask.cc TaskManager/kernel/schedule/Scheduler.cc TaskManager/kernel/schedule/Scheduler.h
diffstat 13 files changed, 106 insertions(+), 62 deletions(-) [+]
line wrap: on
line diff
--- a/TaskManager/ChangeLog	Thu Oct 01 19:25:25 2009 +0900
+++ b/TaskManager/ChangeLog	Fri Oct 02 16:40:43 2009 +0900
@@ -1,3 +1,27 @@
+2009-10-02 Shinji KONO <kono@ie.u-ryukyu.ac.jp>
+
+    DrawSpan で、~DrawSpan() で、allocate したデータを DMA_WAIT
+    して、free しているが、これは、抽象化違反。Task で明示的に
+    DMAするのは禁止。Task 内で、add_outData 出来れば良い。
+
+    renew が正しいような気がするが...
+
+    Task 内で大域変数は使えない。なので、smanager からallocateする
+    必要がある。Task の解放のタイミングではなくて、パイプラインの
+    タイミングでDMA waitとfreeを行なう必要がある。DrawSpan の場合は、
+    add_outData で良いが、内部で allocate/free は行なう必要がある。
+    put_segement がパイプライン動作するべきなのか?
+
+    固定のDMA tagが邪魔。
+
+    DrawSpan は全般的にダメだな〜
+
+    でも、その変更は大きいので、とりあえず動くようにしたい。
+
+    memset 0 は、7.7.3 SL1 Data Cache Range Set to Zero コマンド
+    つかうべき。SPE側でやっても良い。でも、本来は全面埋まるのが
+    普通なのでどうでも良いけど。
+
 2009-08-06 Shinji KONO <kono@ie.u-ryukyu.ac.jp>
 
     で、MemList/MemHash が TaskManager 側に移ったので、
--- a/TaskManager/Test/test_render/Func.h	Thu Oct 01 19:25:25 2009 +0900
+++ b/TaskManager/Test/test_render/Func.h	Fri Oct 02 16:40:43 2009 +0900
@@ -16,7 +16,7 @@
      TASK_CS_START,
      TASK_CS_RUN,
      TASK_DRAW_SPAN,
-//     TASK_DRAW_SPAN2,
+     TASK_DRAW_SPAN_END,
      TASK_DRAW_BACK,
      TASK_SET_TEXTURE,
      TASK_MOVE,
--- a/TaskManager/Test/test_render/task/ChainMove.cc	Thu Oct 01 19:25:25 2009 +0900
+++ b/TaskManager/Test/test_render/task/ChainMove.cc	Fri Oct 02 16:40:43 2009 +0900
@@ -1,5 +1,12 @@
 #include <stdlib.h>
 #include <string.h>
 #include "ChainMove.h"
-#include "viewer_types.h"
+
+
+SchedDefineTask(ChainMove);
 
+static int
+run(SchedTask *s,void *rbuf, void *wbuf)
+{
+     return 0;
+}
--- a/TaskManager/Test/test_render/task/CreateSpan.cc	Thu Oct 01 19:25:25 2009 +0900
+++ b/TaskManager/Test/test_render/task/CreateSpan.cc	Fri Oct 02 16:40:43 2009 +0900
@@ -194,8 +194,8 @@
  * @param[in] tex_y_len 分割する前の Triangle に貼られている Texture の
  *                      長さの割合 (0 ... 1)
  */
-void
-CreateSpan::half_triangle(SchedTask *smanager, SpanPackPtr *spackList,
+static void
+half_triangle(SchedTask *smanager, SpanPackPtr *spackList,
 			  int charge_y_top, int charge_y_end,
 			  TriangleTexInfoPtr tex_info,
 			  VertexPack *vMin,VertexPack *vMid,VertexPack *vMid10,
--- a/TaskManager/Test/test_render/task/DrawSpan.cc	Thu Oct 01 19:25:25 2009 +0900
+++ b/TaskManager/Test/test_render/task/DrawSpan.cc	Fri Oct 02 16:40:43 2009 +0900
@@ -9,21 +9,22 @@
 #include "global_alloc.h"
 
 SchedDefineTask(DrawSpan);
+SchedDefineTask1(DrawSpanEnd,draw_span_end);
 
 #define TEX_LOAD1      0
 #define TEX_LOAD2      1
 #define SPAN_PACK_LOAD 2
 #define FB_STORE       3
 
-/*
- *
- * should be done in some where...
-DrawSpan::~DrawSpan()
+static int
+draw_span_end(SchedTask *s, void *rbuf, void *wbuf)
 {
-    dma_wait(FB_STORE);
-    free((void*)((int)linebuf*doneWrite));
+    Gptr g = (Gptr)s->get_param(0);
+    s->dma_wait(FB_STORE);
+    free((void*)((int)g->linebuf*g->doneWrite));
+    free(g);
+    return 0;
 }
- */
 
 /**
  * テクスチャは、TEXTURE_SPLIT_PIXEL^2 のブロックに分割する
@@ -133,16 +134,16 @@
 
 
 static void
-writebuffer(SchedTask *smanager, unsigned int display, 
+writebuffer(SchedTask *smanager, Gptr g, unsigned int display, 
 	int buf_width, int height, int screen_width)
 {
     for (int i = 0; i < height; i++) {
-        smanager->dma_store(&linebuf[i*buf_width],
+        smanager->dma_store(&g->linebuf[i*buf_width],
                             display + (sizeof(int)*screen_width*i),
                             sizeof(int)*buf_width, FB_STORE);
     }
 
-    doneWrite = 1;
+    g->doneWrite = 1;
 }
 
 /**
@@ -157,7 +158,7 @@
  * @param tex_addr テクスチャのアドレス(MainMemory)
  */
 static void
-updateBuffer(float zpos, int rangex, int x, int y, int tex_x, int tex_y,
+updateBuffer(Gptr g, float zpos, int rangex, int x, int y, int tex_x, int tex_y,
                        float normal_x, float normal_y, float normal_z, TilePtr tile)
 {
 
@@ -169,8 +170,8 @@
 
     color = infinity_light_calc(color,normal_x,normal_y,normal_z);
 
-    zRow[x + (rangex*y)] = zpos*flag + zRow[x + (rangex*y)]*(1-flag);
-    linebuf[x + (rangex*y)] = color*flag + linebuf[x + (rangex*y)]*(1-flag);
+    g->zRow[x + (rangex*y)] = zpos*flag + g->zRow[x + (rangex*y)]*(1-flag);
+    g->linebuf[x + (rangex*y)] = color*flag + g->linebuf[x + (rangex*y)]*(1-flag);
 
 }
 
@@ -182,7 +183,7 @@
  * @param endx 描画終了範囲
  */
 static int
-drawDot1(SchedTask *smanager, SpanPtr span, int startx, int endx, int wait_tag)
+drawDot1(SchedTask *smanager, Gptr g, SpanPtr span, int startx, int endx, int wait_tag)
 {
     int rangex = endx - startx + 1;
 
@@ -220,16 +221,16 @@
     tex_xpos = (int)((span->tex_width-1) * tex);
     tex_ypos = (int)((span->tex_height-1) * tey);
 
-    if (zpos < zRow[localx + (rangex*localy)]) {
+    if (zpos < g->zRow[localx + (rangex*localy)]) {
         tex_addr = getTile(tex_xpos, tex_ypos,
                            span->tex_width, (memaddr)span->tex_addr);
         tex_localx = tex_xpos % TEXTURE_SPLIT_PIXEL;
         tex_localy = tex_ypos % TEXTURE_SPLIT_PIXEL;
 
-	TilePtr tile = smanager->get_segment(tex_addr,tileList);
+	TilePtr tile = smanager->get_segment(tex_addr,g->tileList);
 	smanager->wait_segment(tile);
 
-        updateBuffer(zpos, rangex, localx, localy,
+        updateBuffer(g, zpos, rangex, localx, localy,
                      tex_localx, tex_localy,
                      normal_x,normal_y,normal_z,tile);
     }
@@ -237,11 +238,13 @@
     return -1;
 }
 
+#if 0
 static void
 drawDot2(SchedTask *smanager, SpanPtr span, int startx, int end, int js, int wait_tag)
 {
     //printf("%d\n", js);
 }
+#endif
 
 /**
  * 長さが 1 より大きい Span の描画
@@ -261,7 +264,7 @@
  * @return 「span のどの位置まで rendering が終わったか」の x 座標
  */
 static int
-drawLine1(SchedTask *smanager, SpanPtr span, int startx, int endx, int wait_tag)
+drawLine1(SchedTask *smanager, Gptr g, SpanPtr span, int startx, int endx, int wait_tag)
 {
     int x = span->x;
     int rangex = endx - startx + 1;
@@ -312,7 +315,7 @@
         tex_xpos = (int)((span->tex_width-1) * tex_x);
         tex_ypos = (int)((span->tex_height-1) * tex_y);
 
-        if (tex_z < zRow[localx + (rangex*localy)]) {
+        if (tex_z < g->zRow[localx + (rangex*localy)]) {
             // (tex_xpos, tex_ypos) の、Tile 内(上の図参照)での座標と
             // そのブロックのアドレス(MainMemory)
             memaddr tex_addr;
@@ -323,10 +326,10 @@
                                span->tex_width, (memaddr)span->tex_addr);
             tex_localx = tex_xpos % TEXTURE_SPLIT_PIXEL;
             tex_localy = tex_ypos % TEXTURE_SPLIT_PIXEL;
-	    TilePtr tile = smanager->get_segment(tex_addr,tileList);
+	    TilePtr tile = smanager->get_segment(tex_addr,g->tileList);
 	    smanager->wait_segment(tile);
 
-            updateBuffer(tex_z, rangex, localx, localy,
+            updateBuffer(g, tex_z, rangex, localx, localy,
                          tex_localx, tex_localy,
                          normal_x, normal_y, normal_z, tile);
         }
@@ -372,6 +375,8 @@
 static int
 run(SchedTask *smanager, void *rbuf, void *wbuf)
 {
+    Gptr g = (Gptr)smanager->allocate(sizeof(G));
+
     SpanPackPtr spack = (SpanPackPtr)smanager->get_input(0);
     SpanPackPtr next_spack = (SpanPackPtr)smanager->allocate(sizeof(SpanPack));
     SpanPackPtr free_spack = next_spack; // next_spack の free() 用
@@ -380,8 +385,8 @@
     Span nop_span;
     nop_span.length_x = 1;
 
-    int (DrawSpan::*drawFunc1[2])(SchedTask *, SpanPtr, int, int, int) = {
-        &DrawSpan::drawDot1, &DrawSpan::drawLine1
+    int (*drawFunc1[2])(SchedTask *, Gptr, SpanPtr, int, int, int) = {
+        &drawDot1, &drawLine1
     };
 
     uint32 display   = smanager->get_param(0);
@@ -394,13 +399,13 @@
 
     // y の範囲
     int rangey = smanager->get_param(4);
-    tileList = (TileListPtr)smanager->global_get(GLOBAL_TILE_LIST);
+    g->tileList = (TileListPtr)smanager->global_get(GLOBAL_TILE_LIST);
 
-    zRow = zRow_init(smanager, rangex, rangey);
+    g->zRow = zRow_init(smanager, rangex, rangey);
     //linebuf = linebuf_init(rangex, rangey, 0x00ffffff);
-    linebuf = linebuf_init(smanager, rangex, rangey, 0);
+    g->linebuf = linebuf_init(smanager, rangex, rangey, 0);
 
-    doneWrite = 0;
+    g->doneWrite = 0;
 
     int tl_tag[2] = {TEX_LOAD1, TEX_LOAD2};
     int tl_tag_flg1 = 0;
@@ -432,8 +437,8 @@
              * span の長さによって、drawLine か drawDot を選択している
              */
             next_span_x
-                = (this->*drawFunc1[(span->length_x != 1)])(
-		    smanager, 
+                = (*drawFunc1[(span->length_x != 1)])(
+		    smanager, g,
                     span, rangex_start, rangex_end, tl_tag[tl_tag_flg1]);
             next_span = span;
 
@@ -458,12 +463,12 @@
         next_spack = tmp_spack;
     } while (spack);
 
-    writebuffer(smanager, display, rangex, rangey, screen_width);
+    writebuffer(smanager, g, display, rangex, rangey, screen_width);
 
     // linebuf は、writebuffer() の dma_store を wait する
     // DrawSpan::~DrawSpan() 内で free する。
     //free(linebuf);
-    free(zRow);
+    free(g->zRow);
 
 //FINISH:
     /**
@@ -472,6 +477,11 @@
      */
 
     free(free_spack);
+
+    TaskPtr nextTask = smanager->create_task(TASK_DRAW_SPAN_END);
+    nextTask->add_param((int)g);
+    smanager->wait_task(nextTask);
+
     return 0;
 }
 
--- a/TaskManager/Test/test_render/task/DrawSpan.h	Thu Oct 01 19:25:25 2009 +0900
+++ b/TaskManager/Test/test_render/task/DrawSpan.h	Fri Oct 02 16:40:43 2009 +0900
@@ -8,7 +8,7 @@
 #include "TileHash.h"
 #endif
 
-struct g {
+static typedef struct {
     int *linebuf;
     float *zRow;
     TileListPtr tileList;
@@ -19,26 +19,25 @@
 
 static    int* linebuf_init(SchedTask *smanager, int width, int height, int rgb);
 static    float* zRow_init(SchedTask *smanager, int width, int height);
-static    TilePtr set_rgb(memaddr addr, int wait_tag);
-static    void set_rgbs(memaddr addr, uint32 *max_addr, int wait_tag);
+// static    TilePtr set_rgb(memaddr addr, int wait_tag);
+// static    void set_rgbs(memaddr addr, uint32 *max_addr, int wait_tag);
 static    uint32 get_rgb(int tx, int ty, TilePtr tile);
-static    TilePtr isAvailableTile(memaddr addr);
+// static    TilePtr isAvailableTile(memaddr addr);
 static    memaddr getTile(int tx, int ty, int tw, memaddr tex_addr_top);
 static    int getTexBlock(int tx, int ty, int twidth);
-static    void writebuffer(SchedTask *smanager, unsigned int display, 
+static    void writebuffer(SchedTask *smanager, Gptr g, unsigned int display, 
 	    int width, int height, int screen_width);
-static    void updateBuffer(float zpos, int rangex, int x, int y,
+static    void updateBuffer(Gptr g, float zpos, int rangex, int x, int y,
                       int tex_x, int tex_y, float normal_x, float nomral_x, float normal_z, TilePtr tile);
 
 
-static    void reboot(SpanPackPtr spack, int cur_span_x);
+// static    void reboot(SpanPackPtr spack, int cur_span_x);
 
-static    int drawDot1(SchedTask *smanager, SpanPtr span, int startx, int endx, int wait_tag);
-static    void drawDot2(SchedTask *smanager, SpanPtr span, int startx, int endx, int js, int wait_tag);
-static    int drawLine1(SchedTask *smanager, SpanPtr span, int startx, int endx, int wait_tag);
-static    void drawLine2(SchedTask *smanager, SpanPtr span, int startx, int endx, int js, int wait_tag);
+static    int drawDot1(SchedTask *smanager, Gptr g, SpanPtr span, int startx, int endx, int wait_tag);
+//static    void drawDot2(SchedTask *smanager, SpanPtr span, int startx, int endx, int js, int wait_tag);
+static    int drawLine1(SchedTask *smanager, Gptr g, SpanPtr span, int startx, int endx, int wait_tag);
+// static    void drawLine2(SchedTask *smanager, SpanPtr span, int startx, int endx, int js, int wait_tag);
 static    int infinity_light_calc(int color,float normal_x, float normal_y, float normal_z);
-};
 
 typedef struct {
     uint32 display;
--- a/TaskManager/Test/test_render/task/Set_Texture.cc	Thu Oct 01 19:25:25 2009 +0900
+++ b/TaskManager/Test/test_render/task/Set_Texture.cc	Fri Oct 02 16:40:43 2009 +0900
@@ -11,16 +11,16 @@
 {
     void *src[4];
 
-    src[0] = get_input(rbuf, 0);
-    src[1] = get_input(rbuf, 1);
-    src[2] = get_input(rbuf, 2);
-    src[3] = get_input(rbuf, 3);
+    src[0] = s->get_input(rbuf, 0);
+    src[1] = s->get_input(rbuf, 1);
+    src[2] = s->get_input(rbuf, 2);
+    src[3] = s->get_input(rbuf, 3);
 
-    if (global_get(TEXTURE_ID)) {
+    if (s->global_get(TEXTURE_ID)) {
         return 0;
     } else {
         //タスクが共有できる領域確保
-        void *data = global_alloc(TEXTURE_ID, MAX_LOAD_SIZE*4);
+        void *data = s->global_alloc(TEXTURE_ID, MAX_LOAD_SIZE*4);
 
         memcpy(data, src[0], MAX_LOAD_SIZE);
         memcpy((void*)((int)data + MAX_LOAD_SIZE), src[1], MAX_LOAD_SIZE);
--- a/TaskManager/Test/test_render/task/task_init.cc	Thu Oct 01 19:25:25 2009 +0900
+++ b/TaskManager/Test/test_render/task/task_init.cc	Fri Oct 02 16:40:43 2009 +0900
@@ -8,6 +8,7 @@
 SchedExternTask(CreateSpan);
 
 SchedExternTask(DrawSpan);
+SchedExternTask(DrawSpanEnd);
 SchedExternTask(DrawSpanRenew);
 SchedExternTask(DrawBack);
 
@@ -26,7 +27,6 @@
 SchedExternTask(UpdateKey);
 SchedExternTask(InitKey);
 
-SchedExternTask(ChainMove);
 SchedExternTask(Switch);
 
 
@@ -43,6 +43,7 @@
     SchedRegisterTask(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);
 
--- a/TaskManager/Test/test_render/task/update_sgp.cc	Thu Oct 01 19:25:25 2009 +0900
+++ b/TaskManager/Test/test_render/task/update_sgp.cc	Fri Oct 02 16:40:43 2009 +0900
@@ -12,8 +12,8 @@
 run(SchedTask *s,void *rbuf, void *wbuf)
 {
     SceneGraphNodePtr node;
-    SceneGraphPack *sgp  = (SceneGraphPack*)get_input(rbuf, 0);
-    SceneGraphPack *_sgp = (SceneGraphPack*)get_output(wbuf, 0);
+    SceneGraphPack *sgp  = (SceneGraphPack*)s->get_input(rbuf, 0);
+    SceneGraphPack *_sgp = (SceneGraphPack*)s->get_output(wbuf, 0);
     //int screen_width = get_param(0);
     //int screen_height = get_param(1);
 
--- a/TaskManager/Test/test_render/viewer.cc	Thu Oct 01 19:25:25 2009 +0900
+++ b/TaskManager/Test/test_render/viewer.cc	Fri Oct 02 16:40:43 2009 +0900
@@ -509,6 +509,9 @@
                     (uint32)&pixels[(startx-1) + this->width*(starty-1)]);
                 task_draw->add_param(this->width);
             } else {
+		// 7.7.3 SL1 Data Cache Range Set to Zero コマンド
+		//  を使って、DMAでclearするべき... ということは、
+		// それもSPEでやる方が良い?
                 memset(&pixels[(startx-1)+this->width*(starty-1)],
                        0, (this->width)*sizeof(int)*rangey);
 				break;
--- a/TaskManager/kernel/schedule/SchedTask.cc	Thu Oct 01 19:25:25 2009 +0900
+++ b/TaskManager/kernel/schedule/SchedTask.cc	Fri Oct 02 16:40:43 2009 +0900
@@ -321,7 +321,7 @@
 {
     __debug("[SchedTask:%s]\n", __FUNCTION__);
 
-    delete p;
+    // delete p;  move to Scheduler
 
     return (this->*ex_next)();
 }
--- a/TaskManager/kernel/schedule/Scheduler.cc	Thu Oct 01 19:25:25 2009 +0900
+++ b/TaskManager/kernel/schedule/Scheduler.cc	Fri Oct 02 16:40:43 2009 +0900
@@ -55,8 +55,6 @@
 void
 Scheduler::run(void)
 {
-    SchedTaskBase* taskTmp;
-
     task1 = new SchedNop();
     task2 = new SchedNop();
     task3 = new SchedNop();
@@ -67,11 +65,11 @@
         task3->write();
         task2->exec();
         task1->read();
+	delete task3; 
 
-        taskTmp = task3;
         task3 = task2;
         task2 = task1;
-        task1 = task1->next(this, taskTmp);
+        task1 = task1->next(this, 0);
     } while (task1);
 
     delete task3;
--- a/TaskManager/kernel/schedule/Scheduler.h	Thu Oct 01 19:25:25 2009 +0900
+++ b/TaskManager/kernel/schedule/Scheduler.h	Fri Oct 02 16:40:43 2009 +0900
@@ -191,7 +191,9 @@
     str() {}                                                            \
     BASE_NEW_DELETE(str)                                                \
 
-#define SchedDefineTask(str)                                            \
+#define SchedDefineTask(str)  SchedDefineTask1(str,run)                                            \
+
+#define SchedDefineTask1(str,run)                                            \
     static int run(SchedTask *smanager, void *rbuf, void *wbuf); \
     extern "C" { \
     int runTask_##str(SchedTask *smanager, void *rbuf, void *wbuf) \