aboutsummaryrefslogtreecommitdiff
path: root/src/codegen
diff options
context:
space:
mode:
authorGinger Bill <bill@gingerbill.org>2016-09-28 00:07:03 +0100
committerGinger Bill <bill@gingerbill.org>2016-09-28 00:07:03 +0100
commit5f6b0942f405f5595787ba3436e2e5410268e71e (patch)
treef0b585689c1f4762167a58a7a8aa2ac4d2b79028 /src/codegen
parent6088cbeddb84e25e5966a1876ad4ffcaad6676c9 (diff)
Update Standard Library; Fix Type_Info for integers
Diffstat (limited to 'src/codegen')
-rw-r--r--src/codegen/codegen.cpp31
-rw-r--r--src/codegen/ssa.cpp4
2 files changed, 27 insertions, 8 deletions
diff --git a/src/codegen/codegen.cpp b/src/codegen/codegen.cpp
index ffe6854a7..ca6771962 100644
--- a/src/codegen/codegen.cpp
+++ b/src/codegen/codegen.cpp
@@ -352,17 +352,15 @@ void ssa_gen_tree(ssaGen *s) {
case Basic_i16:
case Basic_i32:
case Basic_i64:
- // case Basic_i128:
case Basic_u8:
case Basic_u16:
case Basic_u32:
case Basic_u64:
- // case Basic_u128:
case Basic_int:
case Basic_uint: {
tag = ssa_add_local_generated(proc, t_type_info_integer);
- b32 is_unsigned = (basic_types[t->Basic.kind].flags & BasicFlag_Unsigned) != 0;
- ssaValue *bits = ssa_make_const_int(a, type_size_of(m->sizes, a, t));
+ b32 is_unsigned = (t->Basic.flags & BasicFlag_Unsigned) != 0;
+ ssaValue *bits = ssa_make_const_int(a, type_size_of(m->sizes, a, t));
ssaValue *is_signed = ssa_make_const_bool(a, !is_unsigned);
ssa_emit_store(proc, ssa_emit_struct_gep(proc, tag, v_zero32, t_int_ptr), bits);
ssa_emit_store(proc, ssa_emit_struct_gep(proc, tag, v_one32, t_bool_ptr), is_signed);
@@ -434,8 +432,12 @@ void ssa_gen_tree(ssaGen *s) {
{
ssaValue *packed = ssa_make_const_bool(a, t->Record.struct_is_packed);
ssaValue *ordered = ssa_make_const_bool(a, t->Record.struct_is_ordered);
- ssa_emit_store(proc, ssa_emit_struct_gep(proc, tag, v_one32, t_bool_ptr), packed);
- ssa_emit_store(proc, ssa_emit_struct_gep(proc, tag, v_two32, t_bool_ptr), ordered);
+ ssaValue *size = ssa_make_const_int(a, type_size_of(m->sizes, a, t));
+ ssaValue *align = ssa_make_const_int(a, type_align_of(m->sizes, a, t));
+ ssa_emit_store(proc, ssa_emit_struct_gep(proc, tag, 1, t_bool_ptr), packed);
+ ssa_emit_store(proc, ssa_emit_struct_gep(proc, tag, 2, t_bool_ptr), ordered);
+ ssa_emit_store(proc, ssa_emit_struct_gep(proc, tag, 3, t_int_ptr), size);
+ ssa_emit_store(proc, ssa_emit_struct_gep(proc, tag, 4, t_int_ptr), align);
}
ssaValue *memory = type_info_member_offset(proc, type_info_member_data, t->Record.field_count, &type_info_member_index);
@@ -476,9 +478,21 @@ void ssa_gen_tree(ssaGen *s) {
} break;
case TypeRecord_Union:
tag = ssa_add_local_generated(proc, t_type_info_union);
+ {
+ ssaValue *size = ssa_make_const_int(a, type_size_of(m->sizes, a, t));
+ ssaValue *align = ssa_make_const_int(a, type_align_of(m->sizes, a, t));
+ ssa_emit_store(proc, ssa_emit_struct_gep(proc, tag, 3, t_int_ptr), size);
+ ssa_emit_store(proc, ssa_emit_struct_gep(proc, tag, 4, t_int_ptr), align);
+ }
break;
case TypeRecord_RawUnion: {
tag = ssa_add_local_generated(proc, t_type_info_raw_union);
+ {
+ ssaValue *size = ssa_make_const_int(a, type_size_of(m->sizes, a, t));
+ ssaValue *align = ssa_make_const_int(a, type_align_of(m->sizes, a, t));
+ ssa_emit_store(proc, ssa_emit_struct_gep(proc, tag, 3, t_int_ptr), size);
+ ssa_emit_store(proc, ssa_emit_struct_gep(proc, tag, 4, t_int_ptr), align);
+ }
ssaValue *memory = type_info_member_offset(proc, type_info_member_data, t->Record.field_count, &type_info_member_index);
@@ -590,6 +604,11 @@ void ssa_gen_tree(ssaGen *s) {
case Type_Tuple: {
tag = ssa_add_local_generated(proc, t_type_info_tuple);
+ {
+ ssaValue *align = ssa_make_const_int(a, type_align_of(m->sizes, a, t));
+ ssa_emit_store(proc, ssa_emit_struct_gep(proc, tag, 4, t_int_ptr), align);
+ }
+
ssaValue *memory = type_info_member_offset(proc, type_info_member_data, t->Tuple.variable_count, &type_info_member_index);
for (isize i = 0; i < t->Tuple.variable_count; i++) {
diff --git a/src/codegen/ssa.cpp b/src/codegen/ssa.cpp
index 2cab528c8..e11ead106 100644
--- a/src/codegen/ssa.cpp
+++ b/src/codegen/ssa.cpp
@@ -2369,7 +2369,7 @@ ssaValue *ssa_build_single_expr(ssaProcedure *proc, AstNode *expr, TypeAndValue
args[1] = src;
args[2] = byte_count;
- ssa_emit_global_call(proc, "memory_copy", args, 3);
+ ssa_emit_global_call(proc, "__mem_copy", args, 3);
return len;
} break;
@@ -2418,7 +2418,7 @@ ssaValue *ssa_build_single_expr(ssaProcedure *proc, AstNode *expr, TypeAndValue
args[1] = item;
args[2] = byte_count;
- ssa_emit_global_call(proc, "memory_copy", args, 3);
+ ssa_emit_global_call(proc, "__mem_copy", args, 3);
// Increment slice length
Token add = {Token_Add};