|
@@ -937,8 +937,8 @@ gb_internal void lb_emit_store(lbProcedure *p, lbValue ptr, lbValue value) {
|
|
|
|
|
|
enum {MAX_STORE_SIZE = 64};
|
|
|
|
|
|
- if (!p->in_multi_assignment && lb_sizeof(LLVMTypeOf(value.value)) > MAX_STORE_SIZE) {
|
|
|
- if (LLVMIsALoadInst(value.value)) {
|
|
|
+ if (lb_sizeof(LLVMTypeOf(value.value)) > MAX_STORE_SIZE) {
|
|
|
+ if (!p->in_multi_assignment && LLVMIsALoadInst(value.value)) {
|
|
|
LLVMValueRef dst_ptr = ptr.value;
|
|
|
LLVMValueRef src_ptr_original = LLVMGetOperand(value.value, 0);
|
|
|
LLVMValueRef src_ptr = LLVMBuildPointerCast(p->builder, src_ptr_original, LLVMTypeOf(dst_ptr), "");
|