view TaskManager/Gpu/GpuThreads.cc @ 1877:f73ca57cdc81 draft

add ppe wait semaphore to avoid ppe busy wait
author Kohagura
date Tue, 31 Dec 2013 19:33:26 +0900
parents 289378e5abf8
children
line wrap: on
line source

#include "GpuThreads.h"
#include "GpuScheduler.h"
#include "TaskManagerImpl.h"
#include "SpeTaskManagerImpl.h"

const int gpu_num = 1;

GpuThreads::GpuThreads(int useRefDma) : use_refdma(useRefDma)
{
    threads = new pthread_t[gpu_num];
    args = new gpu_thread_arg_t;
}

GpuThreads::~GpuThreads()
{
    memaddr mail = (memaddr)MY_SPE_COMMAND_EXIT;
    send_mail(0,1,&mail);
    pthread_join(threads[0], NULL);

    delete threads;
    delete args;
}

void
GpuThreads::set_wait(SemPtr wait)
{
    args->wait=wait;
}

void
GpuThreads::init()
{
    args->scheduler = new GpuScheduler();
    args->useRefDma = use_refdma;

    pthread_create(&threads[0], NULL, &gpu_thread_run, args);
}

void
GpuThreads::set_mail_waiter(SemPtr w)
{
    args->scheduler->connector->set_mail_waiter(w);
}

void *
GpuThreads::gpu_thread_run(void *args)
{
    gpu_thread_arg_t *argt = (gpu_thread_arg_t *) args;
    Scheduler *g_scheduler = argt->scheduler;

    TaskManagerImpl *manager = new SpeTaskManagerImpl();
    g_scheduler->init(manager, argt->useRefDma);

    manager->set_scheduler(g_scheduler);

    argt->wait->sem_v();

    g_scheduler->run();
    g_scheduler->finish();

    return NULL;
}

int
GpuThreads::spawn_task(int id, TaskListPtr p) {
    send_mail(id, 1, (memaddr*)p);
    return 0;
}

int
GpuThreads::get_mail(int speid, int count, memaddr *ret)
{
    *ret = args->scheduler->mail_read_from_host();
    return 1;
}

int
GpuThreads::has_mail(int speid, int count, memaddr *ret)
{
    if (args->scheduler->has_mail_from_host() != 0) {
        return get_mail(0, 0, ret);
    } else {
        return 0;
    }
}

void
GpuThreads::send_mail(int speid, int num, memaddr *data)
{
    args->scheduler->mail_write_from_host(*data);
}

void
GpuThreads::add_output_tasklist(int command, memaddr buff, int alloc_size)
{
}