Mercurial > hg > Members > kono > Cerium
view TaskManager/kernel/ppe/Task.cc @ 648:f1e10ba45d28
Mail modification. Working on Mac OS X.
author | Shinji KONO <kono@ie.u-ryukyu.ac.jp> |
---|---|
date | Sat, 21 Nov 2009 20:14:45 +0900 |
parents | 8843edf37c0e |
children | d753b4f6b129 |
line wrap: on
line source
#include "Task.h" /** * タスクの入力データを追加する * * @param [addr] add input data * @param [size] size of data at [addr] * * @return if ([ret] == 0) ? success : failuer; */ int Task::add_inData_t(memaddr addr, int size) { return add_data(inData, addr, size); } /** * タスクの出力先を追加する * * @param[in] addr Address at out data * @param[in] size Size of data transfer * * @return if ([ret] == 0) ? success : failuer; */ int Task::add_outData_t(memaddr addr, int size) { return add_data(outData, addr, size); } /** * エラーの時に -1 を返す、ってことするよりは * perror みたいにしたほうがわかりやすいかな。 * * 現在は MAX_PARAMS 個まで。 * 本当は、MAX_PARAMS個以上にすると task->param[] には アドレスが入り * そのアドレスは メインメモリでアロケートされた int の集合。 */ // こちらのAPIは、受け側と出力側での対応を良く見れない。廃止の方向。 int Task::add_param0(memaddr _param) { if (param_size >= MAX_PARAMS) return -1; this->param[param_size++] = _param; return 0; } int Task::set_param0(int index, memaddr _param) { if (index >= MAX_PARAMS) return -1; this->param[index] = _param; return 0; } /* * エラーの時に -1 を返す、ってことするよりは * perror みたいにしたほうがわかりやすいかな。 */ int Task::add_data(ListData& list, memaddr addr, int size) { if (list.length >= MAX_LIST_DMA_SIZE) return -1; list.bound[list.length] = list.size; // size でも制限かけるべき? list.size += size; ListElementPtr elm = &list.element[list.length++]; #ifdef __CERIUM_CELL__ elm->addr = (uint32)(unsigned long)addr; #else elm->addr = addr; #endif elm->size = size; return 0; }