Mercurial > hg > Game > Cerium
view TaskManager/kernel/ppe/HTask.cc @ 1551:57317332f6ef draft
create fft example
author | Yuhi TOMARI <yuhi@cr.ie.u-ryukyu.ac.jp> |
---|---|
date | Sun, 17 Feb 2013 12:59:12 +0900 |
parents | 163220e54cc0 |
children | 806b4658ced6 |
line wrap: on
line source
#include "HTask.h" #include "ListData.h" #include "TaskManagerImpl.h" #include "strings.h" #include "rdtsc.h" /*! manager->set_task_depend(task1, task2); // task2 は task1 の終了を待つ ってやるより task2->set_depend(task1); ってやったほうがわかりやすいよねー的な話し合いで 下のようなAPIを作りました */ void HTask::spawn(void) { if (export_task_log) tasklog->create_time = rdtsc(); TaskList *tl = (TaskList*)rbuf; tl->self = this; tl->set_last(last); mimpl->spawn_task(this); } /*! @brief この Task が待ち合わせする Task を指定する @param[in] master この Task が終了待ち合わせをする相手の Task 繰り返し使用する事で複数の Task を待ち合わせする事ができる。 wait_for している Task の入力バッファにこの Task から書き込みできる機能があると良い */ void HTask::wait_for(HTaskPtr master) { if (export_task_log) { waitTask *wait_task = new waitTask; wait_task->task_id = master->tasklog->mtask_id; wait_task->cmd = master->tasklog->cmd; tasklog->wait_for_list.addLast(wait_task); } mimpl->set_task_depend(master, this); } /** * タスクが実行する CPU を選択する * * 現在は CPU_PPE, CPU_SPE, SPE_ANY, SPE_0, SPE_1, ..., SPE_5 * types.h に書いてます。 * * mimpl によって使えるCPUが異なるので、mimpl に任せる必要がある */ void HTask::set_cpu(CPU_TYPE type) { mimpl->set_task_cpu(this, type); } /*! @brief このTaskが終了した時に実行する関数 @param arg1, arg2 の二つの引数を持つ (Task に合わせてある) */ void HTask::set_post(PostFunction func,void *arg1, void *arg2) { this->post_func = func; this->post_arg1 = arg1; this->post_arg2 = arg2; } /*! @brief まとまって実行されるTask である Task Array の作成 @param id Task ID @param num_task 実行する Task の数 @param num_param 一つのTaskがset_paramする数 @param num_inData 一つのTaskが読み込む Data の数、set_inData の数 @param num_outData 一つのTaskが書き出す Data の数、set_outData の数 @return Task Array へのポインタ */ Task * HTask::create_task_array(int id, int num_task, int num_param, int num_inData, int num_outData) { r_size = 0; TaskListPtr tl = mimpl->createTaskList(); tl->self = 0; rbuf = (memaddr)tl; bzero(tl->tasks,sizeof(Task)*TASK_MAX_SIZE); Task *task = tl->tasks; task->init(id, num_param,num_inData,num_outData); // next_task_array が呼ばれれば、これは不要 last = task->next(); // return task; // first task } /*! @brief Task Array の次のTask @param t 今のTaskのポインタ 0 の場合は最初のTask @return 次のTaskへのポインタ */ Task * HTask::next_task_array(int id, Task *t) { TaskPtr t1 = t; if (t==0) { TaskList *tl = (TaskList*)rbuf; t1 = tl->tasks; } return next_task_array(id,t,t1->param_count,t1->inData_count,t1->outData_count); } /*! @brief Task Array の次のTask @param t 今のTaskのポインタ 0 の場合は最初のTask @return 次のTaskへのポインタ */ Task * HTask::next_task_array(int id, Task *t, int param_count, int inData_count, int outData_count) { TaskList *tl = (TaskList*)rbuf; if (t==0) { TaskPtr task = tl->tasks; task->init(id, param_count, inData_count, outData_count); last = task->next(); return task; } Task *next = t->next(); if (next >= tl->last()) { tl->set_last(t); TaskListPtr nextTaskList = mimpl->createTaskList(); nextTaskList->prev = tl; tl->next = nextTaskList; tl = nextTaskList; next = tl->tasks; tl->self = 0; rbuf = (memaddr)tl; } next->init(id, param_count, inData_count, outData_count); last = next->next(); return next; } /*! @brief Task Array の中のすべてのTaskが書き込まれたかどうかをチェックする TaskArray 自体の spawn() は別に必要 @param last 今のTaskのポインタ (最後である必要がある) */ void HTask::spawn_task_array(Task * last) { } /* end */