annotate TaskManager/kernel/schedule/SchedTaskList.cc @ 1025:cb170249c752

minor fix
author yutaka@localhost.localdomain
date Mon, 08 Nov 2010 14:40:53 +0900
parents d093d601fc14
children
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"
704
6d497c098455 Compatibility mode works.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 683
diff changeset
5 #include "SysFunc.h"
6d497c098455 Compatibility mode works.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 683
diff changeset
6 #include "SchedTaskArray.h"
6d497c098455 Compatibility mode works.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 683
diff changeset
7 #include "SchedTaskArrayLoad.h"
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
8 #include "SchedNop2Ready.h"
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
9 #include "DmaManager.h"
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
10 #include "error.h"
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
11
184
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
12 /**
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
13 * SchedTaskList を返す
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
14 *
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
15 * @param[in] next_list 次の実行する TaskList のアドレス
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
16 * @param[in] next_list がメインメモリのアドレスか、
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
17 * SPE で生成されたアドレスかのフラグ
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
18 * SPE で生成されている場合、DMA の必要は無い
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 109
diff changeset
19 * 0: メインメモリ, 1: SPE
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
972
Yutaka Kinjyo <yutaka@cr.ie.u-ryukyu.ac.jp>
parents: 970
diff changeset
22 SchedTaskList::SchedTaskList(memaddr addr, Scheduler *sched, int tag)
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
23 {
717
4c12f679a0fa TaskList load timing...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 709
diff changeset
24 // next() で生成された時に、Task List read を始める
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
25 params_addr = addr;
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 88
diff changeset
26 scheduler = sched;
708
56487849ea2d cleean up SchedTasks.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 704
diff changeset
27 cur_index = 0;
717
4c12f679a0fa TaskList load timing...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 709
diff changeset
28 list = scheduler->get_curListBuf();
4c12f679a0fa TaskList load timing...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 709
diff changeset
29 scheduler->dma_load(list, params_addr,
4c12f679a0fa TaskList load timing...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 709
diff changeset
30 sizeof(TaskList), DMA_READ_TASKLIST);
970
33630c6ff445 change pipeline and TaskArray fast
Yutaka Kinjyo <yutaka@cr.ie.u-ryukyu.ac.jp>
parents: 717
diff changeset
31
972
Yutaka Kinjyo <yutaka@cr.ie.u-ryukyu.ac.jp>
parents: 970
diff changeset
32 this->tag = tag;
Yutaka Kinjyo <yutaka@cr.ie.u-ryukyu.ac.jp>
parents: 970
diff changeset
33
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
34 }
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
35
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 88
diff changeset
36
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
37 void
403
8611780d479f clean up and add more info on task_list
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 233
diff changeset
38 SchedTaskList::read()
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
39 {
717
4c12f679a0fa TaskList load timing...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 709
diff changeset
40 // next() で TaskListの中身を見られてしまうので、
4c12f679a0fa TaskList load timing...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 709
diff changeset
41 // ここで DMA 待ちを行う
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
42 __debug("[SchedTaskList:%s]\n", __FUNCTION__);
717
4c12f679a0fa TaskList load timing...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 709
diff changeset
43 scheduler->dma_wait(DMA_READ_TASKLIST);
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
44 }
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
45
708
56487849ea2d cleean up SchedTasks.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 704
diff changeset
46 void
717
4c12f679a0fa TaskList load timing...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 709
diff changeset
47 SchedTaskList::exec() {
4c12f679a0fa TaskList load timing...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 709
diff changeset
48 }
708
56487849ea2d cleean up SchedTasks.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 704
diff changeset
49
56487849ea2d cleean up SchedTasks.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 704
diff changeset
50 void
56487849ea2d cleean up SchedTasks.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 704
diff changeset
51 SchedTaskList::write()
42
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
52 {
aa11038dbdc1 *** empty log message ***
gongo
parents:
diff changeset
53 }
88
504899860e66 *** empty log message ***
gongo
parents: 42
diff changeset
54
709
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 708
diff changeset
55 /**
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 708
diff changeset
56 * next は、SchedTask のものが使われる。
717
4c12f679a0fa TaskList load timing...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 709
diff changeset
57 * それで正しく動くはず。
4c12f679a0fa TaskList load timing...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 709
diff changeset
58 *
4c12f679a0fa TaskList load timing...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 709
diff changeset
59 * next() が呼ばれた時点で、TaskList のloadが終了しているように工夫する。
4c12f679a0fa TaskList load timing...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 709
diff changeset
60 *
709
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 708
diff changeset
61 */
708
56487849ea2d cleean up SchedTasks.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 704
diff changeset
62
403
8611780d479f clean up and add more info on task_list
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 233
diff changeset
63 /* end */