annotate src/context.h @ 47:233a68a261fe

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