annotate Renderer/Engine/viewer.cc @ 1002:c79651141045

many changes.
author koba <koba@cr.ie.u-ryukyu.ac.jp>
date Sun, 24 Oct 2010 19:00:47 +0900
parents 0b8f9d4d7dab
children 295b3c79fb44
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
1 #include <SDL.h>
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
2 #include "viewer.h"
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
3 #include "viewer_types.h"
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
4 #include "SceneGraph.h"
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
5 #include "SceneGraphRoot.h"
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
6 #include "scene_graph_pack.h"
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
7 #include "sys.h"
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
8 #include "Func.h"
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
9 #include "error.h"
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
10 #include "TaskManager.h"
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
11 #include <wchar.h>
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
12 #include "Pad.h"
511
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 510
diff changeset
13 #include "Application.h"
575
0f13810d4492 Linda API worked. (slightly unreliable)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 572
diff changeset
14 #include "lindaapi.h"
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
15
523
b273767962b8 half finish for Cell
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 514
diff changeset
16 static void post2runLoop(SchedTask *s,void *viewer,void *s1);
b273767962b8 half finish for Cell
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 514
diff changeset
17 static void post2runDraw(SchedTask *s,void *viewer,void *s1);
b273767962b8 half finish for Cell
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 514
diff changeset
18 static void post2speRendering(SchedTask *s,void *viewer,void *s1);
b273767962b8 half finish for Cell
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 514
diff changeset
19 static void post2speDraw(SchedTask *s,void *viewer,void *s1);
b273767962b8 half finish for Cell
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 514
diff changeset
20 static void post2runMoveDrawLoop(SchedTask *s,void *viewer,void *s1);
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
21
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
22 /* measure for FPS (Frame Per Second) */
986
ac437c3cf766 double buffering of spanpack/polgonpack
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 985
diff changeset
23 static int start_time;
ac437c3cf766 double buffering of spanpack/polgonpack
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 985
diff changeset
24 static int this_time;
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
25 int frames;
514
2659376067e8 old ball_bound fix...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 511
diff changeset
26 // static void post2speRunLoop(void *viewer);
2659376067e8 old ball_bound fix...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 511
diff changeset
27 //static void post2runMove(void *viewer);
2659376067e8 old ball_bound fix...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 511
diff changeset
28 //static void post2exchange_sgroot(void *viewer);
2659376067e8 old ball_bound fix...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 511
diff changeset
29 //static void post2speRunLoop(void *viewer);
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
30
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
31 //SceneGraphRootPtr sgroot_2;
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
32
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
33 /* Data Pack sent to Other CPUs (ex. SPE) */
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
34
986
ac437c3cf766 double buffering of spanpack/polgonpack
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 985
diff changeset
35 RederingData r[2];
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
36
986
ac437c3cf766 double buffering of spanpack/polgonpack
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 985
diff changeset
37 int ppi, spi;
907
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
38
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
39 /**
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
40 *
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
41 */
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
42
748
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
43 Viewer::Viewer(TaskManager *m, ViewerDevice *vd, int b, int w, int h, int _num)
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
44 {
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
45 spe_num = _num;
748
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
46 manager = m;
895
bed529c55eda add alignment of classes in SPU
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 891
diff changeset
47
748
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
48 dev = vd;
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
49 pixels = dev->video_init(manager, b, w, h);
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
50
895
bed529c55eda add alignment of classes in SPU
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 891
diff changeset
51 width = dev->width;
bed529c55eda add alignment of classes in SPU
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 891
diff changeset
52 height = dev->height;
bed529c55eda add alignment of classes in SPU
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 891
diff changeset
53 bpp = dev->bpp;
bed529c55eda add alignment of classes in SPU
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 891
diff changeset
54
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
55 }
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
56
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
57 int
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
58 Viewer::get_ticks(void)
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
59 {
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
60 int time;
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
61 time = SDL_GetTicks();
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
62 return time;
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
63 }
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
64
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
65 bool
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
66 Viewer::quit_check(void)
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
67 {
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
68 SDL_Event event;
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
69
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
70 while(SDL_PollEvent(&event)) {
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
71 if (event.type==SDL_QUIT) {
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
72 return true;
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
73 }
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
74 }
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
75
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
76 Uint8 *keys=SDL_GetKeyState(NULL);
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
77
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
78 if (keys[SDLK_q] == SDL_PRESSED) {
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
79 return true;
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
80 }
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
81
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
82 return false;
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
83 }
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
84
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
85 void
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
86 Viewer::quit(void)
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
87 {
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
88 SDL_Quit();
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
89 }
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
90
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
91
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
92 void
509
8148c81d2660 Cerium Rendering Library
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 507
diff changeset
93 Viewer::run_init(TaskManager *manager, Application *app)
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
94 {
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
95 this->manager = manager;
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
96
748
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
97 if (spe_num == 0) spe_num = 1;
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
98
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
99 sgroot = new SceneGraphRoot(this->width, this->height);
572
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 565
diff changeset
100 sgroot->tmanager = manager;
792
f2497e0ecd7c add light switch
yutaka@localhost.localdomain
parents: 779
diff changeset
101
f2497e0ecd7c add light switch
yutaka@localhost.localdomain
parents: 779
diff changeset
102 int light_num = 4;
f2497e0ecd7c add light switch
yutaka@localhost.localdomain
parents: 779
diff changeset
103 int size = sizeof(float)*4*light_num; //xyz+alfa(4) * light_num(4)
762
10a8a80c2ea7 add lights
yutaka@henri.cr.ie.u-ryukyu.ac.jp
parents: 760
diff changeset
104 int light_size = size / sizeof(float);
748
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
105
760
24a37fe8419a first of all commit, not work Rendering/Test/create_task
hiroki
parents: 748
diff changeset
106 light_xyz_stock = (float *)manager->allocate(size);
748
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
107 light_xyz = (float *)manager->allocate(size);
762
10a8a80c2ea7 add lights
yutaka@henri.cr.ie.u-ryukyu.ac.jp
parents: 760
diff changeset
108
10a8a80c2ea7 add lights
yutaka@henri.cr.ie.u-ryukyu.ac.jp
parents: 760
diff changeset
109 for (int i = 0; i < light_size ; i++) {
10a8a80c2ea7 add lights
yutaka@henri.cr.ie.u-ryukyu.ac.jp
parents: 760
diff changeset
110 light_xyz[i] = 0.0f;
10a8a80c2ea7 add lights
yutaka@henri.cr.ie.u-ryukyu.ac.jp
parents: 760
diff changeset
111 }
748
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
112
907
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
113
792
f2497e0ecd7c add light switch
yutaka@localhost.localdomain
parents: 779
diff changeset
114 for(int i = 0; i < spe_num; i++) {
986
ac437c3cf766 double buffering of spanpack/polgonpack
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 985
diff changeset
115 HTaskPtr data_load = manager->create_task(DataAllocate);
ac437c3cf766 double buffering of spanpack/polgonpack
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 985
diff changeset
116 data_load->set_param(0,(memaddr)3); // num of allocate block
988
0b6f8c82625a fix for double buffer
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 986
diff changeset
117 data_load->set_param(1,(memaddr)(sizeof(float)*4*light_num)); // 1st allocate size
0b6f8c82625a fix for double buffer
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 986
diff changeset
118 data_load->set_param(2,(memaddr)Light); // 1st id
0b6f8c82625a fix for double buffer
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 986
diff changeset
119 data_load->set_param(3,(memaddr)(light_num * sizeof(int))); // 2nd size
0b6f8c82625a fix for double buffer
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 986
diff changeset
120 data_load->set_param(4,(memaddr)LightSwitch); // 2nd id
0b6f8c82625a fix for double buffer
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 986
diff changeset
121 data_load->set_param(5,(memaddr)16); // 3rd size
0b6f8c82625a fix for double buffer
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 986
diff changeset
122 data_load->set_param(6,(memaddr)LightSysSwitch); // 3rd id
748
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
123 data_load->set_cpu((CPU_TYPE)((int)SPE_0 + i));
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
124 data_load->spawn();
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
125 }
509
8148c81d2660 Cerium Rendering Library
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 507
diff changeset
126
792
f2497e0ecd7c add light switch
yutaka@localhost.localdomain
parents: 779
diff changeset
127 light_switch = (int*)manager->allocate(size);
793
c260205d3185 add light switch api
yutaka@localhost.localdomain
parents: 792
diff changeset
128
792
f2497e0ecd7c add light switch
yutaka@localhost.localdomain
parents: 779
diff changeset
129 for (int i = 0; i < light_num; i++) {
f2497e0ecd7c add light switch
yutaka@localhost.localdomain
parents: 779
diff changeset
130 light_switch[i] = 0;
f2497e0ecd7c add light switch
yutaka@localhost.localdomain
parents: 779
diff changeset
131 }
f2497e0ecd7c add light switch
yutaka@localhost.localdomain
parents: 779
diff changeset
132
f2497e0ecd7c add light switch
yutaka@localhost.localdomain
parents: 779
diff changeset
133 size = 16; // LightSysSwitch は 4byte. 残り 12byte は DMA転送の為のパディング
f2497e0ecd7c add light switch
yutaka@localhost.localdomain
parents: 779
diff changeset
134
793
c260205d3185 add light switch api
yutaka@localhost.localdomain
parents: 792
diff changeset
135 light_sysswitch = (int*)manager->allocate(size);
c260205d3185 add light switch api
yutaka@localhost.localdomain
parents: 792
diff changeset
136
843
0c7d885f0c92 cleanup unused variables and fix warning.
kazz <kazz@cr.ie.u-ryukyu.ac.jp>
parents: 842
diff changeset
137 for (unsigned int i = 0; i < size / sizeof(int); i++) {
793
c260205d3185 add light switch api
yutaka@localhost.localdomain
parents: 792
diff changeset
138 light_sysswitch[i] = 0;
c260205d3185 add light switch api
yutaka@localhost.localdomain
parents: 792
diff changeset
139 }
c260205d3185 add light switch api
yutaka@localhost.localdomain
parents: 792
diff changeset
140
984
df5185513c2d minor fix
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 983
diff changeset
141 start_time = get_ticks();
df5185513c2d minor fix
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 983
diff changeset
142 this_time = 0;
df5185513c2d minor fix
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 983
diff changeset
143 frames = 0;
df5185513c2d minor fix
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 983
diff changeset
144
511
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 510
diff changeset
145 MainLoop *mainloop = app->init(this, this->width, this->height);
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 510
diff changeset
146 mainloop->mainLoop();
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
147 }
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
148
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
149
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
150 HTaskPtr
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
151 Viewer::initLoop()
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
152 {
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
153 HTaskPtr task_next;
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
154 HTaskPtr task_tex;
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
155
986
ac437c3cf766 double buffering of spanpack/polgonpack
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 985
diff changeset
156 for(int i=0;i<2;i++) {
ac437c3cf766 double buffering of spanpack/polgonpack
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 985
diff changeset
157 r[i].ppack = (PolygonPack*)manager->allocate(sizeof(PolygonPack));
989
0b8f9d4d7dab ppack initialization fix
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 988
diff changeset
158 r[i].ppack->next = 0;
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
159
986
ac437c3cf766 double buffering of spanpack/polgonpack
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 985
diff changeset
160 r[i].spackList_length = (this->height + split_screen_h - 1) / split_screen_h;
ac437c3cf766 double buffering of spanpack/polgonpack
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 985
diff changeset
161 r[i].spackList = (SpanPack*)manager->allocate(sizeof(SpanPack)*r[i].spackList_length);
ac437c3cf766 double buffering of spanpack/polgonpack
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 985
diff changeset
162 // printf("spackList %0lx height %d\n",(unsigned long)r[i].spackList, this->height);
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
163
986
ac437c3cf766 double buffering of spanpack/polgonpack
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 985
diff changeset
164 /**
ac437c3cf766 double buffering of spanpack/polgonpack
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 985
diff changeset
165 * SPU に送る address list は 16 バイト倍数でないといけない。
ac437c3cf766 double buffering of spanpack/polgonpack
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 985
diff changeset
166 * spackList_length*sizeof(SpanPack*) が 16 バイト倍数になるような
ac437c3cf766 double buffering of spanpack/polgonpack
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 985
diff changeset
167 * length_align を求めている。はみ出した部分は使われない
ac437c3cf766 double buffering of spanpack/polgonpack
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 985
diff changeset
168 * (ex) spackList_length が 13 の場合
ac437c3cf766 double buffering of spanpack/polgonpack
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 985
diff changeset
169 * spackList_length_align = 16;
ac437c3cf766 double buffering of spanpack/polgonpack
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 985
diff changeset
170 * 実際に送るデータは64バイトになるのでOK
ac437c3cf766 double buffering of spanpack/polgonpack
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 985
diff changeset
171 * 14,15,16 の部分は何も入らない。
ac437c3cf766 double buffering of spanpack/polgonpack
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 985
diff changeset
172 */
ac437c3cf766 double buffering of spanpack/polgonpack
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 985
diff changeset
173 r[i].spackList_length_align = (r[i].spackList_length + 3)&(~3);
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
174
986
ac437c3cf766 double buffering of spanpack/polgonpack
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 985
diff changeset
175 /* 各 SPU が持つ、SpanPack の address list */
ac437c3cf766 double buffering of spanpack/polgonpack
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 985
diff changeset
176 r[i].spackList_ptr =
ac437c3cf766 double buffering of spanpack/polgonpack
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 985
diff changeset
177 (SpanPack**)manager->allocate(sizeof(SpanPack*)*r[i].spackList_length_align);
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
178
988
0b6f8c82625a fix for double buffer
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 986
diff changeset
179 for (int j = 0; j < r[i].spackList_length; j++) {
986
ac437c3cf766 double buffering of spanpack/polgonpack
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 985
diff changeset
180 r[i].spackList_ptr[j] = &r[i].spackList[j];
ac437c3cf766 double buffering of spanpack/polgonpack
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 985
diff changeset
181 }
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
182
988
0b6f8c82625a fix for double buffer
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 986
diff changeset
183 for (int j = 1; j <= r[i].spackList_length; j++) {
986
ac437c3cf766 double buffering of spanpack/polgonpack
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 985
diff changeset
184 r[i].spackList[j-1].init(j*split_screen_h);
ac437c3cf766 double buffering of spanpack/polgonpack
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 985
diff changeset
185 }
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
186 }
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
187
826
a6a6cd8d8499 RenderingEngine's Task -> Simple Task
Yutaka_Kinjyo
parents: 802
diff changeset
188 task_next = manager->create_task(Dummy,0,0,0,0);
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
189
652
dbe137505f2e bulk task list start.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 625
diff changeset
190 // ここは、Iterator を用意するべきだよね
986
ac437c3cf766 double buffering of spanpack/polgonpack
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 985
diff changeset
191 for (int j = 0; j < spe_num; j++) {
826
a6a6cd8d8499 RenderingEngine's Task -> Simple Task
Yutaka_Kinjyo
parents: 802
diff changeset
192 task_tex = manager->create_task(LoadTexture,0,0,0,0);
986
ac437c3cf766 double buffering of spanpack/polgonpack
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 985
diff changeset
193 task_tex->set_cpu((CPU_TYPE)((int)SPE_0 + j));
826
a6a6cd8d8499 RenderingEngine's Task -> Simple Task
Yutaka_Kinjyo
parents: 802
diff changeset
194 task_next->wait_for(task_tex);
748
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
195 task_tex->spawn();
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
196 }
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
197
792
f2497e0ecd7c add light switch
yutaka@localhost.localdomain
parents: 779
diff changeset
198
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
199 return task_next;
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
200 }
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
201
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
202
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
203 void
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
204 Viewer::getKey()
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
205 {
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
206 Pad *pad = sgroot->getController();
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
207 if (pad->right.isHold()) {
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
208 keyPtr->right = HOLD;
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
209 } else if (pad->right.isPush()) {
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
210 keyPtr->right = PUSH;
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
211 } else {
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
212 keyPtr->right = NONE;
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
213 }
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
214
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
215 if (pad->left.isHold()) {
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
216 keyPtr->left = HOLD;
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
217 } else if (pad->left.isPush()) {
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
218 keyPtr->left = PUSH;
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
219 } else {
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
220 keyPtr->left = NONE;
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
221 }
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
222
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
223 if (pad->up.isHold()) {
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
224 keyPtr->up = HOLD;
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
225 } else if (pad->up.isPush()) {
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
226 keyPtr->up = PUSH;
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
227 } else {
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
228 keyPtr->up = NONE;
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
229 }
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
230
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
231 if (pad->down.isHold()) {
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
232 keyPtr->down = HOLD;
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
233 } else if (pad->down.isPush()) {
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
234 keyPtr->down = PUSH;
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
235 } else {
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
236 keyPtr->down = NONE;
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
237 }
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
238
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
239 if (pad->circle.isHold()) {
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
240 keyPtr->circle = HOLD;
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
241 } else if (pad->circle.isPush()) {
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
242 keyPtr->circle = PUSH;
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
243 } else {
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
244 keyPtr->circle = NONE;
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
245 }
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
246 }
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
247
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
248 static void
514
2659376067e8 old ball_bound fix...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 511
diff changeset
249 post2runMoveDrawLoop(SchedTask *m, void *viewer_, void *arg)
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
250 {
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
251 Viewer *viewer = (Viewer*)viewer_;
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
252
625
60aa3f241b10 64bit mode worked on Mac OS X.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 616
diff changeset
253 // 同じ PPE 上なので sgroot(ポインタ) を set_param で送る。
614
4e44147d78ee remove uncessary Task Name definision
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 603
diff changeset
254 //HTaskPtr send_key_task = viewer->manager->create_task(SendKey);
625
60aa3f241b10 64bit mode worked on Mac OS X.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 616
diff changeset
255 //send_key_task->set_param((int)sgroot);
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
256 // set input data -> viewer keyPtr
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
257 viewer->getKey();
826
a6a6cd8d8499 RenderingEngine's Task -> Simple Task
Yutaka_Kinjyo
parents: 802
diff changeset
258 //HTaskPtr update_key = viewer->manager->create_task(UpdateKey,viewer->keyPtr, sizeof(key_stat),0,0);
a6a6cd8d8499 RenderingEngine's Task -> Simple Task
Yutaka_Kinjyo
parents: 802
diff changeset
259 HTaskPtr update_key = viewer->manager->create_task(UpdateKey,0,0,0,0);
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
260 update_key->add_inData(viewer->keyPtr, sizeof(key_stat));
748
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
261 //update_key->set_cpu(SPE_0);
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
262 update_key->spawn();
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
263
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
264 /* TASK_MOVE は外から引数で取ってくるべき */
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
265 //HTaskPtr move_task = viewer->manager->create_task(viewer->app->move_taskid);
965
1089f24bc86a removing user task from Renderer Engine
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 926
diff changeset
266 // HTaskPtr move_task = viewer->manager->create_task(Move,0,0,0,0);
625
60aa3f241b10 64bit mode worked on Mac OS X.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 616
diff changeset
267 //move_task->set_param(sgroot);
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
268
614
4e44147d78ee remove uncessary Task Name definision
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 603
diff changeset
269 //HTaskPtr draw_task = viewer->manager->create_task(Draw);
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
270
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
271 /* rendering task test */
826
a6a6cd8d8499 RenderingEngine's Task -> Simple Task
Yutaka_Kinjyo
parents: 802
diff changeset
272 HTaskPtr draw_task = viewer->manager->create_task(Dummy,0,0,0,0);
a6a6cd8d8499 RenderingEngine's Task -> Simple Task
Yutaka_Kinjyo
parents: 802
diff changeset
273 HTaskPtr draw_dummy = viewer->manager->create_task(Dummy,0,0,0,0);
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
274
826
a6a6cd8d8499 RenderingEngine's Task -> Simple Task
Yutaka_Kinjyo
parents: 802
diff changeset
275 HTaskPtr switch_task = viewer->manager->create_task(Switch,0,0,0,0);
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
276 viewer->draw_dummy = draw_dummy;
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
277 switch_task->wait_for(draw_dummy);
514
2659376067e8 old ball_bound fix...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 511
diff changeset
278 draw_task->set_post(post2speRendering, (void*)viewer, 0);
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
279
965
1089f24bc86a removing user task from Renderer Engine
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 926
diff changeset
280 // switch_task->wait_for(move_task);
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
281 switch_task->wait_for(draw_task);
965
1089f24bc86a removing user task from Renderer Engine
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 926
diff changeset
282 // move_task->spawn();
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
283 draw_task->spawn();
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
284
514
2659376067e8 old ball_bound fix...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 511
diff changeset
285 switch_task->set_post(post2runMoveDrawLoop, (void*)viewer, 0);
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
286 switch_task->spawn();
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
287
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
288 }
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
289
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
290 void
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
291 Viewer::mainLoop()
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
292 {
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
293 HTaskPtr task_next = initLoop();
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
294
514
2659376067e8 old ball_bound fix...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 511
diff changeset
295 task_next->set_post(&post2runLoop, (void *)this, 0); // set_post(function(this->run_loop()), NULL)
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
296 task_next->spawn();
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
297 }
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
298
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
299 void
748
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
300 Viewer::run_loop(HTaskPtr task_next)
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
301 {
748
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
302 dev->clear_screen();
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
303
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
304 bool quit_flg;
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
305 quit_flg = quit_check();
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
306 if (quit_flg == true) {
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
307 this_time = get_ticks();
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
308 run_finish();
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
309 return;
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
310 }
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
311
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
312 dev->clean_pixels();
981
a193a851b5e3 add double buffering frame device
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 969
diff changeset
313 pixels = dev->flip_screen(pixels);
748
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
314
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
315 sgroot->updateControllerState();
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
316 sgroot->allExecute(width, height);
1002
c79651141045 many changes.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 989
diff changeset
317 sgroot->task_array_finish();
748
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
318 light_xyz_stock = sgroot->getLightVector();
792
f2497e0ecd7c add light switch
yutaka@localhost.localdomain
parents: 779
diff changeset
319 light_switch_stock = sgroot->getLightSwitch();
793
c260205d3185 add light switch api
yutaka@localhost.localdomain
parents: 792
diff changeset
320 light_sysswitch_stock = sgroot->getLightSysSwitch();
748
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
321 //sgroot->checkRemove();
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
322
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
323 // ここから下は Rendering という関数にする
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
324 rendering(task_next);
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
325 }
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
326
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
327
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
328
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
329 void
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
330 Viewer::run_collision()
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
331 {
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
332 }
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
333
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
334 void
514
2659376067e8 old ball_bound fix...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 511
diff changeset
335 post2rendering(SchedTask *s, void *viewer_, void *arg)
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
336 {
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
337 Viewer *viewer = (Viewer *)viewer_;
826
a6a6cd8d8499 RenderingEngine's Task -> Simple Task
Yutaka_Kinjyo
parents: 802
diff changeset
338 HTaskPtr task_next = viewer->manager->create_task(Dummy,0,0,0,0);
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
339 viewer->rendering(task_next);
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
340 }
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
341
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
342 void
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
343 Viewer::rendering(HTaskPtr task_next)
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
344 {
748
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
345 common_rendering(task_next, sgroot);
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
346
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
347 // Barrier 同期
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
348 // run_draw() を呼ぶ post2runDraw
514
2659376067e8 old ball_bound fix...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 511
diff changeset
349 task_next->set_post(post2runDraw, (void*)this, 0); // set_post(function(this->run_draw()), NULL)
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
350 task_next->spawn();
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
351
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
352 // TASK_CREATE_SPAN が全て終わったら DUMMY_TASK が Viewer::run_draw() を呼ぶ
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
353 }
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
354
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
355 static void
514
2659376067e8 old ball_bound fix...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 511
diff changeset
356 post2runLoop(SchedTask *s, void *viewer_, void *arg)
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
357 {
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
358 Viewer *viewer = (Viewer*)viewer_;
826
a6a6cd8d8499 RenderingEngine's Task -> Simple Task
Yutaka_Kinjyo
parents: 802
diff changeset
359 HTaskPtr task_next = viewer->manager->create_task(Dummy,0,0,0,0);
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
360 viewer->run_loop(task_next);
575
0f13810d4492 Linda API worked. (slightly unreliable)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 572
diff changeset
361 psx_sync_n();
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
362 }
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
363
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
364 static void
514
2659376067e8 old ball_bound fix...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 511
diff changeset
365 post2runDraw(SchedTask *s, void *viewer_, void *arg)
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
366 {
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
367 Viewer *viewer = (Viewer*)viewer_;
826
a6a6cd8d8499 RenderingEngine's Task -> Simple Task
Yutaka_Kinjyo
parents: 802
diff changeset
368 HTaskPtr task_next = viewer->manager->create_task(Dummy,0,0,0,0);
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
369 viewer->run_draw(task_next);
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
370
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
371 }
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
372
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
373 void
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
374 Viewer::run_draw(HTaskPtr task_next) // 引数に post2runLoop を入れるようにする
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
375 {
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
376 common_draw(task_next);
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
377
514
2659376067e8 old ball_bound fix...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 511
diff changeset
378 task_next->set_post(post2runLoop, (void*)this, 0); // set_post(function(this->run_loop()), NULL)
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
379 task_next->spawn();
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
380 // TASK_DRAW_SPAN が全て終わったら DUMMY_TASK が Viewer::run_loop() を呼ぶ
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
381
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
382 frames++;
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
383 }
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
384
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
385
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
386 static void
514
2659376067e8 old ball_bound fix...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 511
diff changeset
387 post2speRendering(SchedTask *s, void *viewer_, void *arg)
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
388 {
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
389 Viewer *viewer = (Viewer*)viewer_;
826
a6a6cd8d8499 RenderingEngine's Task -> Simple Task
Yutaka_Kinjyo
parents: 802
diff changeset
390 HTaskPtr task_next = viewer->manager->create_task(Dummy,0,0,0,0);
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
391 viewer->spe_rendering(task_next);
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
392 }
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
393
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
394 void
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
395 Viewer::spe_rendering(HTaskPtr task_next)
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
396 {
748
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
397 common_rendering(task_next, sgroot);
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
398
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
399 this->draw_dummy->wait_for(task_next);
514
2659376067e8 old ball_bound fix...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 511
diff changeset
400 task_next->set_post(post2speDraw, (void*)this, 0);
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
401 task_next->spawn();
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
402
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
403 }
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
404
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
405 static void
514
2659376067e8 old ball_bound fix...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 511
diff changeset
406 post2speDraw(SchedTask *s, void *viewer_, void *arg)
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
407 {
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
408 Viewer *viewer = (Viewer*)viewer_;
826
a6a6cd8d8499 RenderingEngine's Task -> Simple Task
Yutaka_Kinjyo
parents: 802
diff changeset
409 HTaskPtr task_next = viewer->manager->create_task(Dummy,0,0,0,0);
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
410 viewer->spe_draw(task_next);
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
411 }
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
412
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
413 void
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
414 Viewer::spe_draw(HTaskPtr task_next)
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
415 {
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
416 common_draw(task_next);
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
417
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
418 this->draw_dummy->wait_for(task_next);
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
419 task_next->spawn();
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
420 this->draw_dummy->spawn();
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
421
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
422 frames++;
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
423 }
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
424
907
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
425
908
Yutaka_Kinjyo
parents: 907
diff changeset
426 // 完全にMac仕様。。sg_matrix を allocate してやらないといけないよ。
915
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
427 float*
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
428 copy_matrix(SceneGraphPtr sg, TaskManager *manager) {
908
Yutaka_Kinjyo
parents: 907
diff changeset
429
Yutaka_Kinjyo
parents: 907
diff changeset
430 float *matrix = sg->matrix;
Yutaka_Kinjyo
parents: 907
diff changeset
431 float *real_matrix = sg->real_matrix;
Yutaka_Kinjyo
parents: 907
diff changeset
432
915
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
433 //変換行列は4x4 なんで、16。が二つで32.と言い訳を書いてみる。
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
434 float *sg_matrix = (float*)manager->allocate(sizeof(float)*32);
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
435
908
Yutaka_Kinjyo
parents: 907
diff changeset
436 for (int i = 0; i < 16; i++) {
915
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
437 sg_matrix[i] = matrix[i];
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
438 sg_matrix[i+16] = real_matrix[i];
908
Yutaka_Kinjyo
parents: 907
diff changeset
439 }
Yutaka_Kinjyo
parents: 907
diff changeset
440
915
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
441 return sg_matrix;
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
442
908
Yutaka_Kinjyo
parents: 907
diff changeset
443 }
Yutaka_Kinjyo
parents: 907
diff changeset
444
Yutaka_Kinjyo
parents: 907
diff changeset
445 void
Yutaka_Kinjyo
parents: 907
diff changeset
446 print_matrix(float *matrix) {
Yutaka_Kinjyo
parents: 907
diff changeset
447
Yutaka_Kinjyo
parents: 907
diff changeset
448 for (int i = 0; i < 32; i++) {
Yutaka_Kinjyo
parents: 907
diff changeset
449 printf("%f\n",matrix[i]);
Yutaka_Kinjyo
parents: 907
diff changeset
450 }
Yutaka_Kinjyo
parents: 907
diff changeset
451
Yutaka_Kinjyo
parents: 907
diff changeset
452 }
907
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
453
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
454 void
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
455 add_matrix_list(SceneGraphPtr sg, TaskManager *manager, MatrixListInfo* info) {
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
456
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
457 MatrixList *matrix_list = (MatrixList*)manager->allocate(sizeof(MatrixList));
908
Yutaka_Kinjyo
parents: 907
diff changeset
458
Yutaka_Kinjyo
parents: 907
diff changeset
459 #if SPE_CREATE_POLYGON_CHECK
Yutaka_Kinjyo
parents: 907
diff changeset
460 print_matrix(sg->sg_matrix);
Yutaka_Kinjyo
parents: 907
diff changeset
461 #endif
Yutaka_Kinjyo
parents: 907
diff changeset
462
915
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
463 matrix_list->matrix = copy_matrix(sg, manager);;
907
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
464 matrix_list->next = NULL;
908
Yutaka_Kinjyo
parents: 907
diff changeset
465
907
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
466
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
467 if (info->last != NULL) {
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
468 info->last->next = matrix_list;
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
469 }
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
470
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
471 info->last = matrix_list;
915
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
472 info->list_length += 1;
907
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
473
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
474 }
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
475
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
476 void
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
477 new_matrix_info(SceneGraphPtr sg, TaskManager *manager, MatrixListInfo* info) {
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
478
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
479 MatrixListInfo *next = NULL;
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
480
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
481 if (info->id == -1) {
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
482
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
483 info->id = sg->sgid;
915
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
484 info->list_length = 1;
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
485 info->coord_pack = sg->coord_pack;
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
486 info->coord_pack_size = sg->coord_pack_size;
907
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
487 next = info;
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
488
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
489 } else {
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
490
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
491 MatrixListInfo* t;
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
492
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
493 for (t = info; t->next != NULL; t = t->next) {
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
494 }
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
495
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
496 next = (MatrixListInfo*)manager->allocate(sizeof(MatrixListInfo));
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
497 next->id = sg->sgid;
915
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
498 next->list_length = 1;
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
499 next->coord_pack = sg->coord_pack;
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
500 next->coord_pack_size = sg->coord_pack_size;
907
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
501 next->next = NULL;
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
502 t->next = next;
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
503
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
504 }
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
505
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
506 MatrixList *new_list = (MatrixList*)manager->allocate(sizeof(MatrixList));
915
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
507 new_list->matrix = copy_matrix(sg, manager);
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
508
908
Yutaka_Kinjyo
parents: 907
diff changeset
509 #if SPE_CREATE_POLYGON_CHECK
Yutaka_Kinjyo
parents: 907
diff changeset
510 print_matrix(sg->sg_matrix);
Yutaka_Kinjyo
parents: 907
diff changeset
511 #endif
915
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
512
907
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
513 new_list->next = NULL;
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
514
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
515 next->first = new_list;
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
516 next->last = new_list;
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
517
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
518 }
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
519
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
520 void
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
521 collect_matrix(SceneGraphPtr sg, MatrixListInfo *matrix_info, TaskManager *manager) {
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
522
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
523 matrix_info->id = -1;
915
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
524 matrix_info->list_length = 0;
907
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
525 matrix_info->next = NULL;
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
526 matrix_info->first = NULL;
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
527 matrix_info->last = NULL;
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
528
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
529 while (sg) {
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
530
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
531 if (sg->flag_drawable) {
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
532
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
533 int flag = 0;
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
534
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
535 for (MatrixListInfo* t = matrix_info; t != NULL; t = t->next) {
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
536 if (sg->sgid == t->id) {
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
537 add_matrix_list(sg, manager, t);
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
538 flag = 1;
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
539 }
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
540 }
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
541
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
542 if (flag != 1) {
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
543 new_matrix_info(sg, manager, matrix_info);
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
544 }
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
545
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
546 // search SceneGraph. でも、ただのリストがあったハズだから、あとでそれに直す。はず・・
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
547 if (sg->children != NULL) {
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
548 sg = sg->children;
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
549 } else if (sg->brother != NULL) {
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
550 sg = sg->brother;
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
551 } else {
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
552 while (sg) {
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
553 if (sg->brother != NULL) {
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
554 sg = sg->brother;
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
555 break;
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
556 } else {
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
557 if (sg->parent == NULL) {
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
558 sg = NULL;
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
559 break;
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
560 } else {
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
561 sg = sg->parent;
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
562 }
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
563 }
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
564 }
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
565 }
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
566 }
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
567 }
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
568 }
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
569
908
Yutaka_Kinjyo
parents: 907
diff changeset
570 void
915
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
571 check_matrix(MatrixListInfo *matrix_info,SceneGraphPtr sg) {
908
Yutaka_Kinjyo
parents: 907
diff changeset
572
Yutaka_Kinjyo
parents: 907
diff changeset
573 for (MatrixListInfo* t = matrix_info; t != NULL; t = t->next) {
Yutaka_Kinjyo
parents: 907
diff changeset
574 for (MatrixList* u = t->first; u != NULL; u = u->next) {
Yutaka_Kinjyo
parents: 907
diff changeset
575 print_matrix(u->matrix);
Yutaka_Kinjyo
parents: 907
diff changeset
576 }
Yutaka_Kinjyo
parents: 907
diff changeset
577 }
Yutaka_Kinjyo
parents: 907
diff changeset
578
Yutaka_Kinjyo
parents: 907
diff changeset
579 }
Yutaka_Kinjyo
parents: 907
diff changeset
580
915
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
581
908
Yutaka_Kinjyo
parents: 907
diff changeset
582 void
915
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
583 coord_allocate(int &cur_point, float *coord_pack, int spe_num,
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
584 int alloc_size, HTaskPtr alloc_wait, TaskManager *manager)
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
585 {
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
586
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
587 for (int i = 0; i < spe_num; i++) {
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
588
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
589 HTaskPtr data_alloc = manager->create_task(DataAllocate);
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
590 //data_alloc->set_inData(0, &coord_pack[cur_point], alloc_size);
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
591 data_alloc->set_param(0,(memaddr)alloc_size);
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
592 data_alloc->set_param(1,(memaddr)SG_COORD);
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
593 data_alloc->set_cpu((CPU_TYPE)((int)SPE_0 + i));
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
594 alloc_wait->wait_for(data_alloc);
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
595 data_alloc->spawn();
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
596
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
597 }
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
598
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
599 cur_point += alloc_size / sizeof(float);
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
600
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
601 }
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
602
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
603 void
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
604 coord_free(int spe_num, TaskManager *manager, HTaskPtr alloc_wait)
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
605 {
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
606
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
607 for (int i = 0; i < spe_num; i++) {
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
608
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
609 HTaskPtr data_free = manager->create_task(DataFree);
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
610 data_free->set_param(0,(memaddr)SG_COORD);
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
611 data_free->set_cpu((CPU_TYPE)((int)SPE_0 + i));
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
612 data_free->wait_for(alloc_wait);
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
613 data_free->spawn();
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
614
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
615 }
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
616
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
617 }
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
618
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
619 void
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
620 create_pp_task(SceneGraphPtr sg, TaskManager *manager, int spe_num, HTaskPtr task_next)
907
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
621 {
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
622
915
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
623 MatrixListInfo *matrix_info = (MatrixListInfo*)manager->allocate(sizeof(MatrixListInfo));
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
624 collect_matrix(sg, matrix_info, manager);
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
625
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
626
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
627 //HTaskPtr phase_wait = manager->create_task(Dummy);
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
628
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
629 for (MatrixListInfo* t = matrix_info; t != NULL; t = t->next) {
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
630
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
631 printf("list_length %d \n", t->list_length);
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
632
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
633 int alloc_size = 16*1024;
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
634
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
635 if (t->coord_pack_size < alloc_size) {
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
636 alloc_size = t->coord_pack_size;
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
637 }
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
638
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
639
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
640 int division_num = (t->coord_pack_size + alloc_size - 1) / alloc_size;
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
641 int phase_num = (division_num + spe_num -1) / spe_num;
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
642 int cur_point = 0;
907
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
643
915
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
644 for (int i = 0; i < phase_num; i++) {
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
645
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
646 HTaskPtr alloc_wait = manager->create_task(Dummy);
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
647 coord_allocate(cur_point, t->coord_pack, spe_num,
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
648 alloc_size, alloc_wait, manager);
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
649
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
650
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
651 for (MatrixList* u = t->first; u != NULL; u = u->next) {
907
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
652
915
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
653 //HTaskPtr free_wait = manager->create_task(Dummy);
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
654
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
655 //phase_wait = manager->create_task(Dummy);
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
656
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
657 }
907
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
658
915
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
659 coord_free(spe_num, manager, alloc_wait);
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
660 alloc_wait->spawn();
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
661 }
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
662 }
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
663
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
664 printf("-----------------------\n");
908
Yutaka_Kinjyo
parents: 907
diff changeset
665 //return create_pp_wait;
907
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
666
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
667 }
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
668
860
649e4cb84683 Still on the way
yutaka@localhost.localdomain
parents: 857
diff changeset
669 void
748
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
670 Viewer::common_rendering(HTaskPtr task_next, SceneGraphRoot *sgroot)
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
671 {
860
649e4cb84683 Still on the way
yutaka@localhost.localdomain
parents: 857
diff changeset
672
649e4cb84683 Still on the way
yutaka@localhost.localdomain
parents: 857
diff changeset
673 #if SPE_CREATE_POLYGON
649e4cb84683 Still on the way
yutaka@localhost.localdomain
parents: 857
diff changeset
674
907
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
675 SceneGraphPtr sg = sgroot->getDrawSceneGraph();
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
676
915
ad10d6d39ca6 create_polygon_task ..not worked yet.
yutaka@localhost.localdomain
parents: 914
diff changeset
677 create_pp_task(sg, manager, spe_num, task_next);
907
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
678
908
Yutaka_Kinjyo
parents: 907
diff changeset
679 #if SPE_CREATE_POLYGON_CHECK
Yutaka_Kinjyo
parents: 907
diff changeset
680 check_matrix(matrix_info,sg);
Yutaka_Kinjyo
parents: 907
diff changeset
681 #endif
Yutaka_Kinjyo
parents: 907
diff changeset
682
907
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
683
909
Yutaka_Kinjyo
parents: 908
diff changeset
684
Yutaka_Kinjyo
parents: 908
diff changeset
685 #else
907
62838c1cd4b0 collect matrix..
Yutaka_Kinjyo
parents: 900
diff changeset
686
614
4e44147d78ee remove uncessary Task Name definision
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 603
diff changeset
687 HTaskPtr task_create_pp = manager->create_task(CreatePolygonFromSceneGraph);
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
688 // SceneGraph(木構造) -> PolygonPack
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
689
625
60aa3f241b10 64bit mode worked on Mac OS X.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 616
diff changeset
690 task_create_pp->set_param(0,(memaddr)sgroot->getDrawSceneGraph());
986
ac437c3cf766 double buffering of spanpack/polgonpack
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 985
diff changeset
691 task_create_pp->set_param(1,(memaddr)r[ppi].ppack);
969
9a53faae88d8 add new function for dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 965
diff changeset
692 /* GameTaskの終了を待ってからポリゴンを作る */
1002
c79651141045 many changes.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 989
diff changeset
693 task_create_pp->wait_for(sgroot->game_task_array);
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
694
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
695 task_next->wait_for(task_create_pp);
748
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
696
909
Yutaka_Kinjyo
parents: 908
diff changeset
697 #endif
Yutaka_Kinjyo
parents: 908
diff changeset
698
748
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
699 int range_base = spe_num;
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
700
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
701 // 切り上げのつもり
986
ac437c3cf766 double buffering of spanpack/polgonpack
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 985
diff changeset
702 int range = (r[spi].spackList_length + range_base - 1) / range_base;
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
703
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
704 for (int i = 0; i < range_base; i++) {
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
705 int index_start = range*i;
986
ac437c3cf766 double buffering of spanpack/polgonpack
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 985
diff changeset
706 int index_end = (index_start + range >= r[spi].spackList_length)
ac437c3cf766 double buffering of spanpack/polgonpack
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 985
diff changeset
707 ? r[spi].spackList_length : index_start + range;
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
708
652
dbe137505f2e bulk task list start.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 625
diff changeset
709 HTaskPtr task_create_sp = manager->create_task(CreateSpan);
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
710
625
60aa3f241b10 64bit mode worked on Mac OS X.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 616
diff changeset
711 task_create_sp->set_param(0,index_start);
748
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
712
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
713 /**
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
714 * ex. screen_height が 480, spenum が 6 の場合、各SPEのy担当範囲
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
715 * [ 1.. 80] [ 81..160] [161..240]
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
716 * [241..320] [321..400] [401..480]
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
717 *
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
718 * ex. screen_height が 1080, spenum が 5 の場合、
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
719 * [ 1..216] [217..432] [433..648]
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
720 * [649..864] [865..1080]
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
721 */
748
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
722
625
60aa3f241b10 64bit mode worked on Mac OS X.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 616
diff changeset
723 task_create_sp->set_param(1,index_start*split_screen_h + 1);
60aa3f241b10 64bit mode worked on Mac OS X.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 616
diff changeset
724 task_create_sp->set_param(2,index_end*split_screen_h);
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
725
986
ac437c3cf766 double buffering of spanpack/polgonpack
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 985
diff changeset
726 task_create_sp->add_inData(r[ppi].ppack, sizeof(PolygonPack));
ac437c3cf766 double buffering of spanpack/polgonpack
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 985
diff changeset
727 task_create_sp->add_inData(r[spi].spackList_ptr,
ac437c3cf766 double buffering of spanpack/polgonpack
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 985
diff changeset
728 sizeof(SpanPack*)*r[spi].spackList_length_align);
ac437c3cf766 double buffering of spanpack/polgonpack
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 985
diff changeset
729 task_create_sp->add_inData(&r[spi].spackList[index_start], sizeof(SpanPack));
652
dbe137505f2e bulk task list start.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 625
diff changeset
730
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
731 task_next->wait_for(task_create_sp);
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
732 task_create_sp->wait_for(task_create_pp);
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
733
748
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
734 task_create_sp->set_cpu(SPE_ANY);
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
735 task_create_sp->spawn();
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
736 }
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
737
860
649e4cb84683 Still on the way
yutaka@localhost.localdomain
parents: 857
diff changeset
738 task_create_pp->spawn();
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
739 }
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
740
792
f2497e0ecd7c add light switch
yutaka@localhost.localdomain
parents: 779
diff changeset
741
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
742 void
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
743 Viewer::common_draw(HTaskPtr task_next)
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
744 {
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
745
614
4e44147d78ee remove uncessary Task Name definision
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 603
diff changeset
746 //task_next = manager->create_task(Dummy);
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
747 //task_next->set_post(post2runLoop, (void*)this);
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
748
792
f2497e0ecd7c add light switch
yutaka@localhost.localdomain
parents: 779
diff changeset
749 //Light info update
748
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
750
792
f2497e0ecd7c add light switch
yutaka@localhost.localdomain
parents: 779
diff changeset
751 int light_num = 4;
f2497e0ecd7c add light switch
yutaka@localhost.localdomain
parents: 779
diff changeset
752 int size = sizeof(float)*4*light_num; //xyz+alpha(4) * light_num(4)
762
10a8a80c2ea7 add lights
yutaka@henri.cr.ie.u-ryukyu.ac.jp
parents: 760
diff changeset
753 int light_size = size / sizeof(float);
748
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
754
762
10a8a80c2ea7 add lights
yutaka@henri.cr.ie.u-ryukyu.ac.jp
parents: 760
diff changeset
755 for (int i = 0; i < light_size; i++) {
792
f2497e0ecd7c add light switch
yutaka@localhost.localdomain
parents: 779
diff changeset
756 light_xyz[i] = light_xyz_stock[i];
762
10a8a80c2ea7 add lights
yutaka@henri.cr.ie.u-ryukyu.ac.jp
parents: 760
diff changeset
757 }
792
f2497e0ecd7c add light switch
yutaka@localhost.localdomain
parents: 779
diff changeset
758
f2497e0ecd7c add light switch
yutaka@localhost.localdomain
parents: 779
diff changeset
759 for (int i = 0; i < light_num; i++) {
f2497e0ecd7c add light switch
yutaka@localhost.localdomain
parents: 779
diff changeset
760 light_switch[i] = light_switch_stock[i];
f2497e0ecd7c add light switch
yutaka@localhost.localdomain
parents: 779
diff changeset
761 }
793
c260205d3185 add light switch api
yutaka@localhost.localdomain
parents: 792
diff changeset
762
c260205d3185 add light switch api
yutaka@localhost.localdomain
parents: 792
diff changeset
763 light_sysswitch[0] = light_sysswitch_stock;
985
e40dd2384357 fix light data update
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 984
diff changeset
764
e40dd2384357 fix light data update
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 984
diff changeset
765
e40dd2384357 fix light data update
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 984
diff changeset
766 HTask *data_update_wait = 0;
e40dd2384357 fix light data update
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 984
diff changeset
767 for (int i = 0; i < spe_num; i++) {
e40dd2384357 fix light data update
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 984
diff changeset
768 data_update_wait = manager->create_task(DataUpdate);
e40dd2384357 fix light data update
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 984
diff changeset
769 data_update_wait->set_param(0,3);
e40dd2384357 fix light data update
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 984
diff changeset
770 data_update_wait->set_param(1,Light); // GlobalSet ID base
e40dd2384357 fix light data update
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 984
diff changeset
771 data_update_wait->set_inData(0,light_xyz,size); // Light
e40dd2384357 fix light data update
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 984
diff changeset
772 data_update_wait->set_inData(1,light_switch,light_num * sizeof(int)); // LightSwitch = Light+1
e40dd2384357 fix light data update
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 984
diff changeset
773 data_update_wait->set_inData(2,light_sysswitch,16); // LightSysSwitch = Light+2
e40dd2384357 fix light data update
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 984
diff changeset
774 data_update_wait->set_cpu((CPU_TYPE)(SPE_0+i));
e40dd2384357 fix light data update
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 984
diff changeset
775 data_update_wait->spawn();
792
f2497e0ecd7c add light switch
yutaka@localhost.localdomain
parents: 779
diff changeset
776 }
f2497e0ecd7c add light switch
yutaka@localhost.localdomain
parents: 779
diff changeset
777
986
ac437c3cf766 double buffering of spanpack/polgonpack
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 985
diff changeset
778 ppi ^= 1;
ac437c3cf766 double buffering of spanpack/polgonpack
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 985
diff changeset
779 r[ppi].ppack->clear();
914
05696567d1d2 0 is filled on the spe side.
yutaka@localhost.localdomain
parents: 913
diff changeset
780
986
ac437c3cf766 double buffering of spanpack/polgonpack
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 985
diff changeset
781 for (int i = 0; i < r[spi].spackList_length; i++) {
ac437c3cf766 double buffering of spanpack/polgonpack
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 985
diff changeset
782 SpanPack *spack = &r[spi].spackList[i];
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
783 int startx = 1;
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
784 int endx = split_screen_w;
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
785
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
786 int starty = spack->info.y_top - split_screen_h + 1;
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
787 //int endy = spack->info.y_top;
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
788 int rangey = (starty + split_screen_h - 1 > this->height)
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
789 ? this->height - starty + 1 : split_screen_h;
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
790
1002
c79651141045 many changes.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 989
diff changeset
791 #if 0
857
f7276b509710 DrawSpan taskArray bug fix
yutaka@localhost.localdomain
parents: 854
diff changeset
792
914
05696567d1d2 0 is filled on the spe side.
yutaka@localhost.localdomain
parents: 913
diff changeset
793 // mem_flag は spe 側で黒い部分を 0 で埋めるフラグ
05696567d1d2 0 is filled on the spe side.
yutaka@localhost.localdomain
parents: 913
diff changeset
794 if(spack->info.size > 0 || mem_flag == 1) {
838
41302b72c895 Draw Span Task -> Task Array
Yutaka_Kinjyo
parents: 826
diff changeset
795
857
f7276b509710 DrawSpan taskArray bug fix
yutaka@localhost.localdomain
parents: 854
diff changeset
796 int array_task_num = (this->width + split_screen_w - 1) / split_screen_w;
f7276b509710 DrawSpan taskArray bug fix
yutaka@localhost.localdomain
parents: 854
diff changeset
797 HTaskPtr task_draw_array = manager->create_task_array(DrawSpan, array_task_num, 6, 1, rangey);
f7276b509710 DrawSpan taskArray bug fix
yutaka@localhost.localdomain
parents: 854
diff changeset
798 Task *task_draw = 0;
f7276b509710 DrawSpan taskArray bug fix
yutaka@localhost.localdomain
parents: 854
diff changeset
799
f7276b509710 DrawSpan taskArray bug fix
yutaka@localhost.localdomain
parents: 854
diff changeset
800 while (startx < this->width) {
f7276b509710 DrawSpan taskArray bug fix
yutaka@localhost.localdomain
parents: 854
diff changeset
801
839
71350a51c391 if unnecessary
Yutaka_Kinjyo
parents: 838
diff changeset
802 // Draw SpanPack
857
f7276b509710 DrawSpan taskArray bug fix
yutaka@localhost.localdomain
parents: 854
diff changeset
803
839
71350a51c391 if unnecessary
Yutaka_Kinjyo
parents: 838
diff changeset
804 task_draw = task_draw_array->next_task_array(DrawSpan,task_draw);
71350a51c391 if unnecessary
Yutaka_Kinjyo
parents: 838
diff changeset
805 task_draw->set_param(0,(memaddr)&pixels[(startx-1) + this->width*(starty-1)]);
71350a51c391 if unnecessary
Yutaka_Kinjyo
parents: 838
diff changeset
806 task_draw->set_param(1,this->width);
71350a51c391 if unnecessary
Yutaka_Kinjyo
parents: 838
diff changeset
807 task_draw->set_param(2,startx);
71350a51c391 if unnecessary
Yutaka_Kinjyo
parents: 838
diff changeset
808 task_draw->set_param(3,endx);
71350a51c391 if unnecessary
Yutaka_Kinjyo
parents: 838
diff changeset
809 task_draw->set_param(4,rangey);
71350a51c391 if unnecessary
Yutaka_Kinjyo
parents: 838
diff changeset
810 task_draw->set_param(5,spack->info.size);
838
41302b72c895 Draw Span Task -> Task Array
Yutaka_Kinjyo
parents: 826
diff changeset
811
839
71350a51c391 if unnecessary
Yutaka_Kinjyo
parents: 838
diff changeset
812 task_draw->set_inData(0,spack, sizeof(SpanPack));
71350a51c391 if unnecessary
Yutaka_Kinjyo
parents: 838
diff changeset
813
71350a51c391 if unnecessary
Yutaka_Kinjyo
parents: 838
diff changeset
814 for (int i = 0; i < rangey; i++) {
857
f7276b509710 DrawSpan taskArray bug fix
yutaka@localhost.localdomain
parents: 854
diff changeset
815 task_draw->set_outData(i,
f7276b509710 DrawSpan taskArray bug fix
yutaka@localhost.localdomain
parents: 854
diff changeset
816 &pixels[(startx-1) + this->width*(starty-1 + i) ],
f7276b509710 DrawSpan taskArray bug fix
yutaka@localhost.localdomain
parents: 854
diff changeset
817 (endx-startx+1)*sizeof(int));
839
71350a51c391 if unnecessary
Yutaka_Kinjyo
parents: 838
diff changeset
818 }
71350a51c391 if unnecessary
Yutaka_Kinjyo
parents: 838
diff changeset
819
71350a51c391 if unnecessary
Yutaka_Kinjyo
parents: 838
diff changeset
820 startx += split_screen_w;
71350a51c391 if unnecessary
Yutaka_Kinjyo
parents: 838
diff changeset
821 endx += split_screen_w;
71350a51c391 if unnecessary
Yutaka_Kinjyo
parents: 838
diff changeset
822
71350a51c391 if unnecessary
Yutaka_Kinjyo
parents: 838
diff changeset
823 if (endx > this->width) {
71350a51c391 if unnecessary
Yutaka_Kinjyo
parents: 838
diff changeset
824 endx = this->width;
71350a51c391 if unnecessary
Yutaka_Kinjyo
parents: 838
diff changeset
825 }
71350a51c391 if unnecessary
Yutaka_Kinjyo
parents: 838
diff changeset
826
857
f7276b509710 DrawSpan taskArray bug fix
yutaka@localhost.localdomain
parents: 854
diff changeset
827 }
f7276b509710 DrawSpan taskArray bug fix
yutaka@localhost.localdomain
parents: 854
diff changeset
828
f7276b509710 DrawSpan taskArray bug fix
yutaka@localhost.localdomain
parents: 854
diff changeset
829 task_draw_array->spawn_task_array(task_draw->next());
f7276b509710 DrawSpan taskArray bug fix
yutaka@localhost.localdomain
parents: 854
diff changeset
830 task_draw_array->set_cpu(SPE_ANY);
f7276b509710 DrawSpan taskArray bug fix
yutaka@localhost.localdomain
parents: 854
diff changeset
831 task_next->wait_for(task_draw_array);
f7276b509710 DrawSpan taskArray bug fix
yutaka@localhost.localdomain
parents: 854
diff changeset
832 task_draw_array->spawn();
854
6aa20c0dd8f8 may be need ppeManager
yutaka@localhost.localdomain
parents: 843
diff changeset
833
857
f7276b509710 DrawSpan taskArray bug fix
yutaka@localhost.localdomain
parents: 854
diff changeset
834
914
05696567d1d2 0 is filled on the spe side.
yutaka@localhost.localdomain
parents: 913
diff changeset
835
05696567d1d2 0 is filled on the spe side.
yutaka@localhost.localdomain
parents: 913
diff changeset
836 } else {
05696567d1d2 0 is filled on the spe side.
yutaka@localhost.localdomain
parents: 913
diff changeset
837
857
f7276b509710 DrawSpan taskArray bug fix
yutaka@localhost.localdomain
parents: 854
diff changeset
838 memset(&pixels[(startx-1)+this->width*(starty-1)],
f7276b509710 DrawSpan taskArray bug fix
yutaka@localhost.localdomain
parents: 854
diff changeset
839 0, (this->width)*sizeof(int)*rangey);
838
41302b72c895 Draw Span Task -> Task Array
Yutaka_Kinjyo
parents: 826
diff changeset
840
914
05696567d1d2 0 is filled on the spe side.
yutaka@localhost.localdomain
parents: 913
diff changeset
841 }
05696567d1d2 0 is filled on the spe side.
yutaka@localhost.localdomain
parents: 913
diff changeset
842
857
f7276b509710 DrawSpan taskArray bug fix
yutaka@localhost.localdomain
parents: 854
diff changeset
843
f7276b509710 DrawSpan taskArray bug fix
yutaka@localhost.localdomain
parents: 854
diff changeset
844 #else
838
41302b72c895 Draw Span Task -> Task Array
Yutaka_Kinjyo
parents: 826
diff changeset
845
41302b72c895 Draw Span Task -> Task Array
Yutaka_Kinjyo
parents: 826
diff changeset
846 HTaskPtr task_draw;
41302b72c895 Draw Span Task -> Task Array
Yutaka_Kinjyo
parents: 826
diff changeset
847
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
848 while (startx < this->width) {
857
f7276b509710 DrawSpan taskArray bug fix
yutaka@localhost.localdomain
parents: 854
diff changeset
849 if (spack->info.size > 0) {
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
850 // Draw SpanPack
614
4e44147d78ee remove uncessary Task Name definision
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 603
diff changeset
851 task_draw = manager->create_task(DrawSpan);
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
852
625
60aa3f241b10 64bit mode worked on Mac OS X.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 616
diff changeset
853 task_draw->set_param(0,
603
42c94f85c779 long -> memaddr (64 or 32)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 602
diff changeset
854 (memaddr)&pixels[(startx-1) + this->width*(starty-1)]);
625
60aa3f241b10 64bit mode worked on Mac OS X.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 616
diff changeset
855 task_draw->set_param(1,this->width);
652
dbe137505f2e bulk task list start.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 625
diff changeset
856 task_draw->set_param(2,startx);
dbe137505f2e bulk task list start.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 625
diff changeset
857 task_draw->set_param(3,endx);
dbe137505f2e bulk task list start.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 625
diff changeset
858 task_draw->set_param(4,rangey);
838
41302b72c895 Draw Span Task -> Task Array
Yutaka_Kinjyo
parents: 826
diff changeset
859 task_draw->set_param(5,spack->info.size);
652
dbe137505f2e bulk task list start.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 625
diff changeset
860
dbe137505f2e bulk task list start.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 625
diff changeset
861 task_draw->add_inData(spack, sizeof(SpanPack));
615
f7d78b3c1106 First addOutput rendering try failed.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 614
diff changeset
862
616
f21603a335aa Rendering not yet worked.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 615
diff changeset
863 for (int i = 0; i < rangey; i++) {
615
f7d78b3c1106 First addOutput rendering try failed.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 614
diff changeset
864 task_draw->add_outData(
616
f21603a335aa Rendering not yet worked.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 615
diff changeset
865 &pixels[(startx-1) + this->width*(starty-1 + i) ],
f21603a335aa Rendering not yet worked.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 615
diff changeset
866 (endx-startx+1)*sizeof(int));
615
f7d78b3c1106 First addOutput rendering try failed.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 614
diff changeset
867 }
838
41302b72c895 Draw Span Task -> Task Array
Yutaka_Kinjyo
parents: 826
diff changeset
868
857
f7276b509710 DrawSpan taskArray bug fix
yutaka@localhost.localdomain
parents: 854
diff changeset
869 } else {
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
870 // 7.7.3 SL1 Data Cache Range Set to Zero コマンド
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
871 // を使って、DMAでclearするべき... ということは、
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
872 // それもSPEでやる方が良い?
857
f7276b509710 DrawSpan taskArray bug fix
yutaka@localhost.localdomain
parents: 854
diff changeset
873 memset(&pixels[(startx-1)+this->width*(starty-1)],
f7276b509710 DrawSpan taskArray bug fix
yutaka@localhost.localdomain
parents: 854
diff changeset
874 0, (this->width)*sizeof(int)*rangey);
f7276b509710 DrawSpan taskArray bug fix
yutaka@localhost.localdomain
parents: 854
diff changeset
875 break;
f7276b509710 DrawSpan taskArray bug fix
yutaka@localhost.localdomain
parents: 854
diff changeset
876 }
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
877
748
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
878 task_draw->set_cpu(SPE_ANY);
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
879 task_next->wait_for(task_draw);
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
880 task_draw->spawn();
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
881
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
882 startx += split_screen_w;
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
883 endx += split_screen_w;
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
884
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
885 if (endx > this->width) {
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
886 endx = this->width;
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
887 }
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
888 }
838
41302b72c895 Draw Span Task -> Task Array
Yutaka_Kinjyo
parents: 826
diff changeset
889 #endif
41302b72c895 Draw Span Task -> Task Array
Yutaka_Kinjyo
parents: 826
diff changeset
890
792
f2497e0ecd7c add light switch
yutaka@localhost.localdomain
parents: 779
diff changeset
891 }
986
ac437c3cf766 double buffering of spanpack/polgonpack
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 985
diff changeset
892 spi ^= 1;
ac437c3cf766 double buffering of spanpack/polgonpack
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 985
diff changeset
893 for (int i = 1; i <= r[spi].spackList_length; i++) {
ac437c3cf766 double buffering of spanpack/polgonpack
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 985
diff changeset
894 r[spi].spackList[i-1].reinit(i*split_screen_h);
ac437c3cf766 double buffering of spanpack/polgonpack
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 985
diff changeset
895 }
ac437c3cf766 double buffering of spanpack/polgonpack
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 985
diff changeset
896
792
f2497e0ecd7c add light switch
yutaka@localhost.localdomain
parents: 779
diff changeset
897
925
9da903858400 add profile in Redering Engine
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 918
diff changeset
898 if (profile) {
983
ff74988bbb2a minor fix
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 982
diff changeset
899 if (frames % 50 == 49) {
984
df5185513c2d minor fix
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 983
diff changeset
900 manager->show_profile();
983
ff74988bbb2a minor fix
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 982
diff changeset
901 this_time = get_ticks();
ff74988bbb2a minor fix
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 982
diff changeset
902 if (this_time != start_time) {
984
df5185513c2d minor fix
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 983
diff changeset
903 printf("\n%f FPS\n", ((((float)frames)*1000.0)/(this_time-start_time)));
983
ff74988bbb2a minor fix
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 982
diff changeset
904 start_time = this_time; frames = 0;
ff74988bbb2a minor fix
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 982
diff changeset
905 }
982
b29547a5b85b avoid WAIT in virtual console
root@henri.cr.ie.u-ryukyu.ac.jp
parents: 981
diff changeset
906 }
925
9da903858400 add profile in Redering Engine
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 918
diff changeset
907 }
748
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
908 }
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
909
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
910 void
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
911 Viewer::run_finish()
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
912 {
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
913 dev->free_device();
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
914 if (this_time != start_time) {
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
915 printf("%f FPS\n", (((float)frames)/(this_time-start_time))*1000.0);
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
916 }
925
9da903858400 add profile in Redering Engine
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 918
diff changeset
917 if (profile) {
9da903858400 add profile in Redering Engine
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 918
diff changeset
918 manager->show_profile();
9da903858400 add profile in Redering Engine
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 918
diff changeset
919 }
748
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
920
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
921 delete sgroot;
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
922 // delete sgroot_2;
b7376415fa5f TaskManager changeset 683, Renderer changeset 746
hiroki
parents: 652
diff changeset
923 quit();
507
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
924 }
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
925
735f76483bb2 Reorganization..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
926 /* end */