diff options
| author | gingerBill <bill@gingerbill.org> | 2021-06-28 11:05:52 +0100 |
|---|---|---|
| committer | gingerBill <bill@gingerbill.org> | 2021-06-28 11:05:52 +0100 |
| commit | 185277a2b689e31cb9490edfb4f74d16e1ae591a (patch) | |
| tree | 040a280abe42da7126be0844dd1d32ca1797b42b /src/llvm_backend.cpp | |
| parent | 76d3bab955d33abb6d4cab0b95beedd6393c96da (diff) | |
Fix swizzling of pointers to arrays
Diffstat (limited to 'src/llvm_backend.cpp')
| -rw-r--r-- | src/llvm_backend.cpp | 9 |
1 files changed, 7 insertions, 2 deletions
diff --git a/src/llvm_backend.cpp b/src/llvm_backend.cpp index 47ff21ee8..ef49fb6e1 100644 --- a/src/llvm_backend.cpp +++ b/src/llvm_backend.cpp @@ -12978,8 +12978,13 @@ lbAddr lb_build_addr(lbProcedure *p, Ast *expr) { u8 index = swizzle_indices_raw>>(i*2) & 3; swizzle_indices[i] = index; } - lbAddr addr = lb_build_addr(p, se->expr); - lbValue a = lb_addr_get_ptr(p, addr); + lbValue a = {}; + if (is_type_pointer(tav.type)) { + a = lb_build_expr(p, se->expr); + } else { + lbAddr addr = lb_build_addr(p, se->expr); + a = lb_addr_get_ptr(p, addr); + } GB_ASSERT(is_type_array(expr->tav.type)); return lb_addr_swizzle(a, expr->tav.type, swizzle_count, swizzle_indices); |