Mercurial > hg > Game > Cerium
changeset 364:fd0c819bab53 draft
uint32 to memaddr(uint64)
author | tkaito@localhost.localdomain |
---|---|
date | Fri, 24 Jul 2009 17:40:53 +0900 |
parents | 73630476453a |
children | fafed60e2fca |
files | TaskManager/Cell/spe/CellDmaManager.cc example/MemList/Func.h example/MemList/Makefile example/MemList/Makefile.cell example/MemList/Makefile.def example/MemList/Makefile.linux example/MemList/Makefile.macosx example/MemList/README example/MemList/main.cc include/TaskManager/CellDmaManager.h include/TaskManager/types.h |
diffstat | 11 files changed, 247 insertions(+), 5 deletions(-) [+] |
line wrap: on
line diff
--- a/TaskManager/Cell/spe/CellDmaManager.cc Fri Jul 24 17:08:08 2009 +0900 +++ b/TaskManager/Cell/spe/CellDmaManager.cc Fri Jul 24 17:40:53 2009 +0900 @@ -11,7 +11,7 @@ * @param[in] mask DMA tag */ void -CellDmaManager::dma_load(void *buf, uint32 addr, uint32 size, uint32 mask) +CellDmaManager::dma_load(void *buf, memaddr addr, uint32 size, uint32 mask) { if (size == 0) return ; mfc_get((volatile void *)buf, addr, size, mask, 0, 0); @@ -26,7 +26,7 @@ * @param[in] mask DMA tag */ void -CellDmaManager::dma_store(void *buf, uint32 addr, uint32 size, uint32 mask) +CellDmaManager::dma_store(void *buf, memaddr addr, uint32 size, uint32 mask) { if (size == 0) return ; mfc_put((volatile void *)buf, addr, size, mask, 0, 0);
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/example/MemList/Func.h Fri Jul 24 17:40:53 2009 +0900 @@ -0,0 +1,5 @@ +enum { + HELLO_TASK, + RUN_FINISH, +}; +
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/example/MemList/Makefile Fri Jul 24 17:40:53 2009 +0900 @@ -0,0 +1,20 @@ +default: macosx + +macosx: FORCE + @echo "Make for Mac OS X" + @$(MAKE) -f Makefile.macosx + +linux: FORCE + @echo "Make for Linux" + @$(MAKE) -f Makefile.linux + +cell: FORCE + @echo "Make for PS3 (Cell)" + @$(MAKE) -f Makefile.cell + +FORCE: + +clean: + @$(MAKE) -f Makefile.macosx clean + @$(MAKE) -f Makefile.linux clean + @$(MAKE) -f Makefile.cell clean \ No newline at end of file
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/example/MemList/Makefile.cell Fri Jul 24 17:40:53 2009 +0900 @@ -0,0 +1,42 @@ +include ./Makefile.def + +SRCS_TMP = $(wildcard *.cc) +SRCS_EXCLUDE = # 除外するファイルを書く +SRCS = $(filter-out $(SRCS_EXCLUDE),$(SRCS_TMP)) +OBJS = $(SRCS:.cc=.o) + +TASK_DIR = ppe +TASK_SRCS_TMP = $(wildcard $(TASK_DIR)/*.cc) +TASK_SRCS_EXCLUDE = +TASK_SRCS = $(filter-out $(TASK_DIR)/$(TASK_SRCS_EXCLUDE),$(TASK_SRCS_TMP)) +TASK_OBJS = $(TASK_SRCS:.cc=.o) + +LIBS += -lCellManager -lspe2 -lpthread -Wl,--gc-sections + +.SUFFIXES: .cc .o + +.cc.o: + $(CC) $(CFLAGS) $(INCLUDE) -c $< -o $@ + +all: $(TARGET) speobject + +$(TARGET): $(OBJS) $(TASK_OBJS) + $(CC) -o $@ $(OBJS) $(TASK_OBJS) $(LIBS) + +speobject: + cd spe; $(MAKE) + +run: + ./$(TARGET) -cpu 6 + +link: + $(CC) -o $(TARGET) $(OBJS) $(TASK_OBJS) $(LIBS) + +debug: $(TARGET) + sudo ppu-gdb ./$(TARGET) + +clean: + rm -f $(TARGET) $(OBJS) $(TASK_OBJS) + rm -f *~ \#* + rm -f ppe/*~ ppe/\#* + cd spe; $(MAKE) clean
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/example/MemList/Makefile.def Fri Jul 24 17:40:53 2009 +0900 @@ -0,0 +1,14 @@ +TARGET = mainMem + +# include/library path +# ex: macosx +#CERIUM = /Users/gongo/Source/Cerium + +# ex: linux/ps3 +CERIUM = ../../../Cerium + +CC = g++ +CFLAGS = -g -Wall -O9 + +INCLUDE = -I${CERIUM}/include/TaskManager -I. -I.. +LIBS = -L${CERIUM}/TaskManager
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/example/MemList/Makefile.linux Fri Jul 24 17:40:53 2009 +0900 @@ -0,0 +1,36 @@ +include ./Makefile.def + +SRCS_TMP = $(wildcard *.cc) +SRCS_EXCLUDE = # 除外するファイルを書く +SRCS = $(filter-out $(SRCS_EXCLUDE),$(SRCS_TMP)) +OBJS = $(SRCS:.cc=.o) + +TASK_DIR = ppe +TASK_SRCS_TMP = $(wildcard $(TASK_DIR)/*.cc) +TASK_SRCS_EXCLUDE = +TASK_SRCS = $(filter-out $(TASK_DIR)/$(TASK_SRCS_EXCLUDE),$(TASK_SRCS_TMP)) +TASK_OBJS = $(TASK_SRCS:.cc=.o) + +LIBS += -lFifoManager + +.SUFFIXES: .cc .o + +.cc.o: + $(CC) $(CFLAGS) $(INCLUDE) -c $< -o $@ + +all: $(TARGET) + +$(TARGET): $(OBJS) $(TASK_OBJS) + $(CC) -o $@ $(OBJS) $(TASK_OBJS) $(LIBS) + +link: + $(CC) -o $(TARGET) $(OBJS) $(TASK_OBJS) $(LIBS) + +debug: $(TARGET) + sudo gdb ./$(TARGET) + +clean: + rm -f $(TARGET) $(OBJS) $(TASK_OBJS) + rm -f *~ \#* + rm -f ppe/*~ ppe/\#* + rm -f spe/*~ spe/\#*
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/example/MemList/Makefile.macosx Fri Jul 24 17:40:53 2009 +0900 @@ -0,0 +1,36 @@ +include ./Makefile.def + +SRCS_TMP = $(wildcard *.cc) +SRCS_EXCLUDE = # 除外するファイルを書く +SRCS = $(filter-out $(SRCS_EXCLUDE),$(SRCS_TMP)) +OBJS = $(SRCS:.cc=.o) + +TASK_DIR = ppe +TASK_SRCS_TMP = $(wildcard $(TASK_DIR)/*.cc) +TASK_SRCS_EXCLUDE = +TASK_SRCS = $(filter-out $(TASK_DIR)/$(TASK_SRCS_EXCLUDE),$(TASK_SRCS_TMP)) +TASK_OBJS = $(TASK_SRCS:.cc=.o) + +LIBS += -lFifoManager `sdl-config --libs` + +.SUFFIXES: .cc .o + +.cc.o: + $(CC) $(CFLAGS) $(INCLUDE) -c $< -o $@ + +all: $(TARGET) + +$(TARGET): $(OBJS) $(TASK_OBJS) + $(CC) -o $@ $(OBJS) $(TASK_OBJS) $(LIBS) + +link: + $(CC) -o $(TARGET) $(OBJS) $(TASK_OBJS) $(LIBS) + +debug: $(TARGET) + sudo gdb ./$(TARGET) + +clean: + rm -f $(TARGET) $(OBJS) $(TASK_OBJS) + rm -f *~ \#* + rm -f ppe/*~ ppe/\#* + rm -f spe/*~ spe/\#*
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/example/MemList/README Fri Jul 24 17:40:53 2009 +0900 @@ -0,0 +1,47 @@ +/* + * $Id: README,v 1.5 2008/11/01 02:37:12 gongo Exp $ + */ + +- 概要 + +"Hello, World!!" を出力するプログラムです。 +タスク Hello が文字列を表示します。 + +- 実行方法 + +% ./hello [-count COUNT] + + -count 表示する "Hello, World!!" の数(つまり、タスク Hello の数)です。 + +- 実行例 (-cpu は Cerium 標準のオプションです) + +% ./hello +[0] Hello, World!! + +% ./hello -count 10 +[0] Hello, World!! +[1] Hello, World!! +[2] Hello, World!! +[3] Hello, World!! +[4] Hello, World!! +[5] Hello, World!! +[6] Hello, World!! +[7] Hello, World!! +[8] Hello, World!! +[9] Hello, World!! + +% ./hello -count 10 -cpu 3 +[0] Hello, World!! +[2] Hello, World!! +[3] Hello, World!! +[5] Hello, World!! +[6] Hello, World!! +[8] Hello, World!! +[9] Hello, World!! +[1] Hello, World!! +[4] Hello, World!! +[7] Hello, World!! + +上の例では、Hello タスク 10 個を、 +3 つの CPU に振り分けて実行しているので +表示が順になっていない -> 並列に実行されていることがわかります。 \ No newline at end of file
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/example/MemList/main.cc Fri Jul 24 17:40:53 2009 +0900 @@ -0,0 +1,33 @@ +#include <stdio.h> +#include <stdlib.h> +#include <string.h> +#include "TaskManager.h" +#include "Func.h" + +extern void task_init(void); + +static int count = 1; + +extern TaskManager *manager; + +const char *usr_help_str = "Usage: ./hello [-cpu spe_num] [-count N]\n\ + -cpu Number of SPE (default 1) \n\ + -count Number of task is print \"Hello, World!!\""; + +// get 鴻 + +int +main(int argc, char *argv[]) +{ + uint32 size = 128; + uint32 count = 64; + + MemList* active = createMemList(size, 0); + MemList* freelist = createMemList(size,count); + + // 鐚 + for () { + MemorySegment* e = freelost.getFirst(); + } + return 0; +}
--- a/include/TaskManager/CellDmaManager.h Fri Jul 24 17:08:08 2009 +0900 +++ b/include/TaskManager/CellDmaManager.h Fri Jul 24 17:40:53 2009 +0900 @@ -13,7 +13,7 @@ BASE_NEW_DELETE(CellDmaManager); typedef struct dma_list { - uint32 addr; + memaddr addr; uint32 size; } DmaList, *DmaListPtr; @@ -22,8 +22,8 @@ unsigned long long global_busy_time, global_wait_time; /* 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_load(void *buf, memaddr addr, uint32 size, uint32 mask); + void dma_store(void *buf,memaddr addr, uint32 size, uint32 mask); void dma_wait(uint32 mask) ; void start_dmawait_profile(); void end_dmawait_profile();
--- a/include/TaskManager/types.h Fri Jul 24 17:08:08 2009 +0900 +++ b/include/TaskManager/types.h Fri Jul 24 17:40:53 2009 +0900 @@ -5,6 +5,15 @@ typedef uint32_t uint32; typedef uint64_t uint64; +#ifdef SPU +typedef memaddr uint64; +#else +#if (sizeof (void*) == 8) +typedef memaddr uint64; +#else +typedef memaddr uint32; +#endif +#endif #define SPE_ALIGNMENT 16 #define SPE_ALIGNMENT_FULL 128