view TaskManager/kernel/ppe/Task.cc @ 629:8843edf37c0e

Cell 64 bit tried, but not yet worked. Cell's list DMA is 32bit.
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Wed, 18 Nov 2009 13:32:58 +0900
parents 60aa3f241b10
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;
}