Mercurial > hg > Game > Cerium
changeset 616:350b9b8c985f draft
First addOutput rendering try failed.
author | Shinji KONO <kono@ie.u-ryukyu.ac.jp> |
---|---|
date | Sat, 14 Nov 2009 18:57:54 +0900 |
parents | 184d6d3f0cd9 |
children | df618a956eb9 |
files | Renderer/Engine/task/DrawSpan.cc Renderer/Engine/task/DrawSpan.h Renderer/Engine/task/task_init.cc Renderer/Engine/viewer.cc TaskManager/ChangeLog TaskManager/kernel/ppe/Task.cc TaskManager/kernel/ppe/Task.h |
diffstat | 7 files changed, 72 insertions(+), 121 deletions(-) [+] |
line wrap: on
line diff
--- a/Renderer/Engine/task/DrawSpan.cc Sat Nov 14 18:21:14 2009 +0900 +++ b/Renderer/Engine/task/DrawSpan.cc Sat Nov 14 18:57:54 2009 +0900 @@ -7,27 +7,45 @@ #include "Func.h" #include "sys.h" #include "global_alloc.h" +#include "SchedTask.h" +#include "Tapestry.h" +#include "SpanPack.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 -static int -draw_span_end(SchedTask *s, void *rbuf, void *wbuf) -{ - Gptr g = (Gptr)s->get_param(0); - s->dma_wait(FB_STORE); +typedef struct { + int **linebuf; + float *zRow; + TileListPtr tileList; + int doneWrite; +} G, *Gptr; - if (!g->doneWrite) { - free(g->linebuf); - } - free(g); - return 0; -} +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 uint32 get_rgb(int tx, int ty, TilePtr tile); +// 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 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 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); + /** * テクスチャは、TEXTURE_SPLIT_PIXEL^2 のブロックに分割する @@ -95,16 +113,17 @@ * @param rgb Initial value of RGB at Buffer * @return Buffer */ -static int* +static int ** linebuf_init(SchedTask *smanager, int width, int height, int rgb) { - int *buf = (int*)smanager->allocate(sizeof(int)*width*height); - - for (int i = 0; i < width*height; i++) { - buf[i] = rgb; + int **linebuf = (int**)smanager->allocate(height*sizeof(int*)); + for(int h = 0;h<height;h++) { + int *buf = linebuf[height] = (int*)smanager->get_output(height); + for (int i = 0; i < width*height; i++) { + buf[i] = rgb; + } } - - return buf; + return linebuf; } /** @@ -136,18 +155,6 @@ } -static void -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(&g->linebuf[i*buf_width], - display + (sizeof(int)*screen_width*i), - sizeof(int)*buf_width, FB_STORE); - } - - g->doneWrite = 1; -} /** * zRow と Linebuf を更新する @@ -174,7 +181,8 @@ color = infinity_light_calc(color,normal_x,normal_y,normal_z); 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); + int *point = &g->linebuf[y][x] ; + *point = color*flag + *point *(1-flag); } @@ -392,7 +400,7 @@ &drawDot1, &drawLine1 }; - uint32 display = smanager->get_param(0); + // uint32 display = smanager->get_param(0); int screen_width = smanager->get_param(1); int rangex_start = smanager->get_param(2); int rangex_end = smanager->get_param(3); @@ -405,11 +413,8 @@ g->tileList = (TileListPtr)smanager->global_get(GLOBAL_TILE_LIST); g->zRow = zRow_init(smanager, rangex, rangey); - //linebuf = linebuf_init(rangex, rangey, 0x00ffffff); g->linebuf = linebuf_init(smanager, rangex, rangey, 0); - g->doneWrite = 0; - int tl_tag[2] = {TEX_LOAD1, TEX_LOAD2}; int tl_tag_flg1 = 0; int tl_tag_flg2 = 1; @@ -466,12 +471,10 @@ next_spack = tmp_spack; } while (spack); - writebuffer(smanager, g, display, rangex, rangey, screen_width); - // linebuf は、writebuffer() の dma_store を wait する - // DrawSpan::~DrawSpan() 内で free する。 - //free(linebuf); free(g->zRow); + free(g->linebuf); + free(g); //FINISH: /**
--- a/Renderer/Engine/task/DrawSpan.h Sat Nov 14 18:21:14 2009 +0900 +++ b/Renderer/Engine/task/DrawSpan.h Sat Nov 14 18:57:54 2009 +0900 @@ -1,45 +1,5 @@ #ifndef INCLUDED_TASK_DRAW_SPAN #define INCLUDED_TASK_DRAW_SPAN -#include "SchedTask.h" -#include "Tapestry.h" -#include "SpanPack.h" - -typedef struct { - int *linebuf; - float *zRow; - TileListPtr tileList; - int doneWrite; -} G, *Gptr; - -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 uint32 get_rgb(int tx, int ty, TilePtr tile); -// 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, Gptr g, unsigned int display, - int width, int height, int screen_width); -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 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; - int screen_width; - int rangex_start; - int rangex_end; - int rangey; -} DrawSpanArg, *DrawSpanArgPtr; #endif
--- a/Renderer/Engine/task/task_init.cc Sat Nov 14 18:21:14 2009 +0900 +++ b/Renderer/Engine/task/task_init.cc Sat Nov 14 18:57:54 2009 +0900 @@ -8,7 +8,6 @@ SchedExternTask(CreateSpan); SchedExternTask(DrawSpan); -SchedExternTask(DrawSpanEnd); SchedExternTask(DrawSpanRenew); SchedExternTask(DrawBack); @@ -36,35 +35,6 @@ void task_initialize() { -#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); - - SchedRegister(TASK_DRAW_SPAN, DrawSpan); - SchedRegister(TASK_DRAW_SPAN_END, DrawSpanEnd); -// SchedRegister(TASK_DRAW_SPAN2, DrawSpanRenew); - SchedRegister(TASK_DRAW_BACK, DrawBack); - - SchedRegister(TASK_INIT_TEXTURE, LoadTexture); - SchedRegister(TASK_SET_TEXTURE, SetTexture); - - SchedRegister(TASK_MOVE, Move); - SchedRegister(TASK_DRAW, Draw); - - SchedRegister(TASK_DUMMY, Dummy); - - SchedRegister(UPDATE_KEY, UpdateKey); - SchedRegister(INIT_KEY_TASK, InitKey); - - SchedRegister(SHOW_TIME, ShowTime); - SchedRegister(TASK_SWITCH, Switch); - - // usr - SchedRegister(CHAIN_MOVE, ChainMove); -#else SchedRegister( Create_SGP); SchedRegister( Update_SGP); SchedRegister( CreatePolygon); @@ -72,8 +42,6 @@ SchedRegister( CreateSpan); SchedRegister( DrawSpan); - SchedRegister( DrawSpanEnd); -// SchedRegister(DrawSpanRenew); SchedRegister( DrawBack); SchedRegister( LoadTexture); @@ -92,6 +60,5 @@ // usr SchedRegister( ChainMove); -#endif }
--- a/Renderer/Engine/viewer.cc Sat Nov 14 18:21:14 2009 +0900 +++ b/Renderer/Engine/viewer.cc Sat Nov 14 18:57:54 2009 +0900 @@ -521,9 +521,16 @@ task_draw = manager->create_task(DrawSpan); task_draw->add_inData(spack, sizeof(SpanPack)); - task_draw->add_param( + task_draw->add_param(0, (memaddr)&pixels[(startx-1) + this->width*(starty-1)]); - task_draw->add_param(this->width); + task_draw->add_param(1,this->width); + + int height = rangey; + for (int i = 0; i < height; i++) { + task_draw->add_outData( + &pixels[(startx-1) + this->width*(starty-1)], + this->width*sizeof(int)); + } } else { // 7.7.3 SL1 Data Cache Range Set to Zero コマンド // を使って、DMAでclearするべき... ということは、 @@ -533,9 +540,9 @@ break; } - task_draw->add_param(startx); - task_draw->add_param(endx); - task_draw->add_param(rangey); + task_draw->add_param(2,startx); + task_draw->add_param(3,endx); + task_draw->add_param(4,rangey); task_draw->set_cpu(SPE_ANY); task_next->wait_for(task_draw); task_draw->spawn();
--- a/TaskManager/ChangeLog Sat Nov 14 18:21:14 2009 +0900 +++ b/TaskManager/ChangeLog Sat Nov 14 18:57:54 2009 +0900 @@ -13,6 +13,8 @@ せっかく、renew task を外したのに、HD crash で失ってしまいました。 + add_param が順序を持っているのは見づらい。数字で指定する方が合理的。 + 2009-10-11 Shinji KONO <kono@ie.u-ryukyu.ac.jp> 単純な、rbuf, wbuf + write return size の task のAPI
--- a/TaskManager/kernel/ppe/Task.cc Sat Nov 14 18:21:14 2009 +0900 +++ b/TaskManager/kernel/ppe/Task.cc Sat Nov 14 18:57:54 2009 +0900 @@ -32,10 +32,12 @@ * エラーの時に -1 を返す、ってことするよりは * perror みたいにしたほうがわかりやすいかな。 * - * 現在は 3 個まで。 - * 本当は、3個以上にすると task->param[] には アドレスが入り + * 現在は MAX_PARAMS 個まで。 + * 本当は、MAX_PARAMS個以上にすると task->param[] には アドレスが入り * そのアドレスは メインメモリでアロケートされた int の集合。 */ + +// こちらのAPIは、受け側と出力側での対応を良く見れない。廃止の方向。 int Task::add_param(memaddr _param) { @@ -45,6 +47,15 @@ return 0; } +int +Task::add_param(int index, memaddr _param) +{ + if (index >= MAX_PARAMS) return -1; + + this->param[index] = _param; + return 0; +} + /* * エラーの時に -1 を返す、ってことするよりは * perror みたいにしたほうがわかりやすいかな。
--- a/TaskManager/kernel/ppe/Task.h Sat Nov 14 18:21:14 2009 +0900 +++ b/TaskManager/kernel/ppe/Task.h Sat Nov 14 18:57:54 2009 +0900 @@ -26,7 +26,8 @@ int add_inData_t(memaddr addr, int size); // unsigned int ではなく 64bit int add_outData_t(memaddr addr, int size); // unsigned int ではなく 64bit int add_data(ListData &list, memaddr addr, int size); - int add_param(memaddr param); + int add_param(memaddr param); // obsolete. do not use. + int add_param(int index, memaddr param); #define add_inData(addr, size) \ add_inData_t((memaddr)(addr), (size));