changeset 1565:4ef32873b5be draft

merge
author Yuhi TOMARI <yuhi@cr.ie.u-ryukyu.ac.jp>
date Fri, 15 Mar 2013 07:00:34 +0900
parents 4e1899c693f0 (current diff) 4fd1e2ce7d30 (diff)
children 7d307bac94a6 767d99d95fbc
files example/Prime/ppe/Prime.cc.orig example/many_task/spe/QuickSort.cc.orig example/word_count/ppe/Exec.cc.orig include/TaskManager/AddrList.h include/TaskManager/CellDmaManager.h include/TaskManager/CellScheduler.h include/TaskManager/CellTaskManagerImpl.h include/TaskManager/CpuThreads.h include/TaskManager/DmaManager.h include/TaskManager/ExportTaskLog.h include/TaskManager/FifoDmaManager.h include/TaskManager/FifoTaskManagerImpl.h include/TaskManager/Finish.h include/TaskManager/GpuError.h include/TaskManager/GpuFunc.h include/TaskManager/GpuScheduler.h include/TaskManager/GpuThreads.h include/TaskManager/HTask.h include/TaskManager/ListData.h include/TaskManager/MailManager.h include/TaskManager/MainScheduler.h include/TaskManager/MemHash.h include/TaskManager/MemIterator.h include/TaskManager/MemList.h include/TaskManager/MemorySegment.h include/TaskManager/PreRefDmaManager.h include/TaskManager/QueueInfo.h include/TaskManager/ReferencedDmaManager.h include/TaskManager/SchedExit.h include/TaskManager/SchedMail.h include/TaskManager/SchedNop.h include/TaskManager/SchedNop2Ready.h include/TaskManager/SchedTask.h include/TaskManager/SchedTaskBase.h include/TaskManager/SchedTaskList.h include/TaskManager/Scheduler.h include/TaskManager/Sem.h include/TaskManager/SemMailManager.h include/TaskManager/ShowTime.h include/TaskManager/SimpleTask.h include/TaskManager/SpeTaskManagerImpl.h include/TaskManager/SpeThreads.h include/TaskManager/Start.h include/TaskManager/StartProfile.h include/TaskManager/SynchronizedMailManager.h include/TaskManager/SysFunc.h include/TaskManager/SysTask.h include/TaskManager/SysTasks.h include/TaskManager/Task.h include/TaskManager/TaskList.h include/TaskManager/TaskLog.h include/TaskManager/TaskManager.h include/TaskManager/TaskManagerImpl.h include/TaskManager/TaskQueue.h include/TaskManager/Threads.h include/TaskManager/base.h include/TaskManager/error.h include/TaskManager/gettime.h include/TaskManager/rdtsc.h include/TaskManager/types.h
diffstat 59 files changed, 0 insertions(+), 3110 deletions(-) [+]
line wrap: on
line diff
--- a/example/Prime/ppe/Prime.cc.orig	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,37 +0,0 @@
-#include <stdio.h>
-#include <math.h>
-#include "SchedTask.h"
-#include "Prime.h"
-#include "Func.h"
-
-SchedDefineTask1(Prime, prime);
-
-static int
-prime(SchedTask *smanager, void *rbuf, void *wbuf)
-{
-    long start = (long)smanager->get_param(0);	/* 素数判定の開始地点 */
-	long end   = (long)smanager->get_param(1);	/* 素数判定の終了地点 */
-	long range = end - start;					/* 判定する範囲		  */
-
-	/* 判定結果を収める配列を受け取る */
-	bool *output = (bool*)smanager->get_output(wbuf, 0);
-
-	/* 初期化 */
-	for (int i = 0; i < range; i++){
-		output[i] = true;
-	}
-
-
-
-	for (long i = start, index = 0; i < end; i++, index++) {
-		long limit = (long)sqrt((double) i);		/* 割る数の最大値を求める */
-		for (long j = 2; j <= limit; j++) {
-			/* 割り切れた場合、0を代入し素数じゃないという判定を下す */
-			if (i % j == 0) {
-				output[index] = false;
-				break;
-			}
-		}
-	}
-	return 0;
-}
--- a/example/many_task/spe/QuickSort.cc.orig	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,75 +0,0 @@
-#include "QuickSort.h"
-#include <stdio.h>
-#include <string.h>
-
-SchedDefineTask(QuickSort);
-
-static void quick_sort( Data *data, int begin, int end ) ;
-
-static void
-swap( Data *data, int left, int right )
-{
-    Data tmp	      = data[left];
-    data[left]  = data[right];
-    data[right] = tmp;
-}
-
-// #define USE_MEMCPY
-
-static int
-run(SchedTask *s, void* rbuff, void* wbuff) {
-    // copy value
-    int begin	= 0;
-#if USE_SIMPLE_TASK
-    int end = s->read_size()/sizeof(Data);
-    Data *r_data = (Data*)rbuff;
-#ifdef USE_MEMCPY
-    Data *w_data = (Data*)wbuff;
-#endif
-#else
-    int end = s->get_inputSize(0)/sizeof(Data);
-    DataPtr r_data = (DataPtr)s->get_input(0);
-#ifdef USE_MEMCPY
-    DataPtr w_data = (DataPtr)s->get_output(0);
-#endif
-#endif
-
-    //printf("[SPE] Quick: length:%d addr->%x \n",end, (int)rbuff);
-    //printf("[PPE] Quick: data[0]: %d addr->%x\n",sizeof(r_data),r_data); 
-
-    //show_data(r_data, end);
-    quick_sort(r_data, begin, end-1);
-#ifdef USE_MEMCPY
-    memcpy(w_data, r_data, sizeof(Data)*end);
-#else
-    s->swap();
-#endif
-
-    return 0;
-}
-
-static void 
-quick_sort( Data *data, int begin, int end ) {
-
-  if (begin < end) {
-	int where = (begin + end) / 2;
-	int pivot = data[where].index;
-	data[where].index = data[begin].index;
-	int p = begin;
-	int i;
-	for (i=begin+1; i<=end; i++) {
-	    if (data[i].index < pivot) { 
-		p++; 
-		swap(data, p, i); 
-	    }
-	}
-	data[begin].index = data[p].index;
-	data[p].index = pivot;
-	
-	quick_sort(data, begin, p-1);
-	quick_sort(data, p+1, end); // tail call
-    }
-}
-
-
-/* end */
--- a/example/word_count/ppe/Exec.cc.orig	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,45 +0,0 @@
-#include <stdio.h>
-#include <string.h>
-#include "Exec.h"
-#include "Func.h"
-
-/* これは必須 */
-SchedDefineTask(Exec);
-
-static int
-run(SchedTask *s, void *rbuf, void *wbuf)
-{
-    char *i_data = (char *)s->get_input(rbuf,0);
-    unsigned long long *o_data = (unsigned long long*)s->get_output(wbuf,0);
-    unsigned long long *head_tail_flag = o_data +2;
-    int length = (int)s->get_inputSize(0);
-    int word_flag = 0;
-    int word_num = 0;
-    int line_num = 0;
-    int i = 0;
-
-    head_tail_flag[0] = (i_data[0] != 0x20) && (i_data[0] != 0x0A);
-    word_num -= 1-head_tail_flag[0];
-
-    for (; i < length; i++) {
-        if (i_data[i] == 0x20) { // 空白
-            word_flag = 1;
-        } else if (i_data[i] == 0x0A) { // 改行
-            line_num += 1;
-            word_flag = 1;
-        } else {
-            word_num += word_flag;
-            word_flag = 0;
-        }
-    }
-
-    word_num += word_flag;
-    head_tail_flag[1] = (i_data[i-1] != 0x20) && (i_data[i-1] != 0x0A);
-
-    // s->printf("SPE word %d line %d\n",word_num,line_num);
-
-    o_data[0] = (unsigned long long)word_num;
-    o_data[1] = (unsigned long long)line_num;
-
-    return 0;
-}
--- a/include/TaskManager/AddrList.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,20 +0,0 @@
-#ifndef INCLUDED_ADDR_LIST
-#define INCLUDED_ADDR_LIST
-
-#include "types.h"
-
-/*
-
-  MainMemory 側の MemorySegment に近いかも?
-  Iterator で使う、MainMemory 側の アドレスリスト
-
- */
-
-typedef struct AddrList {
-
-  memaddr addr;
-  AddrList *next;
-
-}AddrList, *AddrListPtr; // 8
-
-#endif
--- a/include/TaskManager/CellDmaManager.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,78 +0,0 @@
-#ifndef INCLUDED_CELL_DMA_MANAGER
-#define INCLUDED_CELL_DMA_MANAGER
-
-#include "base.h"
-#include "types.h"
-#include "DmaManager.h"
-#include "MailManager.h"
-#include "TaskManagerImpl.h"
-
-#include <spu_mfcio.h>
-#include <spu_intrinsics.h>
-
-#define SPU_PROFILE 1
-
-class Scheduler;
-
-class CellDmaManager : public DmaManager {
-public:
-    BASE_NEW_DELETE(CellDmaManager);
-
-    typedef struct dma_list {
-	uint32 addr;  // should be memaddr, but in Cell's specification...
-	uint32 size;
-    }  __attribute__ ((aligned (DEFAULT_ALIGNMENT))) DmaList, *DmaListPtr;
-
-
-    CellDmaManager() ;
-
-    /* variables */
-    unsigned int wait_time, busy_time, alloc_busy_time;
-    unsigned long long global_busy_time, global_wait_time, global_mail_time, mainMemalloc_time;
-    unsigned long long task_list_mail_time;
-    unsigned long long mail_read_time, mail_write_time;
-    unsigned long long task_list_mail_read_time, finish_mail_write_time;
-    int task_list_read_count;
-
-    /* functions */
-    void *dma_load(Scheduler *s, memaddr addr, uint32 size, uint32 mask);
-    void *dma_load1(void *buf, memaddr addr, uint32 size, uint32 mask);
-    void *dma_store(Scheduler *s,void *buf, memaddr addr, uint32 size, uint32 mask);
-
-    void *get_writebuf(Scheduler *s, memaddr addr, uint32 size);
-
-    void dma_wait(uint32 mask) ;
-    void dma_wait(uint32 mask, int cmd) ;
-    void (CellDmaManager::*start_dmawait_profile)();
-    void (CellDmaManager::*end_dmawait_profile)(unsigned long long *counter);
-    void start_profile();
-    void stop_profile();
-
-
-    void show_dma_wait(Scheduler *s, int cpu);
-
-    void mail_write(memaddr data);
-    void mail_write_finish_list(memaddr data);
-    memaddr mail_read();
-    memaddr task_list_mail_read();
-    void *dma_loadList(Scheduler *s,ListDataPtr list, uint32 mask);
-    void dma_storeList(ListDataPtr, void *buff, uint32 mask);
-    uint32 get_tag();
-    void bound(ListData *);
-    void *get_writebuf(Scheduler *s, ListDataPtr, uint32 size) ;
-
-
-    private:
-
-    void do_start_dmawait_profile();
-    void do_end_dmawait_profile(unsigned long long *counter);
-    void null_start_dmawait_profile();
-    void null_end_dmawait_profile(unsigned long long *counter);
-
-    MailManagerPtr mail_queue;
-
-
-/* end */
-}  ;
-
-#endif
--- a/include/TaskManager/CellScheduler.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,22 +0,0 @@
-#ifndef INCLUDED_CELL_SCHEDULER
-#define INCLUDED_CELL_SCHEDULER
-
-#include "base.h"
-#include "Scheduler.h"
-
-class CellScheduler : public Scheduler {
-public:
-    BASE_NEW_DELETE(CellScheduler);
-
-    void init_impl(int useRefDma);
-
-    void *allocate(int size);
-    void mainMem_alloc(int id, int size);
-    void mainMem_wait(void);
-    uint32 get_tag();
-
-private:
-    int mainMemNum;
-} ;
-
-#endif
--- a/include/TaskManager/CellTaskManagerImpl.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,53 +0,0 @@
-#ifndef INCLUDED_CELL_TASK_MANAGER_IMPL
-#define INCLUDED_CELL_TASK_MANAGER_IMPL
-
-#include "TaskManagerImpl.h"
-#include "FifoTaskManagerImpl.h"
-#ifdef __CERIUM_CELL__
-#include "SpeThreads.h"
-#else
-#include "CpuThreads.h"
-#endif
-
-class CellTaskManagerImpl : public TaskManagerImpl {
-public:
-    /* constructor */
-    CellTaskManagerImpl(int num, Threads *cpus) : TaskManagerImpl(num) {speThreads = cpus;}
-    ~CellTaskManagerImpl();
-
-    /* variables */
-    QueueInfo<TaskList> **taskListInfo;
-    QueueInfo<TaskList> **speTaskList;  // running task
-
-    Threads *speThreads;
-    FifoTaskManagerImpl *ppeManager;
-    int spe_running;
-    int spuIdle;
-    /* functions */
-    // system
-    void init(int spuIdle,int useRefDma, int export_task_log);
-    void run();
-    void poll();
-    void poll1(int spu_limit);
-    void poll2(int spu_limit);
-    void mail_check(int id);
-    TaskListPtr createTaskList();
-    //void set_runTaskList(*QueueInfo<HTask>);
-    void set_runTaskList(QueueInfo<HTask>* activeTaskQueue);
-    void set_NDRange(void* ndr);
-    void sendTaskList();
-    void append_activeTask(HTaskPtr);
-    void show_profile() ;
-    void start_profile() ;
-    void export_task_log() ;
-    void polling();
-    void debug_check_spe_idle(QueueInfo<HTask> * activeTaskQueue, int spe_running_);
-    void print_arch();
-
-private:
-    void send_taskList(int id);
-    void show_dead_lock_info();
-
-};
-
-#endif
--- a/include/TaskManager/CpuThreads.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,49 +0,0 @@
-#ifndef INCLUDED_CPU_THREADS
-#define INCLUDED_CPU_THREADS
-
-#include <pthread.h>
-#include "Threads.h"
-#include "GpuThreads.h"
-#include "TaskManagerImpl.h"
-#include "MainScheduler.h"
-#include "Sem.h"
-
-typedef struct cpu_arg {
-    int cpuid;
-    // should be syncrhonized
-    MainScheduler *scheduler;
-    TaskManagerImpl *manager;
-    SemPtr wait;
-	int useRefDma;
-    
-} cpu_thread_arg_t;
-
-//class GpuThreads;
-
-class CpuThreads : public Threads {
- public:
-    /* constructor */
-    CpuThreads(int num = 1, int useRefDma = 0, int start_id = 0);
-    ~CpuThreads();
-    static void *cpu_thread_run(void *args);
-    
-    /* functions */
-    virtual void init();
-    virtual int get_mail(int speid, int count, memaddr *ret); // BLOCKING
-    virtual int has_mail(int speid, int count, memaddr *ret); // NONBLOCK
-    virtual void send_mail(int speid, int num, memaddr *data); // BLOCKING
-    virtual void add_output_tasklist(int command, memaddr buff, int alloc_size);
-    virtual int is_gpu(int cpuid);
-    virtual void set_NDRange(void *ndr);
-private:
-    /* variables */
-    pthread_t *threads;
-    cpu_thread_arg_t *args;
-    SemPtr wait; //スレッド生成時の待ち用
-    int cpu_num;
-    int use_refdma;
-    int id_offset;
-    GpuThreads *gpu;
-};
-
-#endif
--- a/include/TaskManager/DmaManager.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,48 +0,0 @@
-#ifndef INCLUDED_DMA_MANAGER
-#define INCLUDED_DMA_MANAGER
-
-#include "base.h"
-#include "ListData.h"
-#include "types.h"
-
-enum dma_tag {
-    DMA_READ  = 25,
-    DMA_READ2  = 26,
-    DMA_WRITE = 27,
-//    DMA_READ_IN_LIST  = 29,
-//    DMA_READ_OUT_LIST = 30,
-    DMA_READ_TASKLIST = 31,
-};
-
-class Scheduler;
-
-class DmaManager {
-public:
-    virtual ~DmaManager() {};
-
-    BASE_NEW_DELETE(DmaManager);
-
-    // API for DMA transfer
-    virtual void *dma_load(Scheduler *s, memaddr addr, uint32 size, uint32 mask) { return 0; }
-    virtual void *dma_load1(void *buf, memaddr addr, uint32 size, uint32 mask) { return 0; }
-    virtual void *dma_store(void *buf,memaddr addr, uint32 size, uint32 mask) { return 0; }
-    virtual void free_(void *buf) { free(buf); }
-    virtual void *get_writebuf(Scheduler *s, memaddr addr, uint32 size) { return 0; }
-    virtual void dma_wait(uint32 mask) {}
-    virtual void show_dma_wait(Scheduler *s, int cpu) {}
-    virtual void start_profile() {}
-
-    // API for SPU inbound/outbound mailbox
-    virtual void mail_write(memaddr data) {}
-    virtual void mail_write_finish_list(memaddr data) {}
-    virtual memaddr mail_read() { return 0; }
-    virtual memaddr task_list_mail_read() { return 0; }
-    
-    // API for MFC list DMA transfer
-    virtual void *dma_loadList(Scheduler *s, ListDataPtr list, uint32 mask) { return 0; }
-    virtual void dma_storeList(ListDataPtr, void *buff, uint32 mask) {}
-    virtual uint32 get_tag() { return 0;}
-    virtual void bound(ListData *) {}
-};
-
-#endif
--- a/include/TaskManager/ExportTaskLog.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,28 +0,0 @@
-#ifndef included_exporttasklog
-#define included_exporttasklog
-
-#include <stdio.h>
-#include "TaskLog.h"
-#include "QueueInfo.h"
-
-class ExportTaskLog {
-public:
-    ExportTaskLog(QueueInfo<TaskLog> *_tasklog);
-    virtual ~ExportTaskLog();
-
-public:
-    void open();
-    void printOut();
-    void close();
-
-private:
-    QueueInfo<TaskLog> *tasklog;
-    FILE *fp;
-
-    static const char* const FILENAME;
-
-};
-
-
-
-#endif
--- a/include/TaskManager/FifoDmaManager.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,85 +0,0 @@
-#ifndef INCLUDED_FIFO_DMA_MANAGER
-#define INCLUDED_FIFO_DMA_MANAGER
-
-#include "base.h"
-#include "DmaManager.h"
-
-#ifdef __CERIUM_PARALLEL__
-#include "SynchronizedMailManager.h"
-#else
-#include "MailManager.h"
-#endif
-
-class FifoDmaManager : public DmaManager {
-
-protected:
-    /* variables */
-    MailManagerPtr mail_queue1;
-    MailManagerPtr mail_queue2;
-
-public:
-    BASE_NEW_DELETE(FifoDmaManager);
-
-    FifoDmaManager() {
-#ifdef __CERIUM_PARALLEL__
-        mail_queue1 = new SynchronizedMailManager();
-        mail_queue2 = new SynchronizedMailManager();
-#else
-        mail_queue1 = new MailManager();
-        mail_queue2 = new MailManager();
-#endif
-        start_dmawait_profile = &FifoDmaManager::null_start_dmawait_profile;
-        end_dmawait_profile = &FifoDmaManager::null_end_dmawait_profile;
-    }
-
-    ~FifoDmaManager() {
-	delete mail_queue1;
-	delete mail_queue2;
-    }
-
-	/* variables */
-protected:
-    unsigned long long start_time, stop_time;
-    unsigned long long global_busy_time, global_load_time, global_store_time, global_mail_time;
-    unsigned long long dma_load_time, dma_store_time, dma_loadList_time, dma_storeList_time;
-    unsigned long long mail_read_time, mail_write_time;
-    unsigned long long mail_read_from_host_time, mail_write_from_host_time;
-
-    /* functions */
-public:
-    virtual void *dma_load(Scheduler *s, memaddr addr, uint32 size, uint32 mask);
-    virtual void *dma_load1(void *buf, memaddr addr, uint32 size, uint32 mask);
-    virtual void *dma_store(void *buf, memaddr addr, uint32 size, uint32 mask);
-    virtual void dma_wait(uint32 mask) ;
-    virtual void *get_writebuf(Scheduler *s, memaddr addr, uint32 size) ;
-    void (FifoDmaManager::*start_dmawait_profile)();
-    void (FifoDmaManager::*end_dmawait_profile)(unsigned long long *counter);
-    void start_profile();
-    void stop_profile();
-
-    void show_dma_wait(Scheduler *s, int cpu);
-
-    void mail_write(memaddr data);
-    void mail_write_finish_list(memaddr data);
-    memaddr mail_read();
-    memaddr task_list_mail_read();
-
-    void mail_write_from_host(memaddr data); 
-    memaddr mail_read_from_host();
-    int has_mail_from_host();
-
-    virtual void *dma_loadList(Scheduler *s, ListDataPtr list, uint32 mask);
-    virtual void dma_storeList(ListDataPtr, void *buff, uint32 mask);
-
-    uint32 get_tag();
-    virtual void bound(ListData *);
-
-private:
-    void do_start_dmawait_profile();
-    void do_end_dmawait_profile(unsigned long long *counter);
-    void null_start_dmawait_profile();
-    void null_end_dmawait_profile(unsigned long long *counter);
-
-};
-
-#endif
--- a/include/TaskManager/FifoTaskManagerImpl.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,52 +0,0 @@
-#ifndef INCLUDED_FIFO_TASK_MANAGER_IMPL
-#define INCLUDED_FIFO_TASK_MANAGER_IMPL
-
-#include "TaskManagerImpl.h"
-#include "MainScheduler.h"
-#include "Scheduler.h"
-#include "CpuThreads.h"
-
-class FifoTaskManagerImpl : public TaskManagerImpl {
-public:
-    /* constructor */
-    FifoTaskManagerImpl(int num) : TaskManagerImpl(num) {}
-    ~FifoTaskManagerImpl(void);
-
-    /* variables */
-    int machineNum;
-    QueueInfo<TaskList> *taskListInfo;  
-    QueueInfo<TaskList> *ppeTaskList;  // running task
-
-    MailManager *mailManager;
-    MainScheduler *mainScheduler;
-
-    /* functions */
-    // call by system
-    void init(int spuIdle, int useRefDma, int export_task_log);
-    void init(MainScheduler*, TaskManagerImpl*, int);
-    void poll();  // called from CellTaskManagerImpl
-    void poll1();  // single CPU run called from CellTaskManagerImpl
-    void run();
-    void show_profile();
-    void start_profile();
-    void export_task_log();
-    void polling();
-    TaskListPtr createTaskList();
-
-    void mail_check();
-
-    void set_runTaskList(QueueInfo<HTask>* activeTaskQueue);
-    //void set_runTaskList();
-    void sendTaskList();
-
-    void print_arch();
-    void set_NDRange(void* ndr);
-
-    // call by user
-private:
-    void set_runTaskList1(QueueInfo<HTask>* activeTaskQueue);
-
-};
-
-
-#endif /* INCLUDED_FIFO_TASK_MANAGER_IMPL */
--- a/include/TaskManager/Finish.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,7 +0,0 @@
-#ifndef INCLUDED_SYSTASK_FINISH
-#define INCLUDED_SYSTASK_FINISH
-
-#include "SchedTask.h"
-
-
-#endif
--- a/include/TaskManager/GpuError.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,62 +0,0 @@
-const char* convert_error_status(cl_uint status){
-    static const struct {
-        const cl_uint status;
-        const char *status_string;
-    } Error_Status[] = {
-        {CL_SUCCESS,                         "CL_SUCCESS"}
-        ,{CL_DEVICE_NOT_FOUND,                "CL_DEVICE_NOT_FOUND"}
-        ,{CL_DEVICE_NOT_AVAILABLE,            "CL_DEVICE_NOT_AVAILABLE"}
-        ,{CL_COMPILER_NOT_AVAILABLE,          "CL_COMPILER_NOT_AVAILABLE"}
-        ,{CL_MEM_OBJECT_ALLOCATION_FAILURE,   "CL_MEM_OBJECT_ALLOCATION_FAILURE"}
-        ,{CL_OUT_OF_RESOURCES,                "CL_OUT_OF_RESOURCES"}
-        ,{CL_OUT_OF_HOST_MEMORY,              "CL_OUT_OF_HOST_MEMORY"}
-        ,{CL_PROFILING_INFO_NOT_AVAILABLE,    "CL_PROFILING_INFO_NOT_AVAILABLE"}
-        ,{CL_MEM_COPY_OVERLAP,                "CL_MEM_COPY_OVERLAP"}
-        ,{CL_IMAGE_FORMAT_MISMATCH,           "CL_IMAGE_FORMAT_MISMATCH"}
-        ,{CL_IMAGE_FORMAT_NOT_SUPPORTED,      "CL_IMAGE_FORMAT_NOT_SUPPORTED"}
-        ,{CL_BUILD_PROGRAM_FAILURE,           "CL_BUILD_PROGRAM_FAILURE"}
-        ,{CL_MAP_FAILURE,                     "CL_MAP_FAILURE"}
-        ,{CL_INVALID_VALUE,                   "CL_INVALID_VALUE"}
-        ,{CL_INVALID_DEVICE_TYPE,             "CL_INVALID_DEVICE_TYPE"}
-        ,{CL_INVALID_PLATFORM,                "CL_INVALID_PLATFORM"}
-        ,{CL_INVALID_DEVICE,                  "CL_INVALID_DEVICE"}
-        ,{CL_INVALID_CONTEXT,                 "CL_INVALID_CONTEXT"}
-        ,{CL_INVALID_QUEUE_PROPERTIES,        "CL_INVALID_QUEUE_PROPERTIES"}
-        ,{CL_INVALID_COMMAND_QUEUE,           "CL_INVALID_COMMAND_QUEUE"}
-        ,{CL_INVALID_HOST_PTR,                "CL_INVALID_HOST_PTR"}
-        ,{CL_INVALID_MEM_OBJECT,              "CL_INVALID_MEM_OBJECT"}
-        ,{CL_INVALID_IMAGE_FORMAT_DESCRIPTOR, "CL_INVALID_IMAGE_FORMAT_DESCRIPTOR"}
-        ,{CL_INVALID_IMAGE_SIZE,              "CL_INVALID_IMAGE_SIZE"}
-        ,{CL_INVALID_SAMPLER,                 "CL_INVALID_SAMPLER"}
-        ,{CL_INVALID_BINARY,                  "CL_INVALID_BINARY"}
-        ,{CL_INVALID_BUILD_OPTIONS,           "CL_INVALID_BUILD_OPTIONS"}
-        ,{CL_INVALID_PROGRAM,                 "CL_INVALID_PROGRAM"}
-        ,{CL_INVALID_PROGRAM_EXECUTABLE,      "CL_INVALID_PROGRAM_EXECUTABLE"}
-        ,{CL_INVALID_KERNEL_NAME,             "CL_INVALID_KERNEL_NAME"}
-        ,{CL_INVALID_KERNEL_DEFINITION,       "CL_INVALID_KERNEL_DEFINITION"}
-        ,{CL_INVALID_KERNEL,                  "CL_INVALID_KERNEL"}
-        ,{CL_INVALID_ARG_INDEX,               "CL_INVALID_ARG_INDEX"}
-        ,{CL_INVALID_ARG_VALUE,               "CL_INVALID_ARG_VALUE"}
-        ,{CL_INVALID_ARG_SIZE,                "CL_INVALID_ARG_SIZE"}
-        ,{CL_INVALID_KERNEL_ARGS,             "CL_INVALID_KERNEL_ARGS"}
-        ,{CL_INVALID_WORK_DIMENSION,          "CL_INVALID_WORK_DIMENSION"}
-        ,{CL_INVALID_WORK_GROUP_SIZE,         "CL_INVALID_WORK_GROUP_SIZE"}
-        ,{CL_INVALID_WORK_ITEM_SIZE,          "CL_INVALID_WORK_ITEM_SIZE"}
-        ,{CL_INVALID_GLOBAL_OFFSET,           "CL_INVALID_GLOBAL_OFFSET"}
-        ,{CL_INVALID_EVENT_WAIT_LIST,         "CL_INVALID_EVENT_WAIT_LIST"}
-        ,{CL_INVALID_EVENT,                   "CL_INVALID_EVENT"}
-        ,{CL_INVALID_OPERATION,               "CL_INVALID_OPERATION"}
-        ,{CL_INVALID_GL_OBJECT,               "CL_INVALID_GL_OBJECT"}
-        ,{CL_INVALID_BUFFER_SIZE,             "CL_INVALID_BUFFER_SIZE"}
-        ,{CL_INVALID_MIP_LEVEL,               "CL_INVALID_MIP_LEVEL"}
-        ,{0, NULL}
-    };
-    const char* message;
-
-    for(int i=0; Error_Status[i].status_string !=NULL; i++){
-        if (Error_Status[i].status == status) {
-            message = Error_Status[i].status_string;
-        }
-    }
-    return message;
-}
--- a/include/TaskManager/GpuFunc.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,7 +0,0 @@
-
-enum {
-#include "SysTasks.h"
-    mogyo,
-    Twice,
-    //    Func1,
-};
--- a/include/TaskManager/GpuScheduler.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,56 +0,0 @@
-#ifndef INCLUDED_GPU_SCHEDULER
-#define INCLUDED_GPU_SCHEDULER
-
-#include "Scheduler.h"
-#include "FifoDmaManager.h"
-#include "GpuThreads.h"
-#include "HTask.h"
-#include "TaskManager.h"
-
-#ifdef __APPLE__
-#include <OpenCL/opencl.h>
-#else
-#include <CL/cl.h>
-#endif
-
-class GpuScheduler : public Scheduler {
- public:
-    GpuScheduler();
-    virtual ~GpuScheduler();
-    void init_impl(int useRefDma);
-    void init_gpu();
-    void run();
-    void set_NDRange(void* ndr_);
-    
-    void mail_write_from_host(memaddr data) {
-        fifoDmaManager->mail_write_from_host(data);
-    }
-
-    memaddr mail_read_from_host() {
-        return fifoDmaManager->mail_read_from_host();
-    }
-
-    int has_mail_from_host() {
-        return fifoDmaManager->has_mail_from_host();
-    }
-
-    cl_platform_id platform_id;
-    cl_device_id device_id;
-    cl_uint ret_num_platforms;
-    cl_uint ret_num_devices;
-    cl_context context;
-    cl_command_queue command_queue;
-    cl_int ret;
-    ND_RANGE_T_PTR ndr;
-private:
-    FifoDmaManager *fifoDmaManager;
-    void load_kernel(int cmd);
-
-};
-
-#define GpuSchedRegister(str, filename, functionname)   \
-    gpu_register_task(str, filename, functionname);
-#endif
-
-extern void gpu_register_task(int cmd,const char* filename,const char* functionname);
-
--- a/include/TaskManager/GpuThreads.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,52 +0,0 @@
-#ifndef INCLUDED_GPU_THREADS
-#define INCLUDED_GPU_THREADS
-
-#include <pthread.h>
-#include "Threads.h"
-#include "GpuScheduler.h"
-#include "Sem.h"
-
-#ifdef __APPLE__
-#include <OpenCL/opencl.h>
-#else
-#include <CL/cl.h>
-#endif
-
-class GpuScheduler;
-
-typedef struct gpu_arg {
-    int cpuid;
-    // should be syncrhonized
-    GpuScheduler *scheduler;
-    TaskManagerImpl *manager;
-    SemPtr wait;
-	int useRefDma;
-} gpu_thread_arg_t;
-
-class GpuThreads : public Threads {
- public:
-    /*
-      static GpuThreads* getInstance() {
-      static GpuThreads singleton;
-      return &singleton;
-      }*/
-    GpuThreads(int useRefDma);
-    ~GpuThreads();
-    
-    void init();
-    static void *gpu_thread_run(void *args);
-
-    int get_mail(int speid, int count, memaddr *ret);
-    int has_mail(int speid, int count, memaddr *ret);
-    void send_mail(int speid, int num, memaddr *data);
-    void add_output_tasklist(int command, memaddr buff, int alloc_size);
-    void set_wait(SemPtr);
-    void set_NDRange(void* ndr);
-    
-  private:
-    gpu_thread_arg_t *args;
-    pthread_t *threads;
-    int use_refdma;
-};
-
-#endif
--- a/include/TaskManager/HTask.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,164 +0,0 @@
-#ifndef INCLUDED_HTASK
-#define INCLUDED_HTASK
-
-#include "base.h"
-#include "types.h"
-#include "Task.h"
-#include "TaskList.h"
-#include "TaskQueue.h"
-#include "QueueInfo.h"
-#include "TaskLog.h"
-//#include <stdio.h>
-
-class TaskManagerImpl;
-class SchedTask;
-
-typedef void (*PostFunction)(SchedTask *s, void *read, void *write);
-
-extern QueueInfo<TaskQueue>* taskQueuePool;
-
-/*!
-  @class
-
-  @brief
-
-  Cerium の Task で、spawn() でキューに格納されて順次実行される。
-  cpu の指定があれば並列に実行される。
-  特定の Task を待ち合わせる事が可能。
-  Task の入出力は dma などで copy される。
- */
-
-#include "SimpleTask.h"
-
-class HTask : public SimpleTask {
-public:
-    BASE_NEW_DELETE(HTask);
-
-    QueueInfo<TaskQueue> *wait_me;  // List of task waiting for me
-    QueueInfo<TaskQueue> *wait_i;   // List of task for which I am waiting
-    PostFunction post_func;
-    void *post_arg1;
-    void *post_arg2;
-    CPU_TYPE cpu_type;
-    TaskManagerImpl *mimpl;
-    TaskPtr last;
-
-    int export_task_log;
-    TaskLog *tasklog;
-
-    HTask *waiter;
-    HTask *next;
-    HTask *prev;
-
-    struct htask_flag {
-        unsigned no_auto_free:1;        //      bit 0    auto free flag (0 .. auto, 1 manual)
-        unsigned flip:1;                //      use read write buffers for all
-        unsigned nd_range:1;            //      openCL nd_range
-    } flag;
-
-    void spawn();
-    void wait_for(HTask *);
-    void set_cpu(CPU_TYPE type);
-    void set_post(PostFunction func, void *read, void *write);
-    Task *create_task_array(int task_id, int num_task, int num_param, int num_inData, int num_outData);
-    Task *next_task_array(int task_id, Task *t);
-    Task *next_task_array(int id, Task *t, int param_count, int inData_count, int outData_count);
-    void spawn_task_array(Task *t);
-
-    HTask *init(int cmd, memaddr rbuf, int rs, memaddr wbuf, int ws) {
-        init(cmd);
-        set_input(rbuf, rs);
-        set_output(wbuf, ws);
-        return this;
-    }
-
-    void initOnce() {
-       wait_me = new QueueInfo<TaskQueue>(taskQueuePool);
-       wait_i = new QueueInfo<TaskQueue>(taskQueuePool);
-    }
-
-    void freeOnce() {
-       delete wait_me;
-       delete wait_i;
-    }
-
-    private:
-
-// compatibility
-    public: // functions
-    void set_inData_t(int index, memaddr addr, int size) {
-#ifdef EARLY_TOUCH
-        if ((unsigned long)addr&0xf) {
-          printf("inData is not aligned. command = %d, index = %d, addr = 0x%lx, size = %d\n",
-                 command, index, (unsigned long)addr, size);
-        }
-        char *p = (char *)addr; char b = *p;
-        p = (char *)(addr+size-1); b += *p;
-#endif
-        Task *t = ((TaskList*)rbuf)->tasks;
-        t->set_inData_t(index, addr,size);
-    }
-    void set_outData_t(int index, memaddr addr, int size) {
-#ifdef EARLY_TOUCH
-        if ((unsigned long)addr&0xf) {
-          printf("inData is not aligned. command = %d, index = %d, addr = 0x%lx, size = %d\n",
-                 command, index, (unsigned long)addr, size);
-        }
-        char *p = (char *)addr; char b = *p;
-        p = (char *)(addr+size-1); b += *p;
-#endif
-        Task *t = ((TaskList*)rbuf)->tasks;
-        t->set_outData_t(index, addr,size);
-    }
-    void set_param_t(int index, memaddr param) {
-        Task *t = ((TaskList*)rbuf)->tasks;
-        t->set_param_t(index, param);
-    }
-
-    void no_auto_free() {
-        flag.no_auto_free = 1;
-    }
-    void auto_free() {
-        flag.no_auto_free = 0;
-    }
-
-    void flip() {
-        flag.flip = 1;
-    }
-    void no_flip() {
-        flag.flip = 0;
-    }
-    void nd_range() {
-        flag.nd_range = 1;
-    }
-
-    htask_flag get_flag(){
-        return flag;
-    }
-
-    void init() {
-        next = prev = NULL;
-        waiter = NULL;
-    }
-
-    void init(int cmd) {
-        command  = cmd;
-        flag.no_auto_free = 0;
-        flag.flip = 0;
-        flag.nd_range = 0;
-        self = (memaddr) this;
-
-        post_func = NULL;
-        mimpl     = NULL;
-        cpu_type  = CPU_PPE;
-
-        post_arg1 = NULL;
-        post_arg2 = NULL;
-    }
-#define set_param(index,param) set_param_t(index, (memaddr) (param))
-
-}  __attribute__ ((aligned (DEFAULT_ALIGNMENT)));
-
-typedef HTask* HTaskPtr;
-
-#endif
--- a/include/TaskManager/ListData.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,50 +0,0 @@
-#ifndef INCLUDED_LIST_DATA
-#define INCLUDED_LIST_DATA
-
-#include "base.h"
-#include "types.h"
-
-#define MAX_LIST_DMA_SIZE 8
-
-class ListElement {
-public:
-    BASE_NEW_DELETE(ListElement);
-
-    int size;
-#ifdef __CERIUM_CELL__
-    uint32 addr;  // Cell の仕様なんでどうしようもない...
-    //     PowerPC 64bit だと動かない可能性も高いんだが...
-#else
-    memaddr addr;
-#endif
-};
-
-typedef ListElement* ListElementPtr;
-
-class ListData {
-public:
-    BASE_NEW_DELETE(ListData);
-
-    int length; // The number of data (4)
-    int size;   // Total size of data (4)
-    int *bound;
-    ListElement *element;
-
-    void clear(void) {
-	length = 0;
-	size = 0;
-    }
-
-/*
-    void print(Scheduler *s) {
-	s->printf("inList length %d size %d\n",length, size);
-	for(int i=0;i<length;i++) {
-	    s->printf("inList element[%d] size %d addr %lx\n",i, element[i].size, (unsigned long)element[i].addr);
-	}
-    }
-*/
-};
-
-typedef ListData* ListDataPtr;
-
-#endif
--- a/include/TaskManager/MailManager.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,32 +0,0 @@
-#ifndef INCLUDED_MAIL_MANAGER
-#define INCLUDED_MAIL_MANAGER
-
-#include "types.h"
-
-class MailManager {
-public:
-    /* constructor */
-    MailManager(unsigned int qsize = 32) ;
-
-    virtual ~MailManager();
-
-    /* functions */
-    virtual void send(memaddr data);
-    virtual memaddr recv();
-    virtual int count();
-
-private:
-    /* variables */
-    memaddr *queue;
-    unsigned int size;
-    unsigned int read;
-    unsigned int write;
-    unsigned int mask;
-
-    void calc_mask(unsigned int qsize);
-    void extend();
-}  ;
-
-typedef MailManager *MailManagerPtr;
-
-#endif
--- a/include/TaskManager/MainScheduler.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,29 +0,0 @@
-#ifndef INCLUDED_MAIN_SCHEDULER
-#define INCLUDED_MAIN_SCHEDULER
-
-#include "Scheduler.h"
-#include "FifoDmaManager.h"
-
-class MainScheduler : public Scheduler {
-protected:
-    FifoDmaManager *fifoDmaManager;
-public:
-    ~MainScheduler(void) {}
-    void init_impl(int useRefDma);
-    void mainMem_alloc(int id, int size);
-
-    void mail_write_from_host(memaddr data) {
-	fifoDmaManager->mail_write_from_host(data);
-    }
-
-    memaddr mail_read_from_host() {
-	return fifoDmaManager->mail_read_from_host();
-    }
-
-    int has_mail_from_host() {
-	return fifoDmaManager->has_mail_from_host();
-    }
-
-};
-
-#endif
--- a/include/TaskManager/MemHash.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,31 +0,0 @@
-#ifndef INCLUDED_MEM_HASH
-#define INCLUDED_MEM_HASH
-
-#include "MemorySegment.h"
-
-class MemHash {
-public:
-    MemHash(void);
-
-private:
-    MemorySegmentPtr *table;
-
-public:
-    void clear(void);
-    unsigned int hash(memaddr data);
-    int put(memaddr addr, MemorySegmentPtr ms);
-    MemorySegmentPtr get(memaddr addr);
-    void remove(memaddr addr);
-};
-
-typedef MemHash* MemHashPtr;
-
-const int hashSize = 263;
-//const int hashSize = 1;
-
-const int tableSize = sizeof(MemorySegmentPtr)*hashSize;
-
-#endif
-
-
-
--- a/include/TaskManager/MemIterator.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,53 +0,0 @@
-#ifndef INCLUDED_MEMORY_ITERATOR
-#define INCLUDED_MEMORY_ITERATOR
-
-#include "MemList.h"
-#include "MemorySegment.h"
-#include "AddrList.h"
-#include "SchedTask.h"
-
-enum {
-
-  READ_WRITE,
-  READ,
-  WRITE,
-
-};
-
-class MemIterator {
-public:
-
-    // 走査する アドレスリスト
-    AddrListPtr addr_list;
-
-    // 扱う MemorySegment のリスト
-    MemList *mem_list;
-
-    // ms の stage
-    MemorySegmentPtr read_ms;
-    MemorySegmentPtr exec_ms;
-    MemorySegmentPtr write_ms;
-    MemorySegmentPtr free_ms;
-
-    SchedTask *smanager;
-
-    MemIterator(AddrListPtr add_list, MemList *mem_list, int cmd, SchedTask *smanager);
-    ~MemIterator();
-
-
-    MemorySegmentPtr (MemIterator::*get_ms)(void);
-
-    int hasNext(void);
-
-    MemorySegmentPtr get_read_write_ms(void);
-    MemorySegmentPtr get_read_ms(void);
-    MemorySegmentPtr get_write_ms(void);
-
-    void collect_ms(void);
-    void overwrite_list(AddrListPtr list);
-
-};
-
-typedef MemIterator *MemIteratorPtr;
-
-#endif
--- a/include/TaskManager/MemList.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,36 +0,0 @@
-#ifndef MEMLIST
-#define MEMLIST
-
-#include <stdlib.h>
-#include "MemorySegment.h"
-
-class MemList : public MemorySegment {
-public:
-    MemorySegment* pool;
-    MemorySegment* first;
-    MemorySegment* last;
-
-    // TaskManager 側で create する
-    //MemList* createMemList(uint32 size, uint32 count);
-
-    MemList(MemorySegment* ms) {
-        first = last = this;
-        next = prev = this;
-        pool = ms;
-    }
-
-    ~MemList() {
-        free(pool);
-    }
-
-    void addFirst(MemorySegment* e);
-    void addLast(MemorySegment* e);
-    MemorySegment* getFirst();
-    MemorySegment* getLast();
-    int remove(MemorySegment* e);
-    MemorySegment* poll();
-    void moveToFirst(MemorySegment* e); // or use();
-    MemorySegment* get(int index);
-};
-
-#endif
--- a/include/TaskManager/MemorySegment.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,17 +0,0 @@
-#ifndef MEMLSEG
-#define MEMLSEG
-#include "types.h"
-
-class MemorySegment {
-public:
-    MemorySegment* next;
-    MemorySegment* prev;
-    uint16 tag;
-    uint16 size;
-    memaddr address;
-    void* data;
-};
-
-typedef MemorySegment *MemorySegmentPtr;
-
-#endif
--- a/include/TaskManager/PreRefDmaManager.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,14 +0,0 @@
-#ifndef INCLUDED_PRE_REFERENCED_DMA_MANAGER
-#define INCLUDED_PRE_REFERENCED_DMA_MANAGER
-
-#include "ReferencedDmaManager.h"
-
-class PreRefDmaManager : public ReferencedDmaManager {
-
-public:
-	/* functions */
-    virtual void *dma_load(Scheduler *s, memaddr addr, uint32 size, uint32 mask);
-    virtual void free_(void *buf);
-} ;
-
-#endif/* PRE_REFERENCED_DMA_MANAGER */
--- a/include/TaskManager/QueueInfo.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,335 +0,0 @@
-#ifndef INCLUDED_QUEUE_INFO
-#define INCLUDED_QUEUE_INFO
-
-#include "base.h"
-#include "types.h"
-
-#if 0
-template <typename T> class Queue : T {
-public:
-
-    T();
-
-    T *waiter;
-    T *next;
-    T *prev;
-
-    void initOnce();  // to initialize object in pool
-    void freeOnce();  // to destroy object in pool
-
-    // virual void init();
-};
-#endif
-
-template <typename T> class QueueInfo : public T {
-
-public:
-    /* constructor */
-
-    /** 
-	singleton queuePool constructor 
-	Do not use this as a Queue
-    */
-    QueueInfo<T>(){
-	queueInfoInit();
-    }
-    /** 
-	normal constructor requires
-    */
-    QueueInfo<T>(QueueInfo<T> *p) {
-	queueInfoInit();
-	queuePool = p;
-    }
-
-    BASE_NEW_DELETE(QueueInfo);
-
-    /* functions */
-    T *create();
-
-    void free_(T *queue);
-
-    void addFirst(T* e);
-    void addLast(T* e);
-    T* getFirst();
-    T* getLast();
-    int remove(T* e);
-    T* poll();
-    void moveToFirst(T* e); // or use();
-    T* get(int index);
-    T* find(T *task);
-    int empty();
-    void freePool() ;
-    void freeAll();
-
-    // Iterator
-    T* getNext(T* q) ;
-    int length();
-
-private:
-    /* variables */
-
-    /* we cannot use static in template */
-    /* static */ QueueInfo<T> *queuePool;
-    T* first;
-    T* last;
-
-    /* functions */
-    int extend_pool(int num);
-    void destroy();  
-    void queueInfoInit();
-}  ;
-
-
-
-#ifdef CHECK
-#include <stdio.h>
-#endif
-#include <stdlib.h>
-
-
-/** 
-    Use singleton queuePool constructor 
-    all queueInfo should share this as a pool.
-
-    exteren QueueInfo<H> pool;
-    QueueInfo<H> pool = new QueueInfo<H>();
-
-    use this in non initialize envrionment is wrong.
-*/
-
-template<typename T>void QueueInfo<T>::queueInfoInit() {
-    // 最初の一つは自分
-    first = last = this;
-    this->next = this->prev = this;
-    this->waiter = NULL;
-}
-
-template<typename T>void
-QueueInfo<T>::freePool() { 
-    for(T * p = queuePool->waiter; p; ) {
-	T * next = p->waiter;
-	p->waiter = NULL;
-	p->freeOnce();
-	free(p);
-	p = next;
-    }
-}
-
-/**
-    all pools are shared among QueueInfo (separated by size and type).
-    it automatically extended by 64.
- */
-template<typename T>int
-QueueInfo<T>::extend_pool(int num)
-{
-#ifdef CHECK
-    if (queuePool) fprintf(stderr, "don't use queuePool directly");
-#endif
-
-    T* q = (T*)malloc(sizeof(T)*(num+1)+DEFAULT_ALIGNMENT);
-
-    // First Queue is previous pool
-    q->waiter = this->waiter; 
-    this->waiter = q;
-    q = (T*)ROUND_UP_ALIGN((long)q, DEFAULT_ALIGNMENT);
-    q++;
-
-    /* Connect all free queue in the pool */
-    T* p = q;
-    for (; num-- > 0;) {
-        p->waiter = NULL;
-	p->initOnce();
-        addLast(p);
-	p = (T*)ROUND_UP_ALIGN((long)(p+1),DEFAULT_ALIGNMENT);
-    }
-
-    return 0;
-
-}
-
-/**
- * Task をプールから取って来て返す
- *
- * @param [cmd] タスクコマンド
- */
-template<typename T>T *
-QueueInfo<T>::create()
-{
-    T * q =  queuePool->poll();
-    if (! q)  {
-	queuePool->extend_pool(64);
-	q = queuePool->poll();
-    }
-    q->init();
-    return q;
-}
-
-
-template<typename T>void
-QueueInfo<T>::free_(T * q)
-{
-    q->waiter = NULL;
-    queuePool->addLast(q);
-}
-
-
-/*!
-  QueueInfo<T> は空にならない。最低1個は要素が入っていて
-  1個目は特別扱いする。getFirst すると first->next を返す
- */
-
-/*!
-  最初の1個は特別扱いなので、それの後に追加していく
- */
-template<typename T>void
-QueueInfo<T>::addFirst(T* e)
-{
-    e->prev = first;
-    e->next = first->next;
-    first->next->prev = e;
-    first->next = e;
-}
-
-template<typename T>void
-QueueInfo<T>::addLast(T* e)
-{
-#ifdef CHECK
-    if (find(e)) { 
-	fprintf(stderr,"Add duplicate task %0x\n",(int)e);
-	return; 
-       // ...  
-    }
-#endif
-    e->next = first;
-    e->prev = last;
-    last->next = e;
-    last = e;
-}
-
-template<typename T>T*
-QueueInfo<T>::getFirst()
-{
-    if (empty()) return NULL;
-    return first->next;
-}
-
-template<typename T>T*
-QueueInfo<T>::getLast()
-{
-    if (empty()) return NULL;
-    return last;
-}
-
-template<typename T>int
-QueueInfo<T>::remove(T* e)
-{
-#ifdef CHECK
-    if (!find(e)) { 
-	fprintf(stderr,"Remove non existing task %0x\n",(int)e);
-	return 0; 
-       // ...  
-    }
-#endif
-    e->prev->next = e->next;
-    e->next->prev = e->prev;
-
-    if (first->next == e) {
-	first->next = e->next;
-    }
-    if (last == e) {
-	last = e->prev;
-    }
-
-    e->prev = NULL;
-    e->next = NULL;
-
-    return 1;
-}
-
-/*!
-  リストの先頭を取得および削除する。リストが空の場合は NULL を返す。
- */
-
-template<typename T>T*
-QueueInfo<T>::poll()
-{
-    T* e = first->next;
-    if (e == this) {
-	return NULL;
-    }
-    remove(e);
-    return e;
-}
-
-template<typename T>void
-QueueInfo<T>::moveToFirst(T* e)
-{
-    remove(e);
-    addFirst(e);
-}
-
-/*!
-  リスト内の指定された位置にある要素を返す。
-  要素数を超えた位置を指定した場合 NULL を返す。
- */
-
-template<typename T>T*
-QueueInfo<T>::get(int index)
-{
-    T* e = first->next;
-    for (int i = 0; i < index; i++) {
-	if (e->next == this) return NULL;
-	e = e->next;
-    }
-    return e;
-}
-
-template<typename T>T*
-QueueInfo<T>::find(T* task)
-{
-    T* e = first->next;
-    for(;;) {
-	if (e == this) return NULL;
-	if (e == task) break;
-	e = e->next;
-    }
-    return e;
-}
-
-template<typename T>int
-QueueInfo<T>::empty()
-{
-    return this->next == this;
-}
-
-template<typename T>T*
-QueueInfo<T>::getNext(T* q) 
-{
-    if (q->next==this) return NULL;
-    return q->next;
-}
-
-template<typename T>int
-QueueInfo<T>::length() 
-{
-    int i = 0;
-    if (empty()) return 0;
-    T* e = first;
-    while((e = e->next) != this ) i++;
-    return i;
-}
-
-template<typename T>void
-QueueInfo<T>::freeAll()
-{
-    T* t;
-    while((t=poll())) free_(t);
-}
-
-
-
-/* end */
-
-
-
-#endif
--- a/include/TaskManager/ReferencedDmaManager.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,21 +0,0 @@
-#ifndef INCLUDED_REFERENCED_DMA_MANAGER
-#define INCLUDED_REFERENCED_DMA_MANAGER
-
-#include "FifoDmaManager.h"
-
-class ReferencedDmaManager : public FifoDmaManager {
-
-public:
-	/* functions */
-    virtual void *dma_load(Scheduler *s, memaddr addr, uint32 size, uint32 mask);
-    virtual void *dma_load1(void *buf, memaddr addr, uint32 size, uint32 mask);
-    virtual void *dma_loadList(Scheduler *s, ListDataPtr list, uint32 mask);
-    virtual void *dma_store(void *buf, memaddr addr, uint32 size, uint32 mask);
-    virtual void dma_storeList(ListDataPtr list, void *buff, uint32 mask);
-    virtual void *get_writebuf(Scheduler *s,memaddr addr, uint32 size);
-
-    virtual void free_(void *buff);
-    virtual void bound(ListData *list);
-} ;
-
-#endif/* REFERENCED_DMA_MANAGER */
--- a/include/TaskManager/SchedExit.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,18 +0,0 @@
-#ifndef INCLUDED_SCHED_EXIT
-#define INCLUDED_SCHED_EXIT
-
-#include "base.h"
-#include "Scheduler.h"
-#include "SchedTaskBase.h"
-
-
-class SchedExit : public SchedTaskBase {
-public:
-    BASE_NEW_DELETE(SchedExit);
-    /* functions */
-    SchedTaskBase* next(Scheduler *, SchedTaskBase *);
-    const char * name() { return "Exit" ; };
-    
-};
-
-#endif
--- a/include/TaskManager/SchedMail.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,22 +0,0 @@
-#ifndef INCLUDED_SCHED_MAIL
-#define INCLUDED_SCHED_MAIL
-
-#include "base.h"
-#include "Scheduler.h"
-#include "SchedTaskBase.h"
-
-#include "error.h"
-
-class SchedMail : public SchedTaskBase {
-public:
-    /* constructor */
-    BASE_NEW_DELETE(SchedMail);
-
-    /* functions */
-    SchedTaskBase* next(Scheduler *, SchedTaskBase *);
-    const char * name() { return "Mail" ; };
-
-
-};
-
-#endif
--- a/include/TaskManager/SchedNop.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,20 +0,0 @@
-#ifndef INCLUDED_SCHED_NOP
-#define INCLUDED_SCHED_NOP
-
-#include "base.h"
-#include "Scheduler.h"
-#include "SchedTaskBase.h"
-
-#include "error.h"
-
-class SchedNop : public SchedTaskBase {
-public:
-    BASE_NEW_DELETE(SchedNop);
-
-    /* functions */
-    SchedTaskBase* next(Scheduler *, SchedTaskBase *);
-    const char * name() { return "Nop" ; };
-
-};
-
-#endif
--- a/include/TaskManager/SchedNop2Ready.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,34 +0,0 @@
-#ifndef INCLUDED_SCHED_NOP2READY
-#define INCLUDED_SCHED_NOP2READY
-
-#include "base.h"
-#include "Scheduler.h"
-#include "SchedTaskBase.h"
-#include "SchedNop.h"
-
-#include "error.h"
-
-class SchedNop2Ready : public SchedNop {
-public:
-    /* constructor */
-    SchedNop2Ready(Scheduler*);
-
-    BASE_NEW_DELETE(SchedNop2Ready);
-
-    /* variables */
-    Scheduler* scheduler;
-
-    /* functions */
-    void exec(void);
-    void write(void);
-    SchedTaskBase* next(Scheduler *, SchedTaskBase *);
-    const char * name() { return "Nop2" ; };
-
-
-#if DEBUG
-    void read(void)  { __debug("[SchedNop2Ready:%s]\n", __FUNCTION__); }
-    //void write(void) { __debug("[SchedNop2Ready:%s]\n", __FUNCTION__); }
-#endif
-};
-
-#endif
--- a/include/TaskManager/SchedTask.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,139 +0,0 @@
-#ifndef INCLUDED_SCHED_TASK
-#define INCLUDED_SCHED_TASK
-
-#include "base.h"
-#include "Scheduler.h"
-#include "SchedTaskBase.h"
-#include "ListData.h"
-#include "HTask.h"
-#include "MemList.h"
-
-
-class SchedTask : public SchedTaskBase {
-public:
-    /* constructor */
-    SchedTask();
-    virtual ~SchedTask();
-
-    BASE_NEW_DELETE(SchedTask);
-
-    /* variables */
-
-    /* functions */
-
-    // override
-    void read();
-    void exec();
-    void write();
-    SchedTaskBase* next(Scheduler *, SchedTaskBase *);
-    const char * name() { return "SchedTask" ; };
-
-
-    // タスクの処理は、task_list に登録された C の関数によっておこなう
-
-public:
-    /* functions */
-
-    void init(TaskListPtr _list, TaskPtr _task, 
-	      Scheduler* sc, int tag);
-
-    //---  User API ---
-    int read_size() ;
-    int write_size();
-    void setup_outputData();
-
-    void* get_input(void *buff, int index);
-    void* get_output(void *buff, int index);
-    memaddr get_param(int index);
-    memaddr get_inputAddr(int index);
-    memaddr get_outputAddr(int index);
-    // 書き出しを追加する API がない... 
-    int get_inputSize(int index);
-    int get_outputSize(int index);
-
-    void set_outputSize(int index, int size);
-
-    int get_cpuid();
-
-    void* global_alloc(int id, int size);
-    void* global_get(int id);
-    void global_set(int id, void *addr);
-    void global_free(int id);
-    MemList* createMemList(int size, int count);
-
-    void mainMem_alloc(int id, int size);
-    void mainMem_wait();
-    memaddr mainMem_get(int id);
-
-    MemorySegment * get_segment(memaddr addr, MemList *m);
-    MemorySegment * get_free_segment(memaddr addr, MemList *m);
-    void overwrite_segment(MemorySegment *s, memaddr addr);
-    // uint32 get_tag();
-    void put_segment(MemorySegment *s);
-    void wait_segment(MemorySegment *s);
-
-
-
-    void *allocate(int size);
-    void free_(void *p) ;
-    void free_htask(HTask *p) ;
-
-    void polling();
-
-    /* これは禁止するべき */
-    void *dma_load(void *buf, memaddr addr, uint32 size, uint32 mask);
-    void dma_store(void *buf,memaddr addr, uint32 size, uint32 mask);
-    void dma_wait(uint32 mask);
-    void *get_load_buf(uint32 size) ;
-    void free_load_buf(void *buf) ;
-
-    void show_dma_wait();
-    void start_profile();
-
-
-    /*!
-      SPU用の get_input, get_output
-     */
-    void* get_input(int index) {
-      return get_input(readbuf, index);
-    }
-
-    void* get_output(int index) {
-      return get_output(writebuf, index);
-    }
-
-    /**
-     * swap read / write buffer
-     * output が read buffer の書き換えならば、memcpy せずに
-     * swap するだけで良い。size は同じである必要がある。
-     */
-    void swap() {
-        void * tmp = readbuf;
-        readbuf = writebuf;
-        writebuf = tmp;
-    }
-
-
-    // user
-    HTaskPtr create_task(int cmd);
-    HTaskPtr create_task(int cmd, memaddr r, long rs, memaddr w, long ws);
-    HTaskPtr create_task_array(int id, int num_task, int num_param, int num_inData, int num_outData);
-
-    void set_task_depend(HTaskPtr master, HTaskPtr slave);
-    void spawn_task(HTaskPtr);
-    void set_task_cpu(HTaskPtr, CPU_TYPE);
-    void* allocate(int size,int align);
-    Scheduler* get_scheduler();
-    long get_random();
-
-    int printf(const char * format, ...);
-
-
-
-} ;
-
-
-extern void loadSchedTask(Scheduler *scheduler,TaskPtr task);
-
-#endif
-
--- a/include/TaskManager/SchedTaskBase.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,125 +0,0 @@
-#ifndef INCLUDED_SCHED_TASK_BASE
-#define INCLUDED_SCHED_TASK_BASE
-
-#include "base.h"
-//#include <stdio.h>
-#include <stdlib.h>
-
-class TaskManagerImpl;
-class Scheduler;
-class MemorySegment;
-class MemList;
-class HTask;
-
-class SchedTaskBase {
-public:
-    /* constructor */
-    // void *called ;  // for debug
-    SchedTaskBase() {
-	// called = __builtin_return_address(1);
-    }
-    virtual ~SchedTaskBase() {}
-
-    BASE_NEW_DELETE(SchedTaskBase);
-
-    // noaction in default
-    // virtual void load()  {}
-    virtual void read()  {}
-    virtual void exec()  {}
-    virtual void write() {}
-    virtual SchedTaskBase* next(Scheduler *, SchedTaskBase*) {return 0;}
-
-    virtual void setup_outputData() {};
-    virtual const char * name() { return "Base" ; };
-
-    /* functions */
-    virtual void* get_output(void *buff, int index) { return 0; }
-    virtual void* get_input(void *buff, int index) { return 0;}
-    virtual memaddr get_param(int index) { return 0;}
-    virtual int read_size() { return 0;}
-    virtual int printf(const char * format, ...) {return 0;};
-
-    virtual memaddr get_inputAddr(int index) {return 0;}
-    virtual memaddr get_outputAddr(int index) {return 0;}
-    virtual int get_inputSize(int index) {return 0;}
-    virtual int get_outputSize(int index) {return 0;}
-    virtual void set_outputSize(int index, int size) {};
-
-    virtual int get_cpuid() {return 0;}
-
-    virtual void* global_alloc(int id, int size) {return 0;}
-    virtual void* global_get(int id) {return 0;}
-    virtual void global_set(int id, void *addr) {}
-    virtual void global_free(int id) {}
-    virtual MemList* createMemList(int size, int count) {return 0;}
-
-    virtual void mainMem_alloc(int id, int size) {}
-    virtual void mainMem_wait() {}
-    virtual memaddr mainMem_get(int id) {return 0; }
-
-    virtual MemorySegment * get_segment(memaddr addr, MemList *m) {return 0; }
-    virtual void put_segment(MemorySegment *s) {}
-    virtual void wait_segment(MemorySegment *s) {}
-
-    virtual void *allocate(int size) {return 0; }
-    virtual void free_(void *p)  {}
-    // virtual void polling();
-
-    /* これは禁止するべき */
-    virtual void *dma_load(void *buf, memaddr addr, uint32 size, uint32 mask) {return buf;}
-    virtual void dma_store(void *buf,memaddr addr, uint32 size, uint32 mask) {}
-    virtual void dma_wait(uint32 mask) {}
-
-    virtual void show_dma_wait() {}
-    virtual void start_profile() {}
-    virtual void* allocate(int size,int align) {return 0;}
-    virtual Scheduler* get_scheduler() {return 0;}
-    virtual long get_random() {return 0;}
-    virtual void free_htask(HTask *h) {}
-
-    /* variables */
-
-    // SchedTask は、すべて同じ大きさであるべきなので、継承するクラスには、
-    // 変数を置かない。ここに、すべて置く。virtual も含めて。
-
-    // Task を実行するスケジューラ自身
-    Scheduler *scheduler;
-    // Task を作成管理するマネージャー
-    TaskManagerImpl *manager;
-    DmaManager* connector;
-
-    TaskPtr atask;
-
-    // 現在スケジューラが実行している TaskList と、このタスクに対応する Task
-    TaskListPtr list;
-    // Task の、Tasklist での位置
-    TaskPtr cur_index;
-
-    int tag;
-
-    memaddr waiter;
-
-    /**
-     * read データ、write 用のバッファ
-     * readbuf には タスク登録時に設定した入力データが入っている。
-     * writebuf にデータを描き込んでおくと、
-     * タスク登録時に設定した出力先に書き込む
-     */
-    void *readbuf;
-    void *writebuf;
-#define DefaultBoundSize (8)
-    int din[DefaultBoundSize];
-    int dout[DefaultBoundSize];
-
-    /* system call */
-
-    FILE *stdout_;
-    FILE *stderr_;
-    FILE *stdin_;
-
-    ListData inListData;
-    ListData outListData;
-
-}  ;
-
-#endif
--- a/include/TaskManager/SchedTaskList.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,30 +0,0 @@
-#ifndef INCLUDED_SCHED_TASKLIST
-#define INCLUDED_SCHED_TASKLIST
-
-#include "base.h"
-#include "Scheduler.h"
-#include "SchedTask.h"
-#include "TaskList.h"
-
-#include "error.h"
-
-class SchedTaskList : public SchedTask {
-public:
-    /* constructor */
-    SchedTaskList(memaddr addr, Scheduler *sched, int tag);
-
-    BASE_NEW_DELETE(SchedTaskList);
-
-    /* override functions */
-    void read();
-    void exec();
-    void write();
-    const char * name() { return "TaskList" ; };
-
-
-
-};
-
-
-#endif
-
--- a/include/TaskManager/Scheduler.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,240 +0,0 @@
-#ifndef INCLUDED_SCHEDULER
-#define INCLUDED_SCHEDULER
-
-#include <stdlib.h>
-#include <stdarg.h>
-#include "base.h"
-#include "TaskList.h"
-#include "ListData.h"
-#include "DmaManager.h"
-#include "SchedTaskBase.h"
-#include "MemList.h"
-#include "MemHash.h"
-#include "types.h"
-
-#ifdef __CERIUM_GPU__
-#ifdef __APPLE__
-#include <OpenCL/opencl.h>
-#else
-#include <CL/cl.h>
-#endif
-#endif
-
-#define MAX_USER_TASK 100
-#define MAX_SYSTEM_TASK 2
-#define MAX_TASK_OBJECT MAX_USER_TASK + MAX_SYSTEM_TASK
-#define MAX_GLOBAL_AREA 32
-#define MAX_MAINMEM_AREA 32
-
-class SchedTaskBase;
-class SchedTask;
-class SchedTaskList;
-class TaskManagerImpl;
-class HTask;
-
-typedef int (*TaskObjectRun)(SchedTask* smanager, void* r, void *w);
-
-typedef struct gpu_task_object {
-#ifdef __CERIUM_GPU__
-    cl_program *program;
-#endif
-} GpuTaskObject;
-
-// Task Object Table
-//  this is named TaskObjectRun but it is not an object.
-//  It is a pointer to an object creation function
-//  大きいので、SPEには置かない方が本当は良い...
-//  get_segment で取って来るのが、おそらくは正しい。
-typedef struct task_object {
-    CPU_TYPE cpu_type;
-    TaskObjectRun run;
-    memaddr location;            // location address in a.out
-    memaddr end;
-    uint32 entry_offset;        // offset for create();
-    MemorySegment *segment;
-    const char *name;
-    void (*load)(Scheduler *,int);
-    void (*wait)(Scheduler *,int);
-
-    GpuTaskObject *gputask;
-
-}  __attribute__ ((aligned (DEFAULT_ALIGNMENT))) //sizeはどれくらい?
-      TaskObject, *TaskObjectPtr;
-
-extern "C" {
-    extern long random();
-}
-
-class Scheduler {
-private:
-    TaskManagerImpl* manager_tmp;
-
-public:
-    virtual ~Scheduler();
-    BASE_NEW_DELETE(Scheduler);
-
-    /* variables */
-    int id;
-    MemHash *hash;
-
-    // double buffering
-    TaskListPtr buff_taskList[2];
-
-    int buffFlag_taskList;
-
-    /* GlobalMemoryList */
-    /* global among Tasks in the same CPU */
-    void* globalList[MAX_GLOBAL_AREA];
-
-    /* MainMemory Allocate Command List */
-    memaddr mainMemList[MAX_MAINMEM_AREA];
-
-    /* Code Area */
-    MemList *code_segment_pool;
-
-    DmaManager* connector;
-    TaskManagerImpl* manager;
-
-
-    /* functions */
-    void init(TaskManagerImpl *m, int useRefDma=0, int export_task_log=0);
-    virtual void run(){};
-    void run(SchedTaskBase* task1);
-
-    virtual void init_impl(int useRefDma) {};
-    void finish();
-
-    TaskListPtr get_curListBuf();
-    TaskListPtr get_renewListBuf();
-
-    void set_backupTaskList(TaskListPtr cur_taskList);
-    void set_backupTaskListIndex(int cur_index);
-    SchedTaskList* get_nextRenewTaskList();
-    TaskListPtr get_backupTaskList();
-    int get_backupTaskListIndex();
-
-
-    /* GlobalMemory */
-    void* global_alloc(int id, int size);
-    void* global_get(int id);
-    void global_set(int id, void *addr);
-    void global_free(int id);
-    //MemList* createMemList(int size, int count);
-    MemList* createMemList(int size, int count);
-    void free_(void *p) { free(p); }
-
-    virtual void mainMem_alloc(int id, int size) {};
-    virtual void mainMem_wait() {};
-    memaddr mainMem_get(int id);
-
-    MemorySegment * get_segment(memaddr addr, MemList *m);
-    MemorySegment * get_segment(memaddr addr, MemList *m, int size);
-    MemorySegment * get_free_segment(memaddr addr, MemList *m);
-    void overwrite_segment(MemorySegment *s, memaddr addr);
-
-    void allocate_code_segment(int size, int count,struct tbl *table);
-
-    void put_segment(MemorySegment *s);
-    void wait_segment(MemorySegment *s);
-
-    /* manager */
-
-    void set_manager(TaskManagerImpl *m) {
-      manager = m;
-    };
-
-    /* user */
-
-    long get_random() ;
-    Scheduler *get_scheduler() { return this; };
-    int printf(const char *format, ...);
-    int vprintf0(const char *format, va_list ap);
-
-}  ;
-
-extern void register_task(int cmd, TaskObjectRun run, const char *str);
-extern void register_dynamic_task(int cmd,
-    memaddr start, int size, TaskObjectRun run,
-        int entry_offset,
-        const char *str);
-
-struct tbl {
-    unsigned int vma;
-    unsigned int size;
-    unsigned int file_offset;
-    unsigned int buf;
-};
-
-extern TaskObject task_list[MAX_TASK_OBJECT];
-
-int null_run(SchedTask* smanager, void* r, void *w);
-void null_loader(Scheduler *m, int task_id);
-
-extern int entry_cmd[MAX_TASK_OBJECT];
-
-inline void
-loadSchedTask(Scheduler *scheduler,int command)
-{
-    task_list[command].load(scheduler,command);
-}
-
-#endif
-
-
-
-#define SchedConstructor(str)                                           \
-    str() {}                                                            \
-    BASE_NEW_DELETE(str)                                                \
-
-#define SchedDefineTask(str)  SchedDefineTask1(str,run)                                            \
-
-#define SchedDefineTask1(str,run)                                            \
-    static int run(SchedTask *smanager, void *rbuf, void *wbuf); \
-    extern "C" { \
-    int runTask_##str(SchedTask *smanager, void *rbuf, void *wbuf) \
-    {                                                                   \
-        return run(smanager, rbuf, wbuf); \
-    } \
-    }
-
-#define SchedExternTask(str)                                            \
-    extern "C" { \
-        extern int runTask_##str(SchedTask *manager, void *rbuf, void *wbuf)   ; \
-    }
-
-#define SchedRegisterTask(cmd, str)             \
-    register_task(cmd, runTask_##str, #str);
-
-#define SchedRegister(str)             \
-    register_task(str, runTask_##str, #str);
-
-#define SchedDefineDynamicTask(str,segment)                             \
-    SchedDefineTask(str)
-
-#ifndef NO_OVERLAY
-#define SchedExternDynamicTask(str,segment)                             \
-    extern "C" { \
-        extern unsigned long long _EAR_; \
-        extern struct tbl _ovly_table[]; \
-        extern int runTask_##str(SchedTask *manager, void *rbuf, void *wbuf)   ; \
-    }
-#else
-#define SchedExternDynamicTask(str,segment) SchedExternTask(str)
-#endif
-
-
-#ifndef NO_OVERLAY
-#define SchedRegisterDynamicTask(cmd, str, segment)                    \
-    register_dynamic_task(cmd,  (memaddr)(_EAR_+_ovly_table[segment].file_offset), \
-                     _ovly_table[segment].size, \
-                    runTask_##str, \
-                                                  runTask_##str##_offset, \
-                #str);
-#define SchedRegisterDynamic(str, segment) SchedRegisterDynamicTask(str, str, segment)
-#else
-#define SchedRegisterDynamicTask(cmd, str, segment) SchedRegisterTask(cmd, str)
-#define SchedRegisterDynamic(str, segment) SchedRegisterDynamicTask(str, str, segment)
-#endif
-
-
-/* end */
--- a/include/TaskManager/Sem.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,27 +0,0 @@
-#ifndef INCLUDED_SEM
-#define INCLUDED_SEM
-
-#include <pthread.h>
-
-typedef struct sem_t {
-	volatile int value;		//セマフォ変数
-	pthread_mutex_t mutex;	//セマフォ操作用のロック
-	pthread_cond_t cond;	//待ち合わせ用の条件変数
-} sem_t, *sem_ptr;
-
-class Sem {
-public:
-	/* constructor */
-	Sem(int value);
-	~Sem();
-	void sem_p();
-	void sem_v();
-	int  count();
-	/* variables */
-private:
-	sem_t *sem;
-};
-
-typedef Sem *SemPtr;
-
-#endif /* INCLUDED_SEM */
--- a/include/TaskManager/SemMailManager.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,37 +0,0 @@
-#ifndef INCLUDED_SEM_MAIL_MANAGER
-#define INCLUDED_SEM_MAIL_MANAGER
-
-#include <pthread.h>
-#include "MailManager.h"
-#include "types.h"
-#include "Sem.h"
-
-class SemMailManager : public MailManager {
-public:
-    /* constructor */
-    SemMailManager(unsigned int qsize = 32) ;
-
-    ~SemMailManager();
-
-    /* functions */
-    void send(memaddr data);
-    memaddr recv();
-    int count();
-
-private:
-    /* variables */
-    memaddr *queue;
-    SemPtr queue_remain;
-    SemPtr queue_count;
-    unsigned int size;
-    unsigned int read;
-    unsigned int write;
-    unsigned int mask;
-
-    void calc_mask(unsigned int qsize);
-    void extend();
-}  ;
-
-typedef SemMailManager *SemMailManagerPtr;
-
-#endif
--- a/include/TaskManager/ShowTime.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,7 +0,0 @@
-#ifndef INCLUDED_TASK_SHOW_TIME
-#define INCLUDED_TASK_SHOW_TIME
-
-#include "SchedTask.h"
-
-
-#endif
--- a/include/TaskManager/SimpleTask.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,42 +0,0 @@
-#ifndef INCLUDED_SIPMLE_TASK
-#define INCLUDED_SIPMLE_TASK
-
-#include "base.h"
-#include "types.h"
-
-#define MAX_PARAMS 8
-
-class SimpleTask {
-public: // variables
-
-    BASE_NEW_DELETE(SimpleTask);
-    int command;         // 4 byte
-    memaddr self;         // 4 byte (or 8byte on 64bit mode)
-
-    memaddr rbuf;
-    memaddr wbuf;
-    int  r_size;
-    int  w_size;
-    memaddr from;
-    memaddr param;       //  sizeof(SimpleTask)==32
-
-
-public: // functions
-    SimpleTask() {};
-
-    SimpleTask(int r, memaddr read, int w, memaddr write) {
-	r_size = r; rbuf = read;
-	w_size = w; wbuf = write;
-    };
-
-    void set_input(memaddr i,int size) { r_size = size; rbuf= i; }
-    void set_output(memaddr o,int size) { w_size = size; wbuf= o; } 
-    void set_param(memaddr data) { param = data; }
-    memaddr get_param() { return param; }
-
-} __attribute__ ((aligned (DEFAULT_ALIGNMENT)));
-
-typedef SimpleTask *SimpleTaskPtr;
-
-#endif
-
--- a/include/TaskManager/SpeTaskManagerImpl.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,46 +0,0 @@
-#ifndef INCLUDED_SPE_TASK_MANAGER_IMPL
-#define INCLUDED_SPE_TASK_MANAGER_IMPL
-
-#include "TaskManagerImpl.h"
-#include "MainScheduler.h"
-#include "Scheduler.h"
-#include "TaskList.h"
-
-class SpeTaskManagerImpl : public TaskManagerImpl {
-public:
-    /* constructor */
-    BASE_NEW_DELETE(SpeTaskManagerImpl);
-
-    SpeTaskManagerImpl() ;
-    ~SpeTaskManagerImpl();
-
-    /* functions */
-    // call by system
-    void init(int spuIdle,int useRefDma, int export_task_log);
-    void run();
-    void start_profile();
-    void show_profile();
-    void export_task_log();
-    HTaskPtr create_task(int cmd,void *from);
-    HTaskPtr create_task(int cmd, memaddr rbuf, long r_size, memaddr wbuf, long w_size,void *from);
-    HTaskPtr create_task_array(int id, int num_task, int num_param, int num_inData, int num_outData,void *from);
-
-    TaskListPtr createTaskList() { return 0; }
-    void set_task_depend(HTaskPtr master, HTaskPtr slave);
-    void spawn_task(HTaskPtr);
-    void set_task_cpu(HTaskPtr, CPU_TYPE);
-    void polling() {}
-    void free_htask(HTaskPtr htask) {}
-    void print_arch();
-    void set_NDRange(void* ndr){}
-#ifdef __CERIUM_GPU__
-    
-    SpeTaskManagerImpl(int i);
-    void append_activeTask(HTask* p);
-    void append_waitTask(HTask* p);
-    
-#endif
-}  ;
-
-
-#endif /* INCLUDED_SPE_TASK_MANAGER_IMPL */
--- a/include/TaskManager/SpeThreads.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,40 +0,0 @@
-#ifndef INCLUDED_SPE_THREADS
-#define INCLUDED_SPE_THREADS
-
-#include <libspe2.h>
-#include <pthread.h>
-#include "Threads.h"
-
-#define SPE_ELF "spe-main"
-
-typedef struct arg {
-    int speid;
-    spe_context_ptr_t ctx;
-} thread_arg_t;
-
-
-class SpeThreads : public Threads {
-public:
-    /* constructor */
-    SpeThreads(int num = 1);
-    ~SpeThreads(void);
-
-    /* functions */
-    void init(void);
-    int get_mail(int speid, int count, memaddr *ret); // BLOCKING
-    int has_mail(int speid, int count, memaddr *ret); // NONBLOCK
-    void send_mail(int speid, int num, memaddr *data); // BLOCKING
-    static void *spe_thread_run(void *arg);
-    static void *frontend_thread_run(void *arg);
-    void add_output_tasklist(int command, memaddr buff, int alloc_size);
-
-private:
-    /* variables */
-    spe_program_handle_t *spe_handle;
-    spe_context_ptr_t *spe_ctx;
-    pthread_t *threads;
-    thread_arg_t *args;
-    int cpu_num;
-};
-
-#endif
--- a/include/TaskManager/Start.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,7 +0,0 @@
-#ifndef INCLUDED_SYSTASK_START
-#define INCLUDED_SYSTASK_START
-
-#include "SchedTask.h"
-
-
-#endif
--- a/include/TaskManager/SynchronizedMailManager.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,37 +0,0 @@
-#ifndef INCLUDED_SYNC_MAIL_MANAGER
-#define INCLUDED_SYNC_MAIL_MANAGER
-
-#include <pthread.h>
-#include "MailManager.h"
-#include "types.h"
-#include "Sem.h"
-
-class SynchronizedMailManager : public MailManager {
-public:
-    /* constructor */
-    SynchronizedMailManager(unsigned int qsize = 32) ;
-
-    ~SynchronizedMailManager();
-
-    /* functions */
-    void send(memaddr data);
-    memaddr recv();
-    int count();
-
-private:
-    /* variables */
-    memaddr *queue;
-    SemPtr queue_remain;
-    SemPtr queue_count;
-    unsigned int size;
-    unsigned int read;
-    unsigned int write;
-    unsigned int mask;
-
-    void calc_mask(unsigned int qsize);
-    void extend();
-}  ;
-
-typedef SynchronizedMailManager *SynchronizedMailManagerPtr;
-
-#endif
--- a/include/TaskManager/SysFunc.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,8 +0,0 @@
-#ifndef SYSFUNCH
-#define SYSFUNCH
-
-enum systask {
-#include "SysTasks.h"
-};
-
-#endif
--- a/include/TaskManager/SysTask.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,1 +0,0 @@
-extern void systask_register();
--- a/include/TaskManager/SysTasks.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,5 +0,0 @@
-StartTask,
-FinishTask,
-ShowTime,
-StartProfile,
-#define Dummy StartTask
--- a/include/TaskManager/Task.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,149 +0,0 @@
-#ifndef INCLUDED_TASK
-#define INCLUDED_TASK
-
-#include "base.h"
-#include "types.h"
-#include "ListData.h"
-#include "SimpleTask.h"
-
-class SchedTask;
-class Scheduler;
-
-class Task {
- public: // variables
-    int task_size;
-    int command;
-    int param_count;
-    int inData_count;
-    int outData_count;
-    int inData_offset;
-    int outData_offset;
-    void *data[] __attribute__ ((aligned (DEFAULT_ALIGNMENT))); 
-
- public: // functions
-
-    void print(Scheduler *s);
-
-    memaddr *param(int index) {
-        memaddr p =  (memaddr)data + sizeof(memaddr)*index;
-        return (memaddr *)p;
-    }
-
-    ListElement *inData(int index) {
-        memaddr p = (memaddr)data + inData_offset;
-        p += sizeof(ListElement)*index;
-        return (ListElement*)p;
-    }
-
-    ListElement *outData(int index) {
-        memaddr p = (memaddr)data + outData_offset;
-        p += sizeof(ListElement)* index;
-        return (ListElement*)p;
-    }
-
-    static int calc_size(int params, int ins, int outs) {
-        int size = round_up16(sizeof(Task))
-            + round_up16(sizeof(memaddr)*params)
-            + round_up16(sizeof(ListElement)*ins)
-            + round_up16(sizeof(ListElement)*outs);
-        return size;
-    }
-
-    void init(int task_id, int params, int ins, int outs) {
-        set_task_id(task_id);
-        param_count = params;
-        inData_count = ins;
-        outData_count = outs;
-        inData_offset = round_up16(sizeof(memaddr)*params);
-        outData_offset = round_up16(inData_offset+sizeof(ListElement)*ins);
-        //task_size = round_up16(sizeof(Task)+outData_offset+sizeof(ListElement)*outs);
-
-        task_size = round_up16(sizeof(Task))
-            + round_up16(sizeof(memaddr)*params)
-            + round_up16(sizeof(ListElement)*ins)
-            + round_up16(sizeof(ListElement)*outs);
-
-    }
-
-    int size() {
-        return task_size;
-    }
-
-    int inData_total_size() {
-        int size = 0;
-        ListElement *in= inData(0);
-        for(int i=0; i< inData_count; i++) {
-            size += in[i].size;
-        }
-        return size;
-    }
-    int outData_total_size() {
-        int size = 0;
-        ListElement *out= outData(0);
-        for(int i=0; i< outData_count; i++) {
-            size += out[i].size;
-        }
-        return size;
-    }
-
-    void set_inData_t( int index, memaddr addr, int size) {
-        ListElement *list = inData(index);
-#ifdef EARLY_TOUCH
-        if ((unsigned long)addr&0xf) {
-            printf("inData is not aligned. command = %d, index = %d, addr = 0x%lx, size = %d\n",
-                   command, index, (unsigned long)addr, size);
-        }
-        char *p = (char *)addr; int b = *p;
-        p = (char *)(addr+size-1); b += *p;
-#endif
-
-#ifdef __CERIUM_CELL__
-        list->addr = (uint32)addr;
-#else
-        list->addr = addr;
-#endif
-        list->size = size;
-    }
-
-    void set_outData_t(int index, memaddr addr, int size) {
-        ListElement *list = outData(index);
-#ifdef EARLY_TOUCH
-        if ((unsigned long)addr&0xf) {
-            printf("inData is not aligned. command = %d, index = %d, addr = 0x%lx, size = %d\n",
-                   command, index, (unsigned long)addr, size);
-        }
-        char *p = (char *)addr; int b = *p;
-        p = (char *)(addr+size-1); b += *p;
-#endif
-#ifdef __CERIUM_CELL__
-        list->addr = (uint32)addr;
-#else
-        list->addr = addr;
-#endif
-        list->size = size;
-    }
-    void set_task_id(int id) { command = id; }
-    void set_param_t(int index, memaddr param) {
-        memaddr *p = (memaddr*)this->param(index);
-        *p = param;
-    }
-
-    Task * next()
-    {
-        char *p = (char*)this;
-        p += size();
-        return (Task*)p;
-    }
-
-
-#define set_param(index,param) set_param_t(index, (memaddr) (param))
-
-#define set_inData(index, addr, size)               \
-    set_inData_t(index, (memaddr)(addr), (size));
-#define set_outData(index, addr, size)              \
-    set_outData_t(index, (memaddr)(addr), (size));
-} __attribute__ ((aligned (DEFAULT_ALIGNMENT))) ;
-
-typedef Task* TaskPtr;
-
-#endif
--- a/include/TaskManager/TaskList.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,34 +0,0 @@
-#ifndef INCLUDED_TASKLIST
-#define INCLUDED_TASKLIST
-
-#include "base.h"
-#include "Task.h"
-
-class HTask;
-
-#define TASK_MAX_SIZE 31
-
-class TaskList { // 1024 byte 
-public:
-    BASE_NEW_DELETE(TaskList);
-
-    long lastTask; // 4 byte
-    TaskList *next; // 4 byte
-    TaskList *prev; // 4 byte
-    TaskList *waiter; // 4 byte
-    HTask *self; // 4 byte
-    long dummy[3]; // 16 byte
-    Task tasks[TASK_MAX_SIZE]; // 32*TASK_MAX_SIZE
-    
-
-    TaskPtr last() { return (TaskPtr)(((memaddr)tasks)+lastTask); }
-    void set_last(Task *t) { lastTask = ((memaddr)t) - ((memaddr)tasks); }
-    void init() { lastTask = ((memaddr)&tasks[TASK_MAX_SIZE])-(memaddr)(tasks); waiter=this; }
-    void initOnce() { }
-    void freeOnce() {}
-
-} ;
-
-typedef TaskList* TaskListPtr;
-
-#endif
--- a/include/TaskManager/TaskLog.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,51 +0,0 @@
-#ifndef INCLUDED_TASKLOG
-#define INCLUDED_TASKLOG
-
-#include "QueueInfo.h"
-
-struct waitTask {
-    int task_id;
-    int cmd;
-
-    waitTask *next;
-    waitTask *prev;
-    waitTask *waiter;
-};
-
-static int task_id;
-
-class TaskLog {
-public:
-    /* variables */
-    int mtask_id;
-    int cmd;
-    QueueInfo<waitTask> wait_for_list;
-    unsigned long long create_time;
-    unsigned long long execute_time;
-    unsigned long long finish_time;
-
-    TaskLog *next;
-    TaskLog *prev;
-    TaskLog *waiter;
-
-    /* constructor */
-    TaskLog() {
-        mtask_id = task_id;
-        task_id++;
-        create_time = 0;
-        execute_time = 0;
-        finish_time = 0;
-    }
-
-    void set_cmd(int _cmd) {
-        cmd = _cmd;
-    }
-
-
-private:
-    // Unique id
-
-
-};
-
-#endif
--- a/include/TaskManager/TaskManager.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,59 +0,0 @@
-#ifndef INCLUDED_TASK_MANAGER
-#define INCLUDED_TASK_MANAGER
-
-#include "TaskManagerImpl.h"
-#include "MemList.h"
-#include "HTask.h"
-
-class Scheduler;
-class MemList;
-
-typedef struct nd_range {
-    cl_uint dimension;
-    size_t gws[3];
-    size_t lws[3];
-} ND_RANGE_T, *ND_RANGE_T_PTR;
-
-class TaskManager {
-public:
-    /* constructor */
-    TaskManager(int num); // The number of threads
-    ~TaskManager();
-
-    /* variables */
-    TaskManagerImpl *m_impl;
-    void (*tm_end)(TaskManager *manager);
-    ND_RANGE_T_PTR ndr;
-
-    /* user function */
-    HTaskPtr create_task(int cmd);
-    HTaskPtr create_task(int cmd, memaddr r, long rs, memaddr w, long ws);
-    HTaskPtr create_task_array(int id, int num_task, int num_param, int num_inData, int num_outData);
-
-    void run();
-    void *allocate(int size);
-    void set_TMend(void (*endf)(TaskManager *manager));
-    int get_cpuNum();
-    int get_random();
-    Scheduler *get_scheduler();
-    void set_NDRange(ND_RANGE_T_PTR ndr) ;
-    MemList* createMemList(int size, int count);
-
-    void start_profile() { m_impl->start_profile(); }
-    void show_profile() { m_impl->show_profile(); }
-    void export_task_log() { m_impl->export_task_log(); }
-
-    SchedTask *get_schedTask() {
-    return m_impl->schedTaskManager;
-    }
-
-    /* functions */
-    void init(int spuIdle, int export_task_log, int useRefDma);
-    void finish();
-    void error(const char* str);
-private:
-    int machineNum;
-}  ;
-
-#endif
-
--- a/include/TaskManager/TaskManagerImpl.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,119 +0,0 @@
-#ifndef INCLUDED_TASK_MANAGER_IMPL
-#define INCLUDED_TASK_MANAGER_IMPL
-
-#include "MailManager.h"
-#include "ListData.h"
-#include "QueueInfo.h"
-#include "TaskQueue.h"
-#include "HTask.h"
-#include "Scheduler.h"
-#include "TaskLog.h"
-#include <OpenCL/opencl.h>
-class MemList;
-
-extern QueueInfo<TaskQueue> *taskQueuePool ;
-extern QueueInfo<HTask> *htaskPool ;
-extern QueueInfo<TaskList> *taskListPool;
-extern QueueInfo<TaskLog> *taskLogQueue;
-
-class TaskManagerImpl {
- public:
-
-    /* variables */
-    int machineNum;
-    QueueInfo<HTask> *activeTaskQueue;
-    QueueInfo<HTask> *waitTaskQueue;
-
-    QueueInfo<TaskQueue> *taskQueueImpl;
-    QueueInfo<HTask> *htaskImpl;
-
-    SchedTask *schedTaskManager;
-    Scheduler *scheduler;
-    TaskManagerImpl *others;
-    int _export_task_log;
-
-    /* constructor */
-    TaskManagerImpl(int num = 0) ;
-
-    virtual ~TaskManagerImpl() { }
-
-    /* functions */
-    // system
-    virtual void init(int,int,int) = 0;
-    virtual void run() = 0;
-    virtual void start_profile() = 0;
-    virtual void show_profile() = 0;
-    virtual void export_task_log(){}
-    virtual void append_activeTask(HTaskPtr);
-    virtual void append_waitTask(HTaskPtr);
-    virtual void polling() = 0;
-    virtual void print_arch() = 0;
-    virtual void set_NDRange(void*) = 0;
-    void check_task_finish(HTaskPtr task, QueueInfo<HTask> *wait_queue);
-    void check_task_list_finish(SchedTask *s, TaskListPtr list, QueueInfo<HTask> *wait_queue);
-
-    void systask_init();
-
-    // user
-    virtual HTaskPtr create_task(int cmd,void *from);
-    virtual HTaskPtr create_task(int cmd, memaddr rbuf, long r_size, memaddr wbuf, long w_size,void *from);
-    virtual HTaskPtr create_task_array(int id, int num_task, int num_param, int num_inData, int num_outData,void *from);
-    virtual TaskListPtr createTaskList() = 0;
-
-    const char *get_task_name(int cmd);
-    const char *get_task_name(TaskPtr task);
-    const char *get_task_name(SimpleTaskPtr simpletask);
-    const char *get_task_name(SchedTaskBase *schedtask);
-    const char *get_task_name(HTaskPtr htask);
-    const char *get_task_name(HTaskPtr htask, int index);
-    virtual void set_task_depend(HTaskPtr master, HTaskPtr slave);
-    virtual void spawn_task(HTaskPtr);
-    virtual void set_task_cpu(HTaskPtr, CPU_TYPE);
-    void set_taskList(HTaskPtr htask, QueueInfo<TaskList> * taskList);
-    
-    void free_htask(HTaskPtr htask) {
-#if !defined(__SPU__)
-        if (htask->self) {
-            htask->flag.no_auto_free = 0;
-            return;
-        }
-        htaskImpl->free_(htask);
-#endif
-    }
-
-    void* allocate(int size, int alignment)
-    {
-
-        void *buff = 0;
-        if (size==0) return 0;
-#if defined(__SPU__) || ! defined(HAS_POSIX_MEMALIGN)
-        buff =  malloc(size);
-#else
-        posix_memalign(&buff, alignment, size);
-#endif
-        if (buff==0)
-            get_scheduler()->printf("Can't allocate memory\n");
-        return buff;
-    }
-    
-    void* allocate(int size)
-    {
-        
-        void *buff = 0;
-        if (size==0) return 0;
-#if defined(__SPU__) || ! defined(HAS_POSIX_MEMALIGN)
-        buff =  malloc(size);
-#else
-        posix_memalign(&buff, DEFAULT_ALIGNMENT, size);
-#endif
-        if (buff==0)
-            get_scheduler()->printf("Can't allocate memory\n");
-        return buff;
-    }
-
-    Scheduler* get_scheduler() { return scheduler; }
-    void set_scheduler(Scheduler *s) {  scheduler = s; }
-    
-}  __attribute__ ((aligned (DEFAULT_ALIGNMENT)));
-extern void error(const char* error_message);
-#endif
--- a/include/TaskManager/TaskQueue.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,38 +0,0 @@
-#ifndef INCLUDED_TASK_QUEUE
-#define INCLUDED_TASK_QUEUE
-
-#include "base.h"
-#include "types.h"
-
-class HTask;
-
-class TaskQueue {
-
-  /**
-     HTask 間の dependency を表すリスト。HTask の wait_me と wait_i がこれ。
-   */
-public:
-    TaskQueue(HTask *q = NULL);
-
-    BASE_NEW_DELETE(TaskQueue);
-
-    HTask *task;
-    TaskQueue *waiter;
-
-    TaskQueue *next;
-    TaskQueue *prev;
-
-    void init() { }
-    void initOnce() { }
-    void freeOnce() {}
-
-    TaskQueue *init(HTask *task) {
-	this->task = task;
-	return this;
-    }
-
-}  ;
-
-typedef TaskQueue* TaskQueuePtr;
-
-#endif
--- a/include/TaskManager/Threads.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,30 +0,0 @@
-#ifndef INCLUDED_THREADS
-#define INCLUDED_THREADS
-
-#include <pthread.h>
-#include "base.h"
-#include "types.h"
-
-
-class Threads {
-public:
-    BASE_NEW_DELETE(Threads);
-
-    /* constructor */
-    Threads(int num = 1) {};
-    virtual ~Threads() {};
-
-    /* functions */
-    virtual void init() = 0;
-    virtual int get_mail(int speid, int count, memaddr *ret) = 0; // BLOCKING
-    virtual int has_mail(int speid, int count, memaddr *ret) = 0; // NONBLOCK
-    virtual void send_mail(int speid, int num, memaddr *data) = 0; // BLOCKING
-    virtual void add_output_tasklist(int command, memaddr buff, int alloc_size) = 0;
-    virtual int is_gpu(int cpuid) { return 0; }
-    virtual void set_NDRange(void* ndr)=0;
-    /* variables */
-    pthread_t *threads;
-    int cpu_num;
-}  ;
-
-#endif
--- a/include/TaskManager/base.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,27 +0,0 @@
-#ifndef INCLUDED_BASE_H_
-
-#include <new>
-#include <stdlib.h>
-#include <stdio.h>
-
-
-#ifdef __SPU__
-#  define BASE_NEW_DELETE(T)						\
-    /* override new/detele */                                           \
-    static void* operator new(size_t size) {                            \
-	if ((int)size == 0) {						\
-            size = 1;                                                   \
-	}                                                               \
-									\
-	void *ptr = malloc(size);					\
-	return ptr;							\
-    }                                                                   \
-    static void operator delete(void* rawMemory, size_t size) {         \
-	free(rawMemory);                                                \
-    }                                                                   \
-
-#else
-# define BASE_NEW_DELETE(T)
-#endif
-
-#endif
--- a/include/TaskManager/error.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,30 +0,0 @@
-#ifndef CERIUM_ERR
-#define CERIUM_ERR
-
-#ifdef DEBUG
-#  include <stdio.h>
-#  define __debugs(s, ...) do { \
-	s->printf(__VA_ARGS__);		\
-    } while (0)
-#else /* DEBUG */
-#  define __debug(...)
-#endif
-
-#ifdef DEBUG
-#  include <stdio.h>
-#  define __debugs_ppe(s, ...) do { \
-	s->printf("[PPE] ", __VA_ARGS__);	\
-    } while (0)
-#else /* DEBUG */
-#  define __debug_ppe(...)
-#endif
-
-#ifdef DEBUG
-#  include <stdio.h>
-#  define __debugs_spe(s, ...) do { \
-	s->printf("[SPE] ", __VA_ARGS__);	\
-    } while (0)
-#else /* DEBUG */
-#  define __debug_spe(...)
-#endif
-#endif
--- a/include/TaskManager/gettime.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,32 +0,0 @@
-#ifndef GETTIME_H_
-#define GETTIME_H_
-
-#include <time.h>
-#ifdef __APPLE__
-#include <sys/time.h>
-#endif
-/**
- *  Mac OS X側には、clock_gettimeがないので、gettimeofdayを使う
- */
-inline unsigned long long gettime() {
-
-	unsigned long long time = 0;
-#ifdef __CERIUM_FIFO__  // ??
-	struct timespec ts;
-
-#ifndef __APPLE__
-	clock_gettime(CLOCK_REALTIME, &ts);
-#else
-	struct timeval tv;
-	gettimeofday(&tv, NULL);
-	ts.tv_sec = tv.tv_sec;
-	ts.tv_nsec = tv.tv_usec * 1000;
-#endif
-
-	time = ((ts.tv_sec << 32) | ts.tv_nsec );
-#endif // __CERIUM_FIFO__
-	return time;
-
-}
-
-#endif
--- a/include/TaskManager/rdtsc.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,16 +0,0 @@
-#ifndef RDTSC_H_
-#define RDTSC_H_
-
-/*
- *  rdtsc is Read Time Stamp Counter
- */
-
-inline unsigned long long rdtsc() {
-	unsigned long long ret = 0;
-#ifdef __CERIUM_FIFO__ // ??
-	__asm__ volatile ("rdtsc" : "=A" (ret));
-#endif // __CERIUM_FIFO__
-	return ret;
-}
-
-#endif /* RDTSC_H_ */
--- a/include/TaskManager/types.h	Fri Mar 15 06:59:19 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,82 +0,0 @@
-#ifndef INCLUDED_TYPES
-#define INCLUDED_TYPES
-
-#include <stdint.h>
-
-typedef uint16_t uint16;
-typedef uint32_t uint32;
-typedef uint64_t uint64;
-
-//  HOST main memory address 
-//       SPU's (void *) is always 32bit (actually 18bit (256kbyte))
-//       memaddr is different from (void *) in SPU.
-//
-#ifdef __SPU__
-#if ABIBIT>32
-typedef uint64_t memaddr;
-#else
-typedef uint32_t memaddr;
-#endif
-#else
-typedef char* memaddr;
-#endif
-
-
-#define Newq(Type,Count) ((Type *)malloc(sizeof(Type)*Count))
-#define ReAlloc(Pointer,Type,Count) ((Type *)realloc((void*)Pointer,sizeof(Type)*Count))
-
-
-#define SPE_ALIGNMENT 16
-#define SPE_ALIGNMENT_FULL 128
-#define SPE_ALIGN __attribute__((aligned(SPE_ALIGNMENT)))
-#define SPE_ALIGN_FULL __attribute__((aligned(SPE_ALIGNMENT_FULL))
-#define ROUND_UP_ALIGN(value, alignment) \
-    (((value) + ((alignment) - 1))&(~((alignment)-1)))
-#define DEFAULT_ALIGNMENT SPE_ALIGNMENT
-//#define DEFAULT_ALIGNMENT SPE_ALIGNMENT_FULL
-
-#define DMA_MAX_SIZE 16384
-
-#define round_up16(value)  ROUND_UP_ALIGN(value, 16)
-#define round_up128(value) ROUND_UP_ALIGN(value, 128)
-
-#define TaskArray (-1)
-#define TaskArray1 (-2)
-
-// SPU 依存 (よろしくないが...)
-
-// ここも typedef しとくか?
-enum {
-// どの方向かで enum 分けるだろjk...
-// PPE -> SPE 
-    MY_SPE_NOP = 0,
-    MY_SPE_COMMAND_EXIT,
-    MY_SPE_COMMAND_GO,
-
-// SPE -> PPE
-    MY_SPE_STATUS_BUSY,
-    MY_SPE_STATUS_READY,
-    MY_SPE_COMMAND_MALLOC,
-};
-
-#define MAX_USE_SPE_NUM 32
-
-typedef enum {
-    CPU_PPE = 0, // default
-    GPU_0 = 1,
-    GPU_1 = 2,
-    GPU_2 = 3,
-    GPU_3 = 4,
-    CPU_SPE = 5,
-    SPE_ANY = CPU_SPE,
-    SPE_0 = 6,
-    SPE_1 = 7,
-    SPE_2 = 8,
-    SPE_3 = 9,
-    SPE_4 = 10,
-    SPE_5 = 11,
-
-
-} CPU_TYPE;
-
-#endif