Mercurial > hg > Game > Cerium
changeset 441:54c49df8dcda draft
slightly worked...
author | Shinji KONO <kono@ie.u-ryukyu.ac.jp> |
---|---|
date | Fri, 25 Sep 2009 03:49:01 +0900 |
parents | a1c670e29cde |
children | 6c63423a7dea |
files | TaskManager/kernel/schedule/Scheduler.cc TaskManager/kernel/schedule/Scheduler.h example/get_segment/spe/Hello.cc example/get_segment/spe/Hello1.cc example/get_segment/spe/LoadEntry.cc example/get_segment/spe/LoadEntry.h example/get_segment/spe/Makefile example/get_segment/spe/ld.script.ed example/get_segment/spe/spe-main.cc |
diffstat | 9 files changed, 85 insertions(+), 39 deletions(-) [+] |
line wrap: on
line diff
--- a/TaskManager/kernel/schedule/Scheduler.cc Fri Sep 25 01:47:03 2009 +0900 +++ b/TaskManager/kernel/schedule/Scheduler.cc Fri Sep 25 03:49:01 2009 +0900 @@ -362,7 +362,7 @@ (TaskObjectCreator)( (char*)task_list[task_id].segment->data + task_list[task_id].entry_offset); - // task_list[task_id].creator = creator; + task_list[task_id].creator = creator; fprintf(stderr,"wait load task id %d done. creator = 0x%x entry_offset = 0x%x\n",task_id, (unsigned int)creator, task_list[task_id].entry_offset); @@ -383,18 +383,19 @@ extern void register_dynamic_task(int cmd, - memaddr start, memaddr end, + memaddr start, int size, TaskObjectCreator creator, int entry_offset) { task_list[cmd].creator = creator; task_list[cmd].location = start; - task_list[cmd].end = end; + task_list[cmd].end = start+size; task_list[cmd].entry_offset = entry_offset; task_list[cmd].load = load_task; task_list[cmd].wait = wait_load; fprintf(stderr,"cmd = %d\n",cmd); -fprintf(stderr,"locatation = 0x%llx\n",start); -fprintf(stderr,"end = 0x%llx\n",end); +fprintf(stderr,"locatation = 0x%x\n",start); +fprintf(stderr,"end = 0x%x\n",start+size); +fprintf(stderr,"size = 0x%x\n",size); fprintf(stderr,"entry = 0x%x\n",entry_offset); }
--- a/TaskManager/kernel/schedule/Scheduler.h Fri Sep 25 01:47:03 2009 +0900 +++ b/TaskManager/kernel/schedule/Scheduler.h Fri Sep 25 03:49:01 2009 +0900 @@ -99,8 +99,8 @@ // 大きいので、SPEには置かない方が本当は良い... typedef struct { TaskObjectCreator creator; - uint64 location; // location address in a.out - uint64 end; + memaddr location; // location address in a.out + memaddr end; uint32 entry_offset; // offset for create(); MemorySegment *segment; void (*load)(Scheduler *,int); @@ -173,9 +173,16 @@ extern void register_task(int cmd, TaskObjectCreator creator); extern void register_dynamic_task(int cmd, - memaddr start, memaddr end, TaskObjectCreator creator, + memaddr start, int size, TaskObjectCreator creator, int entry_offset); +struct tbl { + unsigned int vma; + unsigned int size; + unsigned int file_offset; + unsigned int buf; +}; + #endif @@ -196,18 +203,20 @@ register_task(cmd, createTask_##str); #define SchedDefineDynamicTask(str,segment) \ + extern "C" { \ SchedTask* createTask_##str(Scheduler *manager) \ { \ return new str(); \ + } \ } #ifndef NO_OVERLAY #define SchedExternDynamicTask(str,segment) \ - extern char __load_start_##segment[], \ - __load_stop_##segment[]; \ - extern void spe_load_entry(); \ - extern SchedTask* createTask_##str(Scheduler *manager); \ - extern unsigned long long _EAR_; + extern "C" { \ + extern unsigned long long _EAR_; \ + extern struct tbl _ovly_table[]; \ + extern SchedTask* createTask_##str(Scheduler *manager) ; \ + } #else #define SchedExternDynamicTask(str,segment) SchedExternTask(str) #endif @@ -215,10 +224,10 @@ #ifndef NO_OVERLAY #define SchedRegisterDynamicTask(cmd, str, segment) \ - register_dynamic_task(cmd, _EAR_+(memaddr)__load_start_##segment, \ - _EAR_+(memaddr)__load_stop_##segment,\ + register_dynamic_task(cmd, _EAR_+_ovly_table[segment].file_offset, \ + _ovly_table[segment].size, \ createTask_##str, \ - ((char *)createTask_##str)-(char *)spe_load_entry); + createTask_##str##_offset); #else #define SchedRegisterDynamicTask(cmd, str, segment) SchedRegisterTask(cmd, str) #endif
--- a/example/get_segment/spe/Hello.cc Fri Sep 25 01:47:03 2009 +0900 +++ b/example/get_segment/spe/Hello.cc Fri Sep 25 03:49:01 2009 +0900 @@ -3,7 +3,7 @@ #include "Func.h" /* これは必須 */ -SchedDefineDynamicTask(Hello,segment1); +SchedDefineDynamicTask(Hello,0); int Hello::run(SchedTask *smanager, void *rbuf, void *wbuf)
--- a/example/get_segment/spe/Hello1.cc Fri Sep 25 01:47:03 2009 +0900 +++ b/example/get_segment/spe/Hello1.cc Fri Sep 25 03:49:01 2009 +0900 @@ -3,7 +3,7 @@ #include "Func.h" /* これは必須 */ -SchedDefineDynamicTask(Hello1,segment2); +SchedDefineDynamicTask(Hello1,1); int Hello1::run(SchedTask *smanager, void *rbuf, void *wbuf)
--- a/example/get_segment/spe/LoadEntry.cc Fri Sep 25 01:47:03 2009 +0900 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,5 +0,0 @@ -#include "LoadEntry.h" - -void spe_load_entry() -{ -}
--- a/example/get_segment/spe/LoadEntry.h Fri Sep 25 01:47:03 2009 +0900 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,6 +0,0 @@ -#ifndef INCLUDED_LOAD_ENTRY -#define INCLUDED_LOAD_ENTRY - -extern void spe_load_entry(); - -#endif
--- a/example/get_segment/spe/Makefile Fri Sep 25 01:47:03 2009 +0900 +++ b/example/get_segment/spe/Makefile Fri Sep 25 03:49:01 2009 +0900 @@ -5,11 +5,11 @@ SRCS = spe-main.o # SRCS = $(filter-out $(SRCS_EXCLUDE),$(SRCS_TMP)) SPEOBJS = $(SRCS:.cc=.o) -OVLOBJS = Hello.o Hello1.o LoadEntry.o +OVLOBJS = Hello.o Hello1.o CC = spu-g++ INCLUDE = -I../${CERIUM}/include/TaskManager -I. -I.. -CFLAGS = $(INCLUDE) -O2 -g -Wall -fno-exceptions -fno-rtti#-DDEBUG +CFLAGS = $(INCLUDE) -O0 -g -Wall -fno-exceptions -fno-rtti#-DDEBUG # CFLAGS = -DNO_OVERLAY=1 $(CFLAGS) LIBS = -L../${CERIUM}/TaskManager -lspemanager -Wl,--gc-sections @@ -19,11 +19,16 @@ LDSCRIPT_ORIG = ld.script.orig LDSCRIPT_ED = ld.script.ed +OFFSET_H = createTask_offset.h + all: $(TARGET) .SUFFIXES: .cc .o -$(SPEOBJS): %.o : %.cc +$(OFFSET_H) : + perl ovly_table.pl $(TARGET) > $(OFFSET_H) + +$(SPEOBJS): %.o : %.cc $(OFFSET_H) $(CC) $(CFLAGS) -c $< -o $@ $(OVLOBJS): %.o : %.cc
--- a/example/get_segment/spe/ld.script.ed Fri Sep 25 01:47:03 2009 +0900 +++ b/example/get_segment/spe/ld.script.ed Fri Sep 25 03:49:01 2009 +0900 @@ -5,9 +5,8 @@ a OVERLAY : { - .segment0 { LoadEntry.o(.text) } - .segment1 { Hello.o(.text) } - .segment2 { Hello1.o(.text) } + .segment0 { Hello.o(.text) } + .segment1 { Hello1.o(.text) } } . w
--- a/example/get_segment/spe/spe-main.cc Fri Sep 25 01:47:03 2009 +0900 +++ b/example/get_segment/spe/spe-main.cc Fri Sep 25 03:49:01 2009 +0900 @@ -2,8 +2,12 @@ #include "Scheduler.h" #include "LoadEntry.h" -SchedExternDynamicTask(Hello,segment1); -SchedExternDynamicTask(Hello1,segment2); +#include "createTask_offset.h" + +SchedExternDynamicTask(Hello,0); +SchedExternDynamicTask(Hello1,1); + +void print_ovly_table(); /** * この関数は SpeScheduler から呼ばれるので @@ -12,7 +16,46 @@ void task_init(Scheduler *scheduler) { - SchedRegisterDynamicTask(HELLO_TASK, Hello, segment1); - SchedRegisterDynamicTask(HELLO_TASK1, Hello1, segment2); + SchedRegisterDynamicTask(HELLO_TASK, Hello, 0); + SchedRegisterDynamicTask(HELLO_TASK1, Hello1, 1); scheduler->allocate_code_segment(4,1024); + print_ovly_table(); } + +typedef unsigned int u32; +extern unsigned long long _EAR_; + +/* +extern struct tbl1 { + u32 vma; + u32 size; + u32 file_offset; + u32 buf; +} _ovly_table; + */ + +#if 0 +unsigned long long _EAR_ = 0; +struct tbl _ovly_table; +#endif + +void +print_ovly_table() +{ + int i; + struct tbl *ov; + + ov = _ovly_table; + + fprintf(stderr,"memaddr = %d\n",sizeof(memaddr)); + for(i=0;i<2;i++) { + unsigned long long adr = _EAR_; + fprintf(stderr,"ovly_table[%d] vma=%08x size=%08x offset=%08x address=%08llx\n", + i, + ov[i].vma, + ov[i].size, ov[i].file_offset, + (adr) + ov[i].file_offset); + } +} + +/* end */