aboutsummaryrefslogtreecommitdiff
path: root/src/ir.cpp
diff options
context:
space:
mode:
authorgingerBill <bill@gingerbill.org>2019-05-09 13:04:15 +0100
committergingerBill <bill@gingerbill.org>2019-05-09 13:04:15 +0100
commit71a733e3b5bda4e8baafac35c7140e0b3a0d9445 (patch)
treecc6feb3b929b52d6cd75c1caf4f75231935c7f60 /src/ir.cpp
parenta66612e8aed520c8068a0c626056dd096f67eb65 (diff)
Allow booleans to be assigned to a 1-bit bit field value
Diffstat (limited to 'src/ir.cpp')
-rw-r--r--src/ir.cpp17
1 files changed, 10 insertions, 7 deletions
diff --git a/src/ir.cpp b/src/ir.cpp
index 838415eaa..5eb1634d1 100644
--- a/src/ir.cpp
+++ b/src/ir.cpp
@@ -3377,6 +3377,7 @@ void ir_addr_store(irProcedure *proc, irAddr const &addr, irValue *value) {
}
irValue *ptr = ir_emit_conv(proc, bytes, alloc_type_pointer(int_type));
+
irValue *sv = ir_emit_load(proc, ptr, 1);
// NOTE(bill): Zero out the lower bits that need to be stored to
sv = ir_emit_arith(proc, Token_Shr, sv, ir_const_int(size_in_bits), int_type);
@@ -3393,23 +3394,25 @@ void ir_addr_store(irProcedure *proc, irAddr const &addr, irValue *value) {
{
irValue *shift_amount = ir_const_int(bit_inset);
+ irValue *ptr = ir_emit_conv(proc, bytes, alloc_type_pointer(t_u8));
+
irValue *v = ir_emit_conv(proc, value, t_u8);
- v = ir_emit_arith(proc, Token_Shl, v, shift_amount, int_type);
+ v = ir_emit_arith(proc, Token_Shl, v, shift_amount, t_u8);
irValue *sv = ir_emit_load(proc, bytes, 1);
// NOTE(bill): Zero out the upper bits that need to be stored to
- sv = ir_emit_arith(proc, Token_Shl, sv, ir_const_int(bit_inset), int_type);
- sv = ir_emit_arith(proc, Token_Shr, sv, ir_const_int(bit_inset), int_type);
+ sv = ir_emit_arith(proc, Token_Shl, sv, ir_const_int(8-bit_inset), t_u8);
+ sv = ir_emit_arith(proc, Token_Shr, sv, ir_const_int(8-bit_inset), t_u8);
- v = ir_emit_arith(proc, Token_Or, sv, v, int_type);
- ir_emit_store(proc, bytes, v, true);
+ v = ir_emit_arith(proc, Token_Or, sv, v, t_u8);
+ ir_emit_store(proc, ptr, v, true);
}
// Remaining bytes
if (bit_inset+size_in_bits > 8) {
- irValue *shift_amount = ir_const_int(bit_inset);
irValue *ptr = ir_emit_conv(proc, ir_emit_ptr_offset(proc, bytes, v_one), alloc_type_pointer(int_type));
- irValue *v = ir_emit_arith(proc, Token_Shr, value, shift_amount, int_type);
+ irValue *v = ir_emit_conv(proc, value, int_type);
+ v = ir_emit_arith(proc, Token_Shr, v, ir_const_int(8-bit_inset), int_type);
irValue *sv = ir_emit_load(proc, ptr, 1);
// NOTE(bill): Zero out the lower bits that need to be stored to