aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorgingerBill <gingerBill@users.noreply.github.com>2025-03-27 15:05:34 +0000
committerGitHub <noreply@github.com>2025-03-27 15:05:34 +0000
commit71db9ac1ba7ca3aef94bfd026b0e4bc444a20124 (patch)
tree1b431a1cfbef5baab122e7bafbf98fdb0085f447 /src
parent8b30adf60bf7a66318c83ba6c286f7710a79094d (diff)
parent5274aa53b3eefc661e48fb66befd3e75f7bc4177 (diff)
Merge pull request #4976 from voutilad/openbsd-linker
Fix linking of programs on OpenBSD
Diffstat (limited to 'src')
-rw-r--r--src/linker.cpp7
1 files changed, 7 insertions, 0 deletions
diff --git a/src/linker.cpp b/src/linker.cpp
index cf2ef638d..56e8d3034 100644
--- a/src/linker.cpp
+++ b/src/linker.cpp
@@ -701,6 +701,13 @@ gb_internal i32 linker_stage(LinkerData *gen) {
// This points the linker to where the entry point is
link_settings = gb_string_appendc(link_settings, "-e _main ");
}
+ } else if (build_context.metrics.os == TargetOs_openbsd) {
+ // OpenBSD ports install shared libraries in /usr/local/lib. Also, we must explicitly link libpthread.
+ platform_lib_str = gb_string_appendc(platform_lib_str, "-lpthread -Wl,-L/usr/local/lib ");
+ // Until the LLVM back-end can be adapted to emit endbr64 instructions on amd64, we
+ // need to pass -z nobtcfi in order to allow the resulting program to run under
+ // OpenBSD 7.4 and newer. Once support is added at compile time, this can be dropped.
+ platform_lib_str = gb_string_appendc(platform_lib_str, "-Wl,-z,nobtcfi ");
}
if (!build_context.no_rpath) {