aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorgingerBill <bill@gingerbill.org>2022-11-08 13:02:32 +0000
committergingerBill <bill@gingerbill.org>2022-11-08 13:02:32 +0000
commit046dd5503211c617a88d7de7d089dd5b74e63500 (patch)
tree1532f41da9d07318b15c3eaad803de03e7f9b00f /src
parent2fc3da3fde70e4428d23e5f58b93482148c8d2ae (diff)
Change `__dynamic_map_get` signature
Diffstat (limited to 'src')
-rw-r--r--src/checker.cpp1
-rw-r--r--src/llvm_backend.cpp19
-rw-r--r--src/llvm_backend_expr.cpp4
-rw-r--r--src/llvm_backend_general.cpp4
-rw-r--r--src/llvm_backend_utility.cpp23
-rw-r--r--src/types.cpp3
6 files changed, 25 insertions, 29 deletions
diff --git a/src/checker.cpp b/src/checker.cpp
index 5b9e83bda..75a6da6fa 100644
--- a/src/checker.cpp
+++ b/src/checker.cpp
@@ -2854,6 +2854,7 @@ void init_core_map_type(Checker *c) {
t_map_info_ptr = alloc_type_pointer(t_map_info);
t_map_cell_info_ptr = alloc_type_pointer(t_map_cell_info);
+ t_raw_map_ptr = alloc_type_pointer(t_raw_map);
}
void init_preload(Checker *c) {
diff --git a/src/llvm_backend.cpp b/src/llvm_backend.cpp
index bce1fa1d1..629daf1c9 100644
--- a/src/llvm_backend.cpp
+++ b/src/llvm_backend.cpp
@@ -622,14 +622,15 @@ 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_ptr, lbValue const &key) {
- Type *map_type = base_type(type_deref(map_ptr.type));
+lbValue lb_internal_dynamic_map_get_ptr(lbProcedure *p, lbValue const &map, lbValue const &key) {
+ Type *map_type = base_type(map.type);
+ GB_ASSERT(map_type->kind == Type_Map);
lbValue key_ptr = lb_address_from_load_or_generate_local(p, key);
key_ptr = lb_emit_conv(p, key_ptr, t_rawptr);
auto args = array_make<lbValue>(permanent_allocator(), 3);
- args[0] = lb_emit_conv(p, map_ptr, t_rawptr);
+ args[0] = lb_emit_transmute(p, map, t_raw_map);
args[1] = lb_gen_map_info_ptr(p->module, map_type);
args[2] = key_ptr;
@@ -644,17 +645,15 @@ void lb_insert_dynamic_map_key_and_value(lbProcedure *p, lbValue const &map_ptr,
GB_ASSERT(map_type->kind == Type_Map);
lbValue key_ptr = lb_address_from_load_or_generate_local(p, map_key);
- key_ptr = lb_emit_conv(p, key_ptr, t_rawptr);
- lbValue v = lb_emit_conv(p, map_value, map_type->Map.value);
- lbAddr value_addr = lb_add_local_generated(p, v.type, false);
- lb_addr_store(p, value_addr, v);
+ lbValue v = lb_emit_conv(p, map_value, map_type->Map.value);
+ lbValue value_ptr = lb_address_from_load_or_generate_local(p, v);
auto args = array_make<lbValue>(permanent_allocator(), 5);
- args[0] = lb_emit_conv(p, map_ptr, t_rawptr);
+ args[0] = lb_emit_conv(p, map_ptr, t_raw_map_ptr);
args[1] = lb_gen_map_info_ptr(p->module, map_type);
- args[2] = key_ptr;
- args[3] = lb_emit_conv(p, value_addr.addr, t_rawptr);
+ args[2] = lb_emit_conv(p, key_ptr, t_rawptr);
+ args[3] = lb_emit_conv(p, value_ptr, t_rawptr);
args[4] = lb_emit_source_code_location_as_global(p, node);
lb_emit_runtime_call(p, "__dynamic_map_set", args);
}
diff --git a/src/llvm_backend_expr.cpp b/src/llvm_backend_expr.cpp
index 05a9fdfbf..7e9aa3a78 100644
--- a/src/llvm_backend_expr.cpp
+++ b/src/llvm_backend_expr.cpp
@@ -1423,9 +1423,9 @@ lbValue lb_build_binary_expr(lbProcedure *p, Ast *expr) {
switch (rt->kind) {
case Type_Map:
{
- lbValue map_ptr = lb_address_from_load_or_generate_local(p, right);
+ lbValue map = right;
lbValue key = left;
- lbValue ptr = lb_internal_dynamic_map_get_ptr(p, map_ptr, key);
+ lbValue ptr = lb_internal_dynamic_map_get_ptr(p, map, key);
if (be->op.kind == Token_in) {
return lb_emit_conv(p, lb_emit_comp_against_nil(p, Token_NotEq, ptr), t_bool);
} else {
diff --git a/src/llvm_backend_general.cpp b/src/llvm_backend_general.cpp
index b7654614e..e1a926255 100644
--- a/src/llvm_backend_general.cpp
+++ b/src/llvm_backend_general.cpp
@@ -417,7 +417,7 @@ lbValue lb_addr_get_ptr(lbProcedure *p, lbAddr const &addr) {
switch (addr.kind) {
case lbAddr_Map:
- return lb_internal_dynamic_map_get_ptr(p, addr.addr, addr.map.key);
+ return lb_internal_dynamic_map_get_ptr(p, lb_emit_load(p, addr.addr), addr.map.key);
case lbAddr_RelativePointer: {
Type *rel_ptr = base_type(lb_addr_type(addr));
@@ -1074,7 +1074,7 @@ lbValue lb_addr_load(lbProcedure *p, lbAddr const &addr) {
GB_ASSERT(map_type->kind == Type_Map);
lbAddr v = lb_add_local_generated(p, map_type->Map.lookup_result_type, true);
- lbValue ptr = lb_internal_dynamic_map_get_ptr(p, addr.addr, addr.map.key);
+ lbValue ptr = lb_internal_dynamic_map_get_ptr(p, lb_emit_load(p, addr.addr), addr.map.key);
lbValue ok = lb_emit_conv(p, lb_emit_comp_against_nil(p, Token_NotEq, ptr), t_bool);
lb_emit_store(p, lb_emit_struct_ep(p, v.addr, 1), ok);
diff --git a/src/llvm_backend_utility.cpp b/src/llvm_backend_utility.cpp
index f4d17c7a2..a3493f864 100644
--- a/src/llvm_backend_utility.cpp
+++ b/src/llvm_backend_utility.cpp
@@ -203,26 +203,19 @@ lbValue lb_emit_transmute(lbProcedure *p, lbValue value, Type *t) {
if (is_type_uintptr(src) && is_type_internally_pointer_like(dst)) {
res.value = LLVMBuildIntToPtr(p->builder, value.value, lb_type(m, t), "");
return res;
- }
- if (is_type_internally_pointer_like(src) && is_type_uintptr(dst)) {
+ } else if (is_type_internally_pointer_like(src) && is_type_uintptr(dst)) {
res.value = LLVMBuildPtrToInt(p->builder, value.value, lb_type(m, t), "");
return res;
- }
-
- if (is_type_integer(src) && is_type_internally_pointer_like(dst)) {
+ } else if (is_type_integer(src) && is_type_internally_pointer_like(dst)) {
res.value = LLVMBuildIntToPtr(p->builder, value.value, lb_type(m, t), "");
return res;
} else if (is_type_internally_pointer_like(src) && is_type_integer(dst)) {
res.value = LLVMBuildPtrToInt(p->builder, value.value, lb_type(m, t), "");
return res;
- }
-
- if (is_type_internally_pointer_like(src) && is_type_internally_pointer_like(dst)) {
+ } else if (is_type_internally_pointer_like(src) && is_type_internally_pointer_like(dst)) {
res.value = LLVMBuildPointerCast(p->builder, value.value, lb_type(p->module, t), "");
return res;
- }
-
- if (is_type_simd_vector(src) && is_type_simd_vector(dst)) {
+ } else if (is_type_simd_vector(src) && is_type_simd_vector(dst)) {
res.value = LLVMBuildBitCast(p->builder, value.value, lb_type(p->module, t), "");
return res;
} else if (is_type_array_like(src) && is_type_simd_vector(dst)) {
@@ -239,9 +232,11 @@ lbValue lb_emit_transmute(lbProcedure *p, lbValue value, Type *t) {
ap = lb_emit_conv(p, ap, alloc_type_pointer(value.type));
lb_emit_store(p, ap, value);
return lb_addr_load(p, addr);
- }
-
- if (lb_is_type_aggregate(src) || lb_is_type_aggregate(dst)) {
+ } else if (is_type_map(src) && are_types_identical(t_raw_map, t)) {
+ res.value = value.value;
+ res.type = t;
+ return res;
+ } else if (lb_is_type_aggregate(src) || lb_is_type_aggregate(dst)) {
lbValue s = lb_address_from_load_or_generate_local(p, value);
lbValue d = lb_emit_transmute(p, s, alloc_type_pointer(t));
return lb_emit_load(p, d);
diff --git a/src/types.cpp b/src/types.cpp
index ca15531dd..ab82e87b8 100644
--- a/src/types.cpp
+++ b/src/types.cpp
@@ -685,9 +685,10 @@ gb_global Type *t_source_code_location_ptr = nullptr;
gb_global Type *t_map_info = nullptr;
gb_global Type *t_map_cell_info = nullptr;
+gb_global Type *t_raw_map = nullptr;
gb_global Type *t_map_info_ptr = nullptr;
gb_global Type *t_map_cell_info_ptr = nullptr;
-gb_global Type *t_raw_map = nullptr;
+gb_global Type *t_raw_map_ptr = nullptr;
gb_global Type *t_equal_proc = nullptr;