annotate TaskManager/kernel/schedule/Scheduler.cc @ 1015:80b18af207c2

debug mail timing.
author yutaka@localhost.localdomain
date Fri, 05 Nov 2010 22:25:33 +0900
parents c67379f9d411
children 19a57960c436
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
48
70a0ac46133e *** empty log message ***
gongo
parents: 42
diff changeset
1 #include <stdio.h>
50
7927e00fb8e2 *** empty log message ***
gongo
parents: 48
diff changeset
2 #include <stdlib.h>
736
31d0a5baafdf cut printf
hiroki@localhost.localdomain
parents: 698
diff changeset
3 #include <stdarg.h>
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
4 #include "Scheduler.h"
736
31d0a5baafdf cut printf
hiroki@localhost.localdomain
parents: 698
diff changeset
5 #include "SchedTask.h"
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
6 #include "SchedNop.h"
923
e015a4e5e4b0 fix DMA/Mail wait profiler
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 893
diff changeset
7 #include "SysFunc.h"
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
8 #include "error.h"
386
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
9 #include <assert.h>
621
5b178db5988a Cell fix
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 619
diff changeset
10 #include "TaskManagerImpl.h"
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
11
313
c9f8cfcdc5c2 fix ppu mail box waiting (mainMem allocate)
kono@localhost.localdomain
parents: 301
diff changeset
12 /*
c9f8cfcdc5c2 fix ppu mail box waiting (mainMem allocate)
kono@localhost.localdomain
parents: 301
diff changeset
13 * Edit kernel/schedule/xx.cc, Cell/spe/xx.cc will be over writen by this.
c9f8cfcdc5c2 fix ppu mail box waiting (mainMem allocate)
kono@localhost.localdomain
parents: 301
diff changeset
14 * Do not edit Cell/spe/xx.cc unless there is no kernel/schedule/xx.cc files.
c9f8cfcdc5c2 fix ppu mail box waiting (mainMem allocate)
kono@localhost.localdomain
parents: 301
diff changeset
15 */
c9f8cfcdc5c2 fix ppu mail box waiting (mainMem allocate)
kono@localhost.localdomain
parents: 301
diff changeset
16
698
dcaa40ec963d no compile error for Task Array
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 685
diff changeset
17 TaskObject task_list[MAX_TASK_OBJECT];
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
18
501
4a2c9ff53605 Cell inData/outData DMA removal
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 483
diff changeset
19 Scheduler::~Scheduler()
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
20 {
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
21 delete connector;
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
22 }
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
23
664
7405d92733a8 word count
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 635
diff changeset
24 static int
7405d92733a8 word count
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 635
diff changeset
25 null_run(SchedTask* smanager, void* r, void *w)
7405d92733a8 word count
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 635
diff changeset
26 {
923
e015a4e5e4b0 fix DMA/Mail wait profiler
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 893
diff changeset
27 smanager->printf("Calling Undefined Task %d\n", smanager->task->command==TaskArray1? smanager->atask->command: smanager->task->command);
664
7405d92733a8 word count
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 635
diff changeset
28 return 0;
7405d92733a8 word count
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 635
diff changeset
29 }
7405d92733a8 word count
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 635
diff changeset
30
684
458a1ad91427 Task Array generation worked.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 664
diff changeset
31 static void null_loader(Scheduler *m, int task_id);
458a1ad91427 Task Array generation worked.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 664
diff changeset
32
301
bcb81858aa62 remove deprecated source. not work.
tkaito@localhost.localdomain
parents: 298
diff changeset
33 /*! @brief speTaskの入出力のパイプラインバッファを確保する
bcb81858aa62 remove deprecated source. not work.
tkaito@localhost.localdomain
parents: 298
diff changeset
34 */
bcb81858aa62 remove deprecated source. not work.
tkaito@localhost.localdomain
parents: 298
diff changeset
35
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
36 void
635
8cc609285bbe SimpleTask worked on Mac OS X
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 634
diff changeset
37 Scheduler::init(TaskManagerImpl *m)
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
38 {
388
82cb9368e3ff MemHash (OS X version)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 387
diff changeset
39 hash = 0;
664
7405d92733a8 word count
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 635
diff changeset
40
7405d92733a8 word count
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 635
diff changeset
41 for (int i = 0; i< MAX_TASK_OBJECT; i++) {
684
458a1ad91427 Task Array generation worked.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 664
diff changeset
42 task_list[i].run = null_run;
458a1ad91427 Task Array generation worked.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 664
diff changeset
43 task_list[i].load = null_loader;
458a1ad91427 Task Array generation worked.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 664
diff changeset
44 task_list[i].wait = null_loader;
664
7405d92733a8 word count
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 635
diff changeset
45 }
7405d92733a8 word count
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 635
diff changeset
46
635
8cc609285bbe SimpleTask worked on Mac OS X
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 634
diff changeset
47 set_manager(m);
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
48 init_impl();
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
49
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
50 for (int i = 0; i < 2; i++) {
800
2708c4a7bade run16 word count ( not yet worked. )
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 792
diff changeset
51 buff_taskList[i] = (TaskListPtr)m->allocate(sizeof(TaskList));
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
52 }
373
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
53
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
54 buffFlag_taskList = 0;
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
55
298
58fd16298954 from EUC to UTF-8
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 233
diff changeset
56 // bzero でもいいけど
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
57 for (int i = 0; i < MAX_GLOBAL_AREA; i++) {
373
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
58 globalList[i] = NULL;
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
59 }
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
60
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
61 for (int i = 0; i < MAX_MAINMEM_AREA; i++) {
629
8843edf37c0e Cell 64 bit tried, but not yet worked.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 625
diff changeset
62 mainMemList[i] = (memaddr)NULL;
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
63 }
373
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
64
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
65
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
66 }
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
67
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
68 void
685
b386522827ae Bulk task on going.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 684
diff changeset
69 Scheduler::run(SchedTaskBase* task1)
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
70 {
685
b386522827ae Bulk task on going.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 684
diff changeset
71
b386522827ae Bulk task on going.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 684
diff changeset
72 // Pipeline Stage
b386522827ae Bulk task on going.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 684
diff changeset
73 SchedTaskBase* task2 = new SchedNop();
b386522827ae Bulk task on going.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 684
diff changeset
74 SchedTaskBase* task3 = new SchedNop();
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
75 // main loop
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
76 do {
970
33630c6ff445 change pipeline and TaskArray fast
Yutaka Kinjyo <yutaka@cr.ie.u-ryukyu.ac.jp>
parents: 923
diff changeset
77
33630c6ff445 change pipeline and TaskArray fast
Yutaka Kinjyo <yutaka@cr.ie.u-ryukyu.ac.jp>
parents: 923
diff changeset
78 task1->read();
33630c6ff445 change pipeline and TaskArray fast
Yutaka Kinjyo <yutaka@cr.ie.u-ryukyu.ac.jp>
parents: 923
diff changeset
79 task2->exec();
1015
80b18af207c2 debug mail timing.
yutaka@localhost.localdomain
parents: 1009
diff changeset
80 task3->write();
970
33630c6ff445 change pipeline and TaskArray fast
Yutaka Kinjyo <yutaka@cr.ie.u-ryukyu.ac.jp>
parents: 923
diff changeset
81
468
bd5b93d39597 test_nogl on Mac OS X worked.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 464
diff changeset
82 delete task3;
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
83
373
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
84 task3 = task2;
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
85 task2 = task1;
1015
80b18af207c2 debug mail timing.
yutaka@localhost.localdomain
parents: 1009
diff changeset
86 //SchedMailの場合、Mailの待ちが入る
893
96536163c0a0 fix SimpleTask alignment
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 874
diff changeset
87 task1 = task1->next(this, 0);
970
33630c6ff445 change pipeline and TaskArray fast
Yutaka Kinjyo <yutaka@cr.ie.u-ryukyu.ac.jp>
parents: 923
diff changeset
88
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
89 } while (task1);
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
90
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
91 delete task3;
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
92 delete task2;
50
7927e00fb8e2 *** empty log message ***
gongo
parents: 48
diff changeset
93 }
48
70a0ac46133e *** empty log message ***
gongo
parents: 42
diff changeset
94
50
7927e00fb8e2 *** empty log message ***
gongo
parents: 48
diff changeset
95
7927e00fb8e2 *** empty log message ***
gongo
parents: 48
diff changeset
96 void
501
4a2c9ff53605 Cell inData/outData DMA removal
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 483
diff changeset
97 Scheduler::finish()
50
7927e00fb8e2 *** empty log message ***
gongo
parents: 48
diff changeset
98 {
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
99 free(buff_taskList[0]);
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
100 free(buff_taskList[1]);
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
101 }
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
102
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
103 /**
298
58fd16298954 from EUC to UTF-8
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 233
diff changeset
104 * あらかじめ memory allocte してある TaskList の領域を
58fd16298954 from EUC to UTF-8
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 233
diff changeset
105 * パイプラインの各処理が交代して使う。
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
106 */
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
107 TaskListPtr
501
4a2c9ff53605 Cell inData/outData DMA removal
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 483
diff changeset
108 Scheduler::get_curListBuf()
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
109 {
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
110 buffFlag_taskList ^= 1;
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
111
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
112 return buff_taskList[buffFlag_taskList];
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
113 }
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
114
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
115 void
625
60aa3f241b10 64bit mode worked on Mac OS X.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 621
diff changeset
116 Scheduler::dma_load(void *buf, memaddr addr, uint32 size, uint32 mask)
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
117 {
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
118 connector->dma_load(buf, addr, size, mask);
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
119 }
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
120
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
121 void
625
60aa3f241b10 64bit mode worked on Mac OS X.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 621
diff changeset
122 Scheduler::dma_store(void *buf, memaddr addr, uint32 size, uint32 mask)
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
123 {
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
124 connector->dma_store(buf, addr, size, mask);
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
125 }
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
126
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
127 void
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
128 Scheduler::dma_wait(uint32 mask)
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
129 {
970
33630c6ff445 change pipeline and TaskArray fast
Yutaka Kinjyo <yutaka@cr.ie.u-ryukyu.ac.jp>
parents: 923
diff changeset
130 //printf("%d\n",mask);
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
131 connector->dma_wait(mask);
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
132 }
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
133
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
134 void
970
33630c6ff445 change pipeline and TaskArray fast
Yutaka Kinjyo <yutaka@cr.ie.u-ryukyu.ac.jp>
parents: 923
diff changeset
135 Scheduler::dma_wait(uint32 mask, int cmd)
33630c6ff445 change pipeline and TaskArray fast
Yutaka Kinjyo <yutaka@cr.ie.u-ryukyu.ac.jp>
parents: 923
diff changeset
136 {
33630c6ff445 change pipeline and TaskArray fast
Yutaka Kinjyo <yutaka@cr.ie.u-ryukyu.ac.jp>
parents: 923
diff changeset
137 connector->dma_wait(mask,cmd);
33630c6ff445 change pipeline and TaskArray fast
Yutaka Kinjyo <yutaka@cr.ie.u-ryukyu.ac.jp>
parents: 923
diff changeset
138 }
33630c6ff445 change pipeline and TaskArray fast
Yutaka Kinjyo <yutaka@cr.ie.u-ryukyu.ac.jp>
parents: 923
diff changeset
139
33630c6ff445 change pipeline and TaskArray fast
Yutaka Kinjyo <yutaka@cr.ie.u-ryukyu.ac.jp>
parents: 923
diff changeset
140 void
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
141 Scheduler::dma_loadList(ListDataPtr list, void *buff, uint32 mask)
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
142 {
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
143 connector->dma_loadList(list, buff, mask);
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
144 }
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
145
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
146
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
147 void
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
148 Scheduler::dma_storeList(ListDataPtr list, void *buff, uint32 mask)
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
149 {
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
150 return connector->dma_storeList(list, buff, mask);
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
151 }
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
152
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
153 void
625
60aa3f241b10 64bit mode worked on Mac OS X.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 621
diff changeset
154 Scheduler::mail_write(memaddr data)
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
155 {
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
156 connector->mail_write(data);
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
157 }
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
158
1007
18a548c337cb add mail_queue
yutaka@localhost.localdomain
parents: 970
diff changeset
159 void
18a548c337cb add mail_queue
yutaka@localhost.localdomain
parents: 970
diff changeset
160 Scheduler::mail_write_queue(memaddr data)
18a548c337cb add mail_queue
yutaka@localhost.localdomain
parents: 970
diff changeset
161 {
18a548c337cb add mail_queue
yutaka@localhost.localdomain
parents: 970
diff changeset
162 connector->mail_write_queue(data);
18a548c337cb add mail_queue
yutaka@localhost.localdomain
parents: 970
diff changeset
163 }
18a548c337cb add mail_queue
yutaka@localhost.localdomain
parents: 970
diff changeset
164
18a548c337cb add mail_queue
yutaka@localhost.localdomain
parents: 970
diff changeset
165 void
18a548c337cb add mail_queue
yutaka@localhost.localdomain
parents: 970
diff changeset
166 Scheduler::mail_write_finish_list(memaddr data)
18a548c337cb add mail_queue
yutaka@localhost.localdomain
parents: 970
diff changeset
167 {
1009
c67379f9d411 not yet....
yutaka@localhost.localdomain
parents: 1007
diff changeset
168 connector->mail_write_finish_list(data);
1007
18a548c337cb add mail_queue
yutaka@localhost.localdomain
parents: 970
diff changeset
169 }
18a548c337cb add mail_queue
yutaka@localhost.localdomain
parents: 970
diff changeset
170
625
60aa3f241b10 64bit mode worked on Mac OS X.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 621
diff changeset
171 memaddr
501
4a2c9ff53605 Cell inData/outData DMA removal
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 483
diff changeset
172 Scheduler::mail_read()
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
173 {
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
174 return connector->mail_read();
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
175 }
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
176
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
177
871
ab3cd3aeacff fix get segment dma tag zero problem
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 805
diff changeset
178
386
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
179 /*
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
180 ここから下は、memory 以下にあるべき
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
181 */
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
182
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
183 void*
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
184 Scheduler::global_alloc(int id, int size)
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
185 {
792
f2497e0ecd7c add light switch
yutaka@localhost.localdomain
parents: 786
diff changeset
186
800
2708c4a7bade run16 word count ( not yet worked. )
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 792
diff changeset
187 globalList[id] = manager->allocate(size);
792
f2497e0ecd7c add light switch
yutaka@localhost.localdomain
parents: 786
diff changeset
188
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
189 return globalList[id];
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
190 }
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
191
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
192 void*
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
193 Scheduler::global_get(int id)
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
194 {
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
195 return globalList[id];
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
196 }
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
197
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
198 void
373
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
199 Scheduler::global_set(int id, void *addr)
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
200 {
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
201 globalList[id] = addr;
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
202 }
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
203
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
204 void
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
205 Scheduler::global_free(int id)
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
206 {
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
207 free(globalList[id]);
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
208 globalList[id] = NULL;
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
209 }
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
210
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
211 /**
298
58fd16298954 from EUC to UTF-8
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 233
diff changeset
212 * mainMem_alloc で確保したメインメモリの領域アドレスを返す。
58fd16298954 from EUC to UTF-8
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 233
diff changeset
213 * これは Fifo, Cell で共通
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
214 */
629
8843edf37c0e Cell 64 bit tried, but not yet worked.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 625
diff changeset
215 memaddr
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
216 Scheduler::mainMem_get(int id)
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
217 {
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
218 return mainMemList[id];
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
219 }
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
220
421
cd77224d4224 Code load implementation... (not yet tested)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 403
diff changeset
221 /**
cd77224d4224 Code load implementation... (not yet tested)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 403
diff changeset
222 * Task load API
cd77224d4224 Code load implementation... (not yet tested)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 403
diff changeset
223 */
425
799071db126e add code load API
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 421
diff changeset
224 void
872
e49c1b29c43d add overlay segment
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 871
diff changeset
225 Scheduler::allocate_code_segment(int size, int count, struct tbl *table)
425
799071db126e add code load API
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 421
diff changeset
226 {
437
fd44dbd049aa overlay...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 425
diff changeset
227 // 既に overlay 領域があるので、それを追加する必要がある...
442
95a856a2d552 hoge... size/count
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 441
diff changeset
228 code_segment_pool = createMemList(size, count);
872
e49c1b29c43d add overlay segment
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 871
diff changeset
229 if (table) {
e49c1b29c43d add overlay segment
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 871
diff changeset
230 MemorySegment* here = (MemorySegment*)(
e49c1b29c43d add overlay segment
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 871
diff changeset
231 manager->allocate(sizeof(MemorySegment)));
e49c1b29c43d add overlay segment
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 871
diff changeset
232 here->data = (void*)(table->vma);
e49c1b29c43d add overlay segment
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 871
diff changeset
233 here->size = size;
e49c1b29c43d add overlay segment
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 871
diff changeset
234 here->address = (memaddr)here;
e49c1b29c43d add overlay segment
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 871
diff changeset
235 code_segment_pool->addLast(here);
e49c1b29c43d add overlay segment
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 871
diff changeset
236 }
425
799071db126e add code load API
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 421
diff changeset
237 }
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
238
421
cd77224d4224 Code load implementation... (not yet tested)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 403
diff changeset
239 static void
cd77224d4224 Code load implementation... (not yet tested)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 403
diff changeset
240 load_task(Scheduler *m, int task_id)
cd77224d4224 Code load implementation... (not yet tested)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 403
diff changeset
241 {
cd77224d4224 Code load implementation... (not yet tested)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 403
diff changeset
242 MemorySegment *s = m->get_segment(
cd77224d4224 Code load implementation... (not yet tested)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 403
diff changeset
243 task_list[task_id].location,
437
fd44dbd049aa overlay...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 425
diff changeset
244 m->code_segment_pool,
fd44dbd049aa overlay...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 425
diff changeset
245 task_list[task_id].end-task_list[task_id].location);
421
cd77224d4224 Code load implementation... (not yet tested)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 403
diff changeset
246 task_list[task_id].segment = s;
871
ab3cd3aeacff fix get segment dma tag zero problem
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 805
diff changeset
247 // calcurate call address
ab3cd3aeacff fix get segment dma tag zero problem
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 805
diff changeset
248 TaskObjectRun run =
ab3cd3aeacff fix get segment dma tag zero problem
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 805
diff changeset
249 (TaskObjectRun)(
ab3cd3aeacff fix get segment dma tag zero problem
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 805
diff changeset
250 (char*)task_list[task_id].segment->data +
ab3cd3aeacff fix get segment dma tag zero problem
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 805
diff changeset
251 task_list[task_id].entry_offset);
ab3cd3aeacff fix get segment dma tag zero problem
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 805
diff changeset
252 task_list[task_id].run = run;
874
8df4323f9fdb new hash function
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 873
diff changeset
253 #if 0
873
3b9536925fb8 fix hash problem ( unsigned int-> long overflow )
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 872
diff changeset
254 m->printf("loadng task id %d at 0x%x entry 0x%x location 0x%x\n",task_id,
461
942f451341a4 overlay worked.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 458
diff changeset
255 (unsigned int)(task_list[task_id].segment->data ),
942f451341a4 overlay worked.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 458
diff changeset
256 (unsigned int)(
942f451341a4 overlay worked.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 458
diff changeset
257 (char*)task_list[task_id].segment->data +
873
3b9536925fb8 fix hash problem ( unsigned int-> long overflow )
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 872
diff changeset
258 task_list[task_id].entry_offset),
3b9536925fb8 fix hash problem ( unsigned int-> long overflow )
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 872
diff changeset
259 task_list[task_id].location);
506
1d4a8a86f26b code_load in read()
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 501
diff changeset
260 #endif
421
cd77224d4224 Code load implementation... (not yet tested)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 403
diff changeset
261 }
cd77224d4224 Code load implementation... (not yet tested)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 403
diff changeset
262
cd77224d4224 Code load implementation... (not yet tested)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 403
diff changeset
263 static void
cd77224d4224 Code load implementation... (not yet tested)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 403
diff changeset
264 null_loader(Scheduler *m, int task_id)
cd77224d4224 Code load implementation... (not yet tested)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 403
diff changeset
265 {
cd77224d4224 Code load implementation... (not yet tested)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 403
diff changeset
266 }
cd77224d4224 Code load implementation... (not yet tested)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 403
diff changeset
267
cd77224d4224 Code load implementation... (not yet tested)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 403
diff changeset
268 static void
cd77224d4224 Code load implementation... (not yet tested)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 403
diff changeset
269 wait_load(Scheduler *m, int task_id)
cd77224d4224 Code load implementation... (not yet tested)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 403
diff changeset
270 {
523
b273767962b8 half finish for Cell
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 506
diff changeset
271 #if 0
442
95a856a2d552 hoge... size/count
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 441
diff changeset
272 MemorySegment *s = task_list[task_id].segment;
95a856a2d552 hoge... size/count
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 441
diff changeset
273 if (s)
736
31d0a5baafdf cut printf
hiroki@localhost.localdomain
parents: 698
diff changeset
274 m->printf("wait load task id %d 0x%x\n",task_id,(int)s->data);
442
95a856a2d552 hoge... size/count
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 441
diff changeset
275 else
736
31d0a5baafdf cut printf
hiroki@localhost.localdomain
parents: 698
diff changeset
276 m->printf("wait load task id %d 000000\n",task_id);
506
1d4a8a86f26b code_load in read()
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 501
diff changeset
277 #endif
421
cd77224d4224 Code load implementation... (not yet tested)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 403
diff changeset
278 // wait for code segment load
cd77224d4224 Code load implementation... (not yet tested)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 403
diff changeset
279 m->wait_segment(task_list[task_id].segment);
506
1d4a8a86f26b code_load in read()
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 501
diff changeset
280 #if 0
736
31d0a5baafdf cut printf
hiroki@localhost.localdomain
parents: 698
diff changeset
281 m->printf("wait load task id %d done. creator = 0x%x entry_offset = 0x%x\n",task_id,
871
ab3cd3aeacff fix get segment dma tag zero problem
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 805
diff changeset
282 (unsigned int)(task_list[task_id].run),
439
95c0457a7d31 still overlay...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 437
diff changeset
283 task_list[task_id].entry_offset);
506
1d4a8a86f26b code_load in read()
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 501
diff changeset
284 #endif
421
cd77224d4224 Code load implementation... (not yet tested)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 403
diff changeset
285 }
cd77224d4224 Code load implementation... (not yet tested)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 403
diff changeset
286
cd77224d4224 Code load implementation... (not yet tested)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 403
diff changeset
287 static void
cd77224d4224 Code load implementation... (not yet tested)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 403
diff changeset
288 null_waiter(Scheduler *m, int task_id)
cd77224d4224 Code load implementation... (not yet tested)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 403
diff changeset
289 {
cd77224d4224 Code load implementation... (not yet tested)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 403
diff changeset
290 }
cd77224d4224 Code load implementation... (not yet tested)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 403
diff changeset
291
cd77224d4224 Code load implementation... (not yet tested)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 403
diff changeset
292 extern void
464
01b321c86747 task run is mere C function now.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 461
diff changeset
293 register_task(int cmd, TaskObjectRun run)
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
294 {
464
01b321c86747 task run is mere C function now.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 461
diff changeset
295 task_list[cmd].run = run;
421
cd77224d4224 Code load implementation... (not yet tested)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 403
diff changeset
296 task_list[cmd].load = null_loader;
cd77224d4224 Code load implementation... (not yet tested)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 403
diff changeset
297 task_list[cmd].wait = null_waiter;
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
298 }
373
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
299
421
cd77224d4224 Code load implementation... (not yet tested)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 403
diff changeset
300 extern void
cd77224d4224 Code load implementation... (not yet tested)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 403
diff changeset
301 register_dynamic_task(int cmd,
441
7bae2117f239 slightly worked...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 439
diff changeset
302 memaddr start, int size,
464
01b321c86747 task run is mere C function now.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 461
diff changeset
303 TaskObjectRun run, int entry_offset)
421
cd77224d4224 Code load implementation... (not yet tested)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 403
diff changeset
304 {
464
01b321c86747 task run is mere C function now.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 461
diff changeset
305 task_list[cmd].run = run;
421
cd77224d4224 Code load implementation... (not yet tested)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 403
diff changeset
306 task_list[cmd].location = start;
442
95a856a2d552 hoge... size/count
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 441
diff changeset
307 size &= 0xfffffffe;
441
7bae2117f239 slightly worked...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 439
diff changeset
308 task_list[cmd].end = start+size;
421
cd77224d4224 Code load implementation... (not yet tested)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 403
diff changeset
309 task_list[cmd].entry_offset = entry_offset;
cd77224d4224 Code load implementation... (not yet tested)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 403
diff changeset
310 task_list[cmd].load = load_task;
cd77224d4224 Code load implementation... (not yet tested)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 403
diff changeset
311 task_list[cmd].wait = wait_load;
506
1d4a8a86f26b code_load in read()
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 501
diff changeset
312 #if 0
736
31d0a5baafdf cut printf
hiroki@localhost.localdomain
parents: 698
diff changeset
313 this->printf("cmd = %d\n",cmd);
31d0a5baafdf cut printf
hiroki@localhost.localdomain
parents: 698
diff changeset
314 this->printf("locatation = 0x%x\n",start);
31d0a5baafdf cut printf
hiroki@localhost.localdomain
parents: 698
diff changeset
315 this->printf("end = 0x%x\n",start+size);
31d0a5baafdf cut printf
hiroki@localhost.localdomain
parents: 698
diff changeset
316 this->printf("size = 0x%x\n",size);
31d0a5baafdf cut printf
hiroki@localhost.localdomain
parents: 698
diff changeset
317 this->printf("entry = 0x%x\n",entry_offset);
506
1d4a8a86f26b code_load in read()
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 501
diff changeset
318 #endif
439
95c0457a7d31 still overlay...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 437
diff changeset
319
421
cd77224d4224 Code load implementation... (not yet tested)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 403
diff changeset
320 }
cd77224d4224 Code load implementation... (not yet tested)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 403
diff changeset
321
cd77224d4224 Code load implementation... (not yet tested)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 403
diff changeset
322
373
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
323 /*!
386
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
324
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
325 size 単位のMemory Segment を count 個作る
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
326
373
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
327 @param [size] リストの要素1つのサイズ
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
328 @param [count] 要素数
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
329 @return allocate した領域のポインタ
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
330
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
331 */
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
332 MemList*
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
333 Scheduler::createMemList(int size, int count)
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
334 {
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
335 uint32 head_size = round_up16(sizeof(MemorySegment));
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
336 uint32 seg_size = round_up16(head_size+size);
800
2708c4a7bade run16 word count ( not yet worked. )
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 792
diff changeset
337 char* mseg = (char*)manager->allocate(seg_size*count);
373
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
338 MemList* mlist = new MemList((MemorySegment*)mseg);
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
339
388
82cb9368e3ff MemHash (OS X version)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 387
diff changeset
340 if (!hash) {
82cb9368e3ff MemHash (OS X version)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 387
diff changeset
341 hash = new MemHash();
82cb9368e3ff MemHash (OS X version)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 387
diff changeset
342 }
82cb9368e3ff MemHash (OS X version)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 387
diff changeset
343
373
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
344 for(int i = 0; i < count; i++) {
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
345 MemorySegment* next = (MemorySegment*)(mseg+seg_size*i);
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
346 char* data = (char*)next+head_size;
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
347 next->data = (void*)data;
386
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
348 next->size = size;
395
8c5fa57128cb chain on SPE
game@localhost.localdomain
parents: 391
diff changeset
349 next->address = (memaddr)next;
373
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
350 mlist->addLast(next);
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
351 }
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
352
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
353 return mlist;
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
354 }
386
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
355
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
356 /*!
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
357
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
358 Main Memory のSegmentを取得する
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
359
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
360 @param [addr] Main Memory のアドレス
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
361 @param [m] Mem List
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
362 @return allocate した領域のポインタ
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
363 memory directory にあるべきだが...
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
364
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
365 */
387
5e2d30bfbf23 no compile error but not worked.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 386
diff changeset
366 MemorySegment *
386
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
367 Scheduler::get_segment(memaddr addr, MemList *m)
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
368 {
449
4f11245e3504 get_segment fixed. and test_nogl rollback to 426. move!
kazz@henri.cr.ie.u-ryukyu.ac.jp
parents: 442
diff changeset
369 MemorySegment *s = m->getFirst();
4f11245e3504 get_segment fixed. and test_nogl rollback to 426. move!
kazz@henri.cr.ie.u-ryukyu.ac.jp
parents: 442
diff changeset
370 return get_segment(addr, m, s->size);
437
fd44dbd049aa overlay...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 425
diff changeset
371 }
fd44dbd049aa overlay...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 425
diff changeset
372
fd44dbd049aa overlay...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 425
diff changeset
373 MemorySegment *
fd44dbd049aa overlay...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 425
diff changeset
374 Scheduler::get_segment(memaddr addr, MemList *m, int size)
fd44dbd049aa overlay...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 425
diff changeset
375 {
fd44dbd049aa overlay...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 425
diff changeset
376 // memory segment のsizeをoverride する場合がある
386
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
377 MemorySegment *s = hash->get(addr);
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
378 if (s) {
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
379 /* 既に load されている */
736
31d0a5baafdf cut printf
hiroki@localhost.localdomain
parents: 698
diff changeset
380 // this->printf("get_segement loaded %llx 0x%x size 0x%d\n",addr,s->data,size);
391
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 388
diff changeset
381 m->moveToFirst(s);
386
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
382 return s;
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
383 }
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
384
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
385 /* LRU なので、もっとも使われてない segment を上書きする */
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
386 s = m->getLast();
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
387 m->moveToFirst(s);
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
388
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
389 memaddr old_addr = s->address;
387
5e2d30bfbf23 no compile error but not worked.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 386
diff changeset
390 s->tag = get_tag();
5e2d30bfbf23 no compile error but not worked.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 386
diff changeset
391 dma_load(s->data, addr,
437
fd44dbd049aa overlay...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 425
diff changeset
392 size, s->tag);
386
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
393 /* 前のをhashから削除 */
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
394 hash->remove(old_addr);
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
395 /* 新しいaddress を登録 */
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
396 s->address = addr;
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
397 hash->put(s->address, s);
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
398
736
31d0a5baafdf cut printf
hiroki@localhost.localdomain
parents: 698
diff changeset
399 // this->printf("get_segement %llx 0x%x size 0x%d\n",addr, s->data,size);
439
95c0457a7d31 still overlay...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 437
diff changeset
400
386
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
401 return s;
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
402 }
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
403
421
cd77224d4224 Code load implementation... (not yet tested)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 403
diff changeset
404
386
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
405 uint32
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
406 Scheduler::get_tag()
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
407 {
458
1c767b68d936 add ovly table tag modified
kono@localhost.localdomain
parents: 451
diff changeset
408 static int tag = 16;
1c767b68d936 add ovly table tag modified
kono@localhost.localdomain
parents: 451
diff changeset
409 tag ++;
1c767b68d936 add ovly table tag modified
kono@localhost.localdomain
parents: 451
diff changeset
410 tag &= 0x0f;
1c767b68d936 add ovly table tag modified
kono@localhost.localdomain
parents: 451
diff changeset
411 return tag+16;
386
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
412 }
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
413
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
414 /*!
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
415
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
416 Main Memory のSegmentを書き出す
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
417 Segment は get_segement されていて、
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
418 追い出されていてはいけない。
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
419 それを保証するのは難しい?
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
420
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
421 @param [addr] Main Memory のアドレス
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
422 @param [m] Mem List
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
423 @return allocate した領域のポインタ
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
424
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
425 */
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
426 void
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
427 Scheduler::put_segment(MemorySegment *s)
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
428 {
387
5e2d30bfbf23 no compile error but not worked.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 386
diff changeset
429 dma_store(s->data, s->address,
386
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
430 s->size, s->tag);
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
431 }
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
432
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
433 /*!
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
434
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
435 Main Memory のSegmentを読込、書き出しを待つ
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
436
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
437 @param [id] MemorySegment のid
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
438
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
439 */
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
440 void
387
5e2d30bfbf23 no compile error but not worked.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 386
diff changeset
441 Scheduler::wait_segment(MemorySegment *s)
386
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
442 {
391
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 388
diff changeset
443 // えーと、dma してない時には、skip しないとだめなんじゃないの?
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 388
diff changeset
444
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 388
diff changeset
445 if (s->tag) dma_wait(s->tag);
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 388
diff changeset
446 s->tag = 0;
386
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
447 }
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
448
621
5b178db5988a Cell fix
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 619
diff changeset
449 long Scheduler::get_random() {
5b178db5988a Cell fix
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 619
diff changeset
450 #if defined(__SPU__)
5b178db5988a Cell fix
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 619
diff changeset
451 return 0;
5b178db5988a Cell fix
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 619
diff changeset
452 #else
5b178db5988a Cell fix
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 619
diff changeset
453 return random();
5b178db5988a Cell fix
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 619
diff changeset
454 #endif
5b178db5988a Cell fix
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 619
diff changeset
455
5b178db5988a Cell fix
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 619
diff changeset
456 }
5b178db5988a Cell fix
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 619
diff changeset
457
736
31d0a5baafdf cut printf
hiroki@localhost.localdomain
parents: 698
diff changeset
458 int
31d0a5baafdf cut printf
hiroki@localhost.localdomain
parents: 698
diff changeset
459 Scheduler::printf(const char * format, ...)
31d0a5baafdf cut printf
hiroki@localhost.localdomain
parents: 698
diff changeset
460 {
786
ccf78a465459 fix early free of TaskArray, add SchedTaskArrayNop stage.
yutaka@localhost.localdomain
parents: 742
diff changeset
461 #if !defined(__SPU__) || 1
736
31d0a5baafdf cut printf
hiroki@localhost.localdomain
parents: 698
diff changeset
462 va_list ap;
31d0a5baafdf cut printf
hiroki@localhost.localdomain
parents: 698
diff changeset
463 va_start(ap,format);
742
4c2e6493b008 continue..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 736
diff changeset
464 int ret= vprintf0(format, ap);
736
31d0a5baafdf cut printf
hiroki@localhost.localdomain
parents: 698
diff changeset
465 va_end(ap);
31d0a5baafdf cut printf
hiroki@localhost.localdomain
parents: 698
diff changeset
466 return ret;
31d0a5baafdf cut printf
hiroki@localhost.localdomain
parents: 698
diff changeset
467 #else
31d0a5baafdf cut printf
hiroki@localhost.localdomain
parents: 698
diff changeset
468 return 0;
31d0a5baafdf cut printf
hiroki@localhost.localdomain
parents: 698
diff changeset
469 #endif
31d0a5baafdf cut printf
hiroki@localhost.localdomain
parents: 698
diff changeset
470 }
31d0a5baafdf cut printf
hiroki@localhost.localdomain
parents: 698
diff changeset
471
31d0a5baafdf cut printf
hiroki@localhost.localdomain
parents: 698
diff changeset
472
31d0a5baafdf cut printf
hiroki@localhost.localdomain
parents: 698
diff changeset
473 int
742
4c2e6493b008 continue..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 736
diff changeset
474 Scheduler::vprintf0(const char * format, va_list ap)
736
31d0a5baafdf cut printf
hiroki@localhost.localdomain
parents: 698
diff changeset
475 {
786
ccf78a465459 fix early free of TaskArray, add SchedTaskArrayNop stage.
yutaka@localhost.localdomain
parents: 742
diff changeset
476 #if !defined(__SPU__) || 1
736
31d0a5baafdf cut printf
hiroki@localhost.localdomain
parents: 698
diff changeset
477 int ret= vprintf(format, ap);
31d0a5baafdf cut printf
hiroki@localhost.localdomain
parents: 698
diff changeset
478 return ret;
31d0a5baafdf cut printf
hiroki@localhost.localdomain
parents: 698
diff changeset
479 #else
31d0a5baafdf cut printf
hiroki@localhost.localdomain
parents: 698
diff changeset
480 return 0;
31d0a5baafdf cut printf
hiroki@localhost.localdomain
parents: 698
diff changeset
481 #endif
31d0a5baafdf cut printf
hiroki@localhost.localdomain
parents: 698
diff changeset
482 }
31d0a5baafdf cut printf
hiroki@localhost.localdomain
parents: 698
diff changeset
483
31d0a5baafdf cut printf
hiroki@localhost.localdomain
parents: 698
diff changeset
484
386
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
485 /* end */