aboutsummaryrefslogtreecommitdiff
path: root/src/linker.cpp
diff options
context:
space:
mode:
authorJesse Meyer <jesse.r.meyer@me.com>2026-02-01 09:04:53 -0500
committerJesse Meyer <jesse.r.meyer@me.com>2026-02-03 20:16:20 -0500
commit43ad4a1d9f18a89822e1b9f554adef1a228136db (patch)
treeca7a569d1e5adc6fa3f1d7eb6c1a5fe36b175715 /src/linker.cpp
parentf7901cffc9f4983259586241d5b336cdb6377b9c (diff)
Add ThinLTO support via -lto:thin and -lto:thin-files flags
- Add -lto:thin and -lto:thin-files CLI flags with validation - Emit LLVM bitcode (.bc) instead of object files when LTO is enabled - Pass -flto=thin and -flto-jobs to clang/lld linkers - Guard linkage corrections to skip declarations without definitions (required for LTO where declarations appear across modules) - Allow module-per-file with LTO even at higher optimization levels Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
Diffstat (limited to 'src/linker.cpp')
-rw-r--r--src/linker.cpp16
1 files changed, 15 insertions, 1 deletions
diff --git a/src/linker.cpp b/src/linker.cpp
index bc6268049..f369a5a38 100644
--- a/src/linker.cpp
+++ b/src/linker.cpp
@@ -328,6 +328,12 @@ try_cross_linking:;
String windows_sdk_bin_path = path_to_string(heap_allocator(), build_context.build_paths[BuildPath_Win_SDK_Bin_Path]);
defer (gb_free(heap_allocator(), windows_sdk_bin_path.text));
+ gbString lld_lto_flags = gb_string_make(heap_allocator(), "");
+ defer (gb_string_free(lld_lto_flags));
+ if (build_context.lto_kind != LTO_None) {
+ lld_lto_flags = gb_string_append_fmt(lld_lto_flags, "/lldltojobs:%d ", build_context.thread_count);
+ }
+
switch (build_context.linker_choice) {
case Linker_lld:
result = system_exec_command_line_app("msvc-lld-link",
@@ -336,13 +342,15 @@ try_cross_linking:;
"%.*s "
"%.*s "
"%s "
+ "%s "
"",
LIT(build_context.ODIN_ROOT), object_files, LIT(output_filename),
link_settings,
LIT(windows_subsystem_names[build_context.ODIN_WINDOWS_SUBSYSTEM]),
LIT(build_context.link_flags),
LIT(build_context.extra_linker_flags),
- lib_str
+ lib_str,
+ lld_lto_flags
);
if (result) {
@@ -966,6 +974,12 @@ try_cross_linking:;
link_command_line = gb_string_appendc(link_command_line, clang_path);
}
link_command_line = gb_string_appendc(link_command_line, " -Wno-unused-command-line-argument ");
+
+ if (build_context.lto_kind != LTO_None) {
+ link_command_line = gb_string_appendc(link_command_line, " -flto=thin");
+ link_command_line = gb_string_append_fmt(link_command_line, " -flto-jobs=%d ", build_context.thread_count);
+ }
+
link_command_line = gb_string_appendc(link_command_line, object_files);
link_command_line = gb_string_append_fmt(link_command_line, " -o \"%.*s\" ", LIT(output_filename));
link_command_line = gb_string_append_fmt(link_command_line, " %s ", platform_lib_str);