view include/TaskManager/CellDmaManager.h @ 245:852f781ce069 draft

Document/Cerium_2009.mm
author aaa
date Mon, 01 Jun 2009 10:54:09 +0900
parents b1cfa1c19662
children 23e76c5369b7
line wrap: on
line source

#ifndef INCLUDED_CELL_DMA_MANAGER
#define INCLUDED_CELL_DMA_MANAGER

#ifndef INCLUDED_BASE_H_
#  include "base.h"
#endif

#ifndef INCLUDED_DMA_MANAGER
#  include "DmaManager.h"
#endif

#include <spu_mfcio.h>

class CellDmaManager : public DmaManager {
public:
    BASE_NEW_DELETE(CellDmaManager);

    typedef struct dma_list {
	uint32 addr;
	uint32 size;
    } DmaList, *DmaListPtr;

    /* variables */

    /* functions */
    void dma_load(void *buf, uint32 addr, uint32 size, uint32 mask);
    void dma_store(void *buf, uint32 addr, uint32 size, uint32 mask);
    void dma_wait(uint32 mask) ;

    void mail_write(uint32 data);
    uint32 mail_read(void);
    void dma_loadList(ListDataPtr list, void *buff, uint32 mask);
    void dma_storeList(ListDataPtr, void *buff, uint32 mask);
};

#endif