annotate src/context.h @ 41:087d7b61c86b

cbc cmake version
author kono
date Sat, 02 Mar 2019 19:01:03 +0900
parents
children 233a68a261fe
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
41
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
1 /* Context definition for llrb example */
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
2 #ifndef CONTEXT_H
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
3 #define CONTEXT_H
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
4 #include <stdlib.h>
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
5 #include <pthread.h>
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
6 #ifdef USE_CUDAWorker
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
7 #include <cuda.h>
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
8 #include <driver_types.h>
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
9 #include <cuda_runtime.h>
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
10 #include "helper_cuda.h"
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
11 #endif
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
12
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
13 #define ALLOCATE_SIZE 20000000
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
14 #define NEW(type) (type*)(calloc(1, sizeof(type)))
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
15 #define NEWN(n, type) (type*)(calloc(n, sizeof(type)))
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
16
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
17 #define ALLOC_DATA(context, dseg) ({\
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
18 Meta* meta = (Meta*)context->heap;\
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
19 meta->type = D_##dseg;\
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
20 meta->size = sizeof(dseg);\
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
21 meta->len = 1;\
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
22 context->heap += sizeof(Meta);\
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
23 context->data[D_##dseg] = context->heap; context->heap += sizeof(dseg); (dseg *)context->data[D_##dseg]; })
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
24
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
25 #define ALLOC_DATA_TYPE(context, dseg, t) ({\
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
26 Meta* meta = (Meta*)context->heap;\
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
27 meta->type = D_##t;\
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
28 meta->size = sizeof(t);\
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
29 meta->len = 1;\
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
30 context->heap += sizeof(Meta);\
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
31 context->data[D_##dseg] = context->heap; context->heap += sizeof(t); (t *)context->data[D_##dseg]; })
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
32
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
33 #define ALLOCATE(context, t) ({ \
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
34 Meta* meta = (Meta*)context->heap;\
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
35 context->heap += sizeof(Meta);\
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
36 union Data* data = context->heap; \
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
37 context->heap += sizeof(t); \
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
38 meta->type = D_##t; \
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
39 meta->size = sizeof(t); \
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
40 meta->len = 1;\
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
41 data; })
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
42
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
43 #define ALLOCATE_ARRAY(context, t, length) ({ \
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
44 Meta* meta = (Meta*)context->heap;\
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
45 context->heap += sizeof(Meta);\
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
46 union Data* data = context->heap; \
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
47 context->heap += sizeof(t)*length; \
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
48 meta->type = D_##t; \
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
49 meta->size = sizeof(t)*length; \
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
50 meta->len = length; \
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
51 data; })
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
52
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
53 #define ALLOCATE_PTR_ARRAY(context, dseg, length) ({\
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
54 Meta* meta = (Meta*)context->heap;\
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
55 context->heap += sizeof(Meta);\
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
56 union Data* data = context->heap; \
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
57 context->heap += sizeof(dseg *)*length; \
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
58 meta->type = D_##dseg; \
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
59 meta->size = sizeof(dseg *)*length; \
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
60 meta->len = length; \
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
61 data; })
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
62
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
63 #define ALLOCATE_DATA_GEAR(context, t) ({ \
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
64 union Data* data = ALLOCATE(context, t); \
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
65 Meta* meta = GET_META(data); \
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
66 meta->wait = createSynchronizedQueue(context); \
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
67 data; })
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
68
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
69 #define ALLOC(context, t) (&ALLOCATE(context, t)->t)
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
70
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
71 #define GET_META(dseg) ((Meta*)(((void*)dseg) - sizeof(Meta)))
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
72 #define GET_TYPE(dseg) (GET_META(dseg)->type)
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
73 #define GET_SIZE(dseg) (GET_META(dseg)->size)
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
74 #define GET_LEN(dseg) (GET_META(dseg)->len)
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
75 #define GET_WAIT_LIST(dseg) (GET_META(dseg)->wait)
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
76
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
77 #define Gearef(context, t) (&(context)->data[D_##t]->t)
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
78
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
79 // (SingleLinkedStack *)context->data[D_Stack]->Stack.stack->Stack.stack
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
80
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
81 #define GearImpl(context, intf, name) (Gearef(context, intf)->name->intf.name)
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
82
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
83 #include "c/enumCode.h"
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
84
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
85 enum Relational {
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
86 EQ,
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
87 GT,
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
88 LT,
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
89 };
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
90
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
91 #include "c/enumData.h"
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
92
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
93 struct Context {
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
94 enum Code next;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
95 struct Worker* worker;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
96 struct TaskManager* taskManager;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
97 int codeNum;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
98 __code (**code) (struct Context*);
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
99 union Data **data;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
100 void* heapStart;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
101 void* heap;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
102 long heapLimit;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
103 int dataNum;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
104
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
105 // task parameter
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
106 int idgCount; //number of waiting dataGear
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
107 int idg;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
108 int maxIdg;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
109 int odg;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
110 int maxOdg;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
111 int gpu; // GPU task
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
112 struct Context* task;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
113 struct Element* taskList;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
114 #ifdef USE_CUDAWorker
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
115 int num_exec;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
116 CUmodule module;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
117 CUfunction function;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
118 #endif
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
119 /* multi dimension parameter */
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
120 int iterate;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
121 struct Iterator* iterator;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
122 enum Code before;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
123 };
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
124
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
125 typedef int Int;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
126 #ifndef USE_CUDAWorker
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
127 typedef unsigned long long CUdeviceptr;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
128 #endif
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
129 union Data {
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
130 struct Meta {
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
131 enum DataType type;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
132 long size;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
133 long len;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
134 struct Queue* wait; // tasks waiting this dataGear
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
135 } Meta;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
136 struct Context Context;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
137 struct Timer {
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
138 union Data* timer;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
139 enum Code start;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
140 enum Code end;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
141 enum Code next;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
142 } Timer;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
143 struct TimerImpl {
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
144 double time;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
145 } TimerImpl;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
146 struct LoopCounter {
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
147 int i;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
148 } LoopCounter;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
149 struct TaskManager {
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
150 union Data* taskManager;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
151 enum Code spawn; // start NEW context on the worker
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
152 enum Code spawnTasks; // start NEW tasks on the worker
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
153 enum Code shutdown;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
154 enum Code incrementTaskCount;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
155 enum Code decrementTaskCount;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
156 enum Code next;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
157 enum Code next1;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
158 enum Code setWaitTask;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
159 struct Context* task;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
160 struct Element* taskList;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
161 union Data* data;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
162 } TaskManager;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
163 struct TaskManagerImpl {
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
164 enum Code next;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
165 int numWorker;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
166 int sendCPUWorkerIndex;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
167 int sendGPUWorkerIndex;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
168 int taskCount;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
169 pthread_mutex_t mutex;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
170 struct Queue* activeQueue;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
171 struct Worker** workers;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
172 struct Element* taskList;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
173 int loopCounter;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
174 int cpu;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
175 int gpu;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
176 int io;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
177 int maxCPU;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
178 } TaskManagerImpl;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
179 struct Worker {
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
180 union Data* worker;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
181 enum Code taskReceive;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
182 enum Code shutdown;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
183 enum Code next;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
184 struct Queue* tasks;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
185 pthread_t thread;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
186 struct TaskManager* taskManager;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
187 struct Context* task;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
188 } Worker;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
189 struct CPUWorker {
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
190 pthread_mutex_t mutex;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
191 pthread_cond_t cond;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
192 struct Context* context;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
193 int id;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
194 int loopCounter;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
195 } CPUWorker;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
196 #ifdef USE_CUDAWorker
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
197 struct CUDAWorker {
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
198 CUdevice device;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
199 CUcontext cuCtx;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
200 struct Context* context;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
201 int id;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
202 int loopCounter;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
203 int deviceNum;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
204 struct Queue* tasks;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
205 int runFlag;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
206 enum Code next;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
207 int numStream;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
208 struct Executor* executor;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
209 CUstream *stream;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
210 } CUDAWorker;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
211 #else
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
212 struct CUDAWorker {
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
213 } CUDAWorker;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
214 #endif
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
215 struct Main {
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
216 enum Code code;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
217 enum Code next;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
218 struct Queue* args;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
219 } Main;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
220 // Queue Interface
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
221 struct Queue {
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
222 union Data* queue;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
223 union Data* data;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
224 enum Code whenEmpty;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
225 enum Code clear;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
226 enum Code put;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
227 enum Code take;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
228 enum Code isEmpty;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
229 enum Code next;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
230 } Queue;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
231 struct SingleLinkedQueue {
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
232 struct Element* top;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
233 struct Element* last;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
234 } SingleLinkedQueue;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
235 struct SynchronizedQueue {
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
236 struct Element* top;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
237 struct Element* last;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
238 struct Atomic* atomic;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
239 } SynchronizedQueue;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
240 // Stack Interface
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
241 struct Stack {
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
242 union Data* stack;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
243 union Data* data;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
244 union Data* data1;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
245 enum Code whenEmpty;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
246 enum Code clear;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
247 enum Code push;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
248 enum Code pop;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
249 enum Code pop2;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
250 enum Code isEmpty;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
251 enum Code get;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
252 enum Code get2;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
253 enum Code next;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
254 } Stack;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
255 // Stack implementations
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
256 struct SingleLinkedStack {
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
257 struct Element* top;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
258 } SingleLinkedStack;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
259 struct ArrayStack {
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
260 int size;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
261 int limit;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
262 struct Element* array;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
263 } ArrayStack;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
264 // Stack implementation end
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
265 struct Element {
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
266 union Data* data;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
267 struct Element* next;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
268 } Element;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
269 struct Array {
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
270 int prefix;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
271 Int* array;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
272 } Array;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
273 struct Tree {
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
274 union Data* tree;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
275 struct Node* node;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
276 enum Code put;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
277 enum Code get;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
278 enum Code remove;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
279 enum Code clear;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
280 enum Code next;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
281 } Tree;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
282 struct RedBlackTree {
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
283 struct Node* root;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
284 struct Node* current; // reading node of original tree
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
285 struct Node* previous; // parent of reading node of original tree
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
286 struct Node* newNode; // writing node of new tree
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
287 struct Node* parent;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
288 struct Node* grandparent;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
289 struct Stack* nodeStack;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
290 enum Code findNodeNext;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
291 int result;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
292 } RedBlackTree;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
293 struct RotateTree {
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
294 enum Code next;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
295 struct RedBlackTree* traverse;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
296 struct Tree* tree;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
297 } RotateTree;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
298 struct Node {
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
299 int key; // comparable data segment
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
300 union Data* value;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
301 struct Node* left;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
302 struct Node* right;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
303 // need to balancing
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
304 enum Color {
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
305 Red,
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
306 Black,
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
307 // Red eq 0,Black eq 1. enum name convert intager.
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
308 } color;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
309 } Node;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
310 struct Atomic {
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
311 union Data* atomic;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
312 union Data** ptr;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
313 union Data* oldData;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
314 union Data* newData;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
315 enum Code checkAndSet;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
316 enum Code next;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
317 enum Code fail;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
318 } Atomic;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
319 struct AtomicReference {
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
320 } AtomicReference;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
321 struct Semaphore {
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
322 union Data* semaphore;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
323 enum Code p;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
324 enum Code v;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
325 enum Code next;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
326 } Semaphore;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
327 struct SemaphoreImpl {
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
328 int value;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
329 struct Lock* lock;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
330 struct Queue* waitThreadQueue;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
331 } SemaphoreImpl;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
332 struct Allocate {
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
333 enum Code next;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
334 long size;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
335 } Allocate;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
336 struct Integer {
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
337 int value;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
338 } Integer;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
339 struct SortArray {
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
340 struct Integer *array; //Array arrayじゃできない?
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
341 int loopCounter;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
342 int block;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
343 int first;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
344 int prefix;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
345 } SortArray;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
346 struct Iterator {
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
347 union Data* iterator;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
348 struct Context* task;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
349 int numGPU;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
350 enum Code exec;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
351 enum Code barrier;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
352 enum Code whenWait;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
353 enum Code next;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
354 } Iterator;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
355 struct MultiDimIterator {
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
356 int x;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
357 int y;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
358 int z;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
359 int count;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
360 int counterX;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
361 int counterY;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
362 int counterZ;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
363 } MultiDimIterator;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
364 struct MultiDim {
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
365 int x;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
366 int y;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
367 int z;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
368 } MultiDim;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
369 struct Executor {
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
370 union Data* executor;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
371 struct Context* task;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
372 enum Code read;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
373 enum Code exec;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
374 enum Code write;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
375 enum Code next;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
376 } Executor;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
377 #ifdef USE_CUDAWorker
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
378 struct CUDAExecutor {
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
379 CUdeviceptr** kernelParams;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
380 struct CUDABuffer* buffer;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
381 int maxThreadPerBlock;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
382 int maxThreadPerBlockX;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
383 int maxThreadPerBlockY;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
384 int maxThreadPerBlockZ;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
385 struct Timer* timer;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
386 } CUDAExecutor;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
387 struct CUDABuffer {
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
388 int inputLen;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
389 int outputLen;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
390 union Data** inputData;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
391 union Data** outputData;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
392 } CUDABuffer;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
393 CUdeviceptr CUdeviceptr;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
394 #else
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
395 struct CUDAExecutor {
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
396 } CUDAExecutor;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
397 struct CUDABuffer {
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
398 } CUDABuffer;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
399 CUdeviceptr CUdeviceptr;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
400 #endif
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
401 Int Int;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
402 struct Memory {
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
403 union Data* adr;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
404 int length;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
405 union Data* body;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
406 int hash;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
407 } Memory;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
408 struct Buffer {
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
409 union Data* buffer;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
410 union Data* data;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
411 enum Code put;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
412 enum Code take;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
413 enum Code next;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
414 } Buffer;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
415 struct BoundedBuffer {
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
416 struct Element* top;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
417 struct Element* last;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
418 struct Semaphore* fullCount;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
419 struct Semaphore* emptyCount;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
420 struct Semaphore* lock;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
421 } BoundedBuffer;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
422 struct Lock {
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
423 union Data* lock;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
424 enum Code doLock;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
425 enum Code doUnlock;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
426 enum Code next;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
427 } Lock;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
428 struct LockImpl {
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
429 Int* lock;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
430 struct Queue* waitThreadQueue;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
431 struct Atomic* atomic;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
432 struct Context* lockContext;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
433 } LockImpl;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
434 struct SpinLock {
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
435 volatile Int* lock;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
436 struct Atomic* atomic;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
437 struct Context* lockContext;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
438 } SpinLock;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
439 }; // union Data end this is necessary for context generator
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
440 typedef union Data Data;
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
441
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
442 #include "c/typedefData.h"
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
443
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
444 #include "c/extern.h"
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
445
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
446 extern __code start_code(struct Context* context);
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
447 extern __code exit_code(struct Context* context);
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
448 extern __code meta(struct Context* context, enum Code next);
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
449 //extern __code par_meta(struct Context* context, enum Code spawns, enum Code next);
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
450 extern __code parGotoMeta(struct Context* context, enum Code next);
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
451 extern void initContext(struct Context* context);
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
452
087d7b61c86b cbc cmake version
kono
parents:
diff changeset
453 #endif