# HG changeset patch # User Shohei KOKUBO # Date 1426849082 -32400 # Node ID 59c1086467f9b18a497b822601467647d6c17735 # Parent b8066055e295a897ab0417b8b7ea6d53e412bb91 fix diff -r b8066055e295 -r 59c1086467f9 src/allocate.c --- a/src/allocate.c Wed Mar 18 16:19:17 2015 +0900 +++ b/src/allocate.c Fri Mar 20 19:58:02 2015 +0900 @@ -11,41 +11,41 @@ #define SIZE 1024 typedef struct DataSegment1 { - int i; // 4 byte - char c; // 1 byte - // padding 3 byte -} ds, *dsptr; // 8 byte + int i; // 4 byte + char c[10]; // 10 byte + // padding 2 byte +} ds; typedef struct metaDataSegment1 { size_t size; // 8 byte - dsptr ds; // 8 byte -} mds, *mdsptr; // 16 byte + ds* ds; // 8 byte +} mds; -typedef struct Context { - dsptr ds; - mdsptr mds; - dsptr ds_heap; - mdsptr mds_heap; -} context, *contextptr; +typedef struct Context_st { + ds* ds; + mds* mds; + ds* ds_heap; + mds* mds_heap; +} Context; -__code start_code(contextptr context) { +__code start_code(Context* context) { goto meta_start_code(context); } -__code meta_start_code(contextptr context) { +__code meta_start_code(Context* context) { goto code1(context); } -__code code1(contextptr context) { +__code code1(Context* context) { goto meta_code1(context); } -__code meta_code1(contextptr context) { +__code meta_code1(Context* context) { goto allocate(context, SIZE); } -__code allocate(contextptr context, int size) { - dsptr in = context->ds; +__code allocate(Context* context, int size) { + ds* in = context->ds; context->ds += size; context->mds->ds = in; context->mds->size = context->ds - in; @@ -53,13 +53,12 @@ goto meta_allocate(context, in); } -__code meta_allocate(contextptr context, dsptr in) { +__code meta_allocate(Context* context, ds* in) { goto exit_code(context, in, 0); } -__code exit_code(contextptr context, dsptr in, int i) { +__code exit_code(Context* context, ds* in, int i) { in[i].i = i; - printf("%d\n", in[i].i); if (i == SIZE) { free(context->ds_heap); free(context->mds_heap); @@ -69,9 +68,9 @@ } int main() { - contextptr context = (contextptr)malloc(sizeof(contextptr)); - context->ds_heap = (dsptr)malloc(1024); - context->mds_heap = (mdsptr)malloc(1024); + Context* context = (Context*)malloc(sizeof(Context)); + context->ds_heap = (ds*)malloc(1024); + context->mds_heap = (mds*)malloc(1024); context->ds = context->ds_heap; context->mds = context->mds_heap; goto start_code(context);