ggml-cpu: extend RVV repack GEMM and GEMV to other VLENs#8
Merged
taimur-10x merged 3 commits intomasterfrom Mar 18, 2026
Merged
ggml-cpu: extend RVV repack GEMM and GEMV to other VLENs#8taimur-10x merged 3 commits intomasterfrom
taimur-10x merged 3 commits intomasterfrom
Conversation
ccce840 to
35bcbdc
Compare
0c39847 to
3d2f7cf
Compare
e9292b0 to
9601769
Compare
fb95e74 to
a037b85
Compare
5f26b14 to
053cb1c
Compare
315d3d9 to
1cf0b0e
Compare
Co-authored-by: Rehan Qasim <rehan.qasim@10xengineers.ai>
1cf0b0e to
d5a370f
Compare
d5a370f to
04719ae
Compare
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
Summary
This PR extends existing repacking and GEMM/GEMV kernels for quantization types to other RVV VLENs 128 to 1024) and adds new kernels for Q5_K and MXFP4.
Key Changes
Added repacking RVV GEMM and GEMV kernels for:
Extended the following implementations to VLEN=128 to 1024.
Tile Sizes
Testing
Kernels were functionally tested on QEMU for VLENs (128-bit to 1024-bit) for a range of input sizes.
Benchmarking Results
End-to-end benchmarking on
BananaPI-BPI F3 (VLEN=256)usingllama-bench.Q5_K
Prompt Processing
Token Generation
MXFP4
Prompt Processing
Token Generation
Future Work
Subsequent PRs plan to add these kernels for Q3_K and Q6_K