annotate Renderer/Engine/viewer.cc @ 998:ad5232ad4952

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