-
Notifications
You must be signed in to change notification settings - Fork 4
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
fix: better CUDA detection #61
Conversation
3ffdcf3
to
3c409f7
Compare
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.
AFAIK unfortunately there is no canonical way to determine where CUDA toolkit is installed and what the version of that installation is.
Parts of https://cmake.org/cmake/help/latest/module/FindCUDAToolkit.html can be taken as inspiration.
Every somewhat recent CUDA toolkit installation now includes the version.json file and all the versions that we care about (11.x and up) included it for sure. We do not support older CUDA versions anyway.
Did you encounter a scenario where using version.json did not work for you?
That's true, and that's most unfortunate :/
AFAICT, the |
Hmm, my experience it that installing CUDA manually on Ubuntu following the official CUDA installation procedure (that uses apt with nvidia's package repository) results in version.json being placed in the root of the CUDA installation. |
Absolutely, but only for the manually installed version. If ones uses Thank you for the feedback, I addressed your comments. |
The PR branch seems to be out of date with the base branch. Can you please rebase? |
ed6c806
to
aa59fa9
Compare
Done |
🤖 I have created a release *beep* *boop* --- ## [0.152.11](v0.152.10...v0.152.11) (2025-01-17) ### Features * **proof-compression:** better proof compression ([#67](#67)) ([f4eac96](f4eac96)) ### Bug Fixes * better CUDA detection ([#61](#61)) ([e902ca4](e902ca4)) --- This PR was generated with [Release Please](https://github.com/googleapis/release-please). See [documentation](https://github.com/googleapis/release-please#release-please). --------- Co-authored-by: zksync-era-bot <zksync-era-bot@users.noreply.github.com>
What ❔
This PR improves the detection of the CUDA toolkit under Linux, and the detection of its version under all OSes.
Why ❔
Under Linux, the CUDA detection is hardcoded to look into
/usr/local/cuda
, which is not guaranteed to be the default installation folder. The new method first looks for theCUDA_PATH
env. var., then default to/usr/local/cuda
if it is empty.The current way of finding out the installed CUDA version is to look for a
version.json
file in the CUDA installation path. This file is not guaranteed to exist. However,nvcc
is guaranteed to be installed with the toolkit; so the new method is to parse its output to find the exact version there.Checklist
zk fmt
andzk lint
.