Mercurial > hg > Game > Cerium
annotate TaskManager/Test/test_render/spe/DrawSpan.cpp @ 192:6694da357750 draft
add example/renew_task
author | gongo@localhost.localdomain |
---|---|
date | Tue, 13 Jan 2009 10:41:05 +0900 |
parents | fe854a6ee9e2 |
children | 1ff24ca2f016 |
rev | line source |
---|---|
109 | 1 #include <stdlib.h> |
2 #include <string.h> | |
192 | 3 #include <spu_mfcio.h> |
109 | 4 #include "DrawSpan.h" |
5 #include "polygon_pack.h" | |
6 #include "texture.h" | |
7 #include "viewer_types.h" | |
184 | 8 #include "Func.h" |
109 | 9 |
10 #define SPAN_PACK_LOAD 0 | |
120 | 11 #define TEX_LOAD 1 |
109 | 12 |
13 SchedDefineTask(DrawSpan); | |
14 | |
164
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
15 /** |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
16 * ƥϡTEXTURE_SPLIT_PIXEL^2 Υ֥åʬ䤹 |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
17 * |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
18 * +---+---+---+---+---+---+ |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
19 * | 0 | 1 | 2 | 3 | 4 | 5 | |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
20 * +---+---+---+---+---+---+ |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
21 * | | | | | |11 | |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
22 * +---+---+---+---+---+---+ |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
23 * | | | | | |17 | |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
24 * +---+---+---+---+---+---+ |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
25 * | | | | | |23 | |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
26 * +---+---+---+---+---+---+ |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
27 * | | | | | |29 | |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
28 * +---+---+---+---+---+---+ |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
29 * | | | | | |35 | |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
30 * +---+---+---+---+---+---+ |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
31 * |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
32 * դ TEXTURE_SPLIT Ȥ |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
33 * ƥ֥åο֥åIDȤʤ롣 |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
34 */ |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
35 |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
36 /** |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
37 * ƥκɸ顢 |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
38 * ƥΤɤΥ֥å |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
39 * |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
40 * @param[in] tx X coordinates of texture |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
41 * @param[in] tx Y coordinates of texture |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
42 * @param[in] twidth Width of texture |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
43 * @return block ID |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
44 */ |
184 | 45 int |
46 DrawSpan::getTexBlock(int tx, int ty, int twidth) | |
164
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
47 { |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
48 int blockX, blockY; |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
49 |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
50 blockX = tx / TEXTURE_SPLIT_PIXEL; |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
51 blockY = ty / TEXTURE_SPLIT_PIXEL; |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
52 |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
53 return blockX + (twidth/TEXTURE_SPLIT_PIXEL)*blockY; |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
54 } |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
55 |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
56 /** |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
57 * block ID ȡƥ TOP address |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
58 * (tx,ty) ǻȤƥ Tile addres |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
59 * |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
60 * @param[in] tx X coordinates of texture |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
61 * @param[in] tx Y coordinates of texture |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
62 * @param[in] tw Width of texture |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
63 * @param[in] tex_addr_top (tx,ty) ǻȤƥƬaddress |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
64 * @return block ID |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
65 */ |
184 | 66 uint32* |
67 DrawSpan::getTile(int tx, int ty, int tw, uint32 *tex_addr_top) | |
164
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
68 { |
184 | 69 int block = getTexBlock(tx, ty, tw); |
164
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
70 return tex_addr_top + block*TEXTURE_BLOCK_SIZE; |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
71 } |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
72 |
109 | 73 void |
74 DrawSpan::linebuf_init(int *buf, int x, int rgb) | |
75 { | |
76 for (int i = 0; i < x; i++) { | |
77 buf[i] = rgb; | |
78 } | |
79 } | |
80 | |
184 | 81 /** |
82 * Span Ȥ Texture Tile 뤫 | |
83 * | |
84 * @retval != NULL ¸ߤ | |
85 * @retval NULL ¸ߤʤ | |
86 */ | |
87 TilePtr | |
88 DrawSpan::isAvailableTile(uint32 *addr) | |
89 { | |
90 return hash->get(addr); | |
91 } | |
92 | |
93 void | |
94 DrawSpan::set_rgb(uint32 *addr) | |
95 { | |
96 TilePtr tile; | |
97 | |
98 if (!isAvailableTile(addr)) { | |
99 tile = tileList->nextTile(); | |
100 /** | |
101 * FIFO ʤΤǡ⤷ΤĤäƤк | |
102 */ | |
103 hash->remove(tile->texture_addr); | |
104 | |
105 tile->texture_addr = addr; | |
106 | |
107 hash->put(tile->texture_addr, tile); | |
108 | |
109 smanager->dma_load(tile->pixel, (uint32)addr, | |
110 sizeof(uint32)*TEXTURE_BLOCK_SIZE, TEX_LOAD); | |
111 | |
188
fe854a6ee9e2
メモりリーク箇所発見:TaskManager/Test/test_render/ChangeLog参照
gongo@localhost.localdomain
parents:
186
diff
changeset
|
112 //smanager->dma_wait(TEX_LOAD); |
184 | 113 } |
114 } | |
115 | |
116 void | |
117 DrawSpan::set_rgbs(uint32 *addr, uint32 *max_addr) | |
118 { | |
119 uint32 start = (uint32)addr; | |
120 uint32 end = (uint32)max_addr; | |
121 uint32 length = end-start; | |
122 uint32 diff = sizeof(uint32)*TEXTURE_BLOCK_SIZE; | |
188
fe854a6ee9e2
メモりリーク箇所発見:TaskManager/Test/test_render/ChangeLog参照
gongo@localhost.localdomain
parents:
186
diff
changeset
|
123 uint32 max_tile = 16; |
184 | 124 |
125 for (uint32 i = 0, j = 0; i <= length && j < max_tile; i += diff, j++) { | |
126 set_rgb((uint32*)(start + i)); | |
127 } | |
128 } | |
129 | |
109 | 130 Uint32 |
166 | 131 DrawSpan::get_rgb(int tx, int ty, uint32 *addr) |
109 | 132 { |
148
74341c8bf935
Span への Texture List の渡し。じゃっかん texture がバグってるので
gongo@charles.cr.ie.u-ryukyu.ac.jp
parents:
147
diff
changeset
|
133 TilePtr tile; |
109 | 134 |
167
508beb59e0eb
DrawSpan で使う Tile の Hash の扱いは class TileHash を生成する事に。
gongo@localhost.localdomain
parents:
166
diff
changeset
|
135 tile = hash->get(addr); |
168 | 136 return tile->pixel[(TEXTURE_SPLIT_PIXEL)*ty+tx]; |
109 | 137 } |
138 | |
184 | 139 /** |
140 * DrawSpan κƵư (DrawSpanRenew ) | |
141 * | |
142 * @param[in] spack ߽Ƥ SpanPack | |
143 * @param[in] cur_span_x span->length_x != 1 λ Span ν | |
144 * ɤޤǿʤǤ뤫 | |
145 */ | |
146 void | |
147 DrawSpan::reboot(SpanPackPtr spack, int cur_span_x) | |
148 { | |
149 TaskPtr renew_task = smanager->create_task(TASK_DRAW_SPAN2); | |
150 int rangey = smanager->get_param(2); | |
164
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
151 |
184 | 152 /** |
153 * ̤ outData, param ϤΤޤϤ | |
154 */ | |
155 for (int i = 0; i < rangey; i++) { | |
156 renew_task->add_outData(smanager->get_outputAddr(i), | |
157 smanager->get_outputSize(i)); | |
158 } | |
159 | |
160 // rangex_start, rangex_end, rangey | |
161 renew_task->add_param(smanager->get_param(0)); | |
162 renew_task->add_param(smanager->get_param(1)); | |
163 renew_task->add_param(smanager->get_param(2)); | |
164 | |
165 /** | |
166 * SpanPack ³鳫ϤΤǡ | |
167 * ߤξ֤ԡƤ | |
168 * spack rbuf Ƥǽ | |
169 * rbuf ϥƥबưŪ free() 뤿 | |
170 * ɥ쥹ϤΤNG | |
171 */ | |
172 SpanPackPtr curr = (SpanPackPtr)smanager->allocate(sizeof(SpanPack)); | |
173 memcpy(curr, spack, sizeof(SpanPack)); | |
174 renew_task->add_param((int)curr); | |
175 renew_task->add_param(cur_span_x); | |
176 | |
192 | 177 fprintf(stderr, "[%p] start %u\n", |
178 curr, spu_readch(SPU_RdDec)); | |
179 | |
184 | 180 /** |
181 * ƵưԤ | |
182 */ | |
183 smanager->wait_task(renew_task); | |
184 | |
185 // next_spack free() Τ wait | |
186 smanager->dma_wait(SPAN_PACK_LOAD); | |
187 } | |
164
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
188 |
109 | 189 int |
190 DrawSpan::run(void *rbuf, void *wbuf) | |
191 { | |
167
508beb59e0eb
DrawSpan で使う Tile の Hash の扱いは class TileHash を生成する事に。
gongo@localhost.localdomain
parents:
166
diff
changeset
|
192 hash = (TileHashPtr)smanager->global_get(GLOBAL_TEXTURE_HASH); |
508beb59e0eb
DrawSpan で使う Tile の Hash の扱いは class TileHash を生成する事に。
gongo@localhost.localdomain
parents:
166
diff
changeset
|
193 tileList = (TileListPtr)smanager->global_get(GLOBAL_TILE_LIST); |
128
95e2046eb46f
texture load use hash table
gongo@charles.cr.ie.u-ryukyu.ac.jp
parents:
126
diff
changeset
|
194 |
182
8e9ada0c1ed0
add get_inputAddr, get_outputAddr
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
180
diff
changeset
|
195 int rangex_start = smanager->get_param(0); |
8e9ada0c1ed0
add get_inputAddr, get_outputAddr
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
180
diff
changeset
|
196 int rangex_end = smanager->get_param(1); |
8e9ada0c1ed0
add get_inputAddr, get_outputAddr
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
180
diff
changeset
|
197 |
8e9ada0c1ed0
add get_inputAddr, get_outputAddr
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
180
diff
changeset
|
198 // Υô x ϰ |
109 | 199 int rangex = rangex_end - rangex_start + 1; |
182
8e9ada0c1ed0
add get_inputAddr, get_outputAddr
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
180
diff
changeset
|
200 |
8e9ada0c1ed0
add get_inputAddr, get_outputAddr
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
180
diff
changeset
|
201 // y ϰ (render_y + rangey - 1) |
8e9ada0c1ed0
add get_inputAddr, get_outputAddr
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
180
diff
changeset
|
202 int rangey = smanager->get_param(2); |
177 | 203 |
184 | 204 float *zRow = (float*)smanager->allocate(sizeof(float)*rangex*rangey); |
205 | |
206 for (int i = 0; i < rangex*rangey; i++) { | |
207 zRow[i] = 65535.0f; | |
208 } | |
209 | |
109 | 210 int **linebuf = (int**)smanager->allocate(sizeof(int*)*rangey); |
211 | |
212 for (int i = 0; i < rangey; i++) { | |
213 linebuf[i] = (int*)smanager->get_output(i); | |
170 | 214 linebuf_init(linebuf[i], rangex, 0xffffffff); |
109 | 215 } |
216 | |
184 | 217 SpanPackPtr spack = (SpanPackPtr)smanager->get_input(0); |
218 SpanPackPtr next_spack = (SpanPackPtr)smanager->allocate(sizeof(SpanPack)); | |
219 SpanPackPtr free_spack = next_spack; // next_spack free() | |
220 Span *span; | |
221 | |
109 | 222 do { |
223 /** | |
224 * SpanPack->next ¸ߤ硢 | |
225 * ߤ SpanPack Ƥ֤ | |
226 * SpanPack DMA žԤ | |
227 */ | |
182
8e9ada0c1ed0
add get_inputAddr, get_outputAddr
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
180
diff
changeset
|
228 if (spack->next != NULL) { |
8e9ada0c1ed0
add get_inputAddr, get_outputAddr
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
180
diff
changeset
|
229 smanager->dma_load(next_spack, (uint32)spack->next, |
109 | 230 sizeof(SpanPack), SPAN_PACK_LOAD); |
231 } else { | |
182
8e9ada0c1ed0
add get_inputAddr, get_outputAddr
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
180
diff
changeset
|
232 next_spack = NULL; |
109 | 233 } |
234 | |
182
8e9ada0c1ed0
add get_inputAddr, get_outputAddr
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
180
diff
changeset
|
235 for (int t = 0; t < spack->info.size; t++) { |
8e9ada0c1ed0
add get_inputAddr, get_outputAddr
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
180
diff
changeset
|
236 span = &spack->span[t]; |
109 | 237 |
164
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
238 Uint32 rgb = 0x00ff00; |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
239 float tex1 = span->tex_x1; |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
240 float tex2 = span->tex_x2; |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
241 float tey1 = span->tex_y1; |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
242 float tey2 = span->tex_y2; |
147 | 243 |
166 | 244 /** |
245 * Span 1 pixel | |
246 * ƥκɸ | |
247 */ | |
109 | 248 int tex_xpos; |
249 int tex_ypos; | |
164
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
250 |
166 | 251 /** |
252 * (tex_xpos, tex_ypos) Ρ֥å(ο)Ǥκɸ | |
253 * Υ֥åΥɥ쥹(MainMemory) | |
254 */ | |
164
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
255 int tex_localx; |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
256 int tex_localy; |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
257 uint32 *tex_addr; |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
258 |
109 | 259 int x = span->x; |
260 int y = span->y; | |
133
8f1419174cdf
DrawSpan のテクスチャ座標を求める部分で、width と height が逆に使われてた。
gongo@charles.cr.ie.u-ryukyu.ac.jp
parents:
131
diff
changeset
|
261 int x_len = span->length_x; |
109 | 262 float z = span->start_z; |
263 float zpos = span->end_z; | |
264 | |
265 // ɸ [0 .. split_screen_w-1] 褦 x,y -1 | |
266 int localx = getLocalX(x-1); | |
267 int localy = getLocalY(y-1); | |
131 | 268 |
133
8f1419174cdf
DrawSpan のテクスチャ座標を求める部分で、width と height が逆に使われてた。
gongo@charles.cr.ie.u-ryukyu.ac.jp
parents:
131
diff
changeset
|
269 if (x_len == 1) { |
109 | 270 if (x < rangex_start || rangex_end < x) { |
271 continue; | |
272 } | |
148
74341c8bf935
Span への Texture List の渡し。じゃっかん texture がバグってるので
gongo@charles.cr.ie.u-ryukyu.ac.jp
parents:
147
diff
changeset
|
273 |
164
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
274 tex_xpos = (int)((span->tex_width-1) * tex1); |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
275 tex_ypos = (int)((span->tex_height-1) * tey1); |
109 | 276 |
277 if (zpos < zRow[localx + (rangex * localy)]) { | |
166 | 278 tex_addr = getTile(tex_xpos, tex_ypos, |
279 span->tex_width, span->tex_addr); | |
164
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
280 tex_localx = tex_xpos % TEXTURE_SPLIT_PIXEL; |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
281 tex_localy = tex_ypos % TEXTURE_SPLIT_PIXEL; |
166 | 282 |
184 | 283 /** |
284 * Tile ̵硢öϤǤ | |
285 * Tile ɤ륿餻˺Ƶư | |
286 */ | |
287 if (!isAvailableTile(tex_addr)) { | |
288 spack->info.start = t; | |
192 | 289 set_rgb(tex_addr); |
290 //set_rgbs(tex_addr, | |
291 //getTile(span->tex_width-1, tex_ypos, | |
292 //span->tex_width, span->tex_addr)); | |
293 //reboot(spack, 0); | |
294 //goto FINISH; | |
184 | 295 } |
296 | |
164
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
297 rgb = get_rgb(tex_localx, tex_localy, tex_addr); |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
298 |
109 | 299 zRow[localx + (rangex * localy)] = zpos; |
300 linebuf[localy][localx] = rgb; | |
301 } | |
302 } else { | |
303 int js = (x < rangex_start) ? rangex_start - x : 0; | |
133
8f1419174cdf
DrawSpan のテクスチャ座標を求める部分で、width と height が逆に使われてた。
gongo@charles.cr.ie.u-ryukyu.ac.jp
parents:
131
diff
changeset
|
304 int je = (x + x_len > rangex_end) ? rangex_end - x : x_len; |
164
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
305 float tex_x, tex_y, tex_z; |
109 | 306 |
164
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
307 for (int j = js; j <= je; j++) { |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
308 localx = getLocalX(x-1+j); |
148
74341c8bf935
Span への Texture List の渡し。じゃっかん texture がバグってるので
gongo@charles.cr.ie.u-ryukyu.ac.jp
parents:
147
diff
changeset
|
309 |
164
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
310 tex_z = z*(x_len-1-j)/(x_len-1) + zpos*j/(x_len-1); |
133
8f1419174cdf
DrawSpan のテクスチャ座標を求める部分で、width と height が逆に使われてた。
gongo@charles.cr.ie.u-ryukyu.ac.jp
parents:
131
diff
changeset
|
311 |
164
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
312 tex_x = tex1*(x_len-1-j)/(x_len-1) + tex2*j/(x_len-1); |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
313 tex_y = tey1*(x_len-1-j)/(x_len-1) + tey2*j/(x_len-1); |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
314 if (tex_x > 1) tex_x = 1; |
165 | 315 if (tex_x < 0) tex_x = 0; |
164
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
316 if (tex_y > 1) tex_y = 1; |
165 | 317 if (tex_y < 0) tex_y = 0; |
164
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
318 tex_xpos = (int)((span->tex_width-1) * tex_x); |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
319 tex_ypos = (int)((span->tex_height-1) * tex_y); |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
320 |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
321 if (tex_z < zRow[localx + (rangex*localy)]) { |
166 | 322 tex_addr = getTile(tex_xpos, tex_ypos, |
323 span->tex_width, span->tex_addr); | |
164
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
324 tex_localx = tex_xpos % TEXTURE_SPLIT_PIXEL; |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
325 tex_localy = tex_ypos % TEXTURE_SPLIT_PIXEL; |
184 | 326 |
327 if (!isAvailableTile(tex_addr)) { | |
328 spack->info.start = t; | |
329 //set_rgb(tex_addr); | |
330 set_rgbs(tex_addr, | |
331 getTile(span->tex_width-1, tex_ypos, | |
332 span->tex_width, span->tex_addr)); | |
333 reboot(spack, j); | |
334 goto FINISH; | |
335 } | |
164
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
336 |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
337 rgb = get_rgb(tex_localx, tex_localy, tex_addr); |
168 | 338 |
164
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
339 zRow[localx + (rangex*localy)] = tex_z; |
dc7d10ae7460
TilePtr は SPE で計算した方がいいと判断して変更。
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
161
diff
changeset
|
340 linebuf[localy][localx] = rgb; |
147 | 341 } |
109 | 342 } |
343 } | |
344 } | |
147 | 345 |
109 | 346 smanager->dma_wait(SPAN_PACK_LOAD); |
347 | |
184 | 348 SpanPackPtr tmp_spack = spack; |
182
8e9ada0c1ed0
add get_inputAddr, get_outputAddr
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
180
diff
changeset
|
349 spack = next_spack; |
8e9ada0c1ed0
add get_inputAddr, get_outputAddr
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
180
diff
changeset
|
350 next_spack = tmp_spack; |
8e9ada0c1ed0
add get_inputAddr, get_outputAddr
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
180
diff
changeset
|
351 } while (spack); |
109 | 352 |
184 | 353 |
354 FINISH: | |
182
8e9ada0c1ed0
add get_inputAddr, get_outputAddr
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents:
180
diff
changeset
|
355 free(free_spack); |
109 | 356 free(linebuf); |
186 | 357 free(zRow); |
109 | 358 |
359 return 0; | |
360 } |