Skip to content

Conversation

@gn64
Copy link
Contributor

@gn64 gn64 commented Dec 16, 2024

Fix division by zero error in soft_max vulkan shader

This PR fixes #2596 by adding a check for p.KY being zero in the soft_max compute shader.

Changes:

  • Modified the calculation of rowy in soft_max.comp to handle the case where p.KY is 0
  • Changed const uint rowy = rowx % p.KY; to const uint rowy = (p.KY > 0) ? (rowx % p.KY) : 0;

The original code would cause a division by zero error when p.KY is 0. This fix ensures that rowy is set to 0 in such cases, preventing the crash while maintaining the expected behavior in normal scenarios.

Testing:

  • Confirmed the fix resolves the crash in my environment
  • Existing functionality remains unchanged when p.KY > 0

Note:
This PR is a focused version of #2604, containing only the Vulkan shader fix. The original PR has been closed in favor of this more targeted change to address the specific issue at hand.

This change prevents a division by zero error when p.KY is 0.
@ggerganov ggerganov merged commit c4aed68 into ggml-org:master Dec 16, 2024
43 of 44 checks passed
bygreencn added a commit to bygreencn/whisper.cpp that referenced this pull request Dec 18, 2024
# By Georgi Gerganov (4) and others
# Via GitHub
* ggerganov/master:
  stream : improve consistency in README (ggml-org#2642)
  whisper : support no_speech_thold (ggml-org#2625)
  whisper : add single-timestamp logic (ggml-org#2629)
  readme : fix typo (ggml-org#2637)
  cmake : fix "amd64" processor string (ggml-org#2638)
  vulkan : fix soft_max.comp division by zero (ggml-org#2633)
  common : add cstdio header
  stream : update build instructions
  android : fix build and ci (ggml-org#2624)
  models : fix typo in download-ggml-model.sh (ggml-org#2623)
  ruby : Sync whisper.cpp and model download feature (ggml-org#2617)
  scripts : update to new build system

# Conflicts:
#	src/whisper.cpp
lyapple2008 pushed a commit to lyapple2008/whisper.cpp.mars that referenced this pull request Feb 4, 2025
This change prevents a division by zero error when p.KY is 0.
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.

Invalid probability vector error with AMD iGPU on Vulkan backend Environment

3 participants