annotate Renderer/Engine/viewer.cc @ 983:ff74988bbb2a

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