diff --git a/docs/markdown/snippets/crosslib.md b/docs/markdown/snippets/crosslib.md new file mode 100644 index 000000000000..14fcc81cf1e8 --- /dev/null +++ b/docs/markdown/snippets/crosslib.md @@ -0,0 +1,7 @@ +## Libdir defaults to `lib` when cross compiling + +Previously `libdir` defaulted to the value of the build machine such +as `lib/x86_64-linux-gnu`, which is almost always incorrect when cross +compiling. It now defaults to plain `lib` when cross compiling. Native +builds remain unchanged and will point to the current system's library +dir. diff --git a/mesonbuild/coredata.py b/mesonbuild/coredata.py index d70c23038c30..4e2f3e008c05 100644 --- a/mesonbuild/coredata.py +++ b/mesonbuild/coredata.py @@ -299,6 +299,7 @@ def __init__(self, options): # Only to print a warning if it changes between Meson invocations. self.pkgconf_envvar = os.environ.get('PKG_CONFIG_PATH', '') self.config_files = self.__load_config_files(options.native_file) + self.libdir_cross_fixup() @staticmethod def __load_config_files(filenames): @@ -348,6 +349,13 @@ def __load_cross_file(filename): raise MesonException('Cannot find specified cross file: ' + filename) + def libdir_cross_fixup(self): + # By default set libdir to "lib" when cross compiling since + # getting the "system default" is always wrong on multiarch + # platforms as it gets a value like lib/x86_64-linux-gnu. + if self.cross_file is not None: + self.builtins['libdir'].value = 'lib' + def sanitize_prefix(self, prefix): if not os.path.isabs(prefix): raise MesonException('prefix value {!r} must be an absolute path' diff --git a/run_unittests.py b/run_unittests.py index 91daa1b2f318..d721646503db 100755 --- a/run_unittests.py +++ b/run_unittests.py @@ -4493,6 +4493,7 @@ def test_ldflag_dedup(self): max_count = max(max_count, line.count(search_term)) self.assertEqual(max_count, 1, 'Export dynamic incorrectly deduplicated.') + class LinuxCrossArmTests(BasePlatformTests): ''' Tests that cross-compilation to Linux/ARM works @@ -4529,6 +4530,18 @@ def test_cross_file_overrides_always_args(self): self.assertRegex(compdb[0]['command'], '-D_FILE_OFFSET_BITS=64.*-U_FILE_OFFSET_BITS') self.build() + def test_cross_libdir(self): + # When cross compiling "libdir" should default to "lib" + # rather than "lib/x86_64-linux-gnu" or something like that. + testdir = os.path.join(self.common_test_dir, '1 trivial') + self.init(testdir) + for i in self.introspect('--buildoptions'): + if i['name'] == 'libdir': + self.assertEqual(i['value'],'lib') + return + self.assertTrue(False, 'Option libdir not in introspect data.') + + class LinuxCrossMingwTests(BasePlatformTests): ''' Tests that cross-compilation to Windows/MinGW works