aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorgingerBill <bill@gingerbill.org>2024-07-23 02:40:51 +0100
committergingerBill <bill@gingerbill.org>2024-07-23 02:40:51 +0100
commitbc5b41938ec29cbc7678c0307e7571a02b3d84b1 (patch)
tree139cf901083e9eaa938ed374766eb0f1d88e4312 /src
parent527c0b3202a5c61c253b83f527aea08fea2370fb (diff)
Fix #3964
Diffstat (limited to 'src')
-rw-r--r--src/llvm_backend.cpp5
-rw-r--r--src/llvm_backend.hpp2
-rw-r--r--src/llvm_backend_const.cpp6
3 files changed, 9 insertions, 4 deletions
diff --git a/src/llvm_backend.cpp b/src/llvm_backend.cpp
index 62909dafb..9fa570eaf 100644
--- a/src/llvm_backend.cpp
+++ b/src/llvm_backend.cpp
@@ -3288,11 +3288,12 @@ gb_internal bool lb_generate_code(lbGenerator *gen) {
if (!is_type_any(e->type) && !is_type_union(e->type)) {
if (tav.mode != Addressing_Invalid) {
if (tav.value.kind != ExactValue_Invalid) {
+ bool is_rodata = e->kind == Entity_Variable && e->Variable.is_rodata;
ExactValue v = tav.value;
- lbValue init = lb_const_value(m, tav.type, v);
+ lbValue init = lb_const_value(m, tav.type, v, false, is_rodata);
LLVMSetInitializer(g.value, init.value);
var.is_initialized = true;
- if (e->kind == Entity_Variable && e->Variable.is_rodata) {
+ if (is_rodata) {
LLVMSetGlobalConstant(g.value, true);
}
}
diff --git a/src/llvm_backend.hpp b/src/llvm_backend.hpp
index 806864c7c..02daecf6b 100644
--- a/src/llvm_backend.hpp
+++ b/src/llvm_backend.hpp
@@ -398,7 +398,7 @@ gb_internal lbBlock *lb_create_block(lbProcedure *p, char const *name, bool appe
gb_internal lbValue lb_const_nil(lbModule *m, Type *type);
gb_internal lbValue lb_const_undef(lbModule *m, Type *type);
-gb_internal lbValue lb_const_value(lbModule *m, Type *type, ExactValue value, bool allow_local=true);
+gb_internal lbValue lb_const_value(lbModule *m, Type *type, ExactValue value, bool allow_local=true, bool is_rodata=false);
gb_internal lbValue lb_const_bool(lbModule *m, Type *type, bool value);
gb_internal lbValue lb_const_int(lbModule *m, Type *type, u64 value);
diff --git a/src/llvm_backend_const.cpp b/src/llvm_backend_const.cpp
index 12bcc4e1f..4f9ca8714 100644
--- a/src/llvm_backend_const.cpp
+++ b/src/llvm_backend_const.cpp
@@ -470,7 +470,7 @@ gb_internal bool lb_is_nested_possibly_constant(Type *ft, Selection const &sel,
return lb_is_elem_const(elem, ft);
}
-gb_internal lbValue lb_const_value(lbModule *m, Type *type, ExactValue value, bool allow_local) {
+gb_internal lbValue lb_const_value(lbModule *m, Type *type, ExactValue value, bool allow_local, bool is_rodata) {
LLVMContextRef ctx = m->ctx;
type = default_type(type);
@@ -565,6 +565,10 @@ gb_internal lbValue lb_const_value(lbModule *m, Type *type, ExactValue value, bo
array_data = LLVMAddGlobal(m->mod, lb_type(m, t), str);
LLVMSetInitializer(array_data, backing_array.value);
+ if (is_rodata) {
+ LLVMSetGlobalConstant(array_data, true);
+ }
+
lbValue g = {};
g.value = array_data;
g.type = t;