diff options
| author | gingerBill <bill@gingerbill.org> | 2023-05-18 11:26:57 +0100 |
|---|---|---|
| committer | gingerBill <bill@gingerbill.org> | 2023-05-18 11:26:57 +0100 |
| commit | 49d1f6aca03672469d8fda0dedd27e330e698edc (patch) | |
| tree | f762ab6c9b9d5ae0d374eda0b31a3c164fc94455 /src/llvm_backend_expr.cpp | |
| parent | e82146bf17908dcc3619c8ec34bb0e902d7c213d (diff) | |
| parent | 49cd9648b05c6eda252122104cb9b1faa2502602 (diff) | |
Merge branch 'master' into separate-int-word-sizes
Diffstat (limited to 'src/llvm_backend_expr.cpp')
| -rw-r--r-- | src/llvm_backend_expr.cpp | 10 |
1 files changed, 6 insertions, 4 deletions
diff --git a/src/llvm_backend_expr.cpp b/src/llvm_backend_expr.cpp index c1d3471f3..412698368 100644 --- a/src/llvm_backend_expr.cpp +++ b/src/llvm_backend_expr.cpp @@ -2083,10 +2083,12 @@ gb_internal lbValue lb_emit_conv(lbProcedure *p, lbValue value, Type *t) { Type *elem = base_array_type(dst); lbValue e = lb_emit_conv(p, value, elem); lbAddr v = lb_add_local_generated(p, t, false); - for (i64 i = 0; i < dst->Matrix.row_count; i++) { - isize j = cast(isize)i; - lbValue ptr = lb_emit_matrix_epi(p, v.addr, j, j); - lb_emit_store(p, ptr, e); + lbValue zero = lb_const_value(p->module, elem, exact_value_i64(0), true); + for (i64 j = 0; j < dst->Matrix.column_count; j++) { + for (i64 i = 0; i < dst->Matrix.row_count; i++) { + lbValue ptr = lb_emit_matrix_epi(p, v.addr, i, j); + lb_emit_store(p, ptr, i == j ? e : zero); + } } |