summaryrefslogtreecommitdiff
path: root/sys-devel/mold
diff options
context:
space:
mode:
Diffstat (limited to 'sys-devel/mold')
-rw-r--r--sys-devel/mold/Manifest11
-rw-r--r--sys-devel/mold/files/mold-2.3.2-mimalloc-visibility-interposition.patch495
-rw-r--r--sys-devel/mold/mold-1.11.0.ebuild89
-rw-r--r--sys-devel/mold/mold-2.0.0-r1.ebuild93
-rw-r--r--sys-devel/mold/mold-2.0.0-r2.ebuild94
-rw-r--r--sys-devel/mold/mold-2.3.2-r1.ebuild (renamed from sys-devel/mold/mold-2.3.1.ebuild)4
-rw-r--r--sys-devel/mold/mold-9999.ebuild3
7 files changed, 503 insertions, 286 deletions
diff --git a/sys-devel/mold/Manifest b/sys-devel/mold/Manifest
index cae18c759cf8..b2b48452d1bc 100644
--- a/sys-devel/mold/Manifest
+++ b/sys-devel/mold/Manifest
@@ -1,16 +1,11 @@
AUX mold-2.0.0-DT_RELR-dependency.patch 5826 BLAKE2B f728523f8fe758d5f61768b4466e36a5fe44fc019f5c31fa41bf2310ef83db6c7eebfa585f776f0145d6b5727a68a686c0a624702af8ae54624ad2571472c977 SHA512 8ccca7ce514b2dd75a62613554237ef60cb527e892516aba35a6ac62a1a1851d217c5da98c821480a120d83ce071bf01fab390d0e80860d2d65b9ac54a8f03e3
AUX mold-2.0.0-reloc-test-fix.patch 1468 BLAKE2B 197e9876667f4f066d801ff304216498aa4eb718d98badcb1a2eb951ae70984728171f5d1f9945201d7ca316d65a3ee1e3438b3e397246e0bdbc821f109bae59 SHA512 a912f06938d8acac52b673bad8a02ac70f13b47db232a51713d80e33dde93c45c7519b6db24451a072b799d6d7a839aabdb577786758d17535284ebe5b7bb055
AUX mold-2.3.0-no-pch.patch 457 BLAKE2B ac313a6409a2e43b6d26833231cb26c36d3d34f25b25d4217d50fbd1f39eda9d5b42a1939ca8ee48f6dfb73d3c27d7c6111da9beb67a43c72d3c2beb070303b0 SHA512 c79b3e998cbc23ca7069eed95a7d7871371da9c21b6970fe2a1d8dcd1009466e262f63febbc267d364e552b2eb4bebd5d74bc6dc8084d48d4c0e9e02e1d868bc
-DIST mold-1.11.0.tar.gz 8210923 BLAKE2B b3854a14a956dd568625fc28c96636e7cadf81b9a93954601b03e249db0aedf726a5a1f24c0758c8189a936501ebb778b472ee6e958fe9f43cb3c3093b2dda2a SHA512 a9068600dd2db757552cce027f358c0b9e6af0941b92f81c1e99e2dde674bd06cc3533d432258e42a2197d9b3f8e7bb263de281928357a79e4fb17fb19719bc0
-DIST mold-2.0.0.tar.gz 9205927 BLAKE2B f80c72c58f4618a74390417fdf90f816810350baf1ac74d21294f5ffba7ee263807175be531c9db77209bd05a31ad11fd84d4aeb03fb057cefac7575f71612d6 SHA512 11c3d1e07fe4fcc28cff58b8e432526e4604aa55b49fa47c9495e439206fb9f6a1686b1c5bd2dc907ffd7fe62ac1c72317619fc8a5d7caaa5c327de585f16827
+AUX mold-2.3.2-mimalloc-visibility-interposition.patch 18190 BLAKE2B dfcc0287bf6dfbcdd91fcb9ebf9b56b3d48ef0e6c83566ce832e1279e6ef83acefaac84822b75978596613802a99318765a08eb9c60ace591b5914c1e194263c SHA512 5596bd7cc81e8f5797960aa3cc24d9f5cff3b464839df9b2ff22bf76d3c22041381415464639d0a2079710ad30acd8b9f593e3cd342aedebd398b3d1196aba67
DIST mold-2.1.0.tar.gz 9278811 BLAKE2B b31e13f92177553adf5069cf35c8c75c7bc28f0af4d1726cdc0c6abc1c9d3baaa5be512c3a8fb9bc3c3110096a79e1c6751c701171769595a2234fc1fa8c441a SHA512 f1c98d349b35b4042109d71f7db6eb8d7d089dc3241735bbd7b5402d513dcc85ca17904828779e5fc8234650fa9fb97f47c3a2f3e89cc2fb3cb9e9110439e5a2
-DIST mold-2.3.1.tar.gz 9958470 BLAKE2B 917e1fd770f841dc4bf6fbbed4954762f3eccff3d01247d4a5eaee7a5dad47f0259eb8ba6a10d13f385c9f0aea4d1ac058ce40070902bf7ef366ad8225cfbd5f SHA512 ea234d0b999bcd308e0c5dae27050ff61fd23971f9c54d5eb5764bfb04064dc68c33f5defd614544762a9891ce4369125a6aac68171e68de4ed09a08d59e599e
DIST mold-2.3.2.tar.gz 9970530 BLAKE2B db943ad6fab336a8c9c7b5588895cc1232ebfac25fe9dd884a2fbd71ba8d76b9bf7543b4d98cbda9635a7898e980ec5dc2866ef1d02e7a80e7fb9d7f0cbca443 SHA512 dd98acb351757f99399b7d52589c339648478624323fd45c9e986eaf7f1a60f52ace4c09a2d20246e9340109641bda676735da9de89a277989851bd5f52ea9d0
-EBUILD mold-1.11.0.ebuild 2168 BLAKE2B e6da026cd317d9bce59fb0c802f11571107df36310b4c69c9a1e01386bd989c7c0c785b23eaddee62447ac1aa472096b63156e07640ec7f978c49f08b1c8f765 SHA512 ac3d33eaa80eee576bb4151664bad21647d6517f97a30ac3448a4294f1f92b86a48dd82af340d499510dbca9b84d1960874223ce0c3e229c34efdeacfc4659dd
-EBUILD mold-2.0.0-r1.ebuild 2216 BLAKE2B 63f97d8f38f04769b66c914addd6bfa42d877fd002008c66df50cd96827cdf467a759c7726c4fbb3355d9dfb52bc924ffa693cc2c2fb49a3de38cb29d6201863 SHA512 bb5538ce441103f9a45d9f6339dffa27d9904b747b835017c0d761a8498a828cab4db14ffba4a5e520a0a2f35e89b8a7f7c428a70c60ff0fef127b3cb464181f
-EBUILD mold-2.0.0-r2.ebuild 2262 BLAKE2B 36664776ccff03553da6d71885104666f3b91be07ab8f4f62c96fc7b116d0499172c9cc43f3b05f5fb2bd6b24f80af93ce0e916ceb7ff6dcefb952c4496cfc16 SHA512 48284ddd900756dcf17cb6e8d7729f7fc45a5019d6760522afcfc6c9e6738df37cafd5e68566569f9465e3288de8f6b4854a9d85d2fc48a0b106a4e3a994e5b0
EBUILD mold-2.1.0.ebuild 2169 BLAKE2B b91dec8fb9890052e06cf40124f7647833a6ea786d95d44863848bfff17c0ba335f28aaac08d6971a619dbb845b9091d1134bae47f70bd811d2fde0f9ca11066 SHA512 5d27926e5003e6bd24ee3baf8258ab043aa660b7a36918500283bbec9d991ad8ea6971add52579ba6ee10a7eeeb97a6dff3a7e065c7292ced42d2f0043e33d1e
-EBUILD mold-2.3.1.ebuild 2254 BLAKE2B b768d9a6a562fdc8d376570cd30b960d46e946a08d4ee1ca42d30a5afb4c351b8fe25d8fdf3a3c3e82e4cad2b5d11dffbfb77386db8755545e006adb2dc2ced3 SHA512 eef9344f9832767e76ae50536c725647613bfdc62b0e0bfd782a090434ff04226ab91a382e811ae636efaf7be5b9248e874259acfae3597caa511177aaebc2b2
+EBUILD mold-2.3.2-r1.ebuild 2354 BLAKE2B 29e57a9904a365d0701c1ce5312d86a868fa2a774de8195f276939d6b6787c0f4b60108aa5a6f0ba3ad17bd991891b830600a5ef3e8befa617080cb972c8b22a SHA512 a08f94433862001d6fe50a444f3a50d9ee7aa73c6b76cb6380cbb193399ec5e41386966e8a845c7f7b0570127732b1327c7b3ed7b2fe4345714feb4ea3b0acee
EBUILD mold-2.3.2.ebuild 2299 BLAKE2B 82d0b9e69c44234e971de8740f7dffbe427581562420019fbb8fc52cdf6f4be891161a2c8c4029897ee644cd9787df61cc16e31ff14e33fcbf0c15e9682a2c3e SHA512 3fb1bb02abc0e36efad29b73eb62d48bfe874c67fb6cfdb569ced028a126ebdb027d5fa4c1dd460d16fc5dbb2f98bedcd79e4c4eed5514ad25a441d9a6633272
-EBUILD mold-9999.ebuild 2254 BLAKE2B b768d9a6a562fdc8d376570cd30b960d46e946a08d4ee1ca42d30a5afb4c351b8fe25d8fdf3a3c3e82e4cad2b5d11dffbfb77386db8755545e006adb2dc2ced3 SHA512 eef9344f9832767e76ae50536c725647613bfdc62b0e0bfd782a090434ff04226ab91a382e811ae636efaf7be5b9248e874259acfae3597caa511177aaebc2b2
+EBUILD mold-9999.ebuild 2294 BLAKE2B 82186052b195e75f60946fb6c36730b20ccea478dfee065aaa35e2fb5ed2490e5ded76fde6a84b8b5e1c04084bd3475e05ae2679421b547993dca2f26d47715b SHA512 4e65624b420d77bf0ae35e2b1194dd4873b69ac431c1cbfe949034b98343d359f7b31ee394ef95cf97206f7b5be1cd5a6e30a1f130750df8cf3c9a92c8891c99
MISC metadata.xml 424 BLAKE2B a1c0cbdcb86c323fa1e6143c9665ec548f7713e74002a25b2fc26c51b60dae00922d3448a5aaecd5027a8cb026a681386ca7dea90657a3e10b25fb194dafc0d3 SHA512 1adc934e78ca0210743a1aa7479ebc4b5ea0b66a348c4408423460f02b404b885d3a8eca6e89ea8ac53ac9c76e85116965f1eef79e3f3e1f0451c8cf5ce0dfd6
diff --git a/sys-devel/mold/files/mold-2.3.2-mimalloc-visibility-interposition.patch b/sys-devel/mold/files/mold-2.3.2-mimalloc-visibility-interposition.patch
new file mode 100644
index 000000000000..e569bfaf3013
--- /dev/null
+++ b/sys-devel/mold/files/mold-2.3.2-mimalloc-visibility-interposition.patch
@@ -0,0 +1,495 @@
+https://bugs.gentoo.org/917089
+https://github.com/microsoft/mimalloc/issues/360
+https://github.com/rui314/mold/issues/1071
+https://github.com/rui314/mold/commit/da3f5dd4ecf4faaba466ba41c7c30ba4f8f73bfd
+
+From da3f5dd4ecf4faaba466ba41c7c30ba4f8f73bfd Mon Sep 17 00:00:00 2001
+From: Rui Ueyama <ruiu@cs.stanford.edu>
+Date: Sat, 11 Nov 2023 17:59:54 +0900
+Subject: [PATCH] Fix --dynamic-list for DSOs
+
+--dynamic-list, --export-dynamic-symbol and --export-dynamic-symbol-list
+have different semantics for executables and DSOs. If the output is an
+executable, they specify a list of symbols that are to be exported.
+If the output is a shared object, they specify the list of symbols that
+are to be interposable.
+
+mold havne't implemented the latter semantics. This commit fixes that
+issue.
+
+Fixes https://github.com/rui314/mold/issues/1071
+---
+ elf/cmdline.cc | 25 +++-----
+ elf/linker-script.cc | 35 ++++++-----
+ elf/main.cc | 16 -----
+ elf/mold.h | 17 +++--
+ elf/output-chunks.cc | 8 ++-
+ elf/passes.cc | 122 +++++++++++++++++++++++++++++-------
+ test/elf/dynamic-list4.sh | 44 +++++++++++++
+ test/elf/version-script6.sh | 4 +-
+ 8 files changed, 194 insertions(+), 77 deletions(-)
+ create mode 100755 test/elf/dynamic-list4.sh
+
+diff --git a/elf/cmdline.cc b/elf/cmdline.cc
+index 6bc13a300..6c06b4b14 100644
+--- a/elf/cmdline.cc
++++ b/elf/cmdline.cc
+@@ -1104,21 +1104,21 @@ std::vector<std::string> parse_nonpositional_args(Context<E> &ctx) {
+ } else if (read_flag("no-keep-memory")) {
+ } else if (read_arg("max-cache-size")) {
+ } else if (read_arg("version-script")) {
+- // --version-script, --dynamic-list and --export-dynamic-symbol[-list]
+- // are treated as positional arguments even though they are actually not
+- // positional. This is because linker scripts (a positional argument)
+- // can also specify a version script, and it's better to consolidate
+- // parsing in read_input_files. In particular, version scripts can
+- // modify ctx.default_version which we initialize *after* parsing
+- // non-positional args, so the parsing cannot be done right here.
++ // --version-script is treated as positional arguments even though
++ // they are actually not positional. This is because linker scripts
++ // (a positional argument) can also specify a version script, and
++ // it's better to consolidate parsing in read_input_files. In
++ // particular, version scripts can modify ctx.default_version which
++ // we initialize *after* parsing non-positional args, so the parsing
++ // cannot be done right here.
+ remaining.push_back("--version-script=" + std::string(arg));
+ } else if (read_arg("dynamic-list")) {
+ ctx.arg.Bsymbolic = true;
+- remaining.push_back("--dynamic-list=" + std::string(arg));
++ append(ctx.dynamic_list_patterns, parse_dynamic_list(ctx, arg));
+ } else if (read_arg("export-dynamic-symbol")) {
+- remaining.push_back("--export-dynamic-symbol=" + std::string(arg));
++ ctx.dynamic_list_patterns.push_back({arg, "<command line>"});
+ } else if (read_arg("export-dynamic-symbol-list")) {
+- remaining.push_back("--export-dynamic-symbol-list=" + std::string(arg));
++ append(ctx.dynamic_list_patterns, parse_dynamic_list(ctx, arg));
+ } else if (read_flag("as-needed")) {
+ remaining.push_back("--as-needed");
+ } else if (read_flag("no-as-needed")) {
+@@ -1228,11 +1228,6 @@ std::vector<std::string> parse_nonpositional_args(Context<E> &ctx) {
+ if (char *env = getenv("MOLD_REPRO"); env && env[0])
+ ctx.arg.repro = true;
+
+- if (ctx.arg.shared || ctx.arg.export_dynamic)
+- ctx.default_version = VER_NDX_GLOBAL;
+- else
+- ctx.default_version = VER_NDX_LOCAL;
+-
+ if (ctx.arg.default_symver) {
+ std::string ver = ctx.arg.soname.empty() ?
+ filepath(ctx.arg.output).filename().string() : std::string(ctx.arg.soname);
+diff --git a/elf/linker-script.cc b/elf/linker-script.cc
+index 4bdc19e7c..7ad500bb8 100644
+--- a/elf/linker-script.cc
++++ b/elf/linker-script.cc
+@@ -312,7 +312,6 @@ read_version_script_commands(Context<E> &ctx, std::span<std::string_view> &tok,
+
+ if (tok[0] == "*") {
+ ctx.default_version = (is_global ? ver_idx : (u32)VER_NDX_LOCAL);
+- ctx.default_version_from_version_script = true;
+ } else if (is_global) {
+ ctx.version_patterns.push_back({unquote(tok[0]), current_file<E>->name,
+ ver_str, ver_idx, is_cpp});
+@@ -367,7 +366,9 @@ void parse_version_script(Context<E> &ctx, MappedFile<Context<E>> *mf) {
+ }
+
+ template <typename E>
+-void read_dynamic_list_commands(Context<E> &ctx, std::span<std::string_view> &tok,
++void read_dynamic_list_commands(Context<E> &ctx,
++ std::vector<DynamicPattern> &result,
++ std::span<std::string_view> &tok,
+ bool is_cpp) {
+ while (!tok.empty() && tok[0] != "}") {
+ if (tok[0] == "extern") {
+@@ -376,11 +377,11 @@ void read_dynamic_list_commands(Context<E> &ctx, std::span<std::string_view> &to
+ if (!tok.empty() && tok[0] == "\"C\"") {
+ tok = tok.subspan(1);
+ tok = skip(ctx, tok, "{");
+- read_dynamic_list_commands(ctx, tok, false);
++ read_dynamic_list_commands(ctx, result, tok, false);
+ } else {
+ tok = skip(ctx, tok, "\"C++\"");
+ tok = skip(ctx, tok, "{");
+- read_dynamic_list_commands(ctx, tok, true);
++ read_dynamic_list_commands(ctx, result, tok, true);
+ }
+
+ tok = skip(ctx, tok, "}");
+@@ -388,29 +389,32 @@ void read_dynamic_list_commands(Context<E> &ctx, std::span<std::string_view> &to
+ continue;
+ }
+
+- if (tok[0] == "*")
+- ctx.default_version = VER_NDX_GLOBAL;
+- else
+- ctx.version_patterns.push_back({unquote(tok[0]), current_file<E>->name,
+- "global", VER_NDX_GLOBAL, is_cpp});
+-
++ result.push_back({unquote(tok[0]), "", is_cpp});
+ tok = skip(ctx, tok.subspan(1), ";");
+ }
+ }
+
+ template <typename E>
+-void parse_dynamic_list(Context<E> &ctx, MappedFile<Context<E>> *mf) {
+- current_file<E> = mf;
+- std::vector<std::string_view> vec = tokenize(ctx, mf->get_contents());
++std::vector<DynamicPattern>
++parse_dynamic_list(Context<E> &ctx, std::string_view path) {
++ std::string_view contents =
++ MappedFile<Context<E>>::must_open(ctx, std::string(path))->get_contents();
++ std::vector<std::string_view> vec = tokenize(ctx, contents);
+ std::span<std::string_view> tok = vec;
++ std::vector<DynamicPattern> result;
+
+ tok = skip(ctx, tok, "{");
+- read_dynamic_list_commands(ctx, tok, false);
++ read_dynamic_list_commands(ctx, result, tok, false);
+ tok = skip(ctx, tok, "}");
+ tok = skip(ctx, tok, ";");
+
+ if (!tok.empty())
+ SyntaxError(ctx, tok[0]) << "trailing garbage token";
++
++ for (DynamicPattern &p : result)
++ p.source = path;
++
++ return result;
+ }
+
+ using E = MOLD_TARGET;
+@@ -418,6 +422,7 @@ using E = MOLD_TARGET;
+ template void parse_linker_script(Context<E> &, MappedFile<Context<E>> *);
+ template std::string_view get_script_output_type(Context<E> &, MappedFile<Context<E>> *);
+ template void parse_version_script(Context<E> &, MappedFile<Context<E>> *);
+-template void parse_dynamic_list(Context<E> &, MappedFile<Context<E>> *);
++template std::vector<DynamicPattern> parse_dynamic_list(Context<E> &, std::string_view);
++
+
+ } // namespace mold::elf
+diff --git a/elf/main.cc b/elf/main.cc
+index c4f3cd6ff..6df00cfe9 100644
+--- a/elf/main.cc
++++ b/elf/main.cc
+@@ -299,22 +299,6 @@ static void read_input_files(Context<E> &ctx, std::span<std::string> args) {
+ if (!mf)
+ Fatal(ctx) << "--version-script: file not found: " << arg;
+ parse_version_script(ctx, mf);
+- } else if (remove_prefix(arg, "--dynamic-list=")) {
+- MappedFile<Context<E>> *mf = find_from_search_paths(ctx, std::string(arg));
+- if (!mf)
+- Fatal(ctx) << "--dynamic-list: file not found: " << arg;
+- parse_dynamic_list(ctx, mf);
+- } else if (remove_prefix(arg, "--export-dynamic-symbol=")) {
+- if (arg == "*")
+- ctx.default_version = VER_NDX_GLOBAL;
+- else
+- ctx.version_patterns.push_back({arg, "--export-dynamic-symbol",
+- "global", VER_NDX_GLOBAL, false});
+- } else if (remove_prefix(arg, "--export-dynamic-symbol-list=")) {
+- MappedFile<Context<E>> *mf = find_from_search_paths(ctx, std::string(arg));
+- if (!mf)
+- Fatal(ctx) << "--export-dynamic-symbol-list: file not found: " << arg;
+- parse_dynamic_list(ctx, mf);
+ } else if (arg == "--push-state") {
+ state.push_back({ctx.as_needed, ctx.whole_archive, ctx.is_static,
+ ctx.in_lib});
+diff --git a/elf/mold.h b/elf/mold.h
+index 7ff7c2e6f..d593f6840 100644
+--- a/elf/mold.h
++++ b/elf/mold.h
+@@ -1281,8 +1281,15 @@ get_script_output_type(Context<E> &ctx, MappedFile<Context<E>> *mf);
+ template <typename E>
+ void parse_version_script(Context<E> &ctx, MappedFile<Context<E>> *mf);
+
++struct DynamicPattern {
++ std::string_view pattern;
++ std::string_view source;
++ bool is_cpp = false;
++};
++
+ template <typename E>
+-void parse_dynamic_list(Context<E> &ctx, MappedFile<Context<E>> *mf);
++std::vector<DynamicPattern>
++parse_dynamic_list(Context<E> &ctx, std::string_view path);
+
+ //
+ // lto.cc
+@@ -1733,13 +1740,11 @@ struct Context {
+ } arg;
+
+ std::vector<VersionPattern> version_patterns;
+- u16 default_version = VER_NDX_GLOBAL;
++ std::vector<DynamicPattern> dynamic_list_patterns;
++ i64 default_version = -1;
+ i64 page_size = E::page_size;
+ std::optional<int> global_lock_fd;
+
+- // true if default_version is set by a wildcard in version script.
+- bool default_version_from_version_script = false;
+-
+ // Reader context
+ bool as_needed = false;
+ bool whole_archive = false;
+@@ -2034,7 +2039,7 @@ class Symbol {
+ i32 sym_idx = -1;
+
+ i32 aux_idx = -1;
+- u16 ver_idx = 0;
++ i32 ver_idx = -1;
+
+ // `flags` has NEEDS_ flags.
+ Atomic<u8> flags = 0;
+diff --git a/elf/output-chunks.cc b/elf/output-chunks.cc
+index f44d448ac..00d5538df 100644
+--- a/elf/output-chunks.cc
++++ b/elf/output-chunks.cc
+@@ -2550,8 +2550,12 @@ void VerdefSection<E>::construct(Context<E> &ctx) {
+ for (std::string_view verstr : ctx.arg.version_definitions)
+ write(verstr, idx++, 0);
+
+- for (Symbol<E> *sym : std::span<Symbol<E> *>(ctx.dynsym->symbols).subspan(1))
+- ctx.versym->contents[sym->get_dynsym_idx(ctx)] = sym->ver_idx;
++ for (Symbol<E> *sym : std::span<Symbol<E> *>(ctx.dynsym->symbols).subspan(1)) {
++ i64 ver = sym->ver_idx;
++ if (ver == -1)
++ ver = VER_NDX_GLOBAL;
++ ctx.versym->contents[sym->get_dynsym_idx(ctx)] = ver;
++ }
+ }
+
+ template <typename E>
+diff --git a/elf/passes.cc b/elf/passes.cc
+index c6ee0f66b..8c7d5d0f5 100644
+--- a/elf/passes.cc
++++ b/elf/passes.cc
+@@ -1612,9 +1612,6 @@ template <typename E>
+ void apply_version_script(Context<E> &ctx) {
+ Timer t(ctx, "apply_version_script");
+
+- // If all patterns are simple (i.e. not containing any meta-
+- // characters and is not a C++ name), we can simply look up
+- // symbols.
+ auto is_simple = [&] {
+ for (VersionPattern &v : ctx.version_patterns)
+ if (v.is_cpp || v.pattern.find_first_of("*?[") != v.pattern.npos)
+@@ -1622,6 +1619,9 @@ void apply_version_script(Context<E> &ctx) {
+ return true;
+ };
+
++ // If all patterns are simple (i.e. not containing any meta-
++ // characters and is not a C++ name), we can simply look up
++ // symbols.
+ if (is_simple()) {
+ for (VersionPattern &v : ctx.version_patterns) {
+ Symbol<E> *sym = get_symbol(ctx, v.pattern);
+@@ -1747,44 +1747,124 @@ void compute_import_export(Context<E> &ctx) {
+ if (!ctx.arg.shared) {
+ tbb::parallel_for_each(ctx.dsos, [&](SharedFile<E> *file) {
+ for (Symbol<E> *sym : file->symbols) {
+- if (sym->file && !sym->file->is_dso && sym->visibility != STV_HIDDEN) {
+- if (sym->ver_idx != VER_NDX_LOCAL ||
+- !ctx.default_version_from_version_script) {
+- std::scoped_lock lock(sym->mu);
+- sym->is_exported = true;
+- }
++ if (sym->file && !sym->file->is_dso && sym->visibility != STV_HIDDEN &&
++ sym->ver_idx != VER_NDX_LOCAL) {
++ std::scoped_lock lock(sym->mu);
++ sym->is_exported = true;
+ }
+ }
+ });
+ }
+
++ auto should_export = [&](Symbol<E> &sym) {
++ if (sym.visibility == STV_HIDDEN)
++ return false;
++
++ switch (sym.ver_idx) {
++ case -1:
++ if (ctx.arg.shared)
++ return !((ObjectFile<E> *)sym.file)->exclude_libs;
++ return ctx.arg.export_dynamic;
++ case VER_NDX_LOCAL:
++ return false;
++ default:
++ return true;
++ }
++ };
++
+ // Export symbols that are not hidden or marked as local.
+ // We also want to mark imported symbols as such.
+ tbb::parallel_for_each(ctx.objs, [&](ObjectFile<E> *file) {
+ for (Symbol<E> *sym : file->get_global_syms()) {
+- if (!sym->file || sym->visibility == STV_HIDDEN ||
+- sym->ver_idx == VER_NDX_LOCAL)
+- continue;
+-
+- // If we are using a symbol in a DSO, we need to import it at runtime.
+- if (sym->file != file && sym->file->is_dso && !sym->is_absolute()) {
+- std::scoped_lock lock(sym->mu);
+- sym->is_imported = true;
++ // If we are using a symbol in a DSO, we need to import it.
++ if (sym->file && sym->file->is_dso) {
++ if (!sym->is_absolute()) {
++ std::scoped_lock lock(sym->mu);
++ sym->is_imported = true;
++ }
+ continue;
+ }
+
+- // If we are creating a DSO, all global symbols are exported by default.
+- if (sym->file == file) {
+- std::scoped_lock lock(sym->mu);
++ // If we have a definition of a symbol, we may want to export it.
++ if (sym->file == file && should_export(*sym)) {
+ sym->is_exported = true;
+
+- if (ctx.arg.shared && sym->visibility != STV_PROTECTED &&
++ // Exported symbols are marked as imported as well by default
++ // for DSOs.
++ if (ctx.arg.shared &&
++ sym->visibility != STV_PROTECTED &&
+ !ctx.arg.Bsymbolic &&
+ !(ctx.arg.Bsymbolic_functions && sym->get_type() == STT_FUNC))
+ sym->is_imported = true;
+ }
+ }
+ });
++
++
++ // Apply --dynamic-list, --export-dynamic-symbol and
++ // --export-dynamic-symbol-list options.
++ //
++ // The semantics of these options vary depending on whether we are
++ // creating an executalbe or a shared object.
++ //
++ // For executable, matched symbols are exported.
++ //
++ // For shared objects, matched symbols are imported if it is already
++ // exported so that they are interposable. In other words, symbols
++ // that did not match will be bound locally within the output file,
++ // effectively turning them into protected symbols.
++ MultiGlob matcher;
++ MultiGlob cpp_matcher;
++
++ auto handle_match = [&](Symbol<E> *sym) {
++ if (ctx.arg.shared) {
++ if (sym->is_exported)
++ sym->is_imported = true;
++ } else {
++ if (sym->file && !sym->file->is_dso && sym->visibility != STV_HIDDEN)
++ sym->is_exported = true;
++ }
++ };
++
++ for (DynamicPattern &p : ctx.dynamic_list_patterns) {
++ if (p.is_cpp) {
++ if (!cpp_matcher.add(p.pattern, 1))
++ Fatal(ctx) << p.source << ": invalid dynamic list entry: "
++ << p.pattern;
++ continue;
++ }
++
++ if (p.pattern.find_first_of("*?[") != p.pattern.npos) {
++ if (!matcher.add(p.pattern, 1))
++ Fatal(ctx) << p.source << ": invalid dynamic list entry: "
++ << p.pattern;
++ continue;
++ }
++
++ handle_match(get_symbol(ctx, p.pattern));
++ }
++
++ if (!matcher.empty() || !cpp_matcher.empty()) {
++ tbb::parallel_for_each(ctx.objs, [&](ObjectFile<E> *file) {
++ for (Symbol<E> *sym : file->get_global_syms()) {
++ if (sym->file != file)
++ continue;
++ if (ctx.arg.shared && !sym->is_exported)
++ continue;
++
++ std::string_view name = sym->name();
++
++ if (matcher.find(name)) {
++ handle_match(sym);
++ } else if (!cpp_matcher.empty()) {
++ if (std::optional<std::string_view> s = cpp_demangle(name))
++ name = *s;
++ if (cpp_matcher.find(name))
++ handle_match(sym);
++ }
++ }
++ });
++ }
+ }
+
+ // Compute the "address-taken" bit for each input section.
+diff --git a/test/elf/dynamic-list4.sh b/test/elf/dynamic-list4.sh
+new file mode 100755
+index 000000000..83d88887e
+--- /dev/null
++++ b/test/elf/dynamic-list4.sh
+@@ -0,0 +1,44 @@
++#!/bin/bash
++. $(dirname $0)/common.inc
++
++cat <<EOF | $CC -o $t/a.o -c -xc - -fPIC
++#include <stdio.h>
++
++void foo() { printf("foo1 "); }
++void bar() { printf("bar1 "); }
++void baz() { printf("baz1 "); }
++
++void print() {
++ foo();
++ bar();
++ baz();
++ printf("\n");
++}
++EOF
++
++cat <<EOF > $t/dyn
++{ foo; bar; };
++EOF
++
++$CC -B. -shared -o $t/b.so $t/a.o -Wl,--dynamic-list=$t/dyn
++
++cat <<EOF | $CC -o $t/c.o -c -xc - -fPIC
++#include <stdio.h>
++void foo() { printf("foo2 "); }
++void bar() { printf("bar2 "); }
++void baz() { printf("baz2 "); }
++EOF
++
++$CC -B. -shared -o $t/d.so $t/c.o
++
++cat <<EOF | $CC -o $t/e.o -c -xc -
++#include <stdio.h>
++void print();
++int main() { print(); }
++EOF
++
++$CC -B. -o $t/exe1 $t/e.o -Wl,-push-state,-no-as-needed $t/b.so -Wl,-pop-state
++$QEMU $t/exe1 | grep -q 'foo1 bar1 baz1'
++
++$CC -B. -o $t/exe2 $t/e.o -Wl,-push-state,-no-as-needed $t/d.so $t/b.so -Wl,-pop-state
++$QEMU $t/exe2 | grep -q 'foo2 bar2 baz1'
+diff --git a/test/elf/version-script6.sh b/test/elf/version-script6.sh
+index 74e2f9a89..44f809ef3 100755
+--- a/test/elf/version-script6.sh
++++ b/test/elf/version-script6.sh
+@@ -9,10 +9,10 @@ EOF
+ cat <<EOF | $CXX -fPIC -c -o $t/b.o -xc -
+ int foo = 5;
+ int bar = 6;
++int quux = 100;
+ EOF
+
+-$CC -B. -shared -Wl,--version-script=$t/a.ver \
+- -o $t/c.so $t/b.o
++$CC -B. -shared -Wl,--version-script=$t/a.ver -o $t/c.so $t/b.o
+
+ cat <<'EOF' > $t/d.ver
+ VER_Y1 { local; *; };
diff --git a/sys-devel/mold/mold-1.11.0.ebuild b/sys-devel/mold/mold-1.11.0.ebuild
deleted file mode 100644
index 4ce10d6ee43c..000000000000
--- a/sys-devel/mold/mold-1.11.0.ebuild
+++ /dev/null
@@ -1,89 +0,0 @@
-# Copyright 2021-2023 Gentoo Authors
-# Distributed under the terms of the GNU General Public License v2
-
-EAPI=8
-
-inherit cmake toolchain-funcs
-
-DESCRIPTION="A Modern Linker"
-HOMEPAGE="https://github.com/rui314/mold"
-if [[ ${PV} == 9999 ]] ; then
- EGIT_REPO_URI="https://github.com/rui314/mold.git"
- inherit git-r3
-else
- SRC_URI="https://github.com/rui314/mold/archive/refs/tags/v${PV}.tar.gz -> ${P}.tar.gz"
- KEYWORDS="amd64 ~arm64 ~ppc64 ~riscv ~x86"
-fi
-
-# mold (AGPL-3)
-# - xxhash (BSD-2)
-LICENSE="AGPL-3 BSD-2"
-SLOT="0"
-
-RDEPEND="
- app-arch/zstd:=
- >=dev-cpp/tbb-2021.7.0-r1:=
- sys-libs/zlib
- !kernel_Darwin? (
- >=dev-libs/mimalloc-2:=
- dev-libs/openssl:=
- )
-"
-DEPEND="${RDEPEND}"
-
-pkg_pretend() {
- # Requires a c++20 compiler, see #831473
- if [[ ${MERGE_TYPE} != binary ]]; then
- if tc-is-gcc && [[ $(gcc-major-version) -lt 10 ]]; then
- die "${PN} needs at least gcc 10"
- elif tc-is-clang && [[ $(clang-major-version) -lt 12 ]]; then
- die "${PN} needs at least clang 12"
- fi
- fi
-}
-
-src_prepare() {
- cmake_src_prepare
-
- # Needs unpackaged dwarfdump
- rm test/elf/{{dead,compress}-debug-sections,compressed-debug-info}.sh || die
-
- # Heavy tests, need qemu
- rm test/elf/gdb-index-{compress-output,dwarf{2,3,4,5}}.sh || die
- rm test/elf/lto-{archive,dso,gcc,llvm,version-script}.sh || die
-
- # Sandbox sadness
- rm test/elf/run.sh || die
- sed -i 's|`pwd`/mold-wrapper.so|"& ${LD_PRELOAD}"|' \
- test/elf/mold-wrapper{,2}.sh || die
-
- # static-pie tests require glibc built with static-pie support
- if ! has_version -d 'sys-libs/glibc[static-pie(+)]'; then
- rm test/elf/{,ifunc-}static-pie.sh || die
- fi
-}
-
-src_configure() {
- local mycmakeargs=(
- -DMOLD_ENABLE_QEMU_TESTS=OFF
- -DMOLD_LTO=OFF # Should be up to the user to decide this with CXXFLAGS.
- -DMOLD_USE_SYSTEM_MIMALLOC=ON
- -DMOLD_USE_SYSTEM_TBB=ON
- )
- cmake_src_configure
-}
-
-src_install() {
- dobin "${BUILD_DIR}"/${PN}
-
- # https://bugs.gentoo.org/872773
- insinto /usr/$(get_libdir)/mold
- doins "${BUILD_DIR}"/${PN}-wrapper.so
-
- dodoc docs/{design,execstack}.md
- doman docs/${PN}.1
-
- dosym ${PN} /usr/bin/ld.${PN}
- dosym ${PN} /usr/bin/ld64.${PN}
- dosym ../../../usr/bin/${PN} /usr/libexec/${PN}/ld
-}
diff --git a/sys-devel/mold/mold-2.0.0-r1.ebuild b/sys-devel/mold/mold-2.0.0-r1.ebuild
deleted file mode 100644
index 74b7d3ab089c..000000000000
--- a/sys-devel/mold/mold-2.0.0-r1.ebuild
+++ /dev/null
@@ -1,93 +0,0 @@
-# Copyright 2021-2023 Gentoo Authors
-# Distributed under the terms of the GNU General Public License v2
-
-EAPI=8
-
-inherit cmake toolchain-funcs
-
-DESCRIPTION="A Modern Linker"
-HOMEPAGE="https://github.com/rui314/mold"
-if [[ ${PV} == 9999 ]] ; then
- EGIT_REPO_URI="https://github.com/rui314/mold.git"
- inherit git-r3
-else
- SRC_URI="https://github.com/rui314/mold/archive/refs/tags/v${PV}.tar.gz -> ${P}.tar.gz"
- KEYWORDS="amd64 ~arm64 ~ppc64 ~riscv ~x86"
-fi
-
-# mold (MIT)
-# - xxhash (BSD-2)
-LICENSE="MIT BSD-2"
-SLOT="0"
-
-RDEPEND="
- app-arch/zstd:=
- >=dev-cpp/tbb-2021.7.0-r1:=
- sys-libs/zlib
- !kernel_Darwin? (
- >=dev-libs/mimalloc-2:=
- dev-libs/openssl:=
- )
-"
-DEPEND="${RDEPEND}"
-
-PATCHES=(
- "${FILESDIR}"/${P}-reloc-test-fix.patch
-)
-
-pkg_pretend() {
- # Requires a c++20 compiler, see #831473
- if [[ ${MERGE_TYPE} != binary ]]; then
- if tc-is-gcc && [[ $(gcc-major-version) -lt 10 ]]; then
- die "${PN} needs at least gcc 10"
- elif tc-is-clang && [[ $(clang-major-version) -lt 12 ]]; then
- die "${PN} needs at least clang 12"
- fi
- fi
-}
-
-src_prepare() {
- cmake_src_prepare
-
- # Needs unpackaged dwarfdump
- rm test/elf/{{dead,compress}-debug-sections,compressed-debug-info}.sh || die
-
- # Heavy tests, need qemu
- rm test/elf/gdb-index-{compress-output,dwarf{2,3,4,5}}.sh || die
- rm test/elf/lto-{archive,dso,gcc,llvm,version-script}.sh || die
-
- # Sandbox sadness
- rm test/elf/run.sh || die
- sed -i 's|`pwd`/mold-wrapper.so|"& ${LD_PRELOAD}"|' \
- test/elf/mold-wrapper{,2}.sh || die
-
- # static-pie tests require glibc built with static-pie support
- if ! has_version -d 'sys-libs/glibc[static-pie(+)]'; then
- rm test/elf/{,ifunc-}static-pie.sh || die
- fi
-}
-
-src_configure() {
- local mycmakeargs=(
- -DMOLD_ENABLE_QEMU_TESTS=OFF
- -DMOLD_LTO=OFF # Should be up to the user to decide this with CXXFLAGS.
- -DMOLD_USE_SYSTEM_MIMALLOC=ON
- -DMOLD_USE_SYSTEM_TBB=ON
- )
- cmake_src_configure
-}
-
-src_install() {
- dobin "${BUILD_DIR}"/${PN}
-
- # https://bugs.gentoo.org/872773
- insinto /usr/$(get_libdir)/mold
- doins "${BUILD_DIR}"/${PN}-wrapper.so
-
- dodoc docs/{design,execstack}.md
- doman docs/${PN}.1
-
- dosym ${PN} /usr/bin/ld.${PN}
- dosym ${PN} /usr/bin/ld64.${PN}
- dosym ../../../usr/bin/${PN} /usr/libexec/${PN}/ld
-}
diff --git a/sys-devel/mold/mold-2.0.0-r2.ebuild b/sys-devel/mold/mold-2.0.0-r2.ebuild
deleted file mode 100644
index 72bb46594d66..000000000000
--- a/sys-devel/mold/mold-2.0.0-r2.ebuild
+++ /dev/null
@@ -1,94 +0,0 @@
-# Copyright 2021-2023 Gentoo Authors
-# Distributed under the terms of the GNU General Public License v2
-
-EAPI=8
-
-inherit cmake toolchain-funcs
-
-DESCRIPTION="A Modern Linker"
-HOMEPAGE="https://github.com/rui314/mold"
-if [[ ${PV} == 9999 ]] ; then
- EGIT_REPO_URI="https://github.com/rui314/mold.git"
- inherit git-r3
-else
- SRC_URI="https://github.com/rui314/mold/archive/refs/tags/v${PV}.tar.gz -> ${P}.tar.gz"
- KEYWORDS="~amd64 ~arm64 ~ppc64 ~riscv ~x86"
-fi
-
-# mold (MIT)
-# - xxhash (BSD-2)
-LICENSE="MIT BSD-2"
-SLOT="0"
-
-RDEPEND="
- app-arch/zstd:=
- >=dev-cpp/tbb-2021.7.0-r1:=
- sys-libs/zlib
- !kernel_Darwin? (
- >=dev-libs/mimalloc-2:=
- dev-libs/openssl:=
- )
-"
-DEPEND="${RDEPEND}"
-
-PATCHES=(
- "${FILESDIR}"/${P}-reloc-test-fix.patch
- "${FILESDIR}"/${P}-DT_RELR-dependency.patch
-)
-
-pkg_pretend() {
- # Requires a c++20 compiler, see #831473
- if [[ ${MERGE_TYPE} != binary ]]; then
- if tc-is-gcc && [[ $(gcc-major-version) -lt 10 ]]; then
- die "${PN} needs at least gcc 10"
- elif tc-is-clang && [[ $(clang-major-version) -lt 12 ]]; then
- die "${PN} needs at least clang 12"
- fi
- fi
-}
-
-src_prepare() {
- cmake_src_prepare
-
- # Needs unpackaged dwarfdump
- rm test/elf/{{dead,compress}-debug-sections,compressed-debug-info}.sh || die
-
- # Heavy tests, need qemu
- rm test/elf/gdb-index-{compress-output,dwarf{2,3,4,5}}.sh || die
- rm test/elf/lto-{archive,dso,gcc,llvm,version-script}.sh || die
-
- # Sandbox sadness
- rm test/elf/run.sh || die
- sed -i 's|`pwd`/mold-wrapper.so|"& ${LD_PRELOAD}"|' \
- test/elf/mold-wrapper{,2}.sh || die
-
- # static-pie tests require glibc built with static-pie support
- if ! has_version -d 'sys-libs/glibc[static-pie(+)]'; then
- rm test/elf/{,ifunc-}static-pie.sh || die
- fi
-}
-
-src_configure() {
- local mycmakeargs=(
- -DMOLD_ENABLE_QEMU_TESTS=OFF
- -DMOLD_LTO=OFF # Should be up to the user to decide this with CXXFLAGS.
- -DMOLD_USE_SYSTEM_MIMALLOC=ON
- -DMOLD_USE_SYSTEM_TBB=ON
- )
- cmake_src_configure
-}
-
-src_install() {
- dobin "${BUILD_DIR}"/${PN}
-
- # https://bugs.gentoo.org/872773
- insinto /usr/$(get_libdir)/mold
- doins "${BUILD_DIR}"/${PN}-wrapper.so
-
- dodoc docs/{design,execstack}.md
- doman docs/${PN}.1
-
- dosym ${PN} /usr/bin/ld.${PN}
- dosym ${PN} /usr/bin/ld64.${PN}
- dosym ../../../usr/bin/${PN} /usr/libexec/${PN}/ld
-}
diff --git a/sys-devel/mold/mold-2.3.1.ebuild b/sys-devel/mold/mold-2.3.2-r1.ebuild
index f16aabe0758e..1ff59907edb2 100644
--- a/sys-devel/mold/mold-2.3.1.ebuild
+++ b/sys-devel/mold/mold-2.3.2-r1.ebuild
@@ -33,6 +33,7 @@ DEPEND="${RDEPEND}"
PATCHES=(
"${FILESDIR}"/${PN}-2.3.0-no-pch.patch
+ "${FILESDIR}"/${P}-mimalloc-visibility-interposition.patch
)
pkg_pretend() {
@@ -72,6 +73,7 @@ src_configure() {
-DCMAKE_DISABLE_PRECOMPILE_HEADERS=ON
-DMOLD_ENABLE_QEMU_TESTS=OFF
-DMOLD_LTO=OFF # Should be up to the user to decide this with CXXFLAGS.
+ -DMOLD_USE_MIMALLOC=$(usex !kernel_Darwin)
-DMOLD_USE_SYSTEM_MIMALLOC=ON
-DMOLD_USE_SYSTEM_TBB=ON
)
@@ -90,5 +92,5 @@ src_install() {
dosym ${PN} /usr/bin/ld.${PN}
dosym ${PN} /usr/bin/ld64.${PN}
- dosym ../../../usr/bin/${PN} /usr/libexec/${PN}/ld
+ dosym -r /usr/bin/${PN} /usr/libexec/${PN}/ld
}
diff --git a/sys-devel/mold/mold-9999.ebuild b/sys-devel/mold/mold-9999.ebuild
index f16aabe0758e..f602c3b96e96 100644
--- a/sys-devel/mold/mold-9999.ebuild
+++ b/sys-devel/mold/mold-9999.ebuild
@@ -72,6 +72,7 @@ src_configure() {
-DCMAKE_DISABLE_PRECOMPILE_HEADERS=ON
-DMOLD_ENABLE_QEMU_TESTS=OFF
-DMOLD_LTO=OFF # Should be up to the user to decide this with CXXFLAGS.
+ -DMOLD_USE_MIMALLOC=$(usex !kernel_Darwin)
-DMOLD_USE_SYSTEM_MIMALLOC=ON
-DMOLD_USE_SYSTEM_TBB=ON
)
@@ -90,5 +91,5 @@ src_install() {
dosym ${PN} /usr/bin/ld.${PN}
dosym ${PN} /usr/bin/ld64.${PN}
- dosym ../../../usr/bin/${PN} /usr/libexec/${PN}/ld
+ dosym -r /usr/bin/${PN} /usr/libexec/${PN}/ld
}