Mercurial > hg > Members > kono > Cerium
changeset 164:38cbb7aecc70
TilePtr は SPE で計算した方がいいと判断して変更。
author | gongo@gendarme.cr.ie.u-ryukyu.ac.jp |
---|---|
date | Tue, 09 Dec 2008 10:48:49 +0900 |
parents | e60e13967016 |
children | 246881f0634b |
files | TaskManager/Test/test_render/Makefile.def TaskManager/Test/test_render/Span.h TaskManager/Test/test_render/polygon_pack.h TaskManager/Test/test_render/scene_graph_pack.h TaskManager/Test/test_render/spe/CreateSpan.cpp TaskManager/Test/test_render/spe/CreateSpan.h TaskManager/Test/test_render/spe/DrawSpan.cpp TaskManager/Test/test_render/task/CreatePolygonFromSceneGraph.cpp TaskManager/Test/test_render/task/CreateSpan.cpp TaskManager/Test/test_render/task/CreateSpan.h TaskManager/Test/test_render/task/DrawSpan.cpp TaskManager/Test/test_render/triangle.h TaskManager/Test/test_render/vertex.h |
diffstat | 13 files changed, 249 insertions(+), 489 deletions(-) [+] |
line wrap: on
line diff
--- a/TaskManager/Test/test_render/Makefile.def Tue Dec 09 10:08:28 2008 +0900 +++ b/TaskManager/Test/test_render/Makefile.def Tue Dec 09 10:48:49 2008 +0900 @@ -3,10 +3,10 @@ # include/library path # ex: macosx #CERIUM = /Users/gongo/Source/Concurrency/Game_project/Cerium -#CERIUM = /Users/gongo/Source/hg/Cerium +CERIUM = /Users/gongo/Source/hg/Cerium # ex: linux/ps3 -CERIUM = /home/gongo/Cerium +#CERIUM = /home/gongo/Cerium #CERIUM = ../../..
--- a/TaskManager/Test/test_render/Span.h Tue Dec 09 10:08:28 2008 +0900 +++ b/TaskManager/Test/test_render/Span.h Tue Dec 09 10:48:49 2008 +0900 @@ -5,6 +5,10 @@ # include "Tapestry.h" #endif +#ifndef INCLUDED_TYPES +# include "types.h" +#endif + #define MAX_TILE_LIST 64 typedef struct tile { @@ -27,9 +31,9 @@ class Span { public: - long *tex_addr; - long tex_width; - long tex_height; + uint32 *tex_addr; + int tex_width; + int tex_height; int x; int y; int length_x;
--- a/TaskManager/Test/test_render/polygon_pack.h Tue Dec 09 10:08:28 2008 +0900 +++ b/TaskManager/Test/test_render/polygon_pack.h Tue Dec 09 10:48:49 2008 +0900 @@ -1,6 +1,10 @@ #ifndef INCLUDED_POLYGON_PACK #define INCLUDED_POLYGON_PACK +#ifndef INCLUDED_TYPES +# include "types.h" +#endif + #define MAX_SIZE_TRIANGLE 128 typedef struct VertexPack { @@ -13,7 +17,8 @@ typedef struct TrianglePack { - long *tex_addr, tex_width, tex_height; + uint32 *tex_addr; + int tex_width, tex_height; VertexPack ver1; VertexPack ver2; VertexPack ver3; @@ -32,7 +37,7 @@ void init(void) { info.size = 0; - next = 0; + next = 0; } void clear(void) {
--- a/TaskManager/Test/test_render/scene_graph_pack.h Tue Dec 09 10:08:28 2008 +0900 +++ b/TaskManager/Test/test_render/scene_graph_pack.h Tue Dec 09 10:48:49 2008 +0900 @@ -5,6 +5,10 @@ # include "SceneGraph.h" #endif +#ifndef INCLUDED_TYPES +# include "types.h" +#endif + #define MAX_NODE 16 #define MAX_POLYGON 36 @@ -15,7 +19,8 @@ float obj_pos[4]; float angle[4]; float translation[16]; - long *tex_addr, tex_width, tex_height; + uint32 *tex_addr; + int tex_width, tex_height; int id; int move, interaction; int pn; // parent number?
--- a/TaskManager/Test/test_render/spe/CreateSpan.cpp Tue Dec 09 10:08:28 2008 +0900 +++ b/TaskManager/Test/test_render/spe/CreateSpan.cpp Tue Dec 09 10:48:49 2008 +0900 @@ -1,12 +1,12 @@ #include "CreateSpan.h" #include "viewer_types.h" -static const int SPAN_PACK_LOAD = 5; -static const int SPAN_PACK_STORE = 6; -static const int POLYGON_PACK_LOAD = 7; -static const int TILE_ALLOCATE = 8; -static const int TILE_LOAD = 9; -static const int TILE_STORE = 10; +static const int SPAN_PACK_LOAD = 5; +static const int SPAN_PACK_STORE = 6; +static const int POLYGON_PACK_LOAD = 7; +static const int TILE_ALLOCATE = 8; +static const int TILE_LOAD = 9; +static const int TILE_STORE = 10; static SpanPackPtr spack = NULL; static SpanPackPtr send_spack = NULL; @@ -123,138 +123,6 @@ return blockX + (twidth/TEXTURE_SPLIT_PIXEL)*blockY; } -void -CreateSpan::setTileInfo(TileInfoPtr tile, int xpos, int ypos, - int tex_width, uint32* tex_addr_top) -{ - /* - * テクスチャの座標 (tex_xpos, tex_ypos) の - * 分割したブロック内での座標 - * 例: - * (450, 318) -> 分割されたブロックの (2, 6) になる - */ - tile->tix = xpos % TEXTURE_SPLIT_PIXEL; - tile->tiy = ypos % TEXTURE_SPLIT_PIXEL; - - /** - * ブロックIDから、あらかじめ分割したテクスチャの - * 先頭addressの addr からの距離を求める。 - * それがこの 1 pixel が使うテクスチャのブロックになる - */ - int block = get_tex_block(xpos, ypos, tex_width); - tile->tile = (void*)(tex_addr_top + block*TEXTURE_BLOCK_SIZE); -} - -/** - * Span の1ドットずつ、必要なテクスチャのブロック(Tile)を求めていく - */ -void -CreateSpan::setTileInfoList(SpanPtr span) -{ - TileInfoListPtr tilelist = - (TileInfoListPtr)smanager->allocate(sizeof(TileInfoList)); - TileInfoListPtr send_tilelist = - (TileInfoListPtr)smanager->allocate(sizeof(TileInfoList)); - TileInfoListPtr tilelist_addr; - TileInfoListPtr send_tilelist_addr; - TileInfoPtr tile; - - int cur_x = 0; - int len = 0; - - smanager->mainMem_wait(); - tilelist_addr = (TileInfoListPtr)smanager->mainMem_get(TILE_ALLOCATE); - span->tilelist = tilelist_addr; - - float tex1 = span->tex_x1; - float tex2 = span->tex_x2; - float tey1 = span->tex_y1; - float tey2 = span->tex_y2; - int tex_xpos; - int tex_ypos; - int end = span->length_x; - - if (span->length_x == 1) { - tilelist->init(); - - tex_xpos = (int)((span->tex_width-1) * tex1); - tex_ypos = (int)((span->tex_height-1) * tey1); - - tile = &tilelist->tileinfo[tilelist->size++]; - setTileInfo(tile, tex_xpos, tex_ypos, span->tex_width, - (uint32*)span->tex_addr); - } else { - while (cur_x <= span->length_x) { - if (cur_x + MAX_TILE_LIST - 1 < span->length_x) { - len = MAX_TILE_LIST - 1; - smanager->mainMem_alloc(TILE_ALLOCATE, sizeof(TileInfoList)); - } else { - len = span->length_x - cur_x; - } - - float tex_x, tex_y; - - tilelist->init(); - - for (int i = cur_x; i <= cur_x + len; i++) { - tex_x = tex1*(end-1-i)/(end-1) + tex2*i/(end-1); - tex_y = tey1*(end-1-i)/(end-1) + tey2*i/(end-1); - if (tex_x > 1) tex_x = 1; - if (tex_y > 1) tex_y = 1; - tex_xpos = (int)((span->tex_width-1) * tex_x); - tex_ypos = (int)((span->tex_height-1) * tex_y); - - /** - * 座標が [0..MAX-1] を超えない様に - * なんかもっと良い書き方ありそうだけど - */ - if (tex_xpos < 0) tex_xpos = 0; - if (span->tex_width - 1 < tex_xpos) { - tex_xpos = span->tex_width - 1; - } - if (tex_ypos < 0) tex_ypos = 0; - if (span->tex_height - 1 < tex_ypos) { - tex_ypos = span->tex_height - 1; - } - - tile = &tilelist->tileinfo[tilelist->size++]; - setTileInfo(tile, tex_xpos, tex_ypos, span->tex_width, - (uint32*)span->tex_addr); - } - - if (cur_x + MAX_TILE_LIST - 1 < span->length_x) { - TileInfoListPtr tmp = tilelist; - tilelist = send_tilelist; - send_tilelist = tmp; - - send_tilelist_addr = tilelist_addr; - - smanager->mainMem_wait(); - tilelist_addr = - (TileInfoListPtr)smanager->mainMem_get(TILE_ALLOCATE); - - send_tilelist->next = tilelist_addr; - - smanager->dma_wait(TILE_STORE); - smanager->dma_store(send_tilelist, (uint32)send_tilelist_addr, - sizeof(TileInfoList), TILE_STORE); - } - - cur_x += MAX_TILE_LIST; - } - } - - smanager->dma_wait(TILE_STORE); - tilelist->next = NULL; - smanager->dma_store(tilelist, (uint32)tilelist_addr, - sizeof(TileInfoList), TILE_STORE); - free(send_tilelist); - - smanager->dma_wait(TILE_STORE); - - free(tilelist); -} - /** * x軸に水平な辺を持つ三角形ポリゴンから、 * Span を抜き出す @@ -262,7 +130,7 @@ void CreateSpan::half_triangle(SpanPackPtr *spackList, int charge_y_top, int charge_y_end, - long *tex_addr, long tex_width, long tex_height, + uint32 *tex_addr, int tex_width, int tex_height, VertexPack *vMin,VertexPack *vMid,VertexPack *vMid10) { float tmp_z,tmp_tex1, tmp_tex2 ,tmp_tey1,tmp_tey2; @@ -332,7 +200,7 @@ if (charge_y_top <= y && y <= charge_y_end) { // 1..8 を index0, 9..16 を index1 にするために y を -1 int index = (y-1) / split_screen_h; - //if (index != 0) continue; + /** * 違う SpanPack を扱う場合、 * 現在の SpanPack をメインメモリに送り、 @@ -400,13 +268,6 @@ continue; } - /** - * メインメモリに、Tile 用の領域確保をここで指定しておく - */ - // ちと仕様変更によりここでは使わない - // 予めやっておいて、その間に処理、だとちょっと動作が怪しいらしい - smanager->mainMem_alloc(TILE_ALLOCATE, sizeof(TileInfoList)); - tmp_tex1 =((i/(div_y)) * vMid10->tex_x) + ( ((div_y - i)/(div_y)) * vMin->tex_x); tmp_tex2 =( (i/(div_y)) * vMid->tex_x) + @@ -458,10 +319,6 @@ span->tex_x2 = end_tex_x; span->tex_y1 = start_tex_y; span->tex_y2 = end_tex_y; - - // TilePtr の計算 - // tix, tiy (Tile 内での x, y) - setTileInfoList(span); } }
--- a/TaskManager/Test/test_render/spe/CreateSpan.h Tue Dec 09 10:08:28 2008 +0900 +++ b/TaskManager/Test/test_render/spe/CreateSpan.h Tue Dec 09 10:48:49 2008 +0900 @@ -20,7 +20,7 @@ int run(void *rbuf, void *wbuf); void half_triangle(SpanPackPtr *spackList, int charge_y_top, int charge_y_end, - long *tex_addr, long tex_width, long tex_height, + uint32 *tex_addr, int tex_width, int tex_height, VertexPack *vMin,VertexPack *vMid,VertexPack *vMid1); void setTileInfoList(SpanPtr span); void setTileInfo(TileInfoPtr tile, int xpos, int ypos,
--- a/TaskManager/Test/test_render/spe/DrawSpan.cpp Tue Dec 09 10:08:28 2008 +0900 +++ b/TaskManager/Test/test_render/spe/DrawSpan.cpp Tue Dec 09 10:48:49 2008 +0900 @@ -22,6 +22,65 @@ static TileListPtr tileList; +/** + * ƥϡTEXTURE_SPLIT_PIXEL^2 Υ֥åʬ䤹 + * + * +---+---+---+---+---+---+ + * | 0 | 1 | 2 | 3 | 4 | 5 | + * +---+---+---+---+---+---+ + * | | | | | |11 | + * +---+---+---+---+---+---+ + * | | | | | |17 | + * +---+---+---+---+---+---+ + * | | | | | |23 | + * +---+---+---+---+---+---+ + * | | | | | |29 | + * +---+---+---+---+---+---+ + * | | | | | |35 | + * +---+---+---+---+---+---+ + * + * դ TEXTURE_SPLIT Ȥ + * ƥ֥åο֥åIDȤʤ롣 + */ + +/** + * ƥκɸ顢 + * ƥΤɤΥ֥å + * + * @param[in] tx X coordinates of texture + * @param[in] tx Y coordinates of texture + * @param[in] twidth Width of texture + * @return block ID + */ +static inline int +get_tex_block(int tx, int ty, int twidth) +{ + int blockX, blockY; + + blockX = tx / TEXTURE_SPLIT_PIXEL; + blockY = ty / TEXTURE_SPLIT_PIXEL; + + return blockX + (twidth/TEXTURE_SPLIT_PIXEL)*blockY; +} + +/** + * block ID ȡƥ TOP address + * (tx,ty) ǻȤƥ Tile addres + * + * @param[in] tx X coordinates of texture + * @param[in] tx Y coordinates of texture + * @param[in] tw Width of texture + * @param[in] tex_addr_top (tx,ty) ǻȤƥƬaddress + * @return block ID + */ +static inline uint32* +getTile(int tx, int ty, int tw, uint32 *tex_addr_top) +{ + int block = get_tex_block(tx, ty, tw); + return tex_addr_top + block*TEXTURE_BLOCK_SIZE; +} + + static int hash(uint32 data) { @@ -153,6 +212,8 @@ + (blue & 0xff) + (alpha << 24); } + + int DrawSpan::run(void *rbuf, void *wbuf) { @@ -163,15 +224,9 @@ SpanPack *tmp_sp = NULL; Span *span; - TileInfoListPtr tilist = - (TileInfoListPtr)smanager->allocate(sizeof(TileInfoList)); - TileInfoListPtr next_tilist = - (TileInfoListPtr)smanager->allocate(sizeof(TileInfoList)); - tileList = (TileListPtr)smanager->allocate(sizeof(TileList)); tileList->init(); - void *texture_image = global_get(TEXTURE_ID); 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) @@ -204,13 +259,20 @@ for (int t = 0; t < sp->info.size; t++) { span = &sp->span[t]; - smanager->dma_load(tilist, (uint32)span->tilelist, - sizeof(TileInfoList), TILE_INFO_LOAD); + Uint32 rgb = 0x00ff00; + float tex1 = span->tex_x1; + float tex2 = span->tex_x2; + float tey1 = span->tex_y1; + float tey2 = span->tex_y2; - Uint32 rgb = 0x00ff00; int tex_xpos; int tex_ypos; int tex_zpos; + + int tex_localx; + int tex_localy; + uint32 *tex_addr; + int x = span->x; int y = span->y; int x_len = span->length_x; @@ -221,98 +283,54 @@ int localx = getLocalX(x-1); int localy = getLocalY(y-1); - smanager->dma_wait(TILE_INFO_LOAD); - if (x_len == 1) { if (x < rangex_start || rangex_end < x) { continue; } - tex_xpos = tilist->tileinfo[0].tix; - tex_ypos = tilist->tileinfo[0].tiy; + tex_xpos = (int)((span->tex_width-1) * tex1); + tex_ypos = (int)((span->tex_height-1) * tey1); tex_zpos = (int)z; - texture_image = tilist->tileinfo[0].tile; if (zpos < zRow[localx + (rangex * localy)]) { - rgb = get_rgb(tex_xpos, tex_ypos, texture_image); + tex_localx = tex_xpos % TEXTURE_SPLIT_PIXEL; + tex_localy = tex_ypos % TEXTURE_SPLIT_PIXEL; + tex_addr = getTile(tex_xpos, tex_ypos, + span->tex_width, span->tex_addr); + + rgb = get_rgb(tex_localx, tex_localy, tex_addr); + zRow[localx + (rangex * localy)] = zpos; linebuf[localy][localx] = rgb; } } else { int js = (x < rangex_start) ? rangex_start - x : 0; int je = (x + x_len > rangex_end) ? rangex_end - x : x_len; - - if (js > je) continue; - - int cur_x = 0; - int max_x = je; - int len = 0; + float tex_x, tex_y, tex_z; - /** - * Span ɽʤϰ([js..je]) TileInfoList - * äƤΤǡФ - */ - while (cur_x + MAX_TILE_LIST <= js) { - smanager->dma_load(next_tilist, (uint32)tilist->next, - sizeof(TileInfoList), TILE_INFO_LOAD); - smanager->dma_wait(TILE_INFO_LOAD); + for (int j = js; j <= je; j++) { + localx = getLocalX(x-1+j); - TileInfoListPtr tmp = tilist; - tilist = next_tilist; - next_tilist = tmp; - - cur_x += MAX_TILE_LIST; - } - - cur_x = js; + tex_z = z*(x_len-1-j)/(x_len-1) + zpos*j/(x_len-1); - while (cur_x <= max_x) { - /** - * TileInfoList 30 ĤǶڤƤΤ - * cur_x TileInfoList 椫ϤޤäƤ - * MAX_TILE_LIST ˼ޤͤ - * (ex.) - * cur_x (=js) 0 Ϥޤä硢 - * cur_x = 0, len = 29 - * cur_x (=js) 15 Ϥޤä硢 - * cur_x = 15, len = 14 ˤʤ - */ - int cur_x_diff = MAX_TILE_LIST - (cur_x % MAX_TILE_LIST); - - if (cur_x + cur_x_diff - 1 < max_x) { - smanager->dma_load(next_tilist, (uint32)tilist->next, - sizeof(TileInfoList), - TILE_INFO_LOAD); - len = cur_x_diff - 1; - } else { - len = max_x - cur_x; - } + 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_y > 1) tex_y = 1; + 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)]) { + tex_localx = tex_xpos % TEXTURE_SPLIT_PIXEL; + tex_localy = tex_ypos % TEXTURE_SPLIT_PIXEL; + tex_addr = getTile(tex_xpos, tex_ypos, + span->tex_width, span->tex_addr); + + rgb = get_rgb(tex_localx, tex_localy, tex_addr); - for (int j = cur_x; j <= cur_x + len; j++) { - TileInfoPtr tinfo = &tilist->tileinfo[j%MAX_TILE_LIST]; - float tex_z - = z*(x_len-1-j)/(x_len-1) + zpos*j/(x_len-1); - - localx = getLocalX(x-1+j); - - tex_xpos = tinfo->tix; - tex_ypos = tinfo->tiy; - texture_image = tinfo->tile; - - if (tex_z < zRow[localx + (rangex*localy)]) { - rgb = get_rgb(tex_xpos, tex_ypos, texture_image); - zRow[localx + (rangex*localy)] = tex_z; - linebuf[localy][localx] = rgb; - } + zRow[localx + (rangex*localy)] = tex_z; + linebuf[localy][localx] = rgb; } - - smanager->dma_wait(TILE_INFO_LOAD); - - TileInfoListPtr tmp = tilist; - tilist = next_tilist; - next_tilist = tmp; - - cur_x += cur_x_diff; } } } @@ -328,8 +346,6 @@ free(linebuf); free(zRow); free(tileList); - free(tilist); - free(next_tilist); return 0; }
--- a/TaskManager/Test/test_render/task/CreatePolygonFromSceneGraph.cpp Tue Dec 09 10:08:28 2008 +0900 +++ b/TaskManager/Test/test_render/task/CreatePolygonFromSceneGraph.cpp Tue Dec 09 10:48:49 2008 +0900 @@ -117,8 +117,8 @@ triangle->ver3.tex_x = sg->data[(i+2)*3 + sg->size*6]; triangle->ver3.tex_y = sg->data[(i+2)*3 + sg->size*6+1]; - triangle->tex_addr = (long*)sg->texture_info.pixels; - triangle->tex_width = sg->texture_info.t_w; + triangle->tex_addr = sg->texture_info.pixels; + triangle->tex_width = sg->texture_info.t_w; triangle->tex_height = sg->texture_info.t_h; }
--- a/TaskManager/Test/test_render/task/CreateSpan.cpp Tue Dec 09 10:08:28 2008 +0900 +++ b/TaskManager/Test/test_render/task/CreateSpan.cpp Tue Dec 09 10:48:49 2008 +0900 @@ -1,12 +1,12 @@ #include "CreateSpan.h" #include "viewer_types.h" -static const int SPAN_PACK_LOAD = 5; -static const int SPAN_PACK_STORE = 6; -static const int POLYGON_PACK_LOAD = 7; -static const int TILE_ALLOCATE = 8; -static const int TILE_LOAD = 9; -static const int TILE_STORE = 10; +static const int SPAN_PACK_LOAD = 5; +static const int SPAN_PACK_STORE = 6; +static const int POLYGON_PACK_LOAD = 7; +static const int TILE_ALLOCATE = 8; +static const int TILE_LOAD = 9; +static const int TILE_STORE = 10; static SpanPackPtr spack = NULL; static SpanPackPtr send_spack = NULL; @@ -123,138 +123,6 @@ return blockX + (twidth/TEXTURE_SPLIT_PIXEL)*blockY; } -void -CreateSpan::setTileInfo(TileInfoPtr tile, int xpos, int ypos, - int tex_width, uint32* tex_addr_top) -{ - /* - * テクスチャの座標 (tex_xpos, tex_ypos) の - * 分割したブロック内での座標 - * 例: - * (450, 318) -> 分割されたブロックの (2, 6) になる - */ - tile->tix = xpos % TEXTURE_SPLIT_PIXEL; - tile->tiy = ypos % TEXTURE_SPLIT_PIXEL; - - /** - * ブロックIDから、あらかじめ分割したテクスチャの - * 先頭addressの addr からの距離を求める。 - * それがこの 1 pixel が使うテクスチャのブロックになる - */ - int block = get_tex_block(xpos, ypos, tex_width); - tile->tile = (void*)(tex_addr_top + block*TEXTURE_BLOCK_SIZE); -} - -/** - * Span の1ドットずつ、必要なテクスチャのブロック(Tile)を求めていく - */ -void -CreateSpan::setTileInfoList(SpanPtr span) -{ - TileInfoListPtr tilelist = - (TileInfoListPtr)smanager->allocate(sizeof(TileInfoList)); - TileInfoListPtr send_tilelist = - (TileInfoListPtr)smanager->allocate(sizeof(TileInfoList)); - TileInfoListPtr tilelist_addr; - TileInfoListPtr send_tilelist_addr; - TileInfoPtr tile; - - int cur_x = 0; - int len = 0; - - smanager->mainMem_wait(); - tilelist_addr = (TileInfoListPtr)smanager->mainMem_get(TILE_ALLOCATE); - span->tilelist = tilelist_addr; - - float tex1 = span->tex_x1; - float tex2 = span->tex_x2; - float tey1 = span->tex_y1; - float tey2 = span->tex_y2; - int tex_xpos; - int tex_ypos; - int end = span->length_x; - - if (span->length_x == 1) { - tilelist->init(); - - tex_xpos = (int)((span->tex_width-1) * tex1); - tex_ypos = (int)((span->tex_height-1) * tey1); - - tile = &tilelist->tileinfo[tilelist->size++]; - setTileInfo(tile, tex_xpos, tex_ypos, span->tex_width, - (uint32*)span->tex_addr); - } else { - while (cur_x <= span->length_x) { - if (cur_x + MAX_TILE_LIST - 1 < span->length_x) { - len = MAX_TILE_LIST - 1; - smanager->mainMem_alloc(TILE_ALLOCATE, sizeof(TileInfoList)); - } else { - len = span->length_x - cur_x; - } - - float tex_x, tex_y; - - tilelist->init(); - - for (int i = cur_x; i <= cur_x + len; i++) { - tex_x = tex1*(end-1-i)/(end-1) + tex2*i/(end-1); - tex_y = tey1*(end-1-i)/(end-1) + tey2*i/(end-1); - if (tex_x > 1) tex_x = 1; - if (tex_y > 1) tex_y = 1; - tex_xpos = (int)((span->tex_width-1) * tex_x); - tex_ypos = (int)((span->tex_height-1) * tex_y); - - /** - * 座標が [0..MAX-1] を超えない様に - * なんかもっと良い書き方ありそうだけど - */ - if (tex_xpos < 0) tex_xpos = 0; - if (span->tex_width - 1 < tex_xpos) { - tex_xpos = span->tex_width - 1; - } - if (tex_ypos < 0) tex_ypos = 0; - if (span->tex_height - 1 < tex_ypos) { - tex_ypos = span->tex_height - 1; - } - - tile = &tilelist->tileinfo[tilelist->size++]; - setTileInfo(tile, tex_xpos, tex_ypos, span->tex_width, - (uint32*)span->tex_addr); - } - - if (cur_x + MAX_TILE_LIST - 1 < span->length_x) { - TileInfoListPtr tmp = tilelist; - tilelist = send_tilelist; - send_tilelist = tmp; - - send_tilelist_addr = tilelist_addr; - - smanager->mainMem_wait(); - tilelist_addr = - (TileInfoListPtr)smanager->mainMem_get(TILE_ALLOCATE); - - send_tilelist->next = tilelist_addr; - - smanager->dma_wait(TILE_STORE); - smanager->dma_store(send_tilelist, (uint32)send_tilelist_addr, - sizeof(TileInfoList), TILE_STORE); - } - - cur_x += MAX_TILE_LIST; - } - } - - smanager->dma_wait(TILE_STORE); - tilelist->next = NULL; - smanager->dma_store(tilelist, (uint32)tilelist_addr, - sizeof(TileInfoList), TILE_STORE); - free(send_tilelist); - - smanager->dma_wait(TILE_STORE); - - free(tilelist); -} - /** * x軸に水平な辺を持つ三角形ポリゴンから、 * Span を抜き出す @@ -262,7 +130,7 @@ void CreateSpan::half_triangle(SpanPackPtr *spackList, int charge_y_top, int charge_y_end, - long *tex_addr, long tex_width, long tex_height, + uint32 *tex_addr, int tex_width, int tex_height, VertexPack *vMin,VertexPack *vMid,VertexPack *vMid10) { float tmp_z,tmp_tex1, tmp_tex2 ,tmp_tey1,tmp_tey2; @@ -332,7 +200,7 @@ if (charge_y_top <= y && y <= charge_y_end) { // 1..8 を index0, 9..16 を index1 にするために y を -1 int index = (y-1) / split_screen_h; - //if (index != 0) continue; + /** * 違う SpanPack を扱う場合、 * 現在の SpanPack をメインメモリに送り、 @@ -400,13 +268,6 @@ continue; } - /** - * メインメモリに、Tile 用の領域確保をここで指定しておく - */ - // ちと仕様変更によりここでは使わない - // 予めやっておいて、その間に処理、だとちょっと動作が怪しいらしい - smanager->mainMem_alloc(TILE_ALLOCATE, sizeof(TileInfoList)); - tmp_tex1 =((i/(div_y)) * vMid10->tex_x) + ( ((div_y - i)/(div_y)) * vMin->tex_x); tmp_tex2 =( (i/(div_y)) * vMid->tex_x) + @@ -458,10 +319,6 @@ span->tex_x2 = end_tex_x; span->tex_y1 = start_tex_y; span->tex_y2 = end_tex_y; - - // TilePtr の計算 - // tix, tiy (Tile 内での x, y) - setTileInfoList(span); } }
--- a/TaskManager/Test/test_render/task/CreateSpan.h Tue Dec 09 10:08:28 2008 +0900 +++ b/TaskManager/Test/test_render/task/CreateSpan.h Tue Dec 09 10:48:49 2008 +0900 @@ -20,7 +20,7 @@ int run(void *rbuf, void *wbuf); void half_triangle(SpanPackPtr *spackList, int charge_y_top, int charge_y_end, - long *tex_addr, long tex_width, long tex_height, + uint32 *tex_addr, int tex_width, int tex_height, VertexPack *vMin,VertexPack *vMid,VertexPack *vMid1); void setTileInfoList(SpanPtr span); void setTileInfo(TileInfoPtr tile, int xpos, int ypos,
--- a/TaskManager/Test/test_render/task/DrawSpan.cpp Tue Dec 09 10:08:28 2008 +0900 +++ b/TaskManager/Test/test_render/task/DrawSpan.cpp Tue Dec 09 10:48:49 2008 +0900 @@ -22,6 +22,65 @@ static TileListPtr tileList; +/** + * ƥϡTEXTURE_SPLIT_PIXEL^2 Υ֥åʬ䤹 + * + * +---+---+---+---+---+---+ + * | 0 | 1 | 2 | 3 | 4 | 5 | + * +---+---+---+---+---+---+ + * | | | | | |11 | + * +---+---+---+---+---+---+ + * | | | | | |17 | + * +---+---+---+---+---+---+ + * | | | | | |23 | + * +---+---+---+---+---+---+ + * | | | | | |29 | + * +---+---+---+---+---+---+ + * | | | | | |35 | + * +---+---+---+---+---+---+ + * + * դ TEXTURE_SPLIT Ȥ + * ƥ֥åο֥åIDȤʤ롣 + */ + +/** + * ƥκɸ顢 + * ƥΤɤΥ֥å + * + * @param[in] tx X coordinates of texture + * @param[in] tx Y coordinates of texture + * @param[in] twidth Width of texture + * @return block ID + */ +static inline int +get_tex_block(int tx, int ty, int twidth) +{ + int blockX, blockY; + + blockX = tx / TEXTURE_SPLIT_PIXEL; + blockY = ty / TEXTURE_SPLIT_PIXEL; + + return blockX + (twidth/TEXTURE_SPLIT_PIXEL)*blockY; +} + +/** + * block ID ȡƥ TOP address + * (tx,ty) ǻȤƥ Tile addres + * + * @param[in] tx X coordinates of texture + * @param[in] tx Y coordinates of texture + * @param[in] tw Width of texture + * @param[in] tex_addr_top (tx,ty) ǻȤƥƬaddress + * @return block ID + */ +static inline uint32* +getTile(int tx, int ty, int tw, uint32 *tex_addr_top) +{ + int block = get_tex_block(tx, ty, tw); + return tex_addr_top + block*TEXTURE_BLOCK_SIZE; +} + + static int hash(uint32 data) { @@ -153,6 +212,8 @@ + (blue & 0xff) + (alpha << 24); } + + int DrawSpan::run(void *rbuf, void *wbuf) { @@ -163,15 +224,9 @@ SpanPack *tmp_sp = NULL; Span *span; - TileInfoListPtr tilist = - (TileInfoListPtr)smanager->allocate(sizeof(TileInfoList)); - TileInfoListPtr next_tilist = - (TileInfoListPtr)smanager->allocate(sizeof(TileInfoList)); - tileList = (TileListPtr)smanager->allocate(sizeof(TileList)); tileList->init(); - void *texture_image = global_get(TEXTURE_ID); 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) @@ -204,13 +259,20 @@ for (int t = 0; t < sp->info.size; t++) { span = &sp->span[t]; - smanager->dma_load(tilist, (uint32)span->tilelist, - sizeof(TileInfoList), TILE_INFO_LOAD); + Uint32 rgb = 0x00ff00; + float tex1 = span->tex_x1; + float tex2 = span->tex_x2; + float tey1 = span->tex_y1; + float tey2 = span->tex_y2; - Uint32 rgb = 0x00ff00; int tex_xpos; int tex_ypos; int tex_zpos; + + int tex_localx; + int tex_localy; + uint32 *tex_addr; + int x = span->x; int y = span->y; int x_len = span->length_x; @@ -221,98 +283,54 @@ int localx = getLocalX(x-1); int localy = getLocalY(y-1); - smanager->dma_wait(TILE_INFO_LOAD); - if (x_len == 1) { if (x < rangex_start || rangex_end < x) { continue; } - tex_xpos = tilist->tileinfo[0].tix; - tex_ypos = tilist->tileinfo[0].tiy; + tex_xpos = (int)((span->tex_width-1) * tex1); + tex_ypos = (int)((span->tex_height-1) * tey1); tex_zpos = (int)z; - texture_image = tilist->tileinfo[0].tile; if (zpos < zRow[localx + (rangex * localy)]) { - rgb = get_rgb(tex_xpos, tex_ypos, texture_image); + tex_localx = tex_xpos % TEXTURE_SPLIT_PIXEL; + tex_localy = tex_ypos % TEXTURE_SPLIT_PIXEL; + tex_addr = getTile(tex_xpos, tex_ypos, + span->tex_width, span->tex_addr); + + rgb = get_rgb(tex_localx, tex_localy, tex_addr); + zRow[localx + (rangex * localy)] = zpos; linebuf[localy][localx] = rgb; } } else { int js = (x < rangex_start) ? rangex_start - x : 0; int je = (x + x_len > rangex_end) ? rangex_end - x : x_len; - - if (js > je) continue; - - int cur_x = 0; - int max_x = je; - int len = 0; + float tex_x, tex_y, tex_z; - /** - * Span ɽʤϰ([js..je]) TileInfoList - * äƤΤǡФ - */ - while (cur_x + MAX_TILE_LIST <= js) { - smanager->dma_load(next_tilist, (uint32)tilist->next, - sizeof(TileInfoList), TILE_INFO_LOAD); - smanager->dma_wait(TILE_INFO_LOAD); + for (int j = js; j <= je; j++) { + localx = getLocalX(x-1+j); - TileInfoListPtr tmp = tilist; - tilist = next_tilist; - next_tilist = tmp; - - cur_x += MAX_TILE_LIST; - } - - cur_x = js; + tex_z = z*(x_len-1-j)/(x_len-1) + zpos*j/(x_len-1); - while (cur_x <= max_x) { - /** - * TileInfoList 30 ĤǶڤƤΤ - * cur_x TileInfoList 椫ϤޤäƤ - * MAX_TILE_LIST ˼ޤͤ - * (ex.) - * cur_x (=js) 0 Ϥޤä硢 - * cur_x = 0, len = 29 - * cur_x (=js) 15 Ϥޤä硢 - * cur_x = 15, len = 14 ˤʤ - */ - int cur_x_diff = MAX_TILE_LIST - (cur_x % MAX_TILE_LIST); - - if (cur_x + cur_x_diff - 1 < max_x) { - smanager->dma_load(next_tilist, (uint32)tilist->next, - sizeof(TileInfoList), - TILE_INFO_LOAD); - len = cur_x_diff - 1; - } else { - len = max_x - cur_x; - } + 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_y > 1) tex_y = 1; + 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)]) { + tex_localx = tex_xpos % TEXTURE_SPLIT_PIXEL; + tex_localy = tex_ypos % TEXTURE_SPLIT_PIXEL; + tex_addr = getTile(tex_xpos, tex_ypos, + span->tex_width, span->tex_addr); + + rgb = get_rgb(tex_localx, tex_localy, tex_addr); - for (int j = cur_x; j <= cur_x + len; j++) { - TileInfoPtr tinfo = &tilist->tileinfo[j%MAX_TILE_LIST]; - float tex_z - = z*(x_len-1-j)/(x_len-1) + zpos*j/(x_len-1); - - localx = getLocalX(x-1+j); - - tex_xpos = tinfo->tix; - tex_ypos = tinfo->tiy; - texture_image = tinfo->tile; - - if (tex_z < zRow[localx + (rangex*localy)]) { - rgb = get_rgb(tex_xpos, tex_ypos, texture_image); - zRow[localx + (rangex*localy)] = tex_z; - linebuf[localy][localx] = rgb; - } + zRow[localx + (rangex*localy)] = tex_z; + linebuf[localy][localx] = rgb; } - - smanager->dma_wait(TILE_INFO_LOAD); - - TileInfoListPtr tmp = tilist; - tilist = next_tilist; - next_tilist = tmp; - - cur_x += cur_x_diff; } } } @@ -328,8 +346,6 @@ free(linebuf); free(zRow); free(tileList); - free(tilist); - free(next_tilist); return 0; }
--- a/TaskManager/Test/test_render/triangle.h Tue Dec 09 10:08:28 2008 +0900 +++ b/TaskManager/Test/test_render/triangle.h Tue Dec 09 10:48:49 2008 +0900 @@ -4,10 +4,10 @@ #include "vertex.h" class Triangle { - public: - Vertex *vertex1,*vertex2,*vertex3; +public: + Vertex *vertex1,*vertex2,*vertex3; - Triangle(Vertex *tmp_vertex1,Vertex *tmp_vertex2,Vertex *tmp_vertex3); + Triangle(Vertex *tmp_vertex1,Vertex *tmp_vertex2,Vertex *tmp_vertex3); }; #endif
--- a/TaskManager/Test/test_render/vertex.h Tue Dec 09 10:08:28 2008 +0900 +++ b/TaskManager/Test/test_render/vertex.h Tue Dec 09 10:48:49 2008 +0900 @@ -2,10 +2,10 @@ #define INCLUDE_VERTEX class Vertex { - public: - float x,y,z,tex_x,tex_y; - - Vertex(float tmp_x, float tmp_y, float tmp_z,float tmp_tex_x, float tmp_tex_y); +public: + float x,y,z,tex_x,tex_y; + + Vertex(float tmp_x, float tmp_y, float tmp_z,float tmp_tex_x, float tmp_tex_y); }; #endif