diff options
| author | gingerBill <bill@gingerbill.org> | 2022-11-09 22:21:36 +0000 |
|---|---|---|
| committer | gingerBill <bill@gingerbill.org> | 2022-11-09 22:21:36 +0000 |
| commit | 1bcec3f7696243664d8bfefa24b4262d4f412755 (patch) | |
| tree | 792d021e72c63e2c0f0a95c2772ad47277935e0e /src/llvm_backend.cpp | |
| parent | b035ee2bcd57bc8616858845f466deb062c999cb (diff) | |
Change map internal calls to use a pointer
Diffstat (limited to 'src/llvm_backend.cpp')
| -rw-r--r-- | src/llvm_backend.cpp | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/src/llvm_backend.cpp b/src/llvm_backend.cpp index 2b95c5b2f..e12a4c016 100644 --- a/src/llvm_backend.cpp +++ b/src/llvm_backend.cpp @@ -757,8 +757,8 @@ lbValue lb_gen_map_key_hash(lbProcedure *p, lbValue key, Type *key_type, lbValue return hashed_key; } -lbValue lb_internal_dynamic_map_get_ptr(lbProcedure *p, lbValue const &map, lbValue const &key) { - Type *map_type = base_type(map.type); +lbValue lb_internal_dynamic_map_get_ptr(lbProcedure *p, lbValue const &map_ptr, lbValue const &key) { + Type *map_type = base_type(type_deref(map_ptr.type)); GB_ASSERT(map_type->kind == Type_Map); lbValue ptr = {}; @@ -770,13 +770,13 @@ lbValue lb_internal_dynamic_map_get_ptr(lbProcedure *p, lbValue const &map, lbVa lbValue map_get_proc = lb_get_map_get_proc_for_type(p->module, map_type); auto args = array_make<lbValue>(permanent_allocator(), 2); - args[0] = lb_address_from_load_or_generate_local(p, map); + args[0] = map_ptr; args[1] = key_ptr; ptr = lb_emit_call(p, map_get_proc, args); } else { auto args = array_make<lbValue>(permanent_allocator(), 3); - args[0] = lb_emit_transmute(p, map, t_raw_map); + args[0] = lb_emit_transmute(p, lb_emit_load(p, map_ptr), t_raw_map); args[1] = lb_gen_map_info_ptr(p->module, map_type); args[2] = key_ptr; |