# HG changeset patch # User aaa # Date 1248777779 -32400 # Node ID 93b33cecba3747e32520f3dec1ef848e4ac03b3e # Parent 1a80a2aa696c27bb82754db3f92d2458a847759c change TaskManager.cc diff -r 1a80a2aa696c -r 93b33cecba37 TaskManager/Makefile.def --- a/TaskManager/Makefile.def Mon Jul 27 18:26:50 2009 +0900 +++ b/TaskManager/Makefile.def Tue Jul 28 19:42:59 2009 +0900 @@ -15,6 +15,9 @@ KERN_SYSTASK_SRCS = $(wildcard $(KERN_SYSTASK_DIR)/*.cc) KERN_SYSTASK_OBJS = $(KERN_SYSTASK_SRCS:.cc=.o) +KERN_MEM_DIR = $(KERN_DIR)/memory +KERN_MEM_SRCS = $(wildcard $(KERN_MEM_DIR)/*.cc) +KERN_MEM_OBJS = $(KERN_MEM_SRCS:.cc=.o) IMPL_FIFO_DIR = Fifo IMPL_FIFO_SRCS = $(wildcard $(IMPL_FIFO_DIR)/*.cc) diff -r 1a80a2aa696c -r 93b33cecba37 TaskManager/Makefile.fifo --- a/TaskManager/Makefile.fifo Mon Jul 27 18:26:50 2009 +0900 +++ b/TaskManager/Makefile.fifo Tue Jul 28 19:42:59 2009 +0900 @@ -12,7 +12,7 @@ all: default default: $(TARGET) -ALL_OBJS = $(KERN_MAIN_OBJS) $(KERN_PPE_OBJS) $(KERN_SCHED_OBJS) $(KERN_SYSTASK_OBJS) $(IMPL_FIFO_OBJS) +ALL_OBJS = $(KERN_MAIN_OBJS) $(KERN_PPE_OBJS) $(KERN_SCHED_OBJS) $(KERN_SYSTASK_OBJS) $(IMPL_FIFO_OBJS) $(KERN_MEM_OBJS) $(TARGET): $(ALL_OBJS) ar crus $@ $(ALL_OBJS) diff -r 1a80a2aa696c -r 93b33cecba37 TaskManager/kernel/memory/MemList.cc --- a/TaskManager/kernel/memory/MemList.cc Mon Jul 27 18:26:50 2009 +0900 +++ b/TaskManager/kernel/memory/MemList.cc Tue Jul 28 19:42:59 2009 +0900 @@ -2,14 +2,14 @@ MemList は空にならない。最低1個は要素が入っていて 1個目は特別扱いする。getFirst すると first->next を返す */ - -#include "MemorySegment.h" +#include +#include "MemList.h" /*! 最初の1個は特別扱いなので、それの後に追加していく */ void -addFirst(MemorySegment* e) +MemList::addFirst(MemorySegment* e) { e->prev = first; e->next = first->next; @@ -18,7 +18,7 @@ } void -addLast(MemorySegment* e) +MemList::addLast(MemorySegment* e) { e->next = first; e->prev = last; @@ -26,20 +26,20 @@ last = e; } -MemorySegment -getFirst() +MemorySegment* +MemList::getFirst() { return first->next; } -MemorySegment -getLast() +MemorySegment* +MemList::getLast() { return last; } int -remove(MemorySegment* e) +MemList::remove(MemorySegment* e) { e->prev->next = e->next; if (e->next != NULL) { @@ -52,7 +52,7 @@ } void -moveToFirst(MemorySegment* e) +MemList::moveToFirst(MemorySegment* e) { remove(e); addFirst(e); diff -r 1a80a2aa696c -r 93b33cecba37 TaskManager/kernel/memory/MemList.h --- a/TaskManager/kernel/memory/MemList.h Mon Jul 27 18:26:50 2009 +0900 +++ b/TaskManager/kernel/memory/MemList.h Tue Jul 28 19:42:59 2009 +0900 @@ -1,6 +1,10 @@ +#ifndef MEMLIST +#define MEMLIST + #include "MemorySegment.h" class MemList { +public: MemorySegment* first; MemorySegment* last; @@ -20,3 +24,4 @@ void moveToFirst(MemorySegment* e); // or use(); }; +#endif diff -r 1a80a2aa696c -r 93b33cecba37 TaskManager/kernel/memory/MemorySegment.h --- a/TaskManager/kernel/memory/MemorySegment.h Mon Jul 27 18:26:50 2009 +0900 +++ b/TaskManager/kernel/memory/MemorySegment.h Tue Jul 28 19:42:59 2009 +0900 @@ -1,12 +1,14 @@ -#ifndef MEMLIST -#define MEMLIST +#ifndef MEMLSEG +#define MEMLSEG +#include "types.h" class MemorySegment { +public: MemorySegment* next; MemorySegment* prev; - uint64 size; - uint64 address; - uint64 dummy; + uint32 size; + uint32 address; + uint32 dummy; }; #endif diff -r 1a80a2aa696c -r 93b33cecba37 TaskManager/kernel/ppe/TaskManager.cc --- a/TaskManager/kernel/ppe/TaskManager.cc Mon Jul 27 18:26:50 2009 +0900 +++ b/TaskManager/kernel/ppe/TaskManager.cc Tue Jul 28 19:42:59 2009 +0900 @@ -93,16 +93,14 @@ */ MemList* -createMemList(uint32 size, uint32 count) +TaskManager::createMemList(uint32 size, uint32 count) { - uint32 head_size = - round_up16(sizeof(MemorySegment)); - uint32 seg_size = - round_up16(head_size+size); - void* mseg = m_impl->allocate(seg_size*count); + uint32 head_size = round_up16(sizeof(MemorySegment)); + uint32 seg_size = round_up16(head_size+size); + char* mseg = (char*)m_impl->allocate(seg_size*count); MemList* mlist = new MemList((MemorySegment*)mseg); - for(int i = 1; i < count; i++) { + for(uint32 i = 1; i < count; i++) { MemorySegment* next = (MemorySegment*)(mseg+seg_size*i); mlist->addLast(next); } diff -r 1a80a2aa696c -r 93b33cecba37 example/MemList/Makefile.macosx --- a/example/MemList/Makefile.macosx Mon Jul 27 18:26:50 2009 +0900 +++ b/example/MemList/Makefile.macosx Tue Jul 28 19:42:59 2009 +0900 @@ -3,7 +3,7 @@ SRCS_TMP = $(wildcard *.cc) SRCS_EXCLUDE = # ե SRCS = $(filter-out $(SRCS_EXCLUDE),$(SRCS_TMP)) -OBJS = $(SRCS:.cc=.o) MemList.o MemorySegment.o +OBJS = $(SRCS:.cc=.o) TASK_DIR = ppe TASK_SRCS_TMP = $(wildcard $(TASK_DIR)/*.cc) @@ -20,10 +20,8 @@ all: $(TARGET) -MemList.o: ${CERIUM}/kernel/memory/MemList.cc - -MemorySegment.o: ${CERIUM}/kernel/memory/MemorySegment.cc - +#MemList.o: ${CERIUM}/kernel/memory/MemList.cc + $(TARGET): $(OBJS) $(TASK_OBJS) $(CC) -o $@ $(OBJS) $(TASK_OBJS) $(LIBS) diff -r 1a80a2aa696c -r 93b33cecba37 example/MemList/main.cc --- a/example/MemList/main.cc Mon Jul 27 18:26:50 2009 +0900 +++ b/example/MemList/main.cc Tue Jul 28 19:42:59 2009 +0900 @@ -19,11 +19,14 @@ int TMmain(int argc, char *argv[]) { + + printf("test\n"); uint32 size = 128; uint32 count = 64; - MemList* active = createMemList(size, 0); - MemList* freelist = createMemList(size, count); + + MemList* active = manager->createMemList(size, 0); + MemList* freelist = manager->createMemList(size, count); // 配列! MemorySegment* e;