Fix for Nvidia Passthrough (#166)

* Fix Nvidia Passthrough closing #127
* Mount libraries parent directory
* Use the dynamic library path from the existing code
This commit is contained in:
Darren Gibbard 2024-05-11 09:29:16 +01:00 committed by GitHub
parent bc8284edb8
commit 525992727a
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
1 changed files with 18 additions and 12 deletions

View File

@ -4,7 +4,7 @@
with full access to all files via bind mounts, \ with full access to all files via bind mounts, \
thanks to systemd-nspawn!""" thanks to systemd-nspawn!"""
__version__ = "1.4.0" __version__ = "1.4.1"
__disclaimer__ = """USE THIS SCRIPT AT YOUR OWN RISK! __disclaimer__ = """USE THIS SCRIPT AT YOUR OWN RISK!
IT COMES WITHOUT WARRANTY AND IS NOT SUPPORTED BY IXSYSTEMS.""" IT COMES WITHOUT WARRANTY AND IS NOT SUPPORTED BY IXSYSTEMS."""
@ -353,6 +353,17 @@ def passthrough_nvidia(
return return
try: try:
# Get list of libraries
nvidia_libraries = set(
[
x
for x in subprocess.check_output(["nvidia-container-cli", "list", "--libraries"])
.decode()
.split("\n")
if x
]
)
# Get full list of files, but excluding library ones from above
nvidia_files = set( nvidia_files = set(
( (
[ [
@ -361,6 +372,7 @@ def passthrough_nvidia(
.decode() .decode()
.split("\n") .split("\n")
if x if x
and x not in nvidia_libraries
] ]
) )
) )
@ -393,16 +405,10 @@ def passthrough_nvidia(
# Check if the parent dir exists where we want to write our conf file # Check if the parent dir exists where we want to write our conf file
if ld_so_conf_path.parent.exists(): if ld_so_conf_path.parent.exists():
nvidia_libraries = set( library_folders = set(str(Path(x).parent) for x in nvidia_libraries)
Path(x) # Add the library folders as mounts
for x in subprocess.check_output( for lf in library_folders:
["nvidia-container-cli", "list", "--libraries"] nvidia_mounts.append(f"--bind-ro={lf}")
)
.decode()
.split("\n")
if x
)
library_folders = set(str(x.parent) for x in nvidia_libraries)
# Only write if the conf file doesn't yet exist or has different contents # Only write if the conf file doesn't yet exist or has different contents
existing_conf_libraries = set() existing_conf_libraries = set()