Mercurial > hg > Game > Cerium
view TaskManager/Cell/spe/CellDmaManager.h @ 1213:a49c02dffe6f draft
DMA connector reogranization
author | Shinji KONO <kono@ie.u-ryukyu.ac.jp> |
---|---|
date | Fri, 22 Jul 2011 13:25:30 +0900 |
parents | c43f49400c22 |
children | 2a4ba6366394 |
line wrap: on
line source
#ifndef INCLUDED_CELL_DMA_MANAGER #define INCLUDED_CELL_DMA_MANAGER #include "base.h" #include "types.h" #include "DmaManager.h" #include "MailManager.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,void *buf, memaddr addr, uint32 size, uint32 mask); void dma_store(Scheduler *s,void *buf, memaddr addr, uint32 size, uint32 mask); void *get_writebuf(Schduler *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_queue(memaddr data); void mail_write_finish_list(memaddr data); memaddr mail_read(); memaddr task_list_mail_read(); void dma_loadList(Scheduler *s,ListDataPtr list, void *buff, 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