# HG changeset patch # User Yutaka_Kinjyo # Date 1272550368 -32400 # Node ID aaf73e612f738fabf3627ef97de408974b32118c # Parent c5e3b75654dd0c8da19ed9f6ab445bf4cfc7a2e9# Parent aa894c646235062feec1d1740473a19adef67051 merge diff -r c5e3b75654dd -r aaf73e612f73 TaskManager/ChangeLog --- a/TaskManager/ChangeLog Thu Apr 29 22:56:28 2010 +0900 +++ b/TaskManager/ChangeLog Thu Apr 29 23:12:48 2010 +0900 @@ -1,3 +1,41 @@ +2010-4-28 Shinji KONO + + SchedTaskBase のみにインスタンス変数を書かせて、 + SchedTask*.h には method のみを書かせる。 + そうすると、デバッグが楽だし、object のallocateも楽。 + + HTask(list) -> TaskList(array) -> SchedTask + + というcopyだが、SchedTask で最初から作る方が良いのかも。 + それを DataSegment で共有する。 + + SimpleTask のMailを、 + if (mail_is_not_full) send_mail() ; + else if (queue is not full) enqueuue() ; + else wait_mail(); + ってな感じに出来ないの? + + Multi thread にすると、PPEのmail loop が暴走する可能性がある。 + このあたりなんか方法があるはずだが... + +2010-4-24 Shinji KONO + + write T3 T2 T1 TL TA0 TA1 + exec T2 T1 TL TA0 TA1 TA2 + read T1 TL TA TA1 TA2 T2 + next T1 TL TA TA1 TA2* T2   + + *のところで終了mailが出てTaskArrayのデータがfreeされてしまうので、よくない + そうならないように、一段TAN(SchedTaskArrayNop)を挟む。 + + write T3 T2 T1 TL TA0 TA1 TA2 TAN% + exec T2 T1 TL TA0 TA1 TA2 TAN T2 + read T1 TL TA TA1 TA2 TAN T2 T3 + next T1 TL TA TA1 TA2 TAN T2 T3  + + %のところで終了mailを送る。T2のreadのところで、TaskArrayのデータはreadbuff上にあるので + 破壊されてしまう。なので、savedTask->task->self の値はTANにコピーして持っていく必要がある + 2009-12-19 Shinji KONO そうか、TaskList->next は、SPE 側で自分で呼び出しているわけね。 diff -r c5e3b75654dd -r aaf73e612f73 TaskManager/Doxyfile --- a/TaskManager/Doxyfile Thu Apr 29 22:56:28 2010 +0900 +++ b/TaskManager/Doxyfile Thu Apr 29 23:12:48 2010 +0900 @@ -25,20 +25,20 @@ # The PROJECT_NAME tag is a single word (or a sequence of words surrounded # by quotes) that should identify the project. -PROJECT_NAME = "Cerium" +PROJECT_NAME = Cerium # The PROJECT_NUMBER tag can be used to enter a project or revision number. # This could be handy for archiving the generated documentation or # if some version control system is used. -PROJECT_NUMBER = 0.1 +PROJECT_NUMBER = # The OUTPUT_DIRECTORY tag is used to specify the (relative or absolute) # base path where the generated documentation will be put. # If a relative path is entered, it will be relative to the location # where doxygen was started. If left blank the current directory will be used. -OUTPUT_DIRECTORY = ../Document/document +OUTPUT_DIRECTORY = ../Document/document # If the CREATE_SUBDIRS tag is set to YES, then doxygen will create # 4096 sub-directories (in 2 levels) under the output directory of each output @@ -60,7 +60,7 @@ # Portuguese, Romanian, Russian, Serbian, Serbian-Cyrilic, Slovak, Slovene, # Spanish, Swedish, and Ukrainian. -OUTPUT_LANGUAGE = Japanese-en +OUTPUT_LANGUAGE = English # If the BRIEF_MEMBER_DESC tag is set to YES (the default) Doxygen will # include brief member descriptions after the members that are listed in @@ -105,7 +105,7 @@ # path before files name in the file list and in the header files. If set # to NO the shortest path that makes the file name unique will be used. -FULL_PATH_NAMES = NO +FULL_PATH_NAMES = YES # If the FULL_PATH_NAMES tag is set to YES then the STRIP_FROM_PATH tag # can be used to strip a user-defined part of the path. Stripping is @@ -552,7 +552,7 @@ # directories like "/usr/src/myproject". Separate the files or directories # with spaces. -INPUT = "./" "../include/TaskManager" "./kernel" "./kernel/schedule" "./kernel/ppe" "./kernel/sys_task" "./Fifo" "./Test" "./Test/Sum" "./Test/test_render" "./Test/test_render/xml_file" "./Test/test_render/xml_file/blend" "./Test/test_render/xml_file/blend/images" "./Test/test_render/task" "./Test/test_render/spe" "./Test/test_render/tools" "./Test/simple_render" "./Test/simple_render/task" "./Test/simple_render/test" "./Test/simple_render/test/LoadTexture" "./Test/simple_render/test/LoadTexture/spe" "./Test/simple_render/spe" "./Test/simple_render/trash" "./Test/simple_pack" "./Test/simple_pack/task" "./Test/simple_pack/trash" "./Cell" "./Cell/spe" +INPUT = # This tag can be used to specify the character encoding of the source files # that doxygen parses. Internally doxygen uses the UTF-8 encoding, which is @@ -569,7 +569,7 @@ # *.c *.cc *.cxx *.cpp *.c++ *.java *.ii *.ixx *.ipp *.i++ *.inl *.h *.hh *.hxx # *.hpp *.h++ *.idl *.odl *.cs *.php *.php3 *.inc *.m *.mm *.py *.f90 -FILE_PATTERNS = "*.cc" "*.h" "*.py" +FILE_PATTERNS = # The RECURSIVE tag can be used to turn specify whether or not subdirectories # should be searched for input files as well. Possible values are YES and NO. @@ -623,7 +623,7 @@ # commands irrespective of the value of the RECURSIVE tag. # Possible values are YES and NO. If left blank NO is used. -EXAMPLE_RECURSIVE = YES +EXAMPLE_RECURSIVE = NO # The IMAGE_PATH tag can be used to specify one or more files or # directories that contain image that are included in the documentation (see @@ -665,7 +665,7 @@ # Note: To get rid of all source code in the generated output, make sure also # VERBATIM_HEADERS is set to NO. -SOURCE_BROWSER = YES +SOURCE_BROWSER = NO # Setting the INLINE_SOURCES tag to YES will include the body # of functions and classes directly in the documentation. diff -r c5e3b75654dd -r aaf73e612f73 TaskManager/Makefile.cell --- a/TaskManager/Makefile.cell Thu Apr 29 22:56:28 2010 +0900 +++ b/TaskManager/Makefile.cell Thu Apr 29 23:12:48 2010 +0900 @@ -12,6 +12,7 @@ $(CELL_SPE_DIR)/SchedMail.cc \ $(CELL_SPE_DIR)/SchedTask.cc \ $(CELL_SPE_DIR)/SchedTaskArray.cc \ + $(CELL_SPE_DIR)/SchedTaskArrayNop.cc \ $(CELL_SPE_DIR)/SchedTaskArrayLoad.cc \ $(CELL_SPE_DIR)/Scheduler.cc\ $(CELL_SPE_DIR)/SchedNop.cc \ diff -r c5e3b75654dd -r aaf73e612f73 TaskManager/kernel/ppe/HTask.h --- a/TaskManager/kernel/ppe/HTask.h Thu Apr 29 22:56:28 2010 +0900 +++ b/TaskManager/kernel/ppe/HTask.h Thu Apr 29 23:12:48 2010 +0900 @@ -5,6 +5,7 @@ #include "types.h" #include "Task.h" #include "TaskQueueInfo.h" +#include class TaskManagerImpl; class SchedTask; @@ -66,12 +67,20 @@ t->set_outData_t(out_index++, addr,size); } void set_inData_t(int index, memaddr addr, int size) { + if ((unsigned long)addr&0xf) { + printf("inData is not aligned. command = %d, index = %d, addr = 0x%lx, size = %d\n", + command, index, (unsigned long)addr, size); + } Task *t = (Task*)rbuf; t->set_inData_t(index, addr,size); } void set_outData_t(int index, memaddr addr, int size) { + if ((unsigned long)addr&0xf) { + printf("inData is not aligned. command = %d, index = %d, addr = 0x%lx, size = %d\n", + command, index, (unsigned long)addr, size); + } Task *t = (Task*)rbuf; - t->set_inData_t(index, addr,size); + t->set_outData_t(index, addr,size); } void add_param_t(memaddr param) { Task *t = (Task*)rbuf; diff -r c5e3b75654dd -r aaf73e612f73 TaskManager/kernel/ppe/Task.h --- a/TaskManager/kernel/ppe/Task.h Thu Apr 29 22:56:28 2010 +0900 +++ b/TaskManager/kernel/ppe/Task.h Thu Apr 29 23:12:48 2010 +0900 @@ -6,7 +6,6 @@ #include "ListData.h" #include "SimpleTask.h" - class SchedTask; class Scheduler; diff -r c5e3b75654dd -r aaf73e612f73 TaskManager/kernel/schedule/SchedTaskArray.cc --- a/TaskManager/kernel/schedule/SchedTaskArray.cc Thu Apr 29 22:56:28 2010 +0900 +++ b/TaskManager/kernel/schedule/SchedTaskArray.cc Thu Apr 29 23:12:48 2010 +0900 @@ -1,4 +1,5 @@ #include "SchedTaskArray.h" +#include "SchedTaskArrayNop.h" #include "Scheduler.h" @@ -154,6 +155,12 @@ // Task List が残っているので、次を準備 return new SchedTaskArray(scheduler, savedTask, next, array); } else { + + //このTaskArrayは終わったが、Pipeline 上にread の TaskArray が残っているので + //1ステージを稼ぐ必要がある + + return new SchedTaskArrayNop(scheduler, savedTask, next, array); +#if 0 // このTaskArrayは終り。save していた Task の次を返す。 // savedTask の read/exec は実行されない (command = TaskArray) SchedTaskBase *n = savedTask->next(scheduler, savedTask); @@ -161,6 +168,8 @@ free(array); delete savedTask; return n; +#endif + } } diff -r c5e3b75654dd -r aaf73e612f73 TaskManager/kernel/schedule/SchedTaskArrayNop.cc --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/TaskManager/kernel/schedule/SchedTaskArrayNop.cc Thu Apr 29 23:12:48 2010 +0900 @@ -0,0 +1,77 @@ +#include "SchedTaskArrayNop.h" +#include "Scheduler.h" + + +SchedTaskArrayNop::SchedTaskArrayNop(Scheduler *s, SchedTaskBase *savedTask_, Task *curTask_, Task *_array) +{ + savedTask = savedTask_; + atask = (memaddr)savedTask->task->self; + array = _array; + scheduler = s; + + inListData.bound = 0; + inListData.size = 0; + inListData.length = 0; + inListData.element = 0; + outListData.bound = 0; + outListData.size = 0; + outListData.length = 0; + outListData.element = 0; +} + + + +/** + */ +SchedTaskArrayNop::~SchedTaskArrayNop() +{ +} + + +/** + * Task data / code read + */ +void +SchedTaskArrayNop::read() +{ + +} + +/** + * Wait read data and execute task + * Start write DMA + */ +void +SchedTaskArrayNop::exec() +{ + +} + +/** + * Wait write DMA + * send finish mail + */ +void +SchedTaskArrayNop::write() +{ + + scheduler->mail_write((memaddr)atask); + free(array); + +} + +SchedTaskBase* +SchedTaskArrayNop::next(Scheduler *scheduler, SchedTaskBase *p) +{ + + // 最後のTask が exec されて、次の Task を実行してかまわない。 + + SchedTaskBase *n = savedTask->next(scheduler, savedTask); + + delete savedTask; + return n; + +} + + +/* end */ diff -r c5e3b75654dd -r aaf73e612f73 TaskManager/kernel/schedule/SchedTaskArrayNop.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/TaskManager/kernel/schedule/SchedTaskArrayNop.h Thu Apr 29 23:12:48 2010 +0900 @@ -0,0 +1,39 @@ +#ifndef INCLUDED_SCHED_TASK_ARRAY_NOP +#define INCLUDED_SCHED_TASK_ARRAY_NOP + +#include "base.h" +#include "Scheduler.h" +#include "SchedTask.h" + + +class SchedTaskArrayNop : public SchedTask { +public: + BASE_NEW_DELETE(SchedTaskArrayNop); + + /* constructor */ + SchedTaskArrayNop(Scheduler *s, SchedTaskBase *savedTask_, Task *task_, Task *array_); + + virtual ~SchedTaskArrayNop(); + + + SchedTaskBase *savedTask; + Task *array; + +private: + /* variables */ + + memaddr atask; + + /* functions */ + + // override + void read(); + void exec(); + void write(); + SchedTaskBase* next(Scheduler *, SchedTaskBase *); + +}; + + +#endif + diff -r c5e3b75654dd -r aaf73e612f73 TaskManager/kernel/schedule/Scheduler.cc --- a/TaskManager/kernel/schedule/Scheduler.cc Thu Apr 29 22:56:28 2010 +0900 +++ b/TaskManager/kernel/schedule/Scheduler.cc Thu Apr 29 23:12:48 2010 +0900 @@ -437,7 +437,7 @@ int Scheduler::printf(const char * format, ...) { -#if !defined(__SPU__) +#if !defined(__SPU__) || 1 va_list ap; va_start(ap,format); int ret= vprintf0(format, ap); @@ -452,7 +452,7 @@ int Scheduler::vprintf0(const char * format, va_list ap) { -#if !defined(__SPU__) +#if !defined(__SPU__) || 1 int ret= vprintf(format, ap); return ret; #else diff -r c5e3b75654dd -r aaf73e612f73 example/Bulk/main.cc --- a/example/Bulk/main.cc Thu Apr 29 22:56:28 2010 +0900 +++ b/example/Bulk/main.cc Thu Apr 29 23:12:48 2010 +0900 @@ -10,12 +10,14 @@ static int length = DATA_NUM; static int task = 3; -static int count = 3; -static int data_count = 3; +static int task_array_num = 3; +static int block_num = 3; -const char *usr_help_str = "Usage: ./twice [-length data_length] [-count task_num]\n\ - -length Number of data (default DATA_NUM (Func.h))\n\ - -count Number of task (default 1)\n"; +const char *usr_help_str = "Usage: ./twice [-length data_length] [-task_array_num task_num]\n\ + -task_array_num Number of data in a block (default 16)\n\ + -block_num Number of block\n\ + -task Number of task\n\ + -block_size Size of a block\n"; static void @@ -36,7 +38,7 @@ { int* data = (int*)a; int* task_buf = (int*)b; - print_data(data, length*count, "after"); + print_data(data, length*task_array_num, "after"); free(data); free(task_buf); } @@ -44,17 +46,19 @@ static int init(int argc, char **argv) { + int block_size = 16; for (int i = 1; argv[i]; ++i) { - if (strcmp(argv[i], "-length") == 0) { - length = atoi(argv[++i]); - } else if (strcmp(argv[i], "-task") == 0) { + if (strcmp(argv[i], "-task") == 0) { task = atoi(argv[++i]); - } else if (strcmp(argv[i], "-count") == 0) { - count = atoi(argv[++i]); - } else if (strcmp(argv[i], "-data_count") == 0) { - data_count = atoi(argv[++i]); + } else if (strcmp(argv[i], "-task_array_num") == 0) { + task_array_num = atoi(argv[++i]); + } else if (strcmp(argv[i], "-block_num") == 0) { + block_num = atoi(argv[++i]); + } else if (strcmp(argv[i], "-block_size") == 0) { + block_size = atoi(argv[++i]); } } + length = task_array_num * block_num * block_size; return 0; } @@ -73,54 +77,54 @@ { - for (int i = 0; i < length*count; i++) { + for (int i = 0; i < length*task_array_num; i++) { data[i] = i; } - print_data(data, length*count, "before"); + print_data(data, length*task_array_num, "before"); /** * Create Task * create_task(Task ID); */ - HTask *twice_main = manager->create_task_array(Twice,count,data_count+1,data_count,data_count); + HTask *twice_main = manager->create_task_array(Twice,task_array_num,block_num+1,block_num,block_num); Task *t = twice_main->next_task_array(Twice, 0); #if 0 printf("allocate task size 0x%0x\n",t->size()); printf("allocate task total size 0x%0x = 0x%0x * %d\n",twice_main->r_size, - t->size(), count); + t->size(), task_array_num); #endif void *task_buf = twice_main->rbuf; twice_main->set_post(twice_result, (void*)data, task_buf); t = 0; - for(int i = 0;inext_task_array(Twice, t); - int length2 = length/data_count; - t->set_param(0, (memaddr)data_count); + int block_size = length/block_num; + t->set_param(0, (memaddr)block_num); - for(int j = 0;jset_param(j+1, (memaddr)length2); + t->set_param(j+1, (memaddr)block_size); /** * Set of Input Data * add_inData(address of input data, size of input data); */ - t->set_inData(j,data, sizeof(int)*length2); + t->set_inData(j,data, sizeof(int)*block_size); /** * Set of Output area * add_outData(address of output area, size of output area); */ - t->set_outData(j,data, sizeof(int)*length2); - data += length2; + t->set_outData(j,data, sizeof(int)*block_size); + data += block_size; } #if 0 - print_ListData(data_count,t->inData(0)); - print_ListData(data_count,t->outData(0)); + print_ListData(block_num,t->inData(0)); + print_ListData(block_num,t->outData(0)); printf("pos 0x%0lx size 0x%0x\n",(unsigned long)t, t->size()); #endif } @@ -146,7 +150,7 @@ task_init(); for (int i = 0; i < task; ++i) { - int *data = (int*)manager->allocate(sizeof(int)*length*count); + int *data = (int*)manager->allocate(sizeof(int)*length*task_array_num); twice_init(manager, data, length); } diff -r c5e3b75654dd -r aaf73e612f73 example/Bulk/ppe/Twice.cc --- a/example/Bulk/ppe/Twice.cc Thu Apr 29 22:56:28 2010 +0900 +++ b/example/Bulk/ppe/Twice.cc Thu Apr 29 23:12:48 2010 +0900 @@ -4,10 +4,10 @@ #include "Func.h" /* これは必須 */ -SchedDefineTask(Twice); +SchedDefineTask1(Twice,twice_run); static int -run(SchedTask *s,void *rbuf, void *wbuf) +twice_run(SchedTask *s,void *rbuf, void *wbuf) { // SchedTaskArray *a = (SchedTaskArray *)s; diff -r c5e3b75654dd -r aaf73e612f73 example/Bulk/spe/Twice.cc --- a/example/Bulk/spe/Twice.cc Thu Apr 29 22:56:28 2010 +0900 +++ b/example/Bulk/spe/Twice.cc Thu Apr 29 23:12:48 2010 +0900 @@ -14,9 +14,9 @@ int *i_data; int *o_data; long length; - int count = (int)s->get_param(0); + int data_count = (int)s->get_param(0); - for(int j = 0; jget_input(rbuf, j); o_data = (int*)s->get_output(wbuf, j); length = (long)s->get_param(j+1); diff -r c5e3b75654dd -r aaf73e612f73 example/HelloWorld/main.cc --- a/example/HelloWorld/main.cc Thu Apr 29 22:56:28 2010 +0900 +++ b/example/HelloWorld/main.cc Thu Apr 29 23:12:48 2010 +0900 @@ -30,14 +30,15 @@ void hello_init(TaskManager *manager) { - HTask *hello; + for (int i = 0; i < count; i++) { /** * Create Task * create_task(Task ID); */ - hello = manager->create_task(HELLO_TASK); + + HTask *hello = manager->create_task(HELLO_TASK); /** * Select CPU @@ -50,7 +51,7 @@ * Set 32bits parameter * add_param(32bit parameter); */ - hello->add_param((memaddr)i); + hello->set_param(0,(memaddr)i); hello->spawn(); } diff -r c5e3b75654dd -r aaf73e612f73 example/hello_array/main.cc --- a/example/hello_array/main.cc Thu Apr 29 22:56:28 2010 +0900 +++ b/example/hello_array/main.cc Thu Apr 29 23:12:48 2010 +0900 @@ -32,8 +32,6 @@ void hello_init(TaskManager *manager) { - - /** * Create Task * create_task(Task ID); @@ -46,7 +44,6 @@ for(int i = 0;inext_task_array(Hello, t); } - twice_main->spawn_task_array(t->next()); twice_main->set_cpu(SPE_ANY); twice_main->spawn(); diff -r c5e3b75654dd -r aaf73e612f73 example/word_count/Makefile.def --- a/example/word_count/Makefile.def Thu Apr 29 22:56:28 2010 +0900 +++ b/example/word_count/Makefile.def Thu Apr 29 23:12:48 2010 +0900 @@ -7,7 +7,7 @@ # ex linux/ps3 CERIUM = ../../../Cerium -OPT = -O9 +OPT = -g #-O9 CC = g++ CFLAGS = -Wall $(OPT) diff -r c5e3b75654dd -r aaf73e612f73 example/word_count/main.cc --- a/example/word_count/main.cc Thu Apr 29 22:56:28 2010 +0900 +++ b/example/word_count/main.cc Thu Apr 29 23:12:48 2010 +0900 @@ -82,8 +82,8 @@ /* 1task分のデータサイズ(byte) */ int division_size; - if (size >= 4096*4) { - division_size = 4096 * 4;/*16kbyte*/ + if (size >= 1024*16) { + division_size = 1024 * 16;/*16kbyte*/ } else { division_size = size; @@ -111,53 +111,63 @@ /*各SPEの結果を合計して出力するタスク*/ t_print = manager->create_task(TASK_PRINT); - t_print->add_inData(o_data, out_size); - t_print->add_param(out_task_num); - t_print->add_param(status_num); + t_print->set_inData(0,o_data, out_size); + t_print->set_param(0,out_task_num); + t_print->set_param(1,status_num); /*各SPEに処理するデータを割り振る。*/ /*渡すデータの最後が文字かどうか。(スペース、改行以外)*/ int word_flag = 0; - int i; - int task_size = 32; - for (i = 0; i < task_num; i+=task_size) { - HTask *task_main = manager->create_task_array(TASK_EXEC,task_size,2,1,1); + int index = 0; + int array_task_num = 32; + for (int i = 0; i < task_num; i += array_task_num) { + HTask *task_main = manager->create_task_array(TASK_EXEC,array_task_num,2,1,1); + t_print->wait_for(task_main); int j ; Task *t_exec = 0; - for(j = 0; j < task_size; j++) { + for(j = 0; j < array_task_num; j++) { t_exec = task_main->next_task_array(TASK_EXEC,t_exec); - task_main->set_cpu(SPE_ANY); - t_print->wait_for(task_main); // t_exec = manager->create_task(TASK_EXEC); t_exec->set_param(0,division_size); t_exec->set_param(1,word_flag); - t_exec->set_inData(0,file_mmap + i*division_size, division_size); - t_exec->set_outData(0,o_data + i*status_num, division_out_size); + + //printf("%c",file_mmap[index*division_size]); - word_flag = ((file_mmap[(i+1)*division_size-1] != 0x20) && (file_mmap[(i+1)*division_size-1] != 0x0A)); + t_exec->set_inData(0,&file_mmap[index*division_size], division_size); + t_exec->set_outData(0,&o_data[index*status_num], division_out_size); + + word_flag = ((file_mmap[(index+1)*division_size-1] != 0x20) && (file_mmap[(index+1)*division_size-1] != 0x0A)); size -= division_size; + index++; + } + task_main->spawn_task_array(t_exec->next()); + task_main->set_cpu(SPE_ANY); + task_main->spawn(); } + //printf("size %d\n",size); + while (size>0) { t_exec = manager->create_task(TASK_EXEC); t_exec->set_param(0,size); t_exec->set_param(1,word_flag); - t_exec->set_inData(0,file_mmap + i*division_size, size); - t_exec->set_outData(0,o_data + i*status_num, division_out_size); + t_exec->set_inData(0,file_mmap + index*division_size, size); + t_exec->set_outData(0,o_data + index*status_num, division_out_size); t_exec->set_cpu(SPE_ANY); t_print->wait_for(t_exec); t_exec->spawn(); - i++; + index++; size -= division_size; } + //printf("size %d\n", st_mmap.size - index*division_size); t_print->spawn(); } diff -r c5e3b75654dd -r aaf73e612f73 example/word_count/ppe/Exec.cc --- a/example/word_count/ppe/Exec.cc Thu Apr 29 22:56:28 2010 +0900 +++ b/example/word_count/ppe/Exec.cc Thu Apr 29 23:12:48 2010 +0900 @@ -19,29 +19,26 @@ word_num -= word_flag; + for (i=0; i < length; i++) { //s->printf("[SPE%d]%c",id,i_data[i]); - - if((i_data[i] != 0x20) && (i_data[i] != 0x0A)) { - //s->printf("文字 数 = %d\n", word_num + word_flag); - word_num += word_flag; - word_flag = 0; - } - - if (i_data[i] == 0x20) { - //printf("スペース\n"); - word_flag = 1; - } - - if (i_data[i] == 0x0A) { - //printf("改行\n"); - line_num += 1; - word_flag = 1; - } - + + if((i_data[i] != 0x20) && (i_data[i] != 0x0A)) { + //s->printf("文字 数 = %d\n", word_num + word_flag); + word_num += word_flag; + word_flag = 0; + } else if (i_data[i] == 0x20) { + //printf("スペース\n"); + word_flag = 1; + } else if (i_data[i] == 0x0A) { + //printf("改行\n"); + line_num += 1; + word_flag = 1; + } + } - + word_num += word_flag; // printf("PPE word %d line %d\n",word_num,line_num); diff -r c5e3b75654dd -r aaf73e612f73 example/word_count/ppe/Print.cc --- a/example/word_count/ppe/Print.cc Thu Apr 29 22:56:28 2010 +0900 +++ b/example/word_count/ppe/Print.cc Thu Apr 29 23:12:48 2010 +0900 @@ -26,8 +26,8 @@ } } - for (int i = status_num; i > 0; i--) { - s->printf("%llu ",word_data[i-1]); + for (int i = 0; i < status_num; i++) { + s->printf("%llu ",word_data[status_num - i - 1]); } s->printf("\n"); diff -r c5e3b75654dd -r aaf73e612f73 example/word_count/spe/Exec.cc --- a/example/word_count/spe/Exec.cc Thu Apr 29 22:56:28 2010 +0900 +++ b/example/word_count/spe/Exec.cc Thu Apr 29 23:12:48 2010 +0900 @@ -11,8 +11,9 @@ { char *i_data = (char*)s->get_input(rbuf, 0); unsigned long long *o_data = (unsigned long long*)s->get_output(wbuf, 0); - long length = (long)s->get_param(0); - long word_flag = 1-(long)s->get_param(1); + int length = (int)s->get_param(0); + int word_flag = 1-(int)s->get_param(1); + //int word_flag = (int)s->get_param(1); int word_num = 0; int line_num = 0; int i ; @@ -23,18 +24,14 @@ //s->printf("[SPE%d]%c",id,i_data[i]); - if((i_data[i] != 0x20) && (i_data[i] != 0x0A)) { + if ((i_data[i] != 0x20) && (i_data[i] != 0x0A)) { //s->printf("文字 数 = %d\n", word_num + word_flag); word_num += word_flag; word_flag = 0; - } - - if (i_data[i] == 0x20) { + } else if (i_data[i] == 0x20) { //printf("スペース\n"); word_flag = 1; - } - - if (i_data[i] == 0x0A) { + } else if (i_data[i] == 0x0A) { //printf("改行\n"); line_num += 1; word_flag = 1;