aboutsummaryrefslogtreecommitdiff
path: root/src/llvm_backend_utility.cpp
diff options
context:
space:
mode:
authorgingerBill <bill@gingerbill.org>2025-04-03 09:33:14 +0100
committergingerBill <bill@gingerbill.org>2025-04-03 09:37:38 +0100
commitcd5bef4f610ec3ee32957cbca354ccbfef310921 (patch)
tree5fd9959ab6d0c36f6a76ae15a16b42ed7bda6275 /src/llvm_backend_utility.cpp
parentd31ad3cd7fbc2dcbc42f2edfa4adacbaf75770ad (diff)
Rewrite objc SEL/Class register handling code
Diffstat (limited to 'src/llvm_backend_utility.cpp')
-rw-r--r--src/llvm_backend_utility.cpp118
1 files changed, 50 insertions, 68 deletions
diff --git a/src/llvm_backend_utility.cpp b/src/llvm_backend_utility.cpp
index efe196e58..0decbcdb8 100644
--- a/src/llvm_backend_utility.cpp
+++ b/src/llvm_backend_utility.cpp
@@ -2094,48 +2094,71 @@ gb_internal void lb_set_wasm_export_attributes(LLVMValueRef value, String export
}
-
gb_internal lbAddr lb_handle_objc_find_or_register_selector(lbProcedure *p, String const &name) {
- mutex_lock(&p->module->objc_selectors_mutex);
- defer (mutex_unlock(&p->module->objc_selectors_mutex));
-
- lbObjcRef *found = string_map_get(&p->module->objc_selectors, name);
-
+ lbModule *m = p->module;
+ lbAddr *found = string_map_get(&m->objc_selectors, name);
if (found) {
- return found->local_module_addr;
+ return *found;
}
lbModule *default_module = &p->module->gen->default_module;
- Entity *entity = {};
- if (default_module != p->module) {
- found = string_map_get(&default_module->objc_selectors, name);
- if (found) {
- entity = found->entity;
- }
+
+ gbString global_name = gb_string_make(permanent_allocator(), "__$objc_SEL::");
+ global_name = gb_string_append_length(global_name, name.text, name.len);
+
+ LLVMTypeRef t = lb_type(m, t_objc_SEL);
+ lbValue g = {};
+ g.value = LLVMAddGlobal(m->mod, t, global_name);
+ g.type = alloc_type_pointer(t_objc_SEL);
+
+ if (default_module == m) {
+ LLVMSetInitializer(g.value, LLVMConstNull(t));
+ lb_add_member(m, make_string_c(global_name), g);
+ } else {
+ LLVMSetLinkage(g.value, LLVMExternalLinkage);
}
- if (!entity) {
- gbString global_name = gb_string_make(permanent_allocator(), "__$objc_SEL::");
- global_name = gb_string_append_length(global_name, name.text, name.len);
+ mpsc_enqueue(&m->gen->objc_selectors, lbObjCGlobal{m, global_name, name, t_objc_SEL});
+
+ lbAddr addr = lb_addr(g);
- lbAddr default_addr = lb_add_global_generated_with_name(default_module, t_objc_SEL, {},
- make_string(cast(u8 const *)global_name, gb_string_length(global_name)),
- &entity);
+ string_map_set(&m->objc_selectors, name, addr);
- mutex_lock(&default_module->objc_selectors_mutex);
- string_map_set(&default_module->objc_selectors, name, lbObjcRef{entity, default_addr});
- mutex_unlock(&default_module->objc_selectors_mutex);
+ return addr;
+}
+
+gb_internal lbAddr lb_handle_objc_find_or_register_class(lbProcedure *p, String const &name) {
+ lbModule *m = p->module;
+ lbAddr *found = string_map_get(&m->objc_classes, name);
+ if (found) {
+ return *found;
}
- lbValue ptr = lb_find_value_from_entity(p->module, entity);
- lbAddr local_addr = lb_addr(ptr);
+ lbModule *default_module = &p->module->gen->default_module;
+
+
+ gbString global_name = gb_string_make(permanent_allocator(), "__$objc_Class::");
+ global_name = gb_string_append_length(global_name, name.text, name.len);
- if (default_module != p->module) {
- string_map_set(&p->module->objc_selectors, name, lbObjcRef{entity, local_addr});
+ LLVMTypeRef t = lb_type(m, t_objc_Class);
+ lbValue g = {};
+ g.value = LLVMAddGlobal(m->mod, t, global_name);
+ g.type = alloc_type_pointer(t_objc_Class);
+
+ if (default_module == m) {
+ LLVMSetInitializer(g.value, LLVMConstNull(t));
+ lb_add_member(m, make_string_c(global_name), g);
+ } else {
+ LLVMSetLinkage(g.value, LLVMExternalLinkage);
}
+ mpsc_enqueue(&m->gen->objc_classes, lbObjCGlobal{m, global_name, name, t_objc_Class});
- return local_addr;
+ lbAddr addr = lb_addr(g);
+
+ string_map_set(&m->objc_classes, name, addr);
+
+ return addr;
}
gb_internal lbValue lb_handle_objc_find_selector(lbProcedure *p, Ast *expr) {
@@ -2164,47 +2187,6 @@ gb_internal lbValue lb_handle_objc_register_selector(lbProcedure *p, Ast *expr)
return lb_addr_load(p, dst);
}
-gb_internal lbAddr lb_handle_objc_find_or_register_class(lbProcedure *p, String const &name) {
- mutex_lock(&p->module->objc_classes_mutex);
- defer (mutex_unlock(&p->module->objc_classes_mutex));
-
- lbObjcRef *found = string_map_get(&p->module->objc_classes, name);
- if (found) {
- return found->local_module_addr;
- }
-
- lbModule *default_module = &p->module->gen->default_module;
- Entity *entity = {};
-
- if (default_module != p->module) {
- found = string_map_get(&default_module->objc_classes, name);
- if (found) {
- entity = found->entity;
- }
- }
-
- if (!entity) {
- gbString global_name = gb_string_make(permanent_allocator(), "__$objc_Class::");
- global_name = gb_string_append_length(global_name, name.text, name.len);
-
- lbAddr default_addr = lb_add_global_generated_with_name(default_module, t_objc_Class, {},
- make_string(cast(u8 const *)global_name, gb_string_length(global_name)),
- &entity);
-
- mutex_lock(&default_module->objc_classes_mutex);
- string_map_set(&default_module->objc_classes, name, lbObjcRef{entity, default_addr});
- mutex_unlock(&default_module->objc_classes_mutex);
- }
-
- lbValue ptr = lb_find_value_from_entity(p->module, entity);
- lbAddr local_addr = lb_addr(ptr);
-
- if (default_module != p->module) {
- string_map_set(&p->module->objc_classes, name, lbObjcRef{entity, local_addr});
- }
-
- return local_addr;
-}
gb_internal lbValue lb_handle_objc_find_class(lbProcedure *p, Ast *expr) {
ast_node(ce, CallExpr, expr);