From 4c467b118d12ca6fabd018e4c0295096fa4d399b Mon Sep 17 00:00:00 2001 From: gingerBill Date: Wed, 10 Aug 2016 20:05:45 +0100 Subject: copy(...) --- src/codegen/codegen.cpp | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) (limited to 'src/codegen/codegen.cpp') diff --git a/src/codegen/codegen.cpp b/src/codegen/codegen.cpp index 7af2c01cd..cde7951df 100644 --- a/src/codegen/codegen.cpp +++ b/src/codegen/codegen.cpp @@ -46,6 +46,8 @@ void ssa_gen_code(ssaGen *s) { ssaModule *m = &s->module; CheckerInfo *info = m->info; gbAllocator a = m->allocator; + ssaProcedure dummy_proc = {}; + dummy_proc.module = m; gb_for_array(i, info->entities.entries) { auto *entry = &info->entities.entries[i]; @@ -61,7 +63,14 @@ void ssa_gen_code(ssaGen *s) { } break; case Entity_Variable: { - ssaValue *g = ssa_make_value_global(a, e, NULL); + ssaValue *value = ssa_build_expr(&dummy_proc, decl->init_expr); + if (value->kind == ssaValue_Instr) { + ssaInstr *i = &value->instr; + if (i->kind == ssaInstr_Load) { + value = i->load.address; + } + } + ssaValue *g = ssa_make_value_global(a, e, value); map_set(&m->values, hash_pointer(e), g); map_set(&m->members, hash_string(name), g); } break; -- cgit v1.2.3