Mercurial > hg > Game > Cerium
view example/word_count_test/WordCount.h @ 800:54f0180cea0f draft
run16 word count ( not yet worked. )
author | Shinji KONO <kono@ie.u-ryukyu.ac.jp> |
---|---|
date | Fri, 21 May 2010 07:47:25 +0900 |
parents | 87040ec6b5f6 |
children |
line wrap: on
line source
#include "TaskManager.h" typedef struct wordCount { struct wordCount *self; int size; // remaining file size int division_size; // for each word count task int division_out_size; int out_size; int task_num; // remaining task count int task_blocks; // spawn task one at a time int status_num; int task_spwaned; unsigned long long *o_data; unsigned long long *head_tail_flag; int out_task_num; int pad; char * file_mmap; HTaskPtr t_print; int waiting; int pipeline_count; HTaskPtr *wait_list; } WordCount; static inline HTask * next_wait_task(WordCount *w, HTask *next) { w->waiting = (w->waiting+1)%w->pipeline_count; HTask *wait = w->wait_list[w->waiting]; w->wait_list[w->waiting] = next; return wait; } static inline void set_pipeline_count(WordCount *w, TaskManager *m, int p) { w->pipeline_count = p; w->wait_list = (HTaskPtr *)m->allocate(sizeof(HTaskPtr)*p); bzero(w->wait_list,sizeof(HTaskPtr)*p); }