view src/parallel_execution/context.h @ 130:2bb5e4f0fd35

Stackinterface
author ikkun
date Mon, 10 Oct 2016 20:19:26 +0900
parents 36ac17d37be4
children a4507906938c
line wrap: on
line source

/* Context definition for llrb example */
#include <pthread.h>
#ifdef USE_CUDA
#include <cuda.h>
#endif
#include "stack.h"

#define ALLOCATE_SIZE 20000000
#define NEW(type) (type*)(calloc(1, sizeof(type)))
#define NEWN(n, type) (type*)(calloc(n, sizeof(type)))

#define ALLOC_DATA(context, dseg) ({ context->data[dseg] = context->heap; context->heap += sizeof(struct dseg); (struct dseg *)context->data[dseg]; })

#define ALLOC_DATA_TYPE(context, dseg, type) ({ context->data[dseg] = context->heap; context->heap += sizeof(struct type); (struct type *)context->data[dseg]; })

enum Code {
    Code1,
    Code2,
    Code3,
    Code4,
    Code5,
    Find,
    Not_find,
    Code6,
    Allocator,
    PutTree,
    Replace,
    Replace1,
    Insert,
    Compare,
    RotateL,
    RotateR,
    SetTree,
    InsertCase1,
    InsertCase2,
    InsertCase3,
    InsertCase31,
    InsertCase4,
    InsertCase4_01,
    InsertCase4_02,
    InsertCase4_1,
    InsertCase4_2,
    InsertCase5,
    StackClear,
    Get,
    Search,
    Delete,
    Delete1,
    Delete2,
    Delete3,
    Replace_d1,
    Replace_d2,
    FindMax1,
    FindMax2,
    DeleteCase1,
    DeleteCase2,
    DeleteCase3,
    DeleteCase4,
    DeleteCase5,
    DeleteCase6,
    CreateWorker,
    TaskManager,
    CreateData1,
    CreateData2,
    CreateTask1,
    CreateTask2,
    CreateTask3,
    CreateTask4,
    PutQueue1,
    PutQueue2,
    PutQueue3,
    PutQueue4,
    GetQueue,
    SpawnTask,
    Twice,
    StartTime,
    EndTime,
    Exit,
};

enum Relational {
    EQ,
    GT,
    LT,
};

enum DataType {
    Worker,
    Allocate,
    Tree,
    Traverse,
    Node,
    LoopCounter,
    Time,
    Element,
    ActiveQueue,
    WaitQueue,
    Queue,
};

struct Context {
    enum Code next;
    int codeNum;
    __code (**code) (struct Context*);
    void* heapStart;
    void* heap;
    long heapLimit;
    pthread_t thread;
    int thread_num;
    stack_ptr code_stack;
    stack_ptr node_stack;
    int dataNum;
    union Data **data;
};

struct QueueInterface {
    enum Code put;
    enum Code get;
    enum Code isEmpty;
};

struct StackInterface {
    enum Code push;
    enum Code pop;
    enum Code isEmpty;
};

union Data {
    enum DataType type;
    struct Time {
        enum Code next;
        double time;
    } time;
    struct LoopCounter {
        int i;
    } loopCounter;
    struct Worker {
        int num;
        struct Context* contexts;
    } worker;
#ifdef USE_CUDA
    struct CudaTask {
        CUdevice device;
        CUcontext cuCtx;
        CUfunction code;
        CUdeviceptr* deviceptr;
        CUstream stream;
    } cudatask;
#endif
    struct Task {
        enum Code code;
        int key;
        struct Queue* waitMe;
        struct Queue* waitI;
        int idsCount;
    } task;
    struct Queue {
        struct Element* first;
        struct Element* last;
        int count;
        struct QueueInterface* i;
        enum Code next;
    } queue;
    struct Stack {
        union StackSelf* stack;
        union Data* data;
        enum Code push;
        enum Code pop;
        enum Code isEmpty;
        enum Code next;
    };
    union StackSelf {
        struct SingleLinkedStack {
            struct Stack i;
            struct Element* top;
        } singleLinekedStack;
        struct ArrayStack {
            int size;
            int limit;
            struct Element* array;
        }
    };
    struct Element {
        union Data* data;
        struct Element* next;
    } element;
    struct Array {
        int index;
        int prefix;
        int* array;
    } array;
    struct Tree {
        struct Node* root;
    } tree;
    struct Traverse {
        enum Code next;
        enum Code rotateNext;
        struct Node* current; // reading node of original tree
        struct Node* newNode; // writing node of new tree
        struct Element* nodeStack;
        int result;
    } traverse;
    struct Node {
        int key; // comparable data segment
        union Data* value;
        struct Node* left;
        struct Node* right;
        // need to balancing
        enum Color {
            Red,
            Black,
        } color;
    } node;
    struct Allocate {
        enum Code next;
        long size;
    } allocate;
    struct OutPutDataSegments {
        union Data **data;
    } ods;
};

union MetaData {
    struct Queue waitMeTasks;
    struct Queue waitI;
};