Skip to content

Commit

Permalink
Merge pull request #87464 from bruvzg/pck_section
Browse files Browse the repository at this point in the history
[Linux] Add support for PCK embedding section with non GNU-ld linkers.
  • Loading branch information
akien-mga committed Feb 8, 2024
2 parents 261952a + 625c4bd commit 11964fb
Show file tree
Hide file tree
Showing 5 changed files with 14 additions and 40 deletions.
18 changes: 0 additions & 18 deletions platform/linuxbsd/detect.py
Original file line number Diff line number Diff line change
Expand Up @@ -496,24 +496,6 @@ def configure(env: "Environment"):
if env["execinfo"]:
env.Append(LIBS=["execinfo"])

if not env.editor_build:
import subprocess
import re

linker_version_str = subprocess.check_output(
[env.subst(env["LINK"]), "-Wl,--version"] + env.subst(env["LINKFLAGS"])
).decode("utf-8")
gnu_ld_version = re.search(r"^GNU ld [^$]*(\d+\.\d+)$", linker_version_str, re.MULTILINE)
if not gnu_ld_version:
print(
"Warning: Creating export template binaries enabled for PCK embedding is currently only supported with GNU ld, not gold, LLD or mold."
)
else:
if float(gnu_ld_version.group(1)) >= 2.30:
env.Append(LINKFLAGS=["-T", "platform/linuxbsd/pck_embed.ld"])
else:
env.Append(LINKFLAGS=["-T", "platform/linuxbsd/pck_embed.legacy.ld"])

if platform.system() == "FreeBSD":
env.Append(LINKFLAGS=["-lkvm"])

Expand Down
12 changes: 12 additions & 0 deletions platform/linuxbsd/godot_linuxbsd.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,18 @@
#include <sys/resource.h>
#endif

// For export templates, add a section; the exporter will patch it to enclose
// the data appended to the executable (bundled PCK).
#if !defined(TOOLS_ENABLED) && defined(__GNUC__)
static const char dummy[8] __attribute__((section("pck"), used)) = { 0 };

// Dummy function to prevent LTO from discarding "pck" section.
extern "C" const char *pck_section_dummy_call() __attribute__((used));
extern "C" const char *pck_section_dummy_call() {
return &dummy[0];
}
#endif

int main(int argc, char *argv[]) {
#if defined(SANITIZERS_ENABLED)
// Note: Set stack size to be at least 30 MB (vs 8 MB default) to avoid overflow, address sanitizer can increase stack usage up to 3 times.
Expand Down
10 changes: 0 additions & 10 deletions platform/linuxbsd/pck_embed.ld

This file was deleted.

10 changes: 0 additions & 10 deletions platform/linuxbsd/pck_embed.legacy.ld

This file was deleted.

4 changes: 2 additions & 2 deletions platform/windows/godot_windows.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,7 @@
#include <stdio.h>

// For export templates, add a section; the exporter will patch it to enclose
// the data appended to the executable (bundled PCK)
// the data appended to the executable (bundled PCK).
#ifndef TOOLS_ENABLED
#if defined _MSC_VER
#pragma section("pck", read)
Expand All @@ -45,7 +45,7 @@ __declspec(allocate("pck")) static char dummy[8] = { 0 };
// Dummy function to prevent LTO from discarding "pck" section.
extern "C" char *__cdecl pck_section_dummy_call() {
return &dummy[0];
};
}
#if defined _AMD64_
#pragma comment(linker, "/include:pck_section_dummy_call")
#elif defined _X86_
Expand Down

0 comments on commit 11964fb

Please sign in to comment.