diff options
| author | 0dminnimda <0dminnimda@gmail.com> | 2024-11-04 02:17:21 +0300 |
|---|---|---|
| committer | 0dminnimda <0dminnimda@gmail.com> | 2024-11-04 02:35:49 +0300 |
| commit | 35f1b0f11ebb97910f3b4c82abd4a87dd52985f9 (patch) | |
| tree | dc5dbd3c58035dd50aab1f98f579b38858747d68 /src/linker.cpp | |
| parent | 5f99d6b42723edd1ed3aa145e5b7c6d56960e33e (diff) | |
Add support for linking as pie
Diffstat (limited to 'src/linker.cpp')
| -rw-r--r-- | src/linker.cpp | 24 |
1 files changed, 22 insertions, 2 deletions
diff --git a/src/linker.cpp b/src/linker.cpp index 2ed0987ac..6b16c6489 100644 --- a/src/linker.cpp +++ b/src/linker.cpp @@ -605,9 +605,29 @@ gb_internal i32 linker_stage(LinkerData *gen) { link_settings = gb_string_appendc(link_settings, "-Wl,-fini,'_odin_exit_point' "); } - } else if (build_context.metrics.os != TargetOs_openbsd && build_context.metrics.os != TargetOs_haiku && build_context.metrics.arch != TargetArch_riscv64) { - // OpenBSD and Haiku default to PIE executable. do not pass -no-pie for it. + } + + switch (build_context.link_pie) { + case (LinkPIE_Default): + if (build_context.build_mode != BuildMode_DynamicLibrary) { + if (build_context.metrics.os != TargetOs_openbsd + && build_context.metrics.os != TargetOs_haiku + && build_context.metrics.arch != TargetArch_riscv64 + ) { + // OpenBSD and Haiku default to PIE executable. do not pass -no-pie for it. + link_settings = gb_string_appendc(link_settings, "-no-pie "); + } + } + break; + case (LinkPIE_Yes): + if (build_context.build_mode != BuildMode_Executable) { + compiler_error("linking NON-EXECUTABLE as pie (position independent EXECUTABLE)"); + } + link_settings = gb_string_appendc(link_settings, "-pie "); + break; + case (LinkPIE_No): link_settings = gb_string_appendc(link_settings, "-no-pie "); + break; } gbString platform_lib_str = gb_string_make(heap_allocator(), ""); |