view TaskManager/kernel/ppe/TaskManagerImpl.h @ 1561:e8c9a7099bcc draft

add set NDRange param
author Yuhi TOMARI <yuhi@cr.ie.u-ryukyu.ac.jp>
date Tue, 12 Mar 2013 16:52:49 +0900
parents 890cb39418ca
children 90c0ad32655f
line wrap: on
line source

#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