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

fix: ggml: fix vulkan-shaders-gen build #10448

Open
wants to merge 3 commits into
base: master
Choose a base branch
from

Conversation

sparkleholic
Copy link
Contributor

The vulkan-shaders-gen target was not being built correctly in case of cross-compilation.
Other outputs need to be built for the cross compile target, but vulkan-shaders-gen needs to be built for the host.

@sparkleholic
Copy link
Contributor Author

sparkleholic commented Nov 25, 2024

@jeffbolznv , @0cc4m
This fix is ​​needed for cross-compilation.
vulkan-shaders-gen is needed at build time, so arch should be the same as host pc, but other binaries (libggml, libllama, etc.) are needed at runtime.
Therefore, CMAKE compilation variables that apply when building the llama.cpp project should not apply when building vulkan-shaders-gen in case of cross-compilation.

@0cc4m
Copy link
Collaborator

0cc4m commented Nov 25, 2024

@sparkleholic @jeffbolznv I understand, I'm sorry that a few PRs are getting delayed because of me. I'm currently ill, but getting better and I should be able to catch up with all of them later this week.

Maybe you can resolve the merge conflict already?

@jeffbolznv
Copy link
Collaborator

No rush, get well!

I'm not an expert at cmake or cross compilation, so I don't think I should review the change.

@sparkleholic
Copy link
Contributor Author

@0cc4m
master rebased to resolve conflicts.
I didn't mean to rush you. I sincerely hope you feel better soon. :)

@0cc4m
Copy link
Collaborator

0cc4m commented Nov 27, 2024

I can confirm this still works as usual on my system, but I'm also not a CMake expert. Maybe @bandoti can take a look?

@bandoti
Copy link
Contributor

bandoti commented Nov 27, 2024

I am happy to take a look. The one thing that comes to mind here after initial look through is being able to customize the compiler in this case. In particular, gcc and g++ are hardcoded.

It would be worthwhile to add a default toolchain file for the build and allow one to customize by passing -DGGML_SHADERS_GEN_CROSS_TOOLCHAIN=... (or similar)

This would allow one to use a desire toolchain—maybe clang, etc.

And a lot of those switches passed to ExternalProject_Add() can of course be moved to the toolchain file instead.

@sparkleholic
Copy link
Contributor Author

@bandoti
Thank you for the valuable feedback.

I have updated the code to handle the GGML_SHADERS_GEN_TOOLCHAIN variable. When this variable is provided, the specified file is used. If it is not set, the code generates a temporary host toolchain file by detecting the host environment's compiler.

Please review the updated code once again.

@github-actions github-actions bot added Vulkan Issues specific to the Vulkan backend ggml changes relating to the ggml tensor library for machine learning labels Nov 28, 2024
@0cc4m
Copy link
Collaborator

0cc4m commented Dec 2, 2024

@bandoti Can you take another look?

ggml/src/ggml-vulkan/CMakeLists.txt Outdated Show resolved Hide resolved
ggml/src/ggml-vulkan/CMakeLists.txt Outdated Show resolved Hide resolved
@bandoti
Copy link
Contributor

bandoti commented Dec 2, 2024

@sparkleholic Sorry for the delay! I had these review comments in but forgot to submit them. 🤦‍♂️

@bandoti
Copy link
Contributor

bandoti commented Dec 15, 2024

@sparkleholic Just following up on this change. If you need further assistance please let me know I am happy to help.

@sparkleholic
Copy link
Contributor Author

sparkleholic commented Dec 24, 2024

@bandoti < Sorry for the late reply.
Thank you for the comments. I'll follow up this soon.

The vulkan-shaders-gen target was not being built correctly
in case of cross-compilation.
Other outputs need to be built for the cross compile target,
but vulkan-shaders-gen needs to be built for the host.
- Add GGML_SHADERS_GEN_TOOLCHAIN CMake option.
- Auto-detect host toolchain if not set.
@sparkleholic
Copy link
Contributor Author

Rebased branch to latest master.

Use configure_file to generate host_toolchain.cmake from template
@bandoti
Copy link
Contributor

bandoti commented Dec 28, 2024

@sparkleholic No worries on the delay! Your contribution is greatly appreciated :)

It appears as though the test failure is unrelated to this. I'm wondering if merging the latest and rerunning the tests will clear the status. I have only one minor question in the review.

@@ -3,7 +3,11 @@ find_package(Vulkan COMPONENTS glslc REQUIRED)

set(TARGET vulkan-shaders-gen)
add_executable(${TARGET} vulkan-shaders-gen.cpp)
install(TARGETS ${TARGET} RUNTIME)
if (${CMAKE_RUNTIME_OUTPUT_DIRECTORY})
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Is the intention here to be the variable value or the name?

if (CMAKE_RUNTIME_OUTPUT_DIRECTORY)

@bandoti
Copy link
Contributor

bandoti commented Jan 8, 2025

@sparkleholic I have submitted a pull request to your master_fix branch which updates to latest and resolves a minor merge conflict. Please merge it into your branch so we can get the CI fixed here and merge these changes in!

Here's the PR for reference: sparkleholic#2

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
ggml changes relating to the ggml tensor library for machine learning Vulkan Issues specific to the Vulkan backend
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants