KEMBAR78
fix scale_shift_factor being on cpu for wan and ltx by vladmandic · Pull Request #12347 · huggingface/diffusers · GitHub
Skip to content

Conversation

@vladmandic
Copy link
Contributor

@vladmandic vladmandic commented Sep 18, 2025

wan transformer block creates scale_shift_table on cpu and then adds it regardless of where temb tensor actually resides
and this causes typical cpu-vs-cuda device mismatch

│  473 │   │   │   shift_msa, scale_msa, gate_msa, c_shift_msa, c_scale_msa, c_gate_msa = (                                                                                                                                                                                                                                                                                                                                        │
│❱ 474 │   │   │   │   self.scale_shift_table + temb.float()                                                                                                                                                                                                                                                                                                                                                                       │
│  475 │   │   │   ).chunk(6, dim=1)                                                                                                                                                                                                                                                                                                                                                                                               │
╰──────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────╯
RuntimeError: Expected all tensors to be on the same device, but found at least two devices, cuda:0 and cpu!

cc @sayakpaul @yiyixuxu @a-r-r-o-w @DN6

@DN6
Copy link
Collaborator

DN6 commented Sep 24, 2025

@vladmandic Do you have a snippet to reproduce the error?

@vladmandic
Copy link
Contributor Author

@vladmandic Do you have a snippet to reproduce the error?

I dont have easy reproduction as it happens relatively randomly when offloading is enabled and on low-memory systems.
but if you look at other pipelines (e.g. sana, pixart, etc.) that implement similar methods, they all guard against this.
and i dont see any risk/side-effects of the device cast.

@vladmandic vladmandic changed the title wan fix scale_shift_factor being on cpu fix scale_shift_factor being on cpu for wan and ltx Sep 25, 2025
@vladmandic
Copy link
Contributor Author

update: same issue occurs for some of my users for ltxvideo so i've extended the pr with the same fix in that pipeline.
see vladmandic/sdnext#4223 for details

@HuggingFaceDocBuilderDev

The docs for this PR live here. All of your documentation changes will be reflected on that endpoint. The docs are available until 30 days after the last update.

@vladmandic
Copy link
Contributor Author

gentle nudge - any particular reason why this pr is not merged?
i understand lack of clear reproduction, but on the other hand, same guards exist in other pipelines plus its clear that scale_shift_factor tensor is created on cpu so even if it works, the operation is performed on cpu which is non-desirable.

@DN6
Copy link
Collaborator

DN6 commented Oct 2, 2025

Hi @vladmandic sorry for the delay. It's just that since the introduction of hooks for offloading and casting, we're trying to avoid direct assignment of device, dtype in the models in case of unexpected behaviour, which is why I asked for the repro to check if there's something else going on.

Could you just share the type of offloading you're using? Is it group offloading?

@vladmandic
Copy link
Contributor Author

vladmandic commented Oct 2, 2025

@DN6 i understand the general desire, however:

  • most pipelines already do this exact thing, this is not new. i'm just adding it to pipelines which dont have it!
  • scale_shift_factor is a manually created tensor on cpu and there is no mechanism anywhere that manages its placement. its not part of the model so it can be managed by hooks.
  • i'm not assigning to manually specified device, i'm assigning just to same as other part of the equation
  • this is not readily reproducible because it works on torch-cuda, but it fails on other flavors of torch (zluda, rocm) i don't know why, but imo correct behavior is to FAIL because like i said, right now there is NO mechanism in the codebase that would handle this
  • sdnext uses custom offloading, not model/sequential/group from diffusers. there are reasons why we felt we needed to develop our own - if you want, i can do a writeup, but thats besides the poinf for this pr. fyi, its onloading is also based on accelerate hooks, its just decision making when to offload are very different.

if you don't want to merge this pr, then please propose an alternative as right now my users are blocked.

@DN6
Copy link
Collaborator

DN6 commented Oct 4, 2025

@bot /style

@github-actions
Copy link
Contributor

github-actions bot commented Oct 4, 2025

Style bot fixed some files and pushed the changes.

@DN6
Copy link
Collaborator

DN6 commented Oct 5, 2025

@vladmandic Parameters in the module are subject to offloading hooks

parameters = _gather_parameters_with_no_group_offloading_parent(module, modules_with_group_offloading)
buffers = _gather_buffers_with_no_group_offloading_parent(module, modules_with_group_offloading)

The direct casts in Pixart and SANA were added before offloading hooks were introduced and no other instances use this type of casting (it shouldn't be necessary)

Based on your description it seems to be an issue with custom offloading logic applied in non-CUDA environments. This really feels like an edge case to me and the issue doesn't seem related to diffusers code.

However, I've run the offloading tests on the models and they're passing so I'm okay to merge this, but FYI, there is a chance we remove direct casts from models in the future if we see any issues. I'll will give you a heads up if that's the case to avoid breaking anything downstream.

@DN6 DN6 merged commit 2b7deff into huggingface:main Oct 5, 2025
9 of 10 checks passed
@vladmandic
Copy link
Contributor Author

vladmandic commented Oct 5, 2025

thanks @DN6

Based on your description it seems to be an issue with custom offloading logic applied in non-CUDA environments.

same custom offloading logic is applied everywhere in sdnext, not specific to rocm/zluda, its just that this problem occurs only for those torch versions.

sayakpaul pushed a commit that referenced this pull request Oct 15, 2025
* wan fix scale_shift_factor being on cpu

* apply device cast to ltx transformer

* Apply style fixes

---------

Co-authored-by: Dhruv Nair <dhruv.nair@gmail.com>
Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>
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

Successfully merging this pull request may close these issues.

3 participants