Skip to content
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

need help with SAMModelLoader failure on Apple Silicon due to CUDA Deserialization Error? #3222

Open
icebergov opened this issue Apr 7, 2024 · 5 comments

Comments

@icebergov
Copy link

Issue #60 in comfyui_segment_anything

SAMModelLoader Failure on Apple Silicon due to CUDA Deserialization Error

Has anyone else encountered this issue when trying to run SAMModelLoader for the segment anything functionality on an Apple Silicon Mac? I'm getting an error related to CUDA deserialization, despite the fact that torch.cuda.is_available() returns False. It seems like the model loading process is mistakenly assuming the availability of CUDA on a platform that clearly does not support it, leading to a failure in executing the desired functionality.

Issue Description

When attempting to run SAMModelLoader for the segment anything functionality on an Apple Silicon Mac, an error is encountered indicating a problem with attempting to deserialize an object on a CUDA device, even though torch.cuda.is_available() returns False.

Environment

  • Operating System: macOS Sonoma 14.4.1 (M1 Max, Apple Silicon)
  • Python Version: 3.11
  • PyTorch Version: torch==2.1.2 ; torchvision==0.16.2

Error Message

Error occurred when executing SAMModelLoader (segment anything):

Attempting to deserialize object on a CUDA device but torch.cuda.is_available() is False. If you are running on a CPU-only machine, please use torch.load with map_location=torch.device('cpu') to map your storages to the CPU.

Expected Behavior

The model loader should detect the absence of CUDA and automatically adjust to use CPU for model deserialization and execution, allowing the functionality to proceed without error, or ideally switch to the GPU Apple Silicon provides.

Actual Behaviour

The process fails with an error message indicating an attempt to deserialize a CUDA object on a system where CUDA is not available, due to torch.cuda.is_available() returning False.

Screenshot

320283574-c9b53012-d557-415c-9979-31955607671a

@NeedsMoar
Copy link

NeedsMoar commented Apr 7, 2024

Edit: Nevermind, I see you linked to a bug you filed over there.

Comfy probably can't do much about this.

Just FYI I'm running a CUDA card and that extension is linked against such an old version of CUDA that it just errors multiple times trying to import DLLs during startup and most parts won't work, so if it's not up to date for that there's not much chance of getting them to update it to work on mac.

@icebergov
Copy link
Author

Thanks for the quick reply!

Yeah, I suspect Comfy can't really solve this, but I wonder what's the current workaround for the issue I'm facing and if others are also facing it.

@sagebru5h
Copy link

I'm curious if a workaround was ever discovered for this issue...?

@icebergov
Copy link
Author

@sagebru5h

Try using this: MarkoCa1/ComfyUI_Segment_Mask#5

@ipaaad4evr
Copy link

Any workarounds for this? Im on m1 max and and find any solution :(

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

No branches or pull requests

4 participants