annotate TaskManager/kernel/schedule/SchedTaskList.cc @ 184:907bda4a1a14

fix
author gongo@gendarme.cr.ie.u-ryukyu.ac.jp
date Tue, 06 Jan 2009 15:39:48 +0900
parents 5c194c71eca8
children d734af296d38
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 88
diff changeset
1 #include <stdlib.h>
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 88
diff changeset
2 #include <string.h>
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
3 #include "SchedTaskList.h"
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
4 #include "SchedTask.h"
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
5 #include "SchedNop2Ready.h"
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
6 #include "DmaManager.h"
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
7 #include "error.h"
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
8
184
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
9 /**
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
10 * SchedTaskList を返す
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
11 *
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
12 * @param[in] next_list 次の実行する TaskList のアドレス
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
13 * @param[in] next_list がメインメモリのアドレスか、
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
14 * SPE で生成されたアドレスかのフラグ
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
15 * SPE で生成されている場合、DMA の必要は無い
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
16 * 0: メインメモリ, 1: SPE
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
17 */
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
18 SchedTaskList*
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
19 createSchedTaskList(uint32 next_list, Scheduler* scheduler, int renew_flag)
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
20 {
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
21 SchedTaskList* sched = new SchedTaskList(next_list, scheduler);
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
22 sched->flag_renewTaskList = renew_flag;
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
23 return sched;
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
24 }
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
25
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 88
diff changeset
26 SchedTaskList::SchedTaskList(unsigned int addr, Scheduler *sched)
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
27 {
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
28 params_addr = addr;
184
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
29 list = NULL;
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 88
diff changeset
30 scheduler = sched;
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 88
diff changeset
31
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 88
diff changeset
32 flag_renewTaskList = 0;
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
33 }
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
34
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 88
diff changeset
35
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
36 void
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
37 SchedTaskList::read(void)
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
38 {
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
39 __debug("[SchedTaskList:%s]\n", __FUNCTION__);
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
40
184
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
41 if (flag_renewTaskList == SCHED_TASKLIST_NORMAL) {
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
42 list = scheduler->get_curListBuf();
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
43 scheduler->dma_load(list, params_addr,
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
44 sizeof(TaskList), DMA_READ_TASKLIST);
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 88
diff changeset
45 scheduler->dma_wait(DMA_READ_TASKLIST);
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 88
diff changeset
46 } else {
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 88
diff changeset
47 list = (TaskListPtr)params_addr;
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 88
diff changeset
48 }
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
49 }
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
50
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
51 SchedTaskBase*
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
52 SchedTaskList::next(Scheduler *m, SchedTaskBase *p)
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
53 {
184
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
54 SchedTaskBase *nextSched;
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
55
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
56 __debug("[SchedTaskList:%s]\n", __FUNCTION__);
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
57
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
58 delete p;
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
59
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
60 if (list->length < 1) {
184
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
61 nextSched = new SchedNop2Ready(scheduler);
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
62
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
63 if (flag_renewTaskList == SCHED_TASKLIST_RENEW) {
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
64 free(list);
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
65 }
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
66
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
67 } else {
184
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
68 TaskPtr nextTask = &list->tasks[0];
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
69 nextSched = createSchedTask(nextTask);
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
70
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
71 if (flag_renewTaskList == SCHED_TASKLIST_RENEW) {
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
72 ((SchedTask*)nextSched)->__setRenew();
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
73 }
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
74
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
75 ((SchedTask*)nextSched)->__init__(list, nextTask, 1,
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
76 scheduler->get_curReadBuf(),
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
77 scheduler->get_curWriteBuf(),
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
78 scheduler);
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
79 }
184
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
80
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
81 return nextSched;
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
82 }
88
504899860e66 *** empty log message ***
gongo
parents: 42
diff changeset
83