Mercurial > hg > Game > Cerium
diff TaskManager/Test/test_render/spe/DrawSpan.cpp @ 167:508beb59e0eb draft
DrawSpan で使う Tile の Hash の扱いは class TileHash を生成する事に。
author | gongo@localhost.localdomain |
---|---|
date | Tue, 09 Dec 2008 15:07:31 +0900 |
parents | 8831c058a1ff |
children | f533a4104d41 |
line wrap: on
line diff
--- a/TaskManager/Test/test_render/spe/DrawSpan.cpp Tue Dec 09 11:53:51 2008 +0900 +++ b/TaskManager/Test/test_render/spe/DrawSpan.cpp Tue Dec 09 15:07:31 2008 +0900 @@ -5,20 +5,14 @@ #include "SpanPack.h" #include "texture.h" #include "viewer_types.h" +#include "TileHash.h" #define SPAN_PACK_LOAD 0 #define TEX_LOAD 1 SchedDefineTask(DrawSpan); -static const int hashsize = 263; - -static TilePtr hash_table[hashsize] = {0}; - -unsigned short PRIME[8] = { - 0x002, 0x065, 0x0c7, 0x133, 0x191, 0x1f3, 0x259, 0x2bd, -}; - +static TileHashPtr hash; static TileListPtr tileList; /** @@ -79,57 +73,6 @@ return tex_addr_top + block*TEXTURE_BLOCK_SIZE; } - -static int -hash(uint32 data) -{ - int value = 0; - int n = 0; - int key; - - for (int i = 0; i < 8; i ++) { - key = data & 0xf; - value += key * PRIME[n++]; - data >>= 4; - } - - return value % hashsize; -} - -static int -put(void *key, TilePtr data) -{ - int hashval = hash((uint32)key); - - for (int i = 0; i < hashsize/2; i++) { - int index = (hashval + i*i)%hashsize; - - if (hash_table[index] == 0) { - hash_table[index] = data; - return index; - } - } - - return -1; -} - -static TilePtr -get(void *key) -{ - int hashval = hash((uint32)key); - - for (int i = 0; i < hashsize/2; i++) { - int index = (hashval + i*i)%hashsize; - - if (hash_table[index] != NULL && - hash_table[index]->texture_addr == key) { - return hash_table[index]; - } - } - - return NULL; -} - void DrawSpan::linebuf_init(int *buf, int x, int rgb) { @@ -170,11 +113,11 @@ /** * get,put ϥ֥(HashȤ)äƥ뤫 */ - tile = get(addr); + tile = hash->get(addr); if (tile == NULL) { if (tileList->size >= MAX_TILE) { tileList->init(); - bzero(hash_table, sizeof(TilePtr)*hashsize); + hash->clear(); } tile = &tileList->tile[tileList->size]; @@ -183,7 +126,7 @@ smanager->dma_load(tile->pixel, (uint32)addr, sizeof(uint32)*TEXTURE_BLOCK_SIZE, TEX_LOAD); - int index = put(tile->texture_addr, tile); + int index = hash->put(tile->texture_addr, tile); /** * TODO: @@ -223,8 +166,8 @@ SpanPack *tmp_sp = NULL; Span *span; - tileList = (TileListPtr)smanager->allocate(sizeof(TileList)); - tileList->init(); + 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) @@ -232,7 +175,6 @@ int rangex = rangex_end - rangex_start + 1; float *zRow = zRow_init(rangex, rangey); - int **linebuf = (int**)smanager->allocate(sizeof(int*)*rangey); for (int i = 0; i < rangey; i++) { @@ -240,8 +182,6 @@ linebuf_init(linebuf[i], rangex, 0xffffff); } - bzero(hash_table, sizeof(TilePtr)*hashsize); - do { /** * SpanPack->next ¸ߤ硢 @@ -355,7 +295,6 @@ free(free_sp); free(linebuf); free(zRow); - free(tileList); return 0; }