Mercurial > hg > Game > Cerium
view example/many_task/sort-compat.cc @ 1592:afcb4a3f3526 draft
merge
author | Masa <e085726@ie.u-ryukyu.ac.jp> |
---|---|
date | Mon, 01 Apr 2013 18:00:35 +0900 |
parents | 9a5f87f4b60f |
children |
line wrap: on
line source
#include "TaskManager.h" #include "SchedTask.h" #include "sort.h" #include "Func.h" #include <string.h> extern void check_data(); extern int all; // allocate task at once extern CPU_TYPE spe_cpu; SchedDefineTask1(SortCompat, sort_start_compat ); static int sort_start_compat(SchedTask *manager, void *a, void *b) { Sort *s = (Sort*)manager->get_param(0); int half_num = s->split_num-1; static int sort_count = s->split_num; // sort 完了に必要な回数 // 一つのタスクで sort する data 数 int block_num = (s->data_length + s->split_num -1)/s->split_num; int half_block_num = block_num/2; int last_block_num = s->data_length - (s->split_num-1)*block_num; int last_half_block_num = half_block_num+(last_block_num/2); if (--sort_count < 0) { return 0; } for (int i = 0; i < s->split_num-1; i++) { s->fsort[i] = manager->create_task(QUICK_SORT); s->fsort[i]->set_inData(0,&s->data[i*block_num], sizeof(Data)*block_num); s->fsort[i]->set_outData(0,&s->data[i*block_num], sizeof(Data)*block_num); if (i>0 && s->bsort[i-1]) { s->fsort[i]->wait_for(s->bsort[i-1]); } if (i<s->split_num-2 && s->bsort[i]) { s->fsort[i]->wait_for(s->bsort[i]); } s->fsort[i]->set_cpu(spe_cpu); } // 最後の block は端数なので last_block_num を使う { int i = s->split_num-1; s->fsort[i] = manager->create_task(QUICK_SORT); s->fsort[i]->set_inData(0,&s->data[i*block_num], sizeof(Data)*last_block_num); s->fsort[i]->set_outData(0,&s->data[i*block_num], sizeof(Data)*last_block_num); if (i>0 && s->bsort[i-1]) { s->fsort[i]->wait_for(s->bsort[i-1]); } s->fsort[i]->set_cpu(spe_cpu); } if (s->split_num > 1) { for (int i = 0; i < half_num-1; i++) { if (s->bsort[i]) manager->free_htask(s->bsort[i]); s->bsort[i] = manager->create_task(QUICK_SORT); s->bsort[i]->set_inData(0,&s->data[i*block_num+half_block_num], sizeof(Data)*block_num); s->bsort[i]->set_outData(0,&s->data[i*block_num+half_block_num], sizeof(Data)*block_num); s->bsort[i]->set_cpu(spe_cpu); } { int i = half_num-1; if (s->bsort[i]) manager->free_htask(s->bsort[i]); s->bsort[i] = manager->create_task(QUICK_SORT); s->bsort[i]->set_inData(0,&s->data[i*block_num+half_block_num], sizeof(Data)*last_half_block_num); s->bsort[i]->set_outData(0,&s->data[i*block_num+half_block_num], sizeof(Data)*last_half_block_num); s->bsort[i]->set_cpu(spe_cpu); } for (int i = 0; i < half_num; i++) { s->bsort[i]->wait_for(s->fsort[i]); s->bsort[i]->wait_for(s->fsort[i+1]); s->bsort[i]->no_auto_free(); s->bsort[i]->spawn(); } } HTaskPtr restart = manager->create_task(SortCompat,0,0,0,0); restart->set_param(0,(memaddr)s); if (!all) restart->wait_for(s->fsort[0]); for (int i = 0; i < s->split_num; i++) { s->fsort[i]->spawn(); } restart->spawn(); return 0; }