view TaskManager/ManyCore/ManyCoreDmaManager.cc @ 2022:fac44ad2867d draft

make a sound
author Masataka Kohagura <kohagura@cr.ie.u-ryukyu.ac.jp>
date Wed, 16 Jul 2014 02:50:32 +0900
parents e0d465efc57e
children
line wrap: on
line source

#include "ReferencedDmaManager.h"
#include "Scheduler.h"
#include "TaskManagerImpl.h"
#include <string.h>

void *
ReferencedDmaManager::dma_load(Scheduler *s, memaddr addr, uint32 size, uint32 mask)
{
    return (void*)addr;
}

void *
ReferencedDmaManager::dma_load1(void *buf, memaddr addr, uint32 size, uint32 mask)
{
//    void *from = (void*)addr;
//    if (buf != from) 
//        memcpy(buf, from, size);
    return (void*)addr;
}


void *
ReferencedDmaManager::dma_loadList(Scheduler *s, ListDataPtr list, uint32 mask)
{
    ListElementPtr elm = &list->element[0];
    return (void*)elm->addr; // ==readbuf
}

void
ReferencedDmaManager::free_(void *buf) {
}

/**
 *  DMA buffer offset in rbuf
 *
 *  faked offset for real address must be set to get correct address by
 *    return (void*)((char*)readbuf + inListData.bound[index]);
 *
 */
void
ReferencedDmaManager::bound(ListData *list)
{
    ListElement *elm = list->element;
    long *bound = list->bound;
#ifdef __CERIUM_CELL__
    uint32  readbuf = elm[0].addr;
#else
    memaddr readbuf = elm[0].addr;
#endif
    for(int i=0;i<list->length;i++) {
        bound[i] = elm[i].addr-readbuf;
    }
}

void *
ReferencedDmaManager::get_writebuf(Scheduler *s,memaddr addr, uint32 size)
{
    return (void*)addr;
}

void *
ReferencedDmaManager::dma_store(void *buf, memaddr addr, uint32 size, uint32 mask)
{
//    void *to = (void*)addr;
//    if (buf != to) 
//        memcpy(to, buf, size);
    return (void*)addr;
}

void
ReferencedDmaManager::dma_storeList(ListDataPtr list, void *buff, uint32 mask)
{
}