nvidia-container-toolkit/cmd/nvidia-cdi-hook
Evan Lezar bdfaea4e9e
Some checks failed
CI Pipeline / code-scanning (push) Has been cancelled
CI Pipeline / variables (push) Has been cancelled
CI Pipeline / golang (push) Has been cancelled
CI Pipeline / image (push) Has been cancelled
CI Pipeline / e2e-test (push) Has been cancelled
Add create-soname-symlinks hook
This change adds a create-soname-symlinks hook that can be used to ensure
that the soname symlinks for injected libraries exist in a container.

This is done by calling ldconfig -n -N for the folders containing the injected
libraries.

This also ensures that libcuda.so is present in the ldcache when the update-ldcache
hook is run.

Signed-off-by: Evan Lezar <elezar@nvidia.com>
2025-03-20 14:54:20 +02:00
..
chmod Move ContainerRoot type to oci package 2025-03-20 13:21:51 +02:00
commands Add create-soname-symlinks hook 2025-03-20 14:54:20 +02:00
create-soname-symlinks Add create-soname-symlinks hook 2025-03-20 14:54:20 +02:00
create-symlinks Move ContainerRoot type to oci package 2025-03-20 13:21:51 +02:00
cudacompat Move CreateLdsoconfdFile to ContainerRoot 2025-03-20 13:21:52 +02:00
update-ldcache Move resolution of host LDConfig to config package 2025-03-20 13:23:59 +02:00
main.go Move nvidia-ctk hook command into own binary 2024-05-21 12:19:44 +02:00
README.md Move nvidia-ctk hook command into own binary 2024-05-21 12:19:44 +02:00

NVIDIA CDI Hook

The CLI nvidia-cdi-hook provides container device runtime hook capabilities when called by a container runtime, as specific in a Container Device Interface file.

Generating a CDI

The CDI itself is created for an NVIDIA-capable device using the nvidia-ctk cdi generate command.

When nvidia-ctk cdi generate is run, the CDI specification is generated as a yaml file. The CDI specification provides instructions for a container runtime to set up devices, files and other resources for the container prior to starting it. Those instructions may include executing command-line tools to prepare the filesystem. The execution of such command-line tools is called a hook.

nvidia-cdi-hook is the CLI tool that is expected to be called by the container runtime, when specified by the CDI file.

See the nvidia-ctk documentation for more information on generating a CDI file.

Functionality

The nvidia-cdi-hook CLI provides the following functionality:

  • chmod - Change the permissions of a file or directory inside the directory path to be mounted into a container.
  • create-symlinks - Create symlinks inside the directory path to be mounted into a container.
  • update-ldcache - Update the dynamic linker cache inside the directory path to be mounted into a container.