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);
}