diff TaskManager/Test/test_render/spe/DrawSpan.cpp @ 182:8e9ada0c1ed0 draft

add get_inputAddr, get_outputAddr
author gongo@gendarme.cr.ie.u-ryukyu.ac.jp
date Tue, 23 Dec 2008 16:27:07 +0900
parents e3b7776b1420
children 90dcdc080e9d a19d3ed4ce5b
line wrap: on
line diff
--- a/TaskManager/Test/test_render/spe/DrawSpan.cpp	Tue Dec 23 15:54:09 2008 +0900
+++ b/TaskManager/Test/test_render/spe/DrawSpan.cpp	Tue Dec 23 16:27:07 2008 +0900
@@ -123,20 +123,23 @@
 int
 DrawSpan::run(void *rbuf, void *wbuf)
 {
-    SpanPack *sp = (SpanPack*)smanager->get_input(0);
-    SpanPack *next_sp =
+    SpanPack *spack = (SpanPack*)smanager->get_input(0);
+    SpanPack *next_spack =
 	(SpanPack*)smanager->allocate(sizeof(SpanPack));
-    SpanPack *free_sp = next_sp; // next_sp の free() 用
-    SpanPack *tmp_sp = NULL;
+    SpanPack *free_spack = next_spack; // next_spack の free() 用
     Span *span;
 
     hash = (TileHashPtr)smanager->global_get(GLOBAL_TEXTURE_HASH);
     tileList = (TileListPtr)smanager->global_get(GLOBAL_TILE_LIST);
 
-    int rangex_start  = get_param(0); // このタスクが担当する x の範囲の始点
-    int rangex_end    = get_param(1); // 終点 (start <= x <= end)
-    int rangey        = get_param(2); // y の範囲 (render_y + rangey - 1)
+    int rangex_start  = smanager->get_param(0);
+    int rangex_end    = smanager->get_param(1); 
+
+    // このタスクが担当する x の範囲
     int rangex        = rangex_end - rangex_start + 1;
+
+    // y の範囲 (render_y + rangey - 1)
+    int rangey        = smanager->get_param(2);
     
     float *zRow = (float*)smanager->get_input(1);
     int **linebuf = (int**)smanager->allocate(sizeof(int*)*rangey);
@@ -152,15 +155,15 @@
 	 * 現在の SpanPack を処理してる間に
 	 * 次の SpanPack の DMA 転送を行う
 	 */
-	if (sp->next != NULL) {
-	    smanager->dma_load(next_sp, (uint32)sp->next,
+	if (spack->next != NULL) {
+	    smanager->dma_load(next_spack, (uint32)spack->next,
 			       sizeof(SpanPack), SPAN_PACK_LOAD);
 	} else {
-	    next_sp = NULL;
+	    next_spack = NULL;
 	}
 
-	for (int t = sp->info.start; t < sp->info.size; t++) {	  
-	    span = &sp->span[t];
+	for (int t = 0; t < spack->info.size; t++) {	  
+	    span = &spack->span[t];
 
 	    Uint32 rgb = 0x00ff00;
 	    float tex1 = span->tex_x1;
@@ -224,9 +227,6 @@
 
 		    tex_x = tex1*(x_len-1-j)/(x_len-1) + tex2*j/(x_len-1);
 		    tex_y = tey1*(x_len-1-j)/(x_len-1) + tey2*j/(x_len-1);
-		    /**
-		     * ・・・なんかかっこいい書き方ないかな
-		     */
 		    if (tex_x > 1) tex_x = 1;
 		    if (tex_x < 0) tex_x = 0;
 		    if (tex_y > 1) tex_y = 1;
@@ -251,12 +251,12 @@
 
 	smanager->dma_wait(SPAN_PACK_LOAD);
 
-	tmp_sp = sp;
-	sp = next_sp;
-	next_sp = tmp_sp;
-    } while (sp);
+	SpanPack *tmp_spack = spack;
+	spack = next_spack;
+	next_spack = tmp_spack;
+    } while (spack);
 
-    free(free_sp);
+    free(free_spack);
     free(linebuf);
 
     return 0;