Mercurial > hg > Game > Cerium
changeset 2040:bc010492ade4 draft
add cuda task with bitonic sort.
author | Shohei KOKUBO <e105744@ie.u-ryukyu.ac.jp> |
---|---|
date | Tue, 10 Mar 2015 17:41:12 +0900 |
parents | 892c77a1529f |
children | 66aa91f6f4df |
files | example/bitonic_sort/cuda/swap.cu example/bitonic_sort/cuda/task_init.cc example/bitonic_sort/main.cc example/bitonic_sort/ppe/swap.cc |
diffstat | 4 files changed, 42 insertions(+), 10 deletions(-) [+] |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/example/bitonic_sort/cuda/swap.cu Tue Mar 10 17:41:12 2015 +0900 @@ -0,0 +1,20 @@ +extern "C" { + __global__ void + swap(long* param, int* Data) + { + long block = param[0]; + long first = param[1]; + int x = blockIdx.x*blockDim.x+threadIdx.x; + + int position = x/block; + int index = x+block*position; + + block = (first == 1) ? ((block<<1)*(position+1))-(index%block)-1 : index+block; + + if (Data[block] < Data[index]) { + int tmp = Data[index]; + Data[index] = Data[block]; + Data[block] = tmp; + } + } +}
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/example/bitonic_sort/cuda/task_init.cc Tue Mar 10 17:41:12 2015 +0900 @@ -0,0 +1,9 @@ +#include "Func.h" +#include "Scheduler.h" +#include "CudaScheduler.h" + +void +gpu_task_init(void) +{ + CudaSchedRegister(SWAP, "cuda/swap.ptx", "swap"); +}
--- a/example/bitonic_sort/main.cc Thu Feb 12 17:04:03 2015 +0900 +++ b/example/bitonic_sort/main.cc Tue Mar 10 17:41:12 2015 +0900 @@ -25,7 +25,7 @@ int length = 1024; int* data; -bool flag = false; +bool wait_flag = false; static double getTime() @@ -101,24 +101,27 @@ HTask* wait; HTask* swap; + bool lastOne = false; for (int i=2; i <= length; i=2*i) { - bool first = true; + long first = 1; + lastOne = (length <= i*2) ? true : false; for (int j=i>>1; 0 < j; j=j>>1) { swap = manager->create_task(SWAP); swap->set_inData(0, data, length*sizeof(int*)); swap->set_outData(0, data, length*sizeof(int*)); swap->set_param(0, (long)j); - swap->set_param(1, (bool)first); + swap->set_param(1, (long)first); swap->set_cpu(spe_cpu); - swap->flip(); - if (flag) + if (!(lastOne && !(0 < (j>>1)))) + swap->flip(); + if (wait_flag) swap->wait_for(wait); swap->iterate(length/2); - first = false; + first = 0; wait = swap; } - flag = true; + wait_flag = true; } } @@ -140,6 +143,6 @@ { ed_time = getTime(); printf("%0.6f\n",ed_time-st_time); - //print(); + // print(); check_data(); }
--- a/example/bitonic_sort/ppe/swap.cc Thu Feb 12 17:04:03 2015 +0900 +++ b/example/bitonic_sort/ppe/swap.cc Tue Mar 10 17:41:12 2015 +0900 @@ -8,13 +8,13 @@ int* inData = (int*)s->get_input(rbuf, 0); int* outData = (int*)s->get_output(wbuf, 0); long block = (long)s->get_param(0); - bool first = (bool)s->get_param(1); + long first = (long)s->get_param(1); int x = s->x; int position = x/block; int index = x+block*position; - block = first ? ((block<<1)*(position+1))-(index%block)-1 : index+block; + block = (first == 1)? ((block<<1)*(position+1))-(index%block)-1 : index+block; if (inData[block] < inData[index]) { int tmp = inData[index];