mirror of
https://github.com/NVIDIA/nvidia-container-toolkit
synced 2024-11-25 21:39:10 +00:00
Merge branch 'CNT-4142/xorg-missing-not-fatal' into 'main'
Make discovery of Xorg libraries optional See merge request nvidia/container-toolkit/container-toolkit!368
This commit is contained in:
commit
f99e863649
@ -4,6 +4,7 @@
|
|||||||
|
|
||||||
* Update `update-ldcache` hook to only update ldcache if it exists.
|
* Update `update-ldcache` hook to only update ldcache if it exists.
|
||||||
* Update `update-ldcache` hook to create `/etc/ld.so.conf.d` folder if it doesn't exist.
|
* Update `update-ldcache` hook to create `/etc/ld.so.conf.d` folder if it doesn't exist.
|
||||||
|
* Fix failure when libcuda cannot be located during XOrg library discovery.
|
||||||
|
|
||||||
## v1.13.0
|
## v1.13.0
|
||||||
|
|
||||||
|
@ -46,10 +46,7 @@ func NewGraphicsDiscoverer(logger *logrus.Logger, devices image.VisibleDevices,
|
|||||||
|
|
||||||
drmByPathSymlinks := newCreateDRMByPathSymlinks(logger, drmDeviceNodes, cfg)
|
drmByPathSymlinks := newCreateDRMByPathSymlinks(logger, drmDeviceNodes, cfg)
|
||||||
|
|
||||||
xorg, err := newXorgDiscoverer(logger, driverRoot, cfg.NvidiaCTKPath)
|
xorg := optionalXorgDiscoverer(logger, driverRoot, cfg.NvidiaCTKPath)
|
||||||
if err != nil {
|
|
||||||
return nil, fmt.Errorf("failed to create Xorg discoverer: %v", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
discover := Merge(
|
discover := Merge(
|
||||||
Merge(drmDeviceNodes, drmByPathSymlinks),
|
Merge(drmDeviceNodes, drmByPathSymlinks),
|
||||||
@ -259,6 +256,17 @@ type xorgHooks struct {
|
|||||||
|
|
||||||
var _ Discover = (*xorgHooks)(nil)
|
var _ Discover = (*xorgHooks)(nil)
|
||||||
|
|
||||||
|
// optionalXorgDiscoverer creates a discoverer for Xorg libraries.
|
||||||
|
// If the creation of the discoverer fails, a None discoverer is returned.
|
||||||
|
func optionalXorgDiscoverer(logger *logrus.Logger, driverRoot string, nvidiaCTKPath string) Discover {
|
||||||
|
xorg, err := newXorgDiscoverer(logger, driverRoot, nvidiaCTKPath)
|
||||||
|
if err != nil {
|
||||||
|
logger.Warnf("Failed to create Xorg discoverer: %v; skipping xorg libraries", err)
|
||||||
|
return None{}
|
||||||
|
}
|
||||||
|
return xorg
|
||||||
|
}
|
||||||
|
|
||||||
func newXorgDiscoverer(logger *logrus.Logger, driverRoot string, nvidiaCTKPath string) (Discover, error) {
|
func newXorgDiscoverer(logger *logrus.Logger, driverRoot string, nvidiaCTKPath string) (Discover, error) {
|
||||||
libCudaPaths, err := cuda.New(
|
libCudaPaths, err := cuda.New(
|
||||||
cuda.WithLogger(logger),
|
cuda.WithLogger(logger),
|
||||||
|
Loading…
Reference in New Issue
Block a user