annotate TaskManager/kernel/ppe/Task.h @ 518:125a72948e44

....
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Fri, 16 Oct 2009 17:57:17 +0900
parents 4a2c9ff53605
children 5c76db2a07fa
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
274
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
1 #ifndef INCLUDED_TASK
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
2 #define INCLUDED_TASK
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
3
307
7075842aa155 clean up include
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 274
diff changeset
4 #include "base.h"
7075842aa155 clean up include
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 274
diff changeset
5 #include "types.h"
7075842aa155 clean up include
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 274
diff changeset
6 #include "ListData.h"
274
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
7
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
8 #define MAX_PARAMS 8
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
9
497
9d225ba0c34f no wakeup loop
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 366
diff changeset
10 class TaskQueue;
518
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 501
diff changeset
11 class SchedTask;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 501
diff changeset
12
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 501
diff changeset
13
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 501
diff changeset
14 /*!
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 501
diff changeset
15 @class
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 501
diff changeset
16
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 501
diff changeset
17 @brief
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 501
diff changeset
18
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 501
diff changeset
19 Host に依存しない Task
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 501
diff changeset
20
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 501
diff changeset
21 以下の三つの可変長データを含む
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 501
diff changeset
22 param
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 501
diff changeset
23 inData
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 501
diff changeset
24 outData
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 501
diff changeset
25 param は inData の最初の部分となる
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 501
diff changeset
26
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 501
diff changeset
27 self はメインホストの中のHTaskのアドレスで、task id として使う
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 501
diff changeset
28
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 501
diff changeset
29 */
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 501
diff changeset
30
497
9d225ba0c34f no wakeup loop
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 366
diff changeset
31
274
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
32 class Task {
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
33 public: // variables
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
34
518
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 501
diff changeset
35 typedef void (*PostFunction)(SchedTask *s, void *read, void *write);
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 501
diff changeset
36
274
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
37 BASE_NEW_DELETE(Task);
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
38
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
39 int command; // 4 byte
498
cb5ecfc5aaa3 double linked HTaskInfo/HTask
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 497
diff changeset
40 int self; // 4 byte
274
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
41
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
42 int param_size; // 4 byte
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
43 int param[MAX_PARAMS]; // 4*MAX_PARAMS byte
518
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 501
diff changeset
44
501
4a2c9ff53605 Cell inData/outData DMA removal
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 498
diff changeset
45 ListData inData __attribute__ ((aligned (DEFAULT_ALIGNMENT))); // 4 byte 64bit であるべき
4a2c9ff53605 Cell inData/outData DMA removal
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 498
diff changeset
46 ListData outData __attribute__ ((aligned (DEFAULT_ALIGNMENT))); // 4 byte 64bit であるべき
274
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
47
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
48 public: // functions
363
a8fcb4431c76 See Changelog
tkaito@localhost.localdomain
parents: 307
diff changeset
49 int add_inData_t(unsigned int addr, int size); // unsigned int ではなく 64bit
a8fcb4431c76 See Changelog
tkaito@localhost.localdomain
parents: 307
diff changeset
50 int add_outData_t(unsigned int addr, int size); // unsigned int ではなく 64bit
498
cb5ecfc5aaa3 double linked HTaskInfo/HTask
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 497
diff changeset
51 int add_data(ListData &list, unsigned int addr, int size);
274
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
52 int add_param(int param);
518
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 501
diff changeset
53 void set_cpu(CPU_TYPE type);
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 501
diff changeset
54 void set_post(PostFunction func, void *read, void *write);
274
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
55
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
56 #define add_inData(addr, size) \
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
57 add_inData_t((unsigned int)(addr), (size));
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
58 #define add_outData(addr, size) \
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
59 add_outData_t((unsigned int)(addr), (size));
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
60 };
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
61
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
62 typedef Task* TaskPtr;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
63
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
64 #endif