-
Notifications
You must be signed in to change notification settings - Fork 314
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Changes required for WSL2 #1180
base: main
Are you sure you want to change the base?
Conversation
Signed-off-by: Christopher Desiniotis <[email protected]>
This change is motivated by WSL2 where the /sys/class/dmi directory does not exist. Mount all of /sys as read-only is a safe approach to account for systems where this directory does not exist. Signed-off-by: Christopher Desiniotis <[email protected]>
@@ -693,6 +693,11 @@ func isDriverManagedByOperator(ctx context.Context) (bool, error) { | |||
|
|||
func validateHostDriver(silent bool) error { | |||
log.Info("Attempting to validate a pre-installed driver on the host") | |||
if fileInfo, err := os.Lstat("/host/usr/lib/wsl/lib/nvidia-smi"); err == nil && fileInfo.Size() != 0 { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Does it make sense to use the info
package from go-nvlib
here instead (for example https://github.com/NVIDIA/k8s-device-plugin/blob/44b263c37e13370f857ef0691b8ab8ff02135c0d/internal/plugin/factory.go#L129).
This will allow for consistent detection across components.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I agree with the overall notion of aligning the detection across components, so I have added a commit to use the info
package as you have suggested.
However, the usage of the platform resolver in the driver-validator
does not work as expected and returns unknown
as the platform. This is because the libdxcore.so
library is not in the ldcache, and likewise, neither is libnvidia-ml.so
. The platform resolver works in the device-plugin because the NVIDIA Container Toolkit takes care of injecting the libdxcore.so
library into the container and updating the ldcache.
Let me know if you have any suggestions to get the platform detection working in the driver-validator
, otherwise I will revert the latest commit I added in favor of the original logic.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looking at the implementiong in the info package, I don't think there's a way to get this working with the current implementation. I think for the time being, let's revert the proposed change and stick with the existing implementation.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I have reverted the commit.
No description provided.