annotate final_main/chapter5.tex @ 4:6d00f6c9bb8a

update
author mir3636
date Mon, 13 Feb 2017 16:28:35 +0900
parents 72e058e7e594
children a2e61c11df3c
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
30a433a94a9a first commit
mir3636
parents:
diff changeset
1 \chapter{Context、stub の自動生成}
2
mir3636
parents: 0
diff changeset
2
mir3636
parents: 0
diff changeset
3 Gears OS では 3 章で述べたように通常の Computation の他に Meta Computation を記述する必要がある。
4
mir3636
parents: 2
diff changeset
4
mir3636
parents: 2
diff changeset
5 \section{stub の生成}
mir3636
parents: 2
diff changeset
6
mir3636
parents: 2
diff changeset
7
2
mir3636
parents: 0
diff changeset
8
mir3636
parents: 0
diff changeset
9 \section{Context の生成}
mir3636
parents: 0
diff changeset
10 Context は Meta Data Gear に相当し、Code Gear や Data Gear を管理している。
4
mir3636
parents: 2
diff changeset
11 Data Gear を取得するために perl スクリプトは context の定義 (リスト\ref{context}) を読み宣言された Data Gear を取得する。
2
mir3636
parents: 0
diff changeset
12 Code Gear は指定された cbc ファイルから stub を見て取得を行う。
mir3636
parents: 0
diff changeset
13
4
mir3636
parents: 2
diff changeset
14 Context では Code Gear の名前とポインタの対応は生成する enum Code によって表現される。
2
mir3636
parents: 0
diff changeset
15 実際に Code Gear に接続する際は enum Code を指定することで接続を行う。
4
mir3636
parents: 2
diff changeset
16 取得した Code/Data Gear の enum の定義は enumCode.h、enumData.h に生成される。
mir3636
parents: 2
diff changeset
17 取得した Code/Data Gear から Context の生成を行うコード (リスト\ref{init_context}) を生成する。
2
mir3636
parents: 0
diff changeset
18
4
mir3636
parents: 2
diff changeset
19 Context には Allocation 等で生成した Data Gear へのポインタが格納されている。
mir3636
parents: 2
diff changeset
20 Code Gear は Context を通して Data Gear へアクセスする。
mir3636
parents: 2
diff changeset
21 Data Gear の Allocation を行うコードは dataGearInit.c に生成される。
2
mir3636
parents: 0
diff changeset
22
4
mir3636
parents: 2
diff changeset
23 Data Gear は union Data とその中の struct によって表現される。
mir3636
parents: 2
diff changeset
24 Context には Data Gear の Data Type の情報が格納されている。
mir3636
parents: 2
diff changeset
25 この情報から確保される Data Gear のサイズなどを決定する。
mir3636
parents: 2
diff changeset
26
mir3636
parents: 2
diff changeset
27 \begin{lstlisting}[frame=lrbt,label=context,caption={\footnotesize context の定義}]
mir3636
parents: 2
diff changeset
28 #define ALLOCATE_SIZE 20000000
mir3636
parents: 2
diff changeset
29 #define NEW(type) (type*)(calloc(1, sizeof(type)))
mir3636
parents: 2
diff changeset
30 #define NEWN(n, type) (type*)(calloc(n, sizeof(type)))
mir3636
parents: 2
diff changeset
31
mir3636
parents: 2
diff changeset
32 #define ALLOC_DATA(context, dseg) ({\
mir3636
parents: 2
diff changeset
33 struct Meta* meta = (struct Meta*)context->heap;\
mir3636
parents: 2
diff changeset
34 meta->type = D_##dseg;\
mir3636
parents: 2
diff changeset
35 meta->size = 1;\
mir3636
parents: 2
diff changeset
36 context->heap += sizeof(struct Meta);\
mir3636
parents: 2
diff changeset
37 context->data[D_##dseg] = context->heap; context->heap += sizeof(struct dseg); (struct dseg *)context->data[D_##dseg]; })
mir3636
parents: 2
diff changeset
38
mir3636
parents: 2
diff changeset
39 #define ALLOCATE(context, t) ({ \
mir3636
parents: 2
diff changeset
40 struct Meta* meta = (struct Meta*)context->heap;\
mir3636
parents: 2
diff changeset
41 context->heap += sizeof(struct Meta);\
mir3636
parents: 2
diff changeset
42 union Data* data = context->heap; \
mir3636
parents: 2
diff changeset
43 context->heap += sizeof(struct t); \
mir3636
parents: 2
diff changeset
44 meta->type = D_##t; \
mir3636
parents: 2
diff changeset
45 meta->size = 1; \
mir3636
parents: 2
diff changeset
46 data; })
mir3636
parents: 2
diff changeset
47
mir3636
parents: 2
diff changeset
48 #define Gearef(context, t) (&(context)->data[D_##t]->t)
mir3636
parents: 2
diff changeset
49 #define GearImpl(context, intf, name) (Gearef(context, intf)->name->intf.name)
mir3636
parents: 2
diff changeset
50
mir3636
parents: 2
diff changeset
51 #include "c/enumCode.h"
mir3636
parents: 2
diff changeset
52
mir3636
parents: 2
diff changeset
53 #include "c/enumData.h"
mir3636
parents: 2
diff changeset
54
mir3636
parents: 2
diff changeset
55 struct Context {
mir3636
parents: 2
diff changeset
56 enum Code next;
mir3636
parents: 2
diff changeset
57 struct Worker* worker;
mir3636
parents: 2
diff changeset
58 struct TaskManager* taskManager;
mir3636
parents: 2
diff changeset
59 int codeNum;
mir3636
parents: 2
diff changeset
60 __code (**code) (struct Context*);
mir3636
parents: 2
diff changeset
61 void* heapStart;
mir3636
parents: 2
diff changeset
62 void* heap;
mir3636
parents: 2
diff changeset
63 long heapLimit;
mir3636
parents: 2
diff changeset
64 int dataNum;
mir3636
parents: 2
diff changeset
65 int idgCount; //number of waiting dataGear
mir3636
parents: 2
diff changeset
66 int odg;
mir3636
parents: 2
diff changeset
67 int maxOdg;
mir3636
parents: 2
diff changeset
68 int workerId;
mir3636
parents: 2
diff changeset
69 union Data **data;
mir3636
parents: 2
diff changeset
70 };
mir3636
parents: 2
diff changeset
71
mir3636
parents: 2
diff changeset
72 union Data {
mir3636
parents: 2
diff changeset
73 struct Meta {
mir3636
parents: 2
diff changeset
74 enum DataType type;
mir3636
parents: 2
diff changeset
75 long size;
mir3636
parents: 2
diff changeset
76 struct Queue* wait; // tasks waiting this dataGear
mir3636
parents: 2
diff changeset
77 } meta;
mir3636
parents: 2
diff changeset
78 struct Task {
mir3636
parents: 2
diff changeset
79 enum Code code;
mir3636
parents: 2
diff changeset
80 struct Queue* dataGears;
mir3636
parents: 2
diff changeset
81 int idsCount;
mir3636
parents: 2
diff changeset
82 } Task;
mir3636
parents: 2
diff changeset
83 // Stack Interface
mir3636
parents: 2
diff changeset
84 struct Stack {
mir3636
parents: 2
diff changeset
85 union Data* stack;
mir3636
parents: 2
diff changeset
86 union Data* data;
mir3636
parents: 2
diff changeset
87 union Data* data1;
mir3636
parents: 2
diff changeset
88 enum Code whenEmpty;
mir3636
parents: 2
diff changeset
89 enum Code clear;
mir3636
parents: 2
diff changeset
90 enum Code push;
mir3636
parents: 2
diff changeset
91 enum Code pop;
mir3636
parents: 2
diff changeset
92 enum Code pop2;
mir3636
parents: 2
diff changeset
93 enum Code isEmpty;
mir3636
parents: 2
diff changeset
94 enum Code get;
mir3636
parents: 2
diff changeset
95 enum Code get2;
mir3636
parents: 2
diff changeset
96 enum Code next;
mir3636
parents: 2
diff changeset
97 } Stack;
mir3636
parents: 2
diff changeset
98 // Stack implementations
mir3636
parents: 2
diff changeset
99 struct SingleLinkedStack {
mir3636
parents: 2
diff changeset
100 struct Element* top;
mir3636
parents: 2
diff changeset
101 } SingleLinkedStack;
mir3636
parents: 2
diff changeset
102 struct Element {
mir3636
parents: 2
diff changeset
103 union Data* data;
mir3636
parents: 2
diff changeset
104 struct Element* next;
mir3636
parents: 2
diff changeset
105 } Element;
mir3636
parents: 2
diff changeset
106 struct Node {
mir3636
parents: 2
diff changeset
107 int key; // comparable data segment
mir3636
parents: 2
diff changeset
108 union Data* value;
mir3636
parents: 2
diff changeset
109 struct Node* left;
mir3636
parents: 2
diff changeset
110 struct Node* right;
mir3636
parents: 2
diff changeset
111 // need to balancing
mir3636
parents: 2
diff changeset
112 enum Color {
mir3636
parents: 2
diff changeset
113 Red,
mir3636
parents: 2
diff changeset
114 Black,
mir3636
parents: 2
diff changeset
115 } color;
mir3636
parents: 2
diff changeset
116 } Node;
mir3636
parents: 2
diff changeset
117 }; // union Data end this is necessary for context generator
mir3636
parents: 2
diff changeset
118
mir3636
parents: 2
diff changeset
119 \end{lstlisting}
mir3636
parents: 2
diff changeset
120
mir3636
parents: 2
diff changeset
121 \begin{lstlisting}[frame=lrbt,label=init_context,caption={\footnotesize 生成された context}]
mir3636
parents: 2
diff changeset
122
mir3636
parents: 2
diff changeset
123 #include <stdlib.h>
mir3636
parents: 2
diff changeset
124
mir3636
parents: 2
diff changeset
125 #include "../context.h"
mir3636
parents: 2
diff changeset
126
mir3636
parents: 2
diff changeset
127 void initContext(struct Context* context) {
mir3636
parents: 2
diff changeset
128 context->heapLimit = sizeof(union Data)*ALLOCATE_SIZE;
mir3636
parents: 2
diff changeset
129 context->code = (__code(**) (struct Context*)) NEWN(ALLOCATE_SIZE, void*);
mir3636
parents: 2
diff changeset
130 context->data = NEWN(ALLOCATE_SIZE, union Data*);
mir3636
parents: 2
diff changeset
131 context->heapStart = NEWN(context->heapLimit, char);
mir3636
parents: 2
diff changeset
132 context->heap = context->heapStart;
mir3636
parents: 2
diff changeset
133
mir3636
parents: 2
diff changeset
134 context->code[C_clearSingleLinkedStack] = clearSingleLinkedStack_stub;
mir3636
parents: 2
diff changeset
135 context->code[C_exit_code] = exit_code_stub;
mir3636
parents: 2
diff changeset
136 context->code[C_get2SingleLinkedStack] = get2SingleLinkedStack_stub;
mir3636
parents: 2
diff changeset
137 context->code[C_getSingleLinkedStack] = getSingleLinkedStack_stub;
mir3636
parents: 2
diff changeset
138 context->code[C_isEmptySingleLinkedStack] = isEmptySingleLinkedStack_stub;
mir3636
parents: 2
diff changeset
139 context->code[C_pop2SingleLinkedStack] = pop2SingleLinkedStack_stub;
mir3636
parents: 2
diff changeset
140 context->code[C_popSingleLinkedStack] = popSingleLinkedStack_stub;
mir3636
parents: 2
diff changeset
141 context->code[C_pushSingleLinkedStack] = pushSingleLinkedStack_stub;
mir3636
parents: 2
diff changeset
142 context->code[C_stack_test1] = stack_test1_stub;
mir3636
parents: 2
diff changeset
143 context->code[C_stack_test2] = stack_test2_stub;
mir3636
parents: 2
diff changeset
144 context->code[C_stack_test3] = stack_test3_stub;
mir3636
parents: 2
diff changeset
145 context->code[C_stack_test4] = stack_test4_stub;
mir3636
parents: 2
diff changeset
146 context->code[C_start_code] = start_code_stub;
mir3636
parents: 2
diff changeset
147
mir3636
parents: 2
diff changeset
148 #include "dataGearInit.c"
mir3636
parents: 2
diff changeset
149
mir3636
parents: 2
diff changeset
150 }
mir3636
parents: 2
diff changeset
151
mir3636
parents: 2
diff changeset
152 __code meta(struct Context* context, enum Code next) {
mir3636
parents: 2
diff changeset
153 // printf("meta %d\n",next);
mir3636
parents: 2
diff changeset
154 goto (context->code[next])(context);
mir3636
parents: 2
diff changeset
155 }
mir3636
parents: 2
diff changeset
156
mir3636
parents: 2
diff changeset
157 __code start_code(struct Context* context) {
mir3636
parents: 2
diff changeset
158 goto meta(context, context->next);
mir3636
parents: 2
diff changeset
159 }
mir3636
parents: 2
diff changeset
160
mir3636
parents: 2
diff changeset
161 __code start_code_stub(struct Context* context) {
mir3636
parents: 2
diff changeset
162 goto start_code(context);
mir3636
parents: 2
diff changeset
163 }
mir3636
parents: 2
diff changeset
164
mir3636
parents: 2
diff changeset
165 __code exit_code(struct Context* context) {
mir3636
parents: 2
diff changeset
166 free(context->code);
mir3636
parents: 2
diff changeset
167 free(context->data);
mir3636
parents: 2
diff changeset
168 free(context->heapStart);
mir3636
parents: 2
diff changeset
169 goto exit(0);
mir3636
parents: 2
diff changeset
170 }
mir3636
parents: 2
diff changeset
171
mir3636
parents: 2
diff changeset
172 __code exit_code_stub(struct Context* context) {
mir3636
parents: 2
diff changeset
173 goto exit_code(context);
mir3636
parents: 2
diff changeset
174 }
mir3636
parents: 2
diff changeset
175
mir3636
parents: 2
diff changeset
176 // end context_c
mir3636
parents: 2
diff changeset
177 \end{lstlisting}
2
mir3636
parents: 0
diff changeset
178 %enum で Code Gear と Data Gear
mir3636
parents: 0
diff changeset
179 %Data Gear の typedef
mir3636
parents: 0
diff changeset
180 %stub の extern
mir3636
parents: 0
diff changeset
181 %Data Gear の init (ALLOCA)
mir3636
parents: 0
diff changeset
182 %target 毎の init context
mir3636
parents: 0
diff changeset
183
mir3636
parents: 0
diff changeset
184