aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorgingerBill <bill@gingerbill.org>2024-02-27 15:45:53 +0000
committergingerBill <bill@gingerbill.org>2024-02-27 15:45:53 +0000
commit5107bdc06b7c1c8d02caef3e270e904218d82911 (patch)
tree555bfb2d3edbb69e27d3d8304d08faefac344bcf
parent5137d12d36e8631201bbf4fcb8ebacd24e7cc4c5 (diff)
Make `lb_type_info` use a procedure to load the global value
-rw-r--r--src/llvm_backend.cpp2
-rw-r--r--src/llvm_backend.hpp2
-rw-r--r--src/llvm_backend_proc.cpp2
-rw-r--r--src/llvm_backend_stmt.cpp2
-rw-r--r--src/llvm_backend_type.cpp13
5 files changed, 9 insertions, 12 deletions
diff --git a/src/llvm_backend.cpp b/src/llvm_backend.cpp
index a8d2df181..efba19f23 100644
--- a/src/llvm_backend.cpp
+++ b/src/llvm_backend.cpp
@@ -1164,7 +1164,7 @@ gb_internal lbProcedure *lb_create_startup_runtime(lbModule *main_module, lbProc
lbValue data = lb_emit_struct_ep(p, var.var, 0);
lbValue ti = lb_emit_struct_ep(p, var.var, 1);
lb_emit_store(p, data, lb_emit_conv(p, gp, t_rawptr));
- lb_emit_store(p, ti, lb_type_info(main_module, var_type));
+ lb_emit_store(p, ti, lb_type_info(p, var_type));
} else {
LLVMTypeRef vt = llvm_addr_type(p->module, var.var);
lbValue src0 = lb_emit_conv(p, var.init, t);
diff --git a/src/llvm_backend.hpp b/src/llvm_backend.hpp
index 48e1c87c6..741557efd 100644
--- a/src/llvm_backend.hpp
+++ b/src/llvm_backend.hpp
@@ -485,7 +485,7 @@ gb_internal lbValue lb_emit_mul_add(lbProcedure *p, lbValue a, lbValue b, lbValu
gb_internal void lb_fill_slice(lbProcedure *p, lbAddr const &slice, lbValue base_elem, lbValue len);
-gb_internal lbValue lb_type_info(lbModule *m, Type *type);
+gb_internal lbValue lb_type_info(lbProcedure *p, Type *type);
gb_internal lbValue lb_find_or_add_entity_string(lbModule *m, String const &str);
gb_internal lbValue lb_generate_anonymous_proc_lit(lbModule *m, String const &prefix_name, Ast *expr, lbProcedure *parent = nullptr);
diff --git a/src/llvm_backend_proc.cpp b/src/llvm_backend_proc.cpp
index 9419f9a3c..13b0171e4 100644
--- a/src/llvm_backend_proc.cpp
+++ b/src/llvm_backend_proc.cpp
@@ -1755,7 +1755,7 @@ gb_internal lbValue lb_build_builtin_proc(lbProcedure *p, Ast *expr, TypeAndValu
TypeAndValue tav = type_and_value_of_expr(arg);
if (tav.mode == Addressing_Type) {
Type *t = default_type(type_of_expr(arg));
- return lb_type_info(p->module, t);
+ return lb_type_info(p, t);
}
GB_ASSERT(is_type_typeid(tav.type));
diff --git a/src/llvm_backend_stmt.cpp b/src/llvm_backend_stmt.cpp
index 388b512b2..0de9c0bf9 100644
--- a/src/llvm_backend_stmt.cpp
+++ b/src/llvm_backend_stmt.cpp
@@ -748,7 +748,7 @@ gb_internal void lb_build_range_enum(lbProcedure *p, Type *enum_type, Type *val_
i64 enum_count = t->Enum.fields.count;
lbValue max_count = lb_const_int(m, t_int, enum_count);
- lbValue ti = lb_type_info(m, t);
+ lbValue ti = lb_type_info(p, t);
lbValue variant = lb_emit_struct_ep(p, ti, 4);
lbValue eti_ptr = lb_emit_conv(p, variant, t_type_info_enum_ptr);
lbValue values = lb_emit_load(p, lb_emit_struct_ep(p, eti_ptr, 2));
diff --git a/src/llvm_backend_type.cpp b/src/llvm_backend_type.cpp
index 881ac3119..aec1fb201 100644
--- a/src/llvm_backend_type.cpp
+++ b/src/llvm_backend_type.cpp
@@ -111,22 +111,19 @@ gb_internal lbValue lb_typeid(lbModule *m, Type *type) {
return res;
}
-gb_internal lbValue lb_type_info(lbModule *m, Type *type) {
+gb_internal lbValue lb_type_info(lbProcedure *p, Type *type) {
GB_ASSERT(!build_context.no_rtti);
type = default_type(type);
+ lbModule *m = p->module;
isize index = lb_type_info_index(m->info, type);
GB_ASSERT(index >= 0);
- LLVMValueRef global = lb_global_type_info_data_ptr(m).value;
+ lbValue global = lb_global_type_info_data_ptr(m);
- LLVMValueRef global_array = LLVMGetInitializer(global);
- LLVMValueRef index_value = LLVMConstInt(lb_type(m, t_int), index, false);
- lbValue res = {};
- res.value = LLVMConstPointerCast(LLVMConstExtractElement(global_array, index_value), lb_type(m, t_type_info_ptr));
- res.type = t_type_info_ptr;
- return res;
+ lbValue ptr = lb_emit_array_epi(p, global, index);
+ return lb_emit_load(p, ptr);
}
gb_internal LLVMTypeRef lb_get_procedure_raw_type(lbModule *m, Type *type) {