diff options
author | Alexander Kanavin <alex.kanavin@gmail.com> | 2023-03-16 10:40:57 +0100 |
---|---|---|
committer | Steve Sakoman <steve@sakoman.com> | 2024-02-28 03:32:09 -1000 |
commit | 6cb27ba5379e0132d7ec46f1633c24855a3fa298 (patch) | |
tree | 6a7ce8f63895a6406c94d595be9a25dd6ba2cace /scripts | |
parent | 45ae93668c052c335b0b5329bbaf4b173dde0447 (diff) | |
download | poky-6cb27ba5379e0132d7ec46f1633c24855a3fa298.tar.gz |
runqemu: direct mesa to use its own drivers, rather than ones provided by host distro
With mesa 23.0, it is not longer possible to use the host drivers, as
mesa upstream has added strict checks for matching builds between
drivers and libraries that load them.
Add a check and a hint to runqemu so that there is a helpful error when
there is no native/nativesdk opengl/virgl support.
(From OE-Core rev: 5103ce67741782e43612f495bcc851c6509b734b)
Signed-off-by: Alexander Kanavin <alex@linutronix.de>
Signed-off-by: Alexandre Belloni <alexandre.belloni@bootlin.com>
(cherry picked from commit f0946844df7270fe368858d8929e6b380675b78b)
Signed-off-by: Steve Sakoman <steve@sakoman.com>
Diffstat (limited to 'scripts')
-rwxr-xr-x | scripts/runqemu | 34 |
1 files changed, 10 insertions, 24 deletions
diff --git a/scripts/runqemu b/scripts/runqemu index 729b067a9f..8e5d22888d 100755 --- a/scripts/runqemu +++ b/scripts/runqemu | |||
@@ -447,30 +447,16 @@ class BaseConfig(object): | |||
447 | self.set("MACHINE", arg) | 447 | self.set("MACHINE", arg) |
448 | 448 | ||
449 | def set_dri_path(self): | 449 | def set_dri_path(self): |
450 | # As runqemu can be run within bitbake (when using testimage, for example), | 450 | drivers_path = os.path.join(self.bindir_native, '../lib/dri') |
451 | # we need to ensure that we run host pkg-config, and that it does not | 451 | if not os.path.exists(drivers_path) or not os.listdir(drivers_path): |
452 | # get mis-directed to native build paths set by bitbake. | 452 | raise RunQemuError(""" |
453 | env = os.environ.copy() | 453 | qemu has been built without opengl support and accelerated graphics support is not available. |
454 | try: | 454 | To enable it, add: |
455 | del env['PKG_CONFIG_PATH'] | 455 | DISTRO_FEATURES_NATIVE:append = " opengl" |
456 | del env['PKG_CONFIG_DIR'] | 456 | DISTRO_FEATURES_NATIVESDK:append = " opengl" |
457 | del env['PKG_CONFIG_LIBDIR'] | 457 | to your build configuration. |
458 | del env['PKG_CONFIG_SYSROOT_DIR'] | 458 | """) |
459 | except KeyError: | 459 | self.qemu_environ['LIBGL_DRIVERS_PATH'] = drivers_path |
460 | pass | ||
461 | try: | ||
462 | dripath = subprocess.check_output("PATH=/bin:/usr/bin:$PATH pkg-config --variable=dridriverdir dri", shell=True, env=env) | ||
463 | except subprocess.CalledProcessError as e: | ||
464 | raise RunQemuError("Could not determine the path to dri drivers on the host via pkg-config.\nPlease install Mesa development files (particularly, dri.pc) on the host machine.") | ||
465 | self.qemu_environ['LIBGL_DRIVERS_PATH'] = dripath.decode('utf-8').strip() | ||
466 | |||
467 | # This preloads uninative libc pieces and therefore ensures that RPATH/RUNPATH | ||
468 | # in host mesa drivers doesn't trick uninative into loading host libc. | ||
469 | preload_items = ['libdl.so.2', 'librt.so.1', 'libpthread.so.0'] | ||
470 | uninative_path = os.path.dirname(self.get("UNINATIVE_LOADER")) | ||
471 | if os.path.exists(uninative_path): | ||
472 | preload_paths = [os.path.join(uninative_path, i) for i in preload_items] | ||
473 | self.qemu_environ['LD_PRELOAD'] = " ".join(preload_paths) | ||
474 | 460 | ||
475 | def check_args(self): | 461 | def check_args(self): |
476 | for debug in ("-d", "--debug"): | 462 | for debug in ("-d", "--debug"): |