annotate TaskManager/kernel/ppe/TaskManager.cc @ 2054:2e7a6f40672f draft

add param(4) in FileMapReduce.cc
author masa
date Fri, 29 Jan 2016 15:56:28 +0900
parents 0f6d0ae5c3f3
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
3
2356238ebea7 *** empty log message ***
gongo
parents:
diff changeset
1 #include "TaskManager.h"
1891
e0d465efc57e directory reogranization for Cell/Fifo/ManyCore/Gpu
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1627
diff changeset
2 #include "TaskManagerFactory.h"
619
278db3ca751d RenewTask removal
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 567
diff changeset
3 #include "Scheduler.h"
700
ef08dd70eafb fix fix ...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 634
diff changeset
4 #include "HTask.h"
ef08dd70eafb fix fix ...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 634
diff changeset
5 #include "Task.h"
ef08dd70eafb fix fix ...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 634
diff changeset
6 #include "SysFunc.h"
3
2356238ebea7 *** empty log message ***
gongo
parents:
diff changeset
7
1627
Shohei KOKUBO <e105744@ie.u-ryukyu.ac.jp>
parents: 1626
diff changeset
8 TaskManager::TaskManager(int num, int gpu) : machineNum(num) , gpuNum(gpu)
229
e6eb4f8d6b0e add Random class
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 220
diff changeset
9 {
e6eb4f8d6b0e add Random class
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 220
diff changeset
10 }
3
2356238ebea7 *** empty log message ***
gongo
parents:
diff changeset
11
397
ce86b0186a4a delete manager (in kernel/ppe/TaskManager.h)
game@henri.cr.ie.u-ryukyu.ac.jp
parents: 373
diff changeset
12 TaskManager::~TaskManager()
194
gongo@localhost.localdomain
parents: 109
diff changeset
13 {
gongo@localhost.localdomain
parents: 109
diff changeset
14 delete m_impl;
gongo@localhost.localdomain
parents: 109
diff changeset
15 }
gongo@localhost.localdomain
parents: 109
diff changeset
16
3
2356238ebea7 *** empty log message ***
gongo
parents:
diff changeset
17 /**
1891
e0d465efc57e directory reogranization for Cell/Fifo/ManyCore/Gpu
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1627
diff changeset
18 * TaskManagerFactory
e0d465efc57e directory reogranization for Cell/Fifo/ManyCore/Gpu
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1627
diff changeset
19 * create_impl(int);
3
2356238ebea7 *** empty log message ***
gongo
parents:
diff changeset
20 *
109
028ffc9c0375 Cerium cvs version
gongo@gendarme.local
parents: 105
diff changeset
21 * % make cell ってすると cell 版が、
028ffc9c0375 Cerium cvs version
gongo@gendarme.local
parents: 105
diff changeset
22 * % make fifo ってすると fifo 版 がリンクされるようにしているので
028ffc9c0375 Cerium cvs version
gongo@gendarme.local
parents: 105
diff changeset
23 * それに応じて create_impl が返す値を変えています。
028ffc9c0375 Cerium cvs version
gongo@gendarme.local
parents: 105
diff changeset
24 * cell だったら CellManagerImpl, fifo だったら FifoManagerImpl です。
3
2356238ebea7 *** empty log message ***
gongo
parents:
diff changeset
25 *
2356238ebea7 *** empty log message ***
gongo
parents:
diff changeset
26 */
2356238ebea7 *** empty log message ***
gongo
parents:
diff changeset
27
2356238ebea7 *** empty log message ***
gongo
parents:
diff changeset
28 void
1479
163220e54cc0 remove hard code for TaskLog
Daichi TOMA <toma@cr.ie.u-ryukyu.ac.jp>
parents: 1229
diff changeset
29 TaskManager::init(int spuIdle, int export_task_log, int useRefDma=0)
3
2356238ebea7 *** empty log message ***
gongo
parents:
diff changeset
30 {
1626
4fed76f4d101 add gpuNum
shuhei kokubo
parents: 1614
diff changeset
31 m_impl = create_impl(machineNum,gpuNum,useRefDma);
1479
163220e54cc0 remove hard code for TaskLog
Daichi TOMA <toma@cr.ie.u-ryukyu.ac.jp>
parents: 1229
diff changeset
32 m_impl->init(spuIdle, useRefDma, export_task_log);
109
028ffc9c0375 Cerium cvs version
gongo@gendarme.local
parents: 105
diff changeset
33 m_impl->systask_init();
3
2356238ebea7 *** empty log message ***
gongo
parents:
diff changeset
34 }
2356238ebea7 *** empty log message ***
gongo
parents:
diff changeset
35
20
31a7ff27ee20 *** empty log message ***
gongo
parents: 18
diff changeset
36 void
397
ce86b0186a4a delete manager (in kernel/ppe/TaskManager.h)
game@henri.cr.ie.u-ryukyu.ac.jp
parents: 373
diff changeset
37 TaskManager::finish()
20
31a7ff27ee20 *** empty log message ***
gongo
parents: 18
diff changeset
38 {
31a7ff27ee20 *** empty log message ***
gongo
parents: 18
diff changeset
39 delete m_impl;
31a7ff27ee20 *** empty log message ***
gongo
parents: 18
diff changeset
40 }
31a7ff27ee20 *** empty log message ***
gongo
parents: 18
diff changeset
41
3
2356238ebea7 *** empty log message ***
gongo
parents:
diff changeset
42 /**
109
028ffc9c0375 Cerium cvs version
gongo@gendarme.local
parents: 105
diff changeset
43 * @param [command] Task executes method number
3
2356238ebea7 *** empty log message ***
gongo
parents:
diff changeset
44 *
2356238ebea7 *** empty log message ***
gongo
parents:
diff changeset
45 * @return this task
2356238ebea7 *** empty log message ***
gongo
parents:
diff changeset
46 */
2356238ebea7 *** empty log message ***
gongo
parents:
diff changeset
47 HTaskPtr
109
028ffc9c0375 Cerium cvs version
gongo@gendarme.local
parents: 105
diff changeset
48 TaskManager::create_task(int cmd)
3
2356238ebea7 *** empty log message ***
gongo
parents:
diff changeset
49 {
897
6bd218d3f643 add return address in SimpleTask for debugging.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 804
diff changeset
50 return m_impl->create_task(cmd,__builtin_return_address(0));
3
2356238ebea7 *** empty log message ***
gongo
parents:
diff changeset
51 }
2356238ebea7 *** empty log message ***
gongo
parents:
diff changeset
52
1542
9ccfdc408d51 fix gpu word count.but not count line num.
Yuhi TOMARI <yuhi@cr.ie.u-ryukyu.ac.jp>
parents: 1479
diff changeset
53 HTaskPtr
634
62e570ac5db2 SimpleTask start
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 625
diff changeset
54 TaskManager::create_task(int cmd, memaddr r, long rs, memaddr w, long ws)
62e570ac5db2 SimpleTask start
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 625
diff changeset
55 {
897
6bd218d3f643 add return address in SimpleTask for debugging.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 804
diff changeset
56 return m_impl->create_task(cmd,r,rs,w,ws,__builtin_return_address(0));
634
62e570ac5db2 SimpleTask start
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 625
diff changeset
57 }
62e570ac5db2 SimpleTask start
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 625
diff changeset
58
1542
9ccfdc408d51 fix gpu word count.but not count line num.
Yuhi TOMARI <yuhi@cr.ie.u-ryukyu.ac.jp>
parents: 1479
diff changeset
59 HTaskPtr
700
ef08dd70eafb fix fix ...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 634
diff changeset
60 TaskManager::create_task_array(int id, int num_task, int num_param, int num_inData, int num_outData) {
897
6bd218d3f643 add return address in SimpleTask for debugging.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 804
diff changeset
61 return m_impl->create_task_array(id, num_task, num_param, num_inData, num_outData,__builtin_return_address(0)) ;
700
ef08dd70eafb fix fix ...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 634
diff changeset
62 }
634
62e570ac5db2 SimpleTask start
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 625
diff changeset
63
216
e9a52d68db42 rename cerium_main to TMmain, add TMend()
gongo@localhost.localdomain
parents: 194
diff changeset
64 /**
e9a52d68db42 rename cerium_main to TMmain, add TMend()
gongo@localhost.localdomain
parents: 194
diff changeset
65 * TaskManaer 終了時に実行される関数の設定
e9a52d68db42 rename cerium_main to TMmain, add TMend()
gongo@localhost.localdomain
parents: 194
diff changeset
66 */
e9a52d68db42 rename cerium_main to TMmain, add TMend()
gongo@localhost.localdomain
parents: 194
diff changeset
67 void
397
ce86b0186a4a delete manager (in kernel/ppe/TaskManager.h)
game@henri.cr.ie.u-ryukyu.ac.jp
parents: 373
diff changeset
68 TaskManager::set_TMend(void (*endf)(TaskManager *manager))
216
e9a52d68db42 rename cerium_main to TMmain, add TMend()
gongo@localhost.localdomain
parents: 194
diff changeset
69 {
e9a52d68db42 rename cerium_main to TMmain, add TMend()
gongo@localhost.localdomain
parents: 194
diff changeset
70 tm_end = endf;
e9a52d68db42 rename cerium_main to TMmain, add TMend()
gongo@localhost.localdomain
parents: 194
diff changeset
71 }
e9a52d68db42 rename cerium_main to TMmain, add TMend()
gongo@localhost.localdomain
parents: 194
diff changeset
72
3
2356238ebea7 *** empty log message ***
gongo
parents:
diff changeset
73 void
397
ce86b0186a4a delete manager (in kernel/ppe/TaskManager.h)
game@henri.cr.ie.u-ryukyu.ac.jp
parents: 373
diff changeset
74 TaskManager::run()
3
2356238ebea7 *** empty log message ***
gongo
parents:
diff changeset
75 {
2356238ebea7 *** empty log message ***
gongo
parents:
diff changeset
76 m_impl->run();
2356238ebea7 *** empty log message ***
gongo
parents:
diff changeset
77 }
216
e9a52d68db42 rename cerium_main to TMmain, add TMend()
gongo@localhost.localdomain
parents: 194
diff changeset
78
e9a52d68db42 rename cerium_main to TMmain, add TMend()
gongo@localhost.localdomain
parents: 194
diff changeset
79 void*
1940
0f6d0ae5c3f3 change manager->allocate size long long to long
Masataka Kohagura <e085726@ie.u-ryukyu.ac.jp>
parents: 1937
diff changeset
80 TaskManager::allocate(long size) {
216
e9a52d68db42 rename cerium_main to TMmain, add TMend()
gongo@localhost.localdomain
parents: 194
diff changeset
81 return m_impl->allocate(size);
e9a52d68db42 rename cerium_main to TMmain, add TMend()
gongo@localhost.localdomain
parents: 194
diff changeset
82 }
220
gongo@localhost.localdomain
parents: 216
diff changeset
83
gongo@localhost.localdomain
parents: 216
diff changeset
84 int
397
ce86b0186a4a delete manager (in kernel/ppe/TaskManager.h)
game@henri.cr.ie.u-ryukyu.ac.jp
parents: 373
diff changeset
85 TaskManager::get_cpuNum()
220
gongo@localhost.localdomain
parents: 216
diff changeset
86 {
gongo@localhost.localdomain
parents: 216
diff changeset
87 return machineNum;
gongo@localhost.localdomain
parents: 216
diff changeset
88 }
229
e6eb4f8d6b0e add Random class
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 220
diff changeset
89
e6eb4f8d6b0e add Random class
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 220
diff changeset
90 int
397
ce86b0186a4a delete manager (in kernel/ppe/TaskManager.h)
game@henri.cr.ie.u-ryukyu.ac.jp
parents: 373
diff changeset
91 TaskManager::get_random()
229
e6eb4f8d6b0e add Random class
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 220
diff changeset
92 {
619
278db3ca751d RenewTask removal
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 567
diff changeset
93 return random();
278db3ca751d RenewTask removal
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 567
diff changeset
94 }
278db3ca751d RenewTask removal
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 567
diff changeset
95
278db3ca751d RenewTask removal
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 567
diff changeset
96 MemList*
278db3ca751d RenewTask removal
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 567
diff changeset
97 TaskManager::createMemList(int size, int count)
278db3ca751d RenewTask removal
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 567
diff changeset
98 {
278db3ca751d RenewTask removal
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 567
diff changeset
99 return get_scheduler()->createMemList(size, count);
229
e6eb4f8d6b0e add Random class
gongo@gendarme.cr.ie.u-ryukyu.ac.jp
parents: 220
diff changeset
100 }
368
1a80a2aa696c change TaskManager
aaa
parents: 229
diff changeset
101
373
205e4a4af635 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 370
diff changeset
102 Scheduler*
205e4a4af635 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 370
diff changeset
103 TaskManager::get_scheduler() {
205e4a4af635 MemList not working
kazz@kazzone.cr.ie.u-ryukyu.ac.jp
parents: 370
diff changeset
104 return m_impl->get_scheduler();
368
1a80a2aa696c change TaskManager
aaa
parents: 229
diff changeset
105 }
480
75e4afa40da2 TaskQueueInfo initiaization...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 397
diff changeset
106
1542
9ccfdc408d51 fix gpu word count.but not count line num.
Yuhi TOMARI <yuhi@cr.ie.u-ryukyu.ac.jp>
parents: 1479
diff changeset
107 void
9ccfdc408d51 fix gpu word count.but not count line num.
Yuhi TOMARI <yuhi@cr.ie.u-ryukyu.ac.jp>
parents: 1479
diff changeset
108 TaskManager::error(const char* error_message) {
9ccfdc408d51 fix gpu word count.but not count line num.
Yuhi TOMARI <yuhi@cr.ie.u-ryukyu.ac.jp>
parents: 1479
diff changeset
109 printf("%s \n",error_message);
9ccfdc408d51 fix gpu word count.but not count line num.
Yuhi TOMARI <yuhi@cr.ie.u-ryukyu.ac.jp>
parents: 1479
diff changeset
110 exit(1);
9ccfdc408d51 fix gpu word count.but not count line num.
Yuhi TOMARI <yuhi@cr.ie.u-ryukyu.ac.jp>
parents: 1479
diff changeset
111 }
480
75e4afa40da2 TaskQueueInfo initiaization...
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 397
diff changeset
112 /* end */