annotate TaskManager/kernel/schedule/Scheduler.cc @ 388:82cb9368e3ff

MemHash (OS X version)
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Thu, 06 Aug 2009 23:30:26 +0900
parents 5e2d30bfbf23
children 136ff78c9e74
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>
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
3 #include "Scheduler.h"
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
4 #include "SchedNop.h"
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
5 #include "error.h"
386
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
6 #include <assert.h>
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
7
313
c9f8cfcdc5c2 fix ppu mail box waiting (mainMem allocate)
kono@localhost.localdomain
parents: 301
diff changeset
8 /*
c9f8cfcdc5c2 fix ppu mail box waiting (mainMem allocate)
kono@localhost.localdomain
parents: 301
diff changeset
9 * 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
10 * 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
11 */
c9f8cfcdc5c2 fix ppu mail box waiting (mainMem allocate)
kono@localhost.localdomain
parents: 301
diff changeset
12
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
13 Scheduler::TaskObject task_list[MAX_TASK_OBJECT];
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
14
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
15 Scheduler::~Scheduler(void)
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
16 {
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
17 delete connector;
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
18 }
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
19
301
bcb81858aa62 remove deprecated source. not work.
tkaito@localhost.localdomain
parents: 298
diff changeset
20 /*! @brief speTaskの入出力のパイプラインバッファを確保する
bcb81858aa62 remove deprecated source. not work.
tkaito@localhost.localdomain
parents: 298
diff changeset
21 */
bcb81858aa62 remove deprecated source. not work.
tkaito@localhost.localdomain
parents: 298
diff changeset
22
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
23 void
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
24 Scheduler::init(void)
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
25 {
388
82cb9368e3ff MemHash (OS X version)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 387
diff changeset
26 hash = 0;
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
27 init_impl();
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
28
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
29 for (int i = 0; i < 2; i++) {
373
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
30 buff_taskList[i] = (TaskListPtr)allocate(sizeof(TaskList));
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
31 buff_inListData[i] = (ListDataPtr)allocate(sizeof(ListData));
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
32 buff_outListData[i] = (ListDataPtr)allocate(sizeof(ListData));
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
33 }
373
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
34
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
35 buffFlag_taskList = 0;
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
36 buffFlag_inListData = 0;
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
37 buffFlag_outListData = 0;
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
38 flag_renewTaskList = 0;
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
39
298
58fd16298954 from EUC to UTF-8
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 233
diff changeset
40 // bzero でもいいけど
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
41 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
42 globalList[i] = NULL;
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
43 }
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
44
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
45 for (int i = 0; i < MAX_MAINMEM_AREA; i++) {
373
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
46 mainMemList[i] = NULL;
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
47 }
373
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
48
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 taskGroup = new TaskGroup;
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
51 renewTop_taskList = NULL;
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
52 renewCur_taskList = NULL;
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
53 }
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
54
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
55 void
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
56 Scheduler::run(void)
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
57 {
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
58 SchedTaskBase* taskTmp;
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
59
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
60 task1 = new SchedNop();
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
61 task2 = new SchedNop();
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
62 task3 = new SchedNop();
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
63
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
64 // main loop
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
65 do {
373
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
66 __debug("----------\n");
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
67 task3->write();
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
68 task2->exec();
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
69 task1->read();
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
70
373
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
71 taskTmp = task3;
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
72 task3 = task2;
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
73 task2 = task1;
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
74 task1 = task1->next(this, taskTmp);
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
75 } while (task1);
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
76
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
77 delete task3;
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
78 delete task2;
50
7927e00fb8e2 *** empty log message ***
gongo
parents: 48
diff changeset
79 }
48
70a0ac46133e *** empty log message ***
gongo
parents: 42
diff changeset
80
50
7927e00fb8e2 *** empty log message ***
gongo
parents: 48
diff changeset
81
7927e00fb8e2 *** empty log message ***
gongo
parents: 48
diff changeset
82 void
7927e00fb8e2 *** empty log message ***
gongo
parents: 48
diff changeset
83 Scheduler::finish(void)
7927e00fb8e2 *** empty log message ***
gongo
parents: 48
diff changeset
84 {
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
85 free(buff_taskList[0]);
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
86 free(buff_taskList[1]);
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
87 free(buff_inListData[0]);
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
88 free(buff_inListData[1]);
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
89 free(buff_outListData[0]);
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
90 free(buff_outListData[1]);
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
91 }
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
92
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
93 /**
298
58fd16298954 from EUC to UTF-8
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 233
diff changeset
94 * あらかじめ memory allocte してある TaskList の領域を
58fd16298954 from EUC to UTF-8
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 233
diff changeset
95 * パイプラインの各処理が交代して使う。
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
96 */
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
97 TaskListPtr
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
98 Scheduler::get_curListBuf(void)
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
99 {
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
100 buffFlag_taskList ^= 1;
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
101
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
102 return buff_taskList[buffFlag_taskList];
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
103 }
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
104
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
105
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
106 /**
298
58fd16298954 from EUC to UTF-8
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 233
diff changeset
107 * あらかじめ memory allocte してある ListData の領域を
58fd16298954 from EUC to UTF-8
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 233
diff changeset
108 * パイプラインの各処理が交代して使う。
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
109 */
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
110 ListDataPtr
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
111 Scheduler::get_curWriteBuf(void)
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
112 {
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
113 buffFlag_outListData ^= 1;
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
114 return buff_outListData[buffFlag_outListData];
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
115 }
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
116
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
117
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
118 ListDataPtr
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
119 Scheduler::get_curReadBuf(void)
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
120 {
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
121 buffFlag_inListData ^= 1;
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
122 return buff_inListData[buffFlag_inListData];
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
123 }
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
124
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
125 /**
298
58fd16298954 from EUC to UTF-8
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 233
diff changeset
126 * タスク内で生成されたタスクを格納する TaskList を取得する
58fd16298954 from EUC to UTF-8
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 233
diff changeset
127 * 現在格納に使っている TaskList (renewCur_taskList) が使えるならそれを返す
58fd16298954 from EUC to UTF-8
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 233
diff changeset
128 * もしそうでないなら、新しく TaskList を allocate してそれを返す
58fd16298954 from EUC to UTF-8
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 233
diff changeset
129 * コード中で renewCur_taskList が NULL になるのは
58fd16298954 from EUC to UTF-8
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 233
diff changeset
130 * - プログラム開始時
58fd16298954 from EUC to UTF-8
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 233
diff changeset
131 * - タスク内生成タスクがある TaskList の実行を新しく始める (Nop2Ready 参照)
58fd16298954 from EUC to UTF-8
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 233
diff changeset
132 * 以上の場合です
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
133 */
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
134 TaskListPtr
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
135 Scheduler::get_renewListBuf(void)
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
136 {
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
137 if (renewCur_taskList && renewCur_taskList->length < TASK_MAX_SIZE) {
373
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
138 return renewCur_taskList;
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
139 } else {
373
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
140 TaskListPtr newList = (TaskListPtr)allocate(sizeof(TaskList));
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
141 newList->length = 0;
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
142 newList->next = NULL;
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
143 renewTop_taskList = TaskList::append(renewTop_taskList, newList);
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
144 renewCur_taskList = newList;
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
145 return newList;
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
146 }
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
147 }
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
148
184
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
149 /**
298
58fd16298954 from EUC to UTF-8
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 233
diff changeset
150 * 次に実行する Renew Task List を返す
184
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
151 *
298
58fd16298954 from EUC to UTF-8
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 233
diff changeset
152 * @param[in] curList 現在実行中の TaskList
58fd16298954 from EUC to UTF-8
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 233
diff changeset
153 * 中断して RenewTaskList を行うため
58fd16298954 from EUC to UTF-8
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 233
diff changeset
154 * バックアップを取っておく
184
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
155 * @return next RenewTaskList
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
156 */
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
157 SchedTaskList*
187
gongo@localhost.localdomain
parents: 184
diff changeset
158 Scheduler::get_nextRenewTaskList(void)
184
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
159 {
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
160 if (renewTop_taskList) {
373
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
161 TaskListPtr list = renewTop_taskList;
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
162 renewTop_taskList = renewTop_taskList->next;
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
163 renewCur_taskList = NULL;
233
gongo@localhost.localdomain
parents: 187
diff changeset
164
373
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
165 list->next = NULL;
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
166 SchedTaskList *sched
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
167 = createSchedTaskList((uint32)list, this, SCHED_TASKLIST_RENEW);
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
168 return sched;
184
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
169 } else {
373
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
170 return NULL;
184
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
171 }
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
172 }
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
173
187
gongo@localhost.localdomain
parents: 184
diff changeset
174 void
gongo@localhost.localdomain
parents: 184
diff changeset
175 Scheduler::set_backupTaskList(TaskListPtr cur_taskList)
gongo@localhost.localdomain
parents: 184
diff changeset
176 {
gongo@localhost.localdomain
parents: 184
diff changeset
177 bak_curTaskList = cur_taskList;
gongo@localhost.localdomain
parents: 184
diff changeset
178 }
gongo@localhost.localdomain
parents: 184
diff changeset
179
gongo@localhost.localdomain
parents: 184
diff changeset
180 void
gongo@localhost.localdomain
parents: 184
diff changeset
181 Scheduler::set_backupTaskListIndex(int cur_index)
gongo@localhost.localdomain
parents: 184
diff changeset
182 {
gongo@localhost.localdomain
parents: 184
diff changeset
183 bakIndex_taskList = cur_index;
gongo@localhost.localdomain
parents: 184
diff changeset
184 }
gongo@localhost.localdomain
parents: 184
diff changeset
185
184
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
186 /**
298
58fd16298954 from EUC to UTF-8
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 233
diff changeset
187 * RenewTaskList 実行前に中断した TaskList を返す
58fd16298954 from EUC to UTF-8
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 233
diff changeset
188 * NULL の場合、中断した TaskList は無い。
184
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
189 *
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
190 * @return TaskList
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
191 */
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
192 TaskListPtr
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
193 Scheduler::get_backupTaskList(void)
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
194 {
187
gongo@localhost.localdomain
parents: 184
diff changeset
195 TaskListPtr ret = bak_curTaskList;
373
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
196
187
gongo@localhost.localdomain
parents: 184
diff changeset
197 bak_curTaskList = NULL;
gongo@localhost.localdomain
parents: 184
diff changeset
198 return ret;
gongo@localhost.localdomain
parents: 184
diff changeset
199 }
gongo@localhost.localdomain
parents: 184
diff changeset
200
gongo@localhost.localdomain
parents: 184
diff changeset
201 int
gongo@localhost.localdomain
parents: 184
diff changeset
202 Scheduler::get_backupTaskListIndex(void)
gongo@localhost.localdomain
parents: 184
diff changeset
203 {
gongo@localhost.localdomain
parents: 184
diff changeset
204 int ret = bakIndex_taskList;
gongo@localhost.localdomain
parents: 184
diff changeset
205
gongo@localhost.localdomain
parents: 184
diff changeset
206 bakIndex_taskList = 0;
gongo@localhost.localdomain
parents: 184
diff changeset
207 return ret;
184
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
208 }
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
209
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
210 void
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
211 Scheduler::dma_load(void *buf, uint32 addr, uint32 size, uint32 mask)
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
212 {
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
213 connector->dma_load(buf, addr, size, mask);
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
214 }
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
215
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
216 void
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
217 Scheduler::dma_store(void *buf, uint32 addr, uint32 size, uint32 mask)
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
218 {
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
219 connector->dma_store(buf, addr, size, mask);
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
220 }
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
221
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
222 void
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
223 Scheduler::dma_wait(uint32 mask)
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
224 {
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
225 connector->dma_wait(mask);
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
226 }
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
227
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
228 void
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
229 Scheduler::dma_loadList(ListDataPtr list, void *buff, uint32 mask)
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
230 {
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
231 connector->dma_loadList(list, buff, mask);
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
232 }
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
233
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
234
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
235 void
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
236 Scheduler::dma_storeList(ListDataPtr list, void *buff, uint32 mask)
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
237 {
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
238 return connector->dma_storeList(list, buff, mask);
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
239 }
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
240
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
241 void
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
242 Scheduler::mail_write(uint32 data)
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
243 {
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
244 connector->mail_write(data);
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
245 }
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
246
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
247 uint32
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
248 Scheduler::mail_read(void)
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
249 {
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
250 return connector->mail_read();
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
251 }
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
252
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
253 TaskGroupPtr
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
254 Scheduler::set_groupTask(uint32 command)
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
255 {
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
256 TaskGroupPtr ret = taskGroup;
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
257
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
258 reload_groupTask();
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
259
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
260 ret->command = command;
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
261 return ret;
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
262 }
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
263
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
264 void
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
265 Scheduler::add_groupTask(TaskGroupPtr group, TaskPtr task)
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
266 {
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
267 group->add(task);
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
268 }
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
269
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
270 void
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
271 Scheduler::remove_groupTask(TaskGroupPtr group, TaskPtr task)
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
272 {
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
273 group->remove(task);
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
274 }
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
275
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
276 void
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
277 Scheduler::reload_groupTask(void)
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
278 {
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
279 taskGroup = new TaskGroup;
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
280 }
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
281
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
282 uint32
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
283 Scheduler::status_groupTask(TaskGroupPtr group)
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
284 {
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
285 return group->status();
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
286 }
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
287
386
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
288 /*
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
289 ここから下は、memory 以下にあるべき
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
290 */
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
291
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
292 void*
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
293 Scheduler::global_alloc(int id, int size)
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
294 {
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
295 globalList[id] = allocate(size);
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
296 return globalList[id];
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
297 }
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
298
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
299 void*
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
300 Scheduler::global_get(int id)
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
301 {
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
302 return globalList[id];
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
303 }
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
304
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
305 void
373
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
306 Scheduler::global_set(int id, void *addr)
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
307 {
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
308 globalList[id] = addr;
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
309 }
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
310
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
311 void
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
312 Scheduler::global_free(int id)
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
313 {
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
314 free(globalList[id]);
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
315 globalList[id] = NULL;
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
316 }
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
317
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
318 /**
298
58fd16298954 from EUC to UTF-8
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 233
diff changeset
319 * mainMem_alloc で確保したメインメモリの領域アドレスを返す。
58fd16298954 from EUC to UTF-8
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 233
diff changeset
320 * これは Fifo, Cell で共通
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
321 */
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
322 void*
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
323 Scheduler::mainMem_get(int id)
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
324 {
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
325 return mainMemList[id];
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
326 }
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
327
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
328
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
329 /**
298
58fd16298954 from EUC to UTF-8
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 233
diff changeset
330 * 本当は Scheduler クラスに入れるべきなんだろうか。。。
58fd16298954 from EUC to UTF-8
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 233
diff changeset
331 * なんか手抜きの感がある
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
332 */
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
333 void
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
334 register_task(int cmd, Scheduler::TaskObject task)
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
335 {
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 50
diff changeset
336 task_list[cmd] = task;
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
337 }
373
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
338
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
339 /*!
386
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
340
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
341 size 単位のMemory Segment を count 個作る
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
342
373
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
343 @param [size] リストの要素1つのサイズ
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
344 @param [count] 要素数
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
345 @return allocate した領域のポインタ
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
346
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
347 */
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
348 MemList*
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
349 Scheduler::createMemList(int size, int count)
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
350 {
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
351 uint32 head_size = round_up16(sizeof(MemorySegment));
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
352 uint32 seg_size = round_up16(head_size+size);
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
353 char* mseg = (char*)allocate(seg_size*count);
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
354 MemList* mlist = new MemList((MemorySegment*)mseg);
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
355
388
82cb9368e3ff MemHash (OS X version)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 387
diff changeset
356 if (!hash) {
82cb9368e3ff MemHash (OS X version)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 387
diff changeset
357 hash = new MemHash();
82cb9368e3ff MemHash (OS X version)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 387
diff changeset
358 }
82cb9368e3ff MemHash (OS X version)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 387
diff changeset
359
373
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
360 for(int i = 0; i < count; i++) {
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
361 MemorySegment* next = (MemorySegment*)(mseg+seg_size*i);
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
362 char* data = (char*)next+head_size;
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
363 next->data = (void*)data;
386
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
364 next->size = size;
373
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
365 mlist->addLast(next);
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
366 }
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
367
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
368 return mlist;
eab18aa0c7f6 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 356
diff changeset
369 }
386
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
370
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
371 /*!
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
372
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
373 Main Memory のSegmentを取得する
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
374
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
375 @param [addr] Main Memory のアドレス
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
376 @param [m] Mem List
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
377 @return allocate した領域のポインタ
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
378
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
379 memory directory にあるべきだが...
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
380
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
381 */
387
5e2d30bfbf23 no compile error but not worked.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 386
diff changeset
382 MemorySegment *
386
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
383 Scheduler::get_segment(memaddr addr, MemList *m)
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 MemorySegment *s = hash->get(addr);
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
386 if (s) {
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
387 /* 既に load されている */
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
388 return s;
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
389 }
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
390
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
391 /* LRU なので、もっとも使われてない segment を上書きする */
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
392 s = m->getLast();
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
393 m->moveToFirst(s);
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
394
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
395 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
396 s->tag = get_tag();
5e2d30bfbf23 no compile error but not worked.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 386
diff changeset
397 dma_load(s->data, addr,
386
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
398 s->size, s->tag);
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
399 /* 前のをhashから削除 */
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
400 hash->remove(old_addr);
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
401 /* 新しいaddress を登録 */
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
402 s->address = addr;
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
403 hash->put(s->address, s);
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
404
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
405 return s;
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
406 }
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
407
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
408 uint32
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
409 Scheduler::get_tag()
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
410 {
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
411 return 0;
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 {
387
5e2d30bfbf23 no compile error but not worked.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 386
diff changeset
443 dma_wait(s->tag);
386
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
444 }
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
445
6113af8f183b MemHash...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 373
diff changeset
446 /* end */