Skip to content
New issue

Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? # to your account

[MacOS:] Metal.functional() wrongly returns true despite no GPUs available #458

Closed
omlins opened this issue Oct 14, 2024 · 3 comments · Fixed by #459
Closed

[MacOS:] Metal.functional() wrongly returns true despite no GPUs available #458

omlins opened this issue Oct 14, 2024 · 3 comments · Fixed by #459

Comments

@omlins
Copy link

omlins commented Oct 14, 2024

The following tests were executed and failed because Metal.functional() returned true:
https://github.com/omlins/CellArrays.jl/actions/runs/11330323307/job/31507893740#step:6:564

@omlins
Copy link
Author

omlins commented Oct 14, 2024

@christiangnrd this is an issue somewhat similar to #453

@christiangnrd
Copy link
Contributor

Thank you for taking the time to report these!

I'm not exactly sure what the best way to resolve this is.

We could enforce MTLGPUFamilyApple7 and MTLGPUFamilyMetal3 support through functional(), or we could add a new function like fully_supported() or something that only returns true if the device's GPU has the above support.

@maleadt @tgymnich Any thoughts?

@maleadt
Copy link
Member

maleadt commented Oct 15, 2024

We could enforce MTLGPUFamilyApple7 and MTLGPUFamilyMetal3 support through functional(),

I think that would be the best option. Since we automatically select a device, without the user having to check if one is available and select it, it's fair to assume that code using said implicit device works after checking Metal.functional().

In CUDA.jl this is automatic, because the driver fails to initialize if no devices are available.

# for free to join this conversation on GitHub. Already have an account? # to comment
Labels
None yet
Projects
None yet
Development

Successfully merging a pull request may close this issue.

3 participants