Simplify use of pie

This commit is contained in:
0dminnimda
2024-11-04 15:39:06 +03:00
committed by flysand7
parent 480f32586e
commit 4f37b34654
3 changed files with 9 additions and 48 deletions
+9 -20
View File
@@ -607,27 +607,16 @@ gb_internal i32 linker_stage(LinkerData *gen) {
}
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 ");
}
if (build_context.build_mode == BuildMode_Executable && build_context.reloc_mode == RelocMode_PIC) {
// Do not disable PIE, let the linker choose. (most likely you want it enabled)
} else 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(), "");