# HG changeset patch # User autobackup # Date 1610550603 -32400 # Node ID 8bc110e35f8ddfc2d06d1b6a3803cb468fc2c28b # Parent 4a2bfdc45e698cb3c0247e2717072d532e346c60 backup 2021-01-14 diff -r 4a2bfdc45e69 -r 8bc110e35f8d user/anatofuz/note/2021/01/13.md --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/user/anatofuz/note/2021/01/13.md Thu Jan 14 00:10:03 2021 +0900 @@ -0,0 +1,266 @@ +# 2021/01/13 + +```c ++kajika+anatofuz$ perl generate_stub.pl --debug AtomicTImpl.cbc +[getDataGear] match 174 : #interface "AtomicT.h" +[getDataGear] match 136 : typedef struct AtomicT <T>{ +[getDataGear] match 308 : union Data* atomicTImpl; +[getDataGear] match 308 : T newData; +[getDataGear] match 308 : T init; +[getDataGear] match 326 : __code checkAndSet(Impl* atomicTImpl, T init, T newData, __code next(...), __code fail(...)); +[getDataGear] match 326 : __code set(Impl* atomicTImpl, T newData, __code next(...)); +[getDataGear] match 326 : __code next(...); +[getDataGear] match 326 : __code fail(...); +[getDataGear] match 308 : } AtomicT; +[getDataGear] match 335 : } AtomicT; +[getCodeGear] match 380 : typedef struct AtomicT <T>{ +[getCodeGear] match 385 : __code checkAndSet(Impl* atomicTImpl, T init, T newData, __code next(...), __code fail(...)); +[getCodeGear] match 385 : __code set(Impl* atomicTImpl, T newData, __code next(...)); +[getCodeGear] match 385 : __code next(...); +[getCodeGear] match 385 : __code fail(...); +[getDataGear] match 174 : #interface "AtomicTImpl.h" +[getDataGear] match 136 : typedef struct AtomicTImpl <T> impl AtomicT { +[getDataGear] match 308 : T atomic; +[getDataGear] match 308 : T init; +[getDataGear] match 326 : __code next(...); +[getDataGear] match 308 : } AtomicTImpl; +[getDataGear] match 335 : } AtomicTImpl; +[getDataGear] match 205 : __code checkAndSetAtomicT(struct AtomicTImpl* atomicTImpl, T* ptr,T init, T newData, __code next(...), __code fail(...)) { +[getDataGear] match 205 : __code setAtomicT(struct AtomicTImpl* atomicTImpl, T* ptr, T newData, __code next(...) ) { +[generateDataGear] match 654 : #include "../context.h" +[generateDataGear] match 649 : #interface "AtomicT.h" +[generateDataGear] match 649 : #interface "AtomicTImpl.h" +[generateDataGear] match 784 : #include <stdio.h> +[generateDataGear] match 784 : +[generateDataGear] match 784 : AtomicT<T>* createAtomicT(struct Context* context,T init) { +[generateDataGear] match 784 : struct AtomicT* atomicT = new AtomicT<T>(); +[generateDataGear] match 784 : struct AtomicTImpl<T>* atomicTImpl = new AtomicTImpl<T>(); +[generateDataGear] match 784 : atomicT->atomicTImpl = atomicTImpl; +[generateDataGear] match 784 : atomicTImpl->atomic = init; +[generateDataGear] match 784 : atomicTImpl->init = init; +[generateDataGear] match 784 : atomic->checkAndSet = C_checkAndSetAtomicT; +[generateDataGear] match 784 : return atomicT; +[generateDataGear] match 784 : } +[generateDataGear] match 784 : +[generateDataGear] match 673 : __code checkAndSetAtomicT(struct AtomicTImpl* atomicTImpl, T* ptr,T init, T newData, __code next(...), __code fail(...)) { +[generateDataGear] match 1034 : if (__sync_bool_compare_and_swap(ptr, init, newData)) { +[generateDataGear] match 972 : goto next(...); +[generateDataGear] match 1034 : } +[generateDataGear] match 972 : goto fail(...); +[generateDataGear] match 1031 : } +[generateDataGear] match 1055 : } +[generateDataGear] match 784 : +[generateDataGear] match 673 : __code setAtomicT(struct AtomicTImpl* atomicTImpl, T* ptr, T newData, __code next(...) ) { +[generateDataGear] match 1034 : *ptr = newData; +[generateDataGear] match 972 : goto next(...); +[generateDataGear] match 1031 : } +[generateDataGear] match 1055 : } +[generateDataGear] match 784 : +``` + + +```c +#include "../context.h" +#include <stdio.h> + +AtomicT<T>* createAtomicT(struct Context* context,T init) { + struct AtomicT* atomicT = new AtomicT<T>(); + struct AtomicTImpl<T>* atomicTImpl = new AtomicTImpl<T>(); + atomicT->atomicTImpl = atomicTImpl; + atomicTImpl->atomic = init; + atomicTImpl->init = init; + atomic->checkAndSet = C_checkAndSetAtomicT; + return atomicT; +} + +__code checkAndSetAtomicT(struct Context *context,struct AtomicTImpl* atomicTImpl, T* ptr,T init, T newData, enum Code next, enum Code fail) { + if (__sync_bool_compare_and_swap(ptr, init, newData)) { + goto meta(context, next); + } + goto meta(context, fail); +} + +__code checkAndSetAtomicT_stub(struct Context* context) { + AtomicTImpl* atomicTImpl = Gearef(context, AtomicTImpl); + T* ptr = Gearef(context, T); + T init = Gearef(context, T); + T newData = Gearef(context, T); + Code next = Gearef(context, Code); + Code fail = Gearef(context, Code); + goto checkAndSetAtomicT(context, atomicTImpl, ptr, init, newData, next, fail); +} + +__code setAtomicT(struct Context *context,struct AtomicTImpl* atomicTImpl, T* ptr, T newData, enum Code next ) { + *ptr = newData; + goto meta(context, next); +} + +__code setAtomicT_stub(struct Context* context) { + AtomicTImpl* atomicTImpl = Gearef(context, AtomicTImpl); + T* ptr = Gearef(context, T); + T newData = Gearef(context, T); + Code next = Gearef(context, Code); + goto setAtomicT(context, atomicTImpl, ptr, newData, next); +} +``` + + + +``` ++kajika+anatofuz$ perl tools/trans_impl.pl examples/pop_and_push/StackTest2Impl.h +#include "../../../context.h" +#interface "StackTest2.h" + +// ---- +// typedef struct StackTest2Impl <> impl StackTest2 { +// __code next(...); +// } StackTest2Impl; +// ---- + +\ { + codeName { + gotoOtherInterface { + argc 4, + args "Impl* stackTest2, struct Stack* stack, union Data* data1, struct StackTest* stackTest, __code next(...)", + name "gotoOtherInterface" + }, + insertTest1 { + argc 3, + args "Impl* stackTest2, struct Stack* stack, union Data* data1, __code next(...)", + name "insertTest1" + } + }, + codes [ + [0] var{codeName}{insertTest1}, + [1] var{codeName}{gotoOtherInterface} + ], + content [ + [0] "enum Code insertTest1;", + [1] "union Data* stackTest2;", + [2] "struct Stack* stack;", + [3] "union Data* data1;", + [4] "enum Code gotoOtherInterface;", + [5] "struct StackTest* stackTest;", + [6] "enum Code next;", + [7] "" + ], + data [ + [0] "union Data* stackTest2;", + [1] "struct Stack* stack;", + [2] "union Data* data1;", + [3] "struct StackTest* stackTest;", + [4] "" + ], + file_name "/home/anatofuz/src/firefly/hg/Gears/Gears/src/parallel_execution/tools/../examples/pop_and_push/StackTest2.h", + hasOutputArgs {}, + inner_code_gears { + next 1 + }, + name "StackTest2" +} +\ { + codeName { + next { + argc 1, + args "...", + name "next" + } + }, + codes [ + [0] var{codeName}{next} + ], + content [ + [0] "enum Code next;" + ], + data [], + file_name "/home/anatofuz/src/firefly/hg/Gears/Gears/src/parallel_execution/examples/pop_and_push/StackTest2Impl.h", + hasOutputArgs {}, + inner_code_gears {}, + isa "StackTest2", + name "StackTest2Impl" +} +StackTest2* createStackTest2Impl(struct Context* context) { + struct StackTest2* stackTest2 = new StackTest2(); + struct StackTest2Impl* stack_test2impl = new StackTest2Impl(); + stackTest2->stackTest2 = (union Data*)stack_test2impl; + stackTest2->stack = NULL; + stackTest2->data1 = NULL; + stackTest2->stackTest = NULL; + stackTest2->insertTest1 = C_insertTest1StackTest2Impl; + stackTest2->gotoOtherInterface = C_gotoOtherInterfaceStackTest2Impl; + return stackTest2; +} +__code insertTest1_StackTest2Impl(struct StackTest2Impl* stackTest2, struct Stack* stack, union Data* data1, __code next(...)) { + + goto next(...); +} + +__code gotoOtherInterface_StackTest2Impl(struct StackTest2Impl* stackTest2, struct Stack* stack, union Data* data1, struct StackTest* stackTest, __code next(...)) { + + goto next(...); +} + +``` + + +```diff +[0;36m1d0[0;0m +[0;31m< +kajika+anatofuz$ perl tools/trans_impl.pl examples/pop_and_push/StackTest2Impl.h[0;0m +[0;36m30,32c29,31[0;0m +[0;31m< [1] "union Data* stackTest2;",[0;0m +[0;31m< [2] "struct Stack* stack;",[0;0m +[0;31m< [3] "union Data* data1;",[0;0m +[0;0m---[0;0m +[0;32m> [1] "union Data stackTest2*;",[0;0m +[0;32m> [2] "struct Stack stack*;",[0;0m +[0;32m> [3] "union Data data1*;",[0;0m +[0;36m34c33[0;0m +[0;31m< [5] "struct StackTest* stackTest;",[0;0m +[0;0m---[0;0m +[0;32m> [5] "struct StackTest stackTest*;",[0;0m +[0;36m39,42c38,41[0;0m +[0;31m< [0] "union Data* stackTest2;",[0;0m +[0;31m< [1] "struct Stack* stack;",[0;0m +[0;31m< [2] "union Data* data1;",[0;0m +[0;31m< [3] "struct StackTest* stackTest;",[0;0m +[0;0m---[0;0m +[0;32m> [0] "union Data stackTest2*;",[0;0m +[0;32m> [1] "struct Stack stack*;",[0;0m +[0;32m> [2] "union Data data1*;",[0;0m +[0;32m> [3] "struct StackTest stackTest*;",[0;0m +[0;36m74c73[0;0m +[0;31m< struct StackTest2* stackTest2 = new StackTest2();[0;0m +[0;0m---[0;0m +[0;32m> struct StackTest2* union Data stackTest2*; = new StackTest2();[0;0m +[0;36m76,82c75,84[0;0m +[0;31m< stackTest2->stackTest2 = (union Data*)stack_test2impl;[0;0m +[0;31m< stackTest2->stack = NULL;[0;0m +[0;31m< stackTest2->data1 = NULL;[0;0m +[0;31m< stackTest2->stackTest = NULL;[0;0m +[0;31m< stackTest2->insertTest1 = C_insertTest1StackTest2Impl;[0;0m +[0;31m< stackTest2->gotoOtherInterface = C_gotoOtherInterfaceStackTest2Impl;[0;0m +[0;31m< return stackTest2;[0;0m +[0;0m---[0;0m +[0;32m> union Data stackTest2*;->union Data stackTest2*; = (union Data*)stack_test2impl;[0;0m +[0;32m> union Data stackTest2*;->stack = 0;[0;0m +[0;32m> union Data stackTest2*;->Stack = 0;[0;0m +[0;32m> union Data stackTest2*;->data1 = 0;[0;0m +[0;32m> union Data stackTest2*;->Data = 0;[0;0m +[0;32m> union Data stackTest2*;->stackTest = 0;[0;0m +[0;32m> union Data stackTest2*;->StackTest = 0;[0;0m +[0;32m> union Data stackTest2*;->insertTest1 = C_insertTest1StackTest2Impl;[0;0m +[0;32m> union Data stackTest2*;->gotoOtherInterface = C_gotoOtherInterfaceStackTest2Impl;[0;0m +[0;32m> return union Data stackTest2*;;[0;0m +``` + +これかぁ原因 + +```diff +< [1] "union Data* stackTest2;", +< [2] "struct Stack* stack;", +< [3] "union Data* data1;", +--- +> [1] "union Data stackTest2*;", +> [2] "struct Stack stack*;", +> [3] "union Data data1*;", +```