whispercpp 1.3.5 → 1.3.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/.document +3 -0
- data/.rdoc_options +2 -0
- data/LICENSE +1 -1
- data/README.md +133 -3
- data/Rakefile +18 -3
- data/ext/dependencies.rb +10 -4
- data/ext/dependencies_for_windows.rb +17 -0
- data/ext/extconf.rb +20 -7
- data/ext/options.rb +54 -14
- data/ext/options_for_windows.rb +51 -0
- data/ext/ruby_whisper.c +56 -46
- data/ext/ruby_whisper.h +165 -2
- data/ext/ruby_whisper_context.c +297 -126
- data/ext/ruby_whisper_context_params.c +163 -0
- data/ext/ruby_whisper_log_queue.c +180 -0
- data/ext/ruby_whisper_log_settable.h +47 -0
- data/ext/ruby_whisper_model.c +0 -1
- data/ext/ruby_whisper_parakeet.c +49 -0
- data/ext/ruby_whisper_parakeet_context.c +304 -0
- data/ext/ruby_whisper_parakeet_context_params.c +117 -0
- data/ext/ruby_whisper_parakeet_model.c +84 -0
- data/ext/ruby_whisper_parakeet_params.c +548 -0
- data/ext/ruby_whisper_parakeet_segment.c +157 -0
- data/ext/ruby_whisper_parakeet_token.c +188 -0
- data/ext/ruby_whisper_parakeet_transcribe.cpp +58 -0
- data/ext/ruby_whisper_params.c +256 -66
- data/ext/ruby_whisper_segment.c +6 -7
- data/ext/ruby_whisper_token.c +29 -9
- data/ext/ruby_whisper_transcribe.cpp +46 -16
- data/ext/ruby_whisper_vad_context.c +48 -1
- data/ext/ruby_whisper_vad_context_detect.cpp +6 -5
- data/ext/ruby_whisper_vad_params.c +0 -1
- data/ext/ruby_whisper_vad_segment.c +0 -1
- data/ext/ruby_whisper_vad_segments.c +0 -1
- data/ext/sources/CMakeLists.txt +41 -3
- data/ext/sources/CMakePresets.json +95 -0
- data/ext/sources/cmake/parakeet-config.cmake.in +30 -0
- data/ext/sources/cmake/parakeet.pc.in +10 -0
- data/ext/sources/cmake/whisper-config.cmake.in +5 -40
- data/ext/sources/cmake/whisper.pc.in +1 -1
- data/ext/sources/examples/CMakeLists.txt +4 -2
- data/ext/sources/examples/bench/bench.cpp +24 -19
- data/ext/sources/examples/cli/cli.cpp +51 -9
- data/ext/sources/examples/common-ggml.cpp +4 -0
- data/ext/sources/examples/common-whisper.cpp +139 -67
- data/ext/sources/examples/common-whisper.h +11 -0
- data/ext/sources/examples/ffmpeg-transcode.cpp +211 -341
- data/ext/sources/examples/miniaudio.h +4507 -2131
- data/ext/sources/examples/parakeet-cli/CMakeLists.txt +8 -0
- data/ext/sources/examples/parakeet-cli/parakeet-cli.cpp +243 -0
- data/ext/sources/examples/parakeet-quantize/CMakeLists.txt +7 -0
- data/ext/sources/examples/parakeet-quantize/parakeet-quantize.cpp +230 -0
- data/ext/sources/examples/server/server.cpp +213 -163
- data/ext/sources/ggml/CMakeLists.txt +29 -15
- data/ext/sources/ggml/cmake/FindNCCL.cmake +36 -0
- data/ext/sources/ggml/cmake/ggml-config.cmake.in +12 -2
- data/ext/sources/ggml/include/ggml-alloc.h +1 -0
- data/ext/sources/ggml/include/ggml-backend.h +73 -11
- data/ext/sources/ggml/include/ggml-cann.h +1 -1
- data/ext/sources/ggml/include/ggml-cpu.h +5 -0
- data/ext/sources/ggml/include/ggml-cuda.h +3 -0
- data/ext/sources/ggml/include/ggml-openvino.h +37 -0
- data/ext/sources/ggml/include/ggml-opt.h +1 -1
- data/ext/sources/ggml/include/ggml-rpc.h +8 -3
- data/ext/sources/ggml/include/ggml-virtgpu.h +14 -0
- data/ext/sources/ggml/include/ggml.h +155 -16
- data/ext/sources/ggml/include/gguf.h +10 -2
- data/ext/sources/ggml/src/CMakeLists.txt +25 -5
- data/ext/sources/ggml/src/ggml-alloc.c +9 -10
- data/ext/sources/ggml/src/ggml-backend-dl.cpp +48 -0
- data/ext/sources/ggml/src/ggml-backend-dl.h +45 -0
- data/ext/sources/ggml/src/ggml-backend-impl.h +22 -2
- data/ext/sources/ggml/src/ggml-backend-meta.cpp +2263 -0
- data/ext/sources/ggml/src/ggml-backend-reg.cpp +40 -86
- data/ext/sources/ggml/src/ggml-backend.cpp +114 -10
- data/ext/sources/ggml/src/ggml-blas/CMakeLists.txt +1 -1
- data/ext/sources/ggml/src/ggml-blas/ggml-blas.cpp +10 -2
- data/ext/sources/ggml/src/ggml-cann/acl_tensor.cpp +1 -1
- data/ext/sources/ggml/src/ggml-cann/acl_tensor.h +1 -1
- data/ext/sources/ggml/src/ggml-cann/aclnn_ops.cpp +1016 -442
- data/ext/sources/ggml/src/ggml-cann/aclnn_ops.h +111 -85
- data/ext/sources/ggml/src/ggml-cann/common.h +23 -14
- data/ext/sources/ggml/src/ggml-cann/ggml-cann.cpp +255 -92
- data/ext/sources/ggml/src/ggml-common.h +22 -0
- data/ext/sources/ggml/src/ggml-cpu/CMakeLists.txt +68 -34
- data/ext/sources/ggml/src/ggml-cpu/amx/amx.cpp +44 -19
- data/ext/sources/ggml/src/ggml-cpu/amx/common.h +34 -10
- data/ext/sources/ggml/src/ggml-cpu/amx/mmq.cpp +101 -101
- data/ext/sources/ggml/src/ggml-cpu/arch/arm/quants.c +194 -1
- data/ext/sources/ggml/src/ggml-cpu/arch/arm/repack.cpp +2874 -613
- data/ext/sources/ggml/src/ggml-cpu/arch/loongarch/quants.c +151 -1
- data/ext/sources/ggml/src/ggml-cpu/arch/powerpc/quants.c +0 -1
- data/ext/sources/ggml/src/ggml-cpu/arch/riscv/quants.c +5480 -840
- data/ext/sources/ggml/src/ggml-cpu/arch/riscv/repack.cpp +1361 -0
- data/ext/sources/ggml/src/ggml-cpu/arch/s390/quants.c +8 -11
- data/ext/sources/ggml/src/ggml-cpu/arch/wasm/quants.c +72 -1
- data/ext/sources/ggml/src/ggml-cpu/arch/x86/quants.c +186 -36
- data/ext/sources/ggml/src/ggml-cpu/arch/x86/repack.cpp +119 -19
- data/ext/sources/ggml/src/ggml-cpu/arch-fallback.h +112 -26
- data/ext/sources/ggml/src/ggml-cpu/binary-ops.cpp +2 -6
- data/ext/sources/ggml/src/ggml-cpu/cmake/FindSMTIME.cmake +32 -0
- data/ext/sources/ggml/src/ggml-cpu/common.h +8 -0
- data/ext/sources/ggml/src/ggml-cpu/ggml-cpu-impl.h +13 -0
- data/ext/sources/ggml/src/ggml-cpu/ggml-cpu.c +153 -16
- data/ext/sources/ggml/src/ggml-cpu/ggml-cpu.cpp +17 -0
- data/ext/sources/ggml/src/ggml-cpu/kleidiai/kernels.cpp +21 -20
- data/ext/sources/ggml/src/ggml-cpu/kleidiai/kleidiai.cpp +976 -251
- data/ext/sources/ggml/src/ggml-cpu/llamafile/sgemm.cpp +671 -266
- data/ext/sources/ggml/src/ggml-cpu/ops.cpp +1277 -263
- data/ext/sources/ggml/src/ggml-cpu/ops.h +4 -0
- data/ext/sources/ggml/src/ggml-cpu/quants.c +95 -0
- data/ext/sources/ggml/src/ggml-cpu/quants.h +6 -0
- data/ext/sources/ggml/src/ggml-cpu/repack.cpp +2893 -679
- data/ext/sources/ggml/src/ggml-cpu/repack.h +119 -8
- data/ext/sources/ggml/src/ggml-cpu/simd-gemm.h +226 -0
- data/ext/sources/ggml/src/ggml-cpu/simd-mappings.h +114 -19
- data/ext/sources/ggml/src/ggml-cpu/spacemit/ime.cpp +1402 -687
- data/ext/sources/ggml/src/ggml-cpu/spacemit/ime.h +8 -0
- data/ext/sources/ggml/src/ggml-cpu/spacemit/ime1_kernels.cpp +597 -2766
- data/ext/sources/ggml/src/ggml-cpu/spacemit/ime2_kernels.cpp +5768 -0
- data/ext/sources/ggml/src/ggml-cpu/spacemit/ime_env.cpp +320 -0
- data/ext/sources/ggml/src/ggml-cpu/spacemit/ime_env.h +55 -0
- data/ext/sources/ggml/src/ggml-cpu/spacemit/ime_kernels.h +182 -19
- data/ext/sources/ggml/src/ggml-cpu/spacemit/repack.cpp +1795 -0
- data/ext/sources/ggml/src/ggml-cpu/spacemit/repack.h +14 -0
- data/ext/sources/ggml/src/ggml-cpu/spacemit/rvv_kernels.cpp +3178 -0
- data/ext/sources/ggml/src/ggml-cpu/spacemit/rvv_kernels.h +95 -0
- data/ext/sources/ggml/src/ggml-cpu/spacemit/spine_barrier.h +34 -0
- data/ext/sources/ggml/src/ggml-cpu/spacemit/spine_mem_pool.cpp +760 -0
- data/ext/sources/ggml/src/ggml-cpu/spacemit/spine_mem_pool.h +32 -0
- data/ext/sources/ggml/src/ggml-cpu/spacemit/spine_tcm.h +409 -0
- data/ext/sources/ggml/src/ggml-cpu/unary-ops.cpp +1 -1
- data/ext/sources/ggml/src/ggml-cpu/vec.cpp +54 -53
- data/ext/sources/ggml/src/ggml-cpu/vec.h +225 -240
- data/ext/sources/ggml/src/ggml-cuda/CMakeLists.txt +18 -8
- data/ext/sources/ggml/src/ggml-cuda/allreduce.cu +971 -0
- data/ext/sources/ggml/src/ggml-cuda/allreduce.cuh +29 -0
- data/ext/sources/ggml/src/ggml-cuda/argsort.cu +73 -28
- data/ext/sources/ggml/src/ggml-cuda/binbcast.cu +69 -41
- data/ext/sources/ggml/src/ggml-cuda/binbcast.cuh +1 -0
- data/ext/sources/ggml/src/ggml-cuda/common.cuh +359 -29
- data/ext/sources/ggml/src/ggml-cuda/concat.cu +120 -114
- data/ext/sources/ggml/src/ggml-cuda/conv2d-transpose.cu +45 -21
- data/ext/sources/ggml/src/ggml-cuda/conv2d-transpose.cuh +1 -0
- data/ext/sources/ggml/src/ggml-cuda/convert.cu +94 -27
- data/ext/sources/ggml/src/ggml-cuda/convert.cuh +10 -0
- data/ext/sources/ggml/src/ggml-cuda/cpy.cu +20 -9
- data/ext/sources/ggml/src/ggml-cuda/dequantize.cuh +22 -0
- data/ext/sources/ggml/src/ggml-cuda/fattn-common.cuh +333 -85
- data/ext/sources/ggml/src/ggml-cuda/fattn-mma-f16.cuh +632 -190
- data/ext/sources/ggml/src/ggml-cuda/fattn-tile.cu +12 -0
- data/ext/sources/ggml/src/ggml-cuda/fattn-tile.cuh +162 -49
- data/ext/sources/ggml/src/ggml-cuda/fattn-vec.cuh +43 -18
- data/ext/sources/ggml/src/ggml-cuda/fattn-wmma-f16.cu +44 -14
- data/ext/sources/ggml/src/ggml-cuda/fattn-wmma-f16.cuh +1 -1
- data/ext/sources/ggml/src/ggml-cuda/fattn.cu +241 -23
- data/ext/sources/ggml/src/ggml-cuda/fattn.cuh +2 -0
- data/ext/sources/ggml/src/ggml-cuda/fwht.cu +101 -0
- data/ext/sources/ggml/src/ggml-cuda/fwht.cuh +4 -0
- data/ext/sources/ggml/src/ggml-cuda/gated_delta_net.cu +312 -0
- data/ext/sources/ggml/src/ggml-cuda/gated_delta_net.cuh +4 -0
- data/ext/sources/ggml/src/ggml-cuda/getrows.cu +34 -12
- data/ext/sources/ggml/src/ggml-cuda/ggml-cuda.cu +1454 -599
- data/ext/sources/ggml/src/ggml-cuda/im2col.cu +32 -29
- data/ext/sources/ggml/src/ggml-cuda/mean.cu +13 -10
- data/ext/sources/ggml/src/ggml-cuda/mma.cuh +397 -183
- data/ext/sources/ggml/src/ggml-cuda/mmf.cu +30 -10
- data/ext/sources/ggml/src/ggml-cuda/mmf.cuh +161 -88
- data/ext/sources/ggml/src/ggml-cuda/mmq.cu +18 -12
- data/ext/sources/ggml/src/ggml-cuda/mmq.cuh +522 -431
- data/ext/sources/ggml/src/ggml-cuda/mmvf.cu +139 -72
- data/ext/sources/ggml/src/ggml-cuda/mmvf.cuh +2 -0
- data/ext/sources/ggml/src/ggml-cuda/mmvq.cu +608 -88
- data/ext/sources/ggml/src/ggml-cuda/mmvq.cuh +6 -0
- data/ext/sources/ggml/src/ggml-cuda/norm.cu +47 -79
- data/ext/sources/ggml/src/ggml-cuda/out-prod.cu +23 -7
- data/ext/sources/ggml/src/ggml-cuda/pad.cu +13 -10
- data/ext/sources/ggml/src/ggml-cuda/quantize.cu +134 -27
- data/ext/sources/ggml/src/ggml-cuda/quantize.cuh +1 -1
- data/ext/sources/ggml/src/ggml-cuda/reduce_rows.cuh +7 -17
- data/ext/sources/ggml/src/ggml-cuda/rope.cu +244 -137
- data/ext/sources/ggml/src/ggml-cuda/scale.cu +4 -1
- data/ext/sources/ggml/src/ggml-cuda/set-rows.cu +14 -6
- data/ext/sources/ggml/src/ggml-cuda/snake.cu +72 -0
- data/ext/sources/ggml/src/ggml-cuda/snake.cuh +8 -0
- data/ext/sources/ggml/src/ggml-cuda/softcap.cu +4 -1
- data/ext/sources/ggml/src/ggml-cuda/softmax.cu +8 -83
- data/ext/sources/ggml/src/ggml-cuda/solve_tri.cu +1 -1
- data/ext/sources/ggml/src/ggml-cuda/ssm-conv.cu +96 -40
- data/ext/sources/ggml/src/ggml-cuda/ssm-conv.cuh +1 -1
- data/ext/sources/ggml/src/ggml-cuda/ssm-scan.cu +40 -18
- data/ext/sources/ggml/src/ggml-cuda/sumrows.cu +8 -4
- data/ext/sources/ggml/src/ggml-cuda/template-instances/fattn-mma-f16-instance-ncols1_1-ncols2_16.cu +1 -0
- data/ext/sources/ggml/src/ggml-cuda/template-instances/fattn-mma-f16-instance-ncols1_1-ncols2_32.cu +6 -0
- data/ext/sources/ggml/src/ggml-cuda/template-instances/fattn-mma-f16-instance-ncols1_1-ncols2_8.cu +2 -0
- data/ext/sources/ggml/src/ggml-cuda/template-instances/fattn-mma-f16-instance-ncols1_16-ncols2_4.cu +2 -0
- data/ext/sources/ggml/src/ggml-cuda/template-instances/fattn-mma-f16-instance-ncols1_2-ncols2_16.cu +1 -0
- data/ext/sources/ggml/src/ggml-cuda/template-instances/fattn-mma-f16-instance-ncols1_2-ncols2_32.cu +6 -0
- data/ext/sources/ggml/src/ggml-cuda/template-instances/fattn-mma-f16-instance-ncols1_2-ncols2_4.cu +2 -0
- data/ext/sources/ggml/src/ggml-cuda/template-instances/fattn-mma-f16-instance-ncols1_2-ncols2_8.cu +2 -0
- data/ext/sources/ggml/src/ggml-cuda/template-instances/fattn-mma-f16-instance-ncols1_4-ncols2_16.cu +1 -0
- data/ext/sources/ggml/src/ggml-cuda/template-instances/fattn-mma-f16-instance-ncols1_4-ncols2_4.cu +2 -0
- data/ext/sources/ggml/src/ggml-cuda/template-instances/fattn-mma-f16-instance-ncols1_4-ncols2_8.cu +2 -0
- data/ext/sources/ggml/src/ggml-cuda/template-instances/fattn-mma-f16-instance-ncols1_8-ncols2_4.cu +2 -0
- data/ext/sources/ggml/src/ggml-cuda/template-instances/fattn-mma-f16-instance-ncols1_8-ncols2_8.cu +2 -0
- data/ext/sources/ggml/src/ggml-cuda/template-instances/fattn-tile-instance-dkq192-dv128.cu +5 -0
- data/ext/sources/ggml/src/ggml-cuda/template-instances/fattn-tile-instance-dkq320-dv256.cu +5 -0
- data/ext/sources/ggml/src/ggml-cuda/template-instances/fattn-tile-instance-dkq512-dv512.cu +5 -0
- data/ext/sources/ggml/src/ggml-cuda/template-instances/fattn-vec-instance-bf16-bf16.cu +7 -0
- data/ext/sources/ggml/src/ggml-cuda/template-instances/fattn-vec-instance-bf16-f16.cu +7 -0
- data/ext/sources/ggml/src/ggml-cuda/template-instances/fattn-vec-instance-bf16-q4_0.cu +7 -0
- data/ext/sources/ggml/src/ggml-cuda/template-instances/fattn-vec-instance-bf16-q4_1.cu +7 -0
- data/ext/sources/ggml/src/ggml-cuda/template-instances/fattn-vec-instance-bf16-q5_0.cu +7 -0
- data/ext/sources/ggml/src/ggml-cuda/template-instances/fattn-vec-instance-bf16-q5_1.cu +7 -0
- data/ext/sources/ggml/src/ggml-cuda/template-instances/fattn-vec-instance-bf16-q8_0.cu +7 -0
- data/ext/sources/ggml/src/ggml-cuda/template-instances/fattn-vec-instance-f16-bf16.cu +7 -0
- data/ext/sources/ggml/src/ggml-cuda/template-instances/fattn-vec-instance-q4_0-bf16.cu +7 -0
- data/ext/sources/ggml/src/ggml-cuda/template-instances/fattn-vec-instance-q4_1-bf16.cu +7 -0
- data/ext/sources/ggml/src/ggml-cuda/template-instances/fattn-vec-instance-q5_0-bf16.cu +7 -0
- data/ext/sources/ggml/src/ggml-cuda/template-instances/fattn-vec-instance-q5_1-bf16.cu +7 -0
- data/ext/sources/ggml/src/ggml-cuda/template-instances/fattn-vec-instance-q8_0-bf16.cu +7 -0
- data/ext/sources/ggml/src/ggml-cuda/template-instances/mmq-instance-nvfp4.cu +5 -0
- data/ext/sources/ggml/src/ggml-cuda/template-instances/mmq-instance-q1_0.cu +5 -0
- data/ext/sources/ggml/src/ggml-cuda/top-k.cu +5 -5
- data/ext/sources/ggml/src/ggml-cuda/topk-moe.cu +202 -135
- data/ext/sources/ggml/src/ggml-cuda/topk-moe.cuh +20 -14
- data/ext/sources/ggml/src/ggml-cuda/unary.cu +86 -2
- data/ext/sources/ggml/src/ggml-cuda/unary.cuh +4 -0
- data/ext/sources/ggml/src/ggml-cuda/vecdotq.cuh +111 -17
- data/ext/sources/ggml/src/ggml-cuda/vendors/cuda.h +7 -2
- data/ext/sources/ggml/src/ggml-cuda/vendors/hip.h +30 -2
- data/ext/sources/ggml/src/ggml-cuda/vendors/musa.h +3 -0
- data/ext/sources/ggml/src/ggml-hexagon/CMakeLists.txt +84 -46
- data/ext/sources/ggml/src/ggml-hexagon/ggml-hexagon.cpp +1612 -753
- data/ext/sources/ggml/src/ggml-hexagon/htp/CMakeLists.txt +51 -11
- data/ext/sources/ggml/src/ggml-hexagon/htp/act-ops.c +361 -261
- data/ext/sources/ggml/src/ggml-hexagon/htp/argsort-ops.c +294 -0
- data/ext/sources/ggml/src/ggml-hexagon/htp/binary-ops.c +753 -241
- data/ext/sources/ggml/src/ggml-hexagon/htp/cmake-toolchain.cmake +5 -5
- data/ext/sources/ggml/src/ggml-hexagon/htp/concat-ops.c +277 -0
- data/ext/sources/ggml/src/ggml-hexagon/htp/cpy-ops.c +295 -0
- data/ext/sources/ggml/src/ggml-hexagon/htp/cumsum-ops.c +270 -0
- data/ext/sources/ggml/src/ggml-hexagon/htp/diag-ops.c +216 -0
- data/ext/sources/ggml/src/ggml-hexagon/htp/fill-ops.c +123 -0
- data/ext/sources/ggml/src/ggml-hexagon/htp/flash-attn-ops.c +471 -296
- data/ext/sources/ggml/src/ggml-hexagon/htp/gated-delta-net-ops.c +1148 -0
- data/ext/sources/ggml/src/ggml-hexagon/htp/get-rows-ops.c +159 -53
- data/ext/sources/ggml/src/ggml-hexagon/htp/{htp-dma.c → hex-dma.c} +3 -3
- data/ext/sources/ggml/src/ggml-hexagon/htp/hex-dma.h +372 -0
- data/ext/sources/ggml/src/ggml-hexagon/htp/hex-dump.h +86 -0
- data/ext/sources/ggml/src/ggml-hexagon/htp/hex-fastdiv.h +37 -0
- data/ext/sources/ggml/src/ggml-hexagon/htp/hex-utils.h +137 -0
- data/ext/sources/ggml/src/ggml-hexagon/htp/hmx-flash-attn-ops.c +1878 -0
- data/ext/sources/ggml/src/ggml-hexagon/htp/hmx-matmul-ops.c +2066 -0
- data/ext/sources/ggml/src/ggml-hexagon/htp/hmx-ops.c +6 -0
- data/ext/sources/ggml/src/ggml-hexagon/htp/hmx-ops.h +88 -0
- data/ext/sources/ggml/src/ggml-hexagon/htp/hmx-profile.h +34 -0
- data/ext/sources/ggml/src/ggml-hexagon/htp/hmx-queue.c +158 -0
- data/ext/sources/ggml/src/ggml-hexagon/htp/hmx-queue.h +134 -0
- data/ext/sources/ggml/src/ggml-hexagon/htp/hmx-utils.h +200 -0
- data/ext/sources/ggml/src/ggml-hexagon/htp/htp-ctx.h +97 -14
- data/ext/sources/ggml/src/ggml-hexagon/htp/htp-ops.h +163 -67
- data/ext/sources/ggml/src/ggml-hexagon/htp/htp_iface.idl +9 -3
- data/ext/sources/ggml/src/ggml-hexagon/htp/hvx-arith.h +443 -0
- data/ext/sources/ggml/src/ggml-hexagon/htp/hvx-base.h +308 -0
- data/ext/sources/ggml/src/ggml-hexagon/htp/hvx-copy.h +262 -0
- data/ext/sources/ggml/src/ggml-hexagon/htp/hvx-div.h +291 -0
- data/ext/sources/ggml/src/ggml-hexagon/htp/hvx-dump.h +129 -0
- data/ext/sources/ggml/src/ggml-hexagon/htp/hvx-exp.h +216 -0
- data/ext/sources/ggml/src/ggml-hexagon/htp/hvx-flash-attn.h +47 -0
- data/ext/sources/ggml/src/ggml-hexagon/htp/hvx-floor.h +100 -0
- data/ext/sources/ggml/src/ggml-hexagon/htp/hvx-inverse.h +210 -0
- data/ext/sources/ggml/src/ggml-hexagon/htp/hvx-log.h +65 -0
- data/ext/sources/ggml/src/ggml-hexagon/htp/hvx-pow.h +42 -0
- data/ext/sources/ggml/src/ggml-hexagon/htp/hvx-reduce.h +296 -0
- data/ext/sources/ggml/src/ggml-hexagon/htp/hvx-repl.h +74 -0
- data/ext/sources/ggml/src/ggml-hexagon/htp/hvx-scale.h +133 -0
- data/ext/sources/ggml/src/ggml-hexagon/htp/hvx-sigmoid.h +142 -0
- data/ext/sources/ggml/src/ggml-hexagon/htp/hvx-sin-cos.h +90 -0
- data/ext/sources/ggml/src/ggml-hexagon/htp/hvx-sqrt.h +126 -0
- data/ext/sources/ggml/src/ggml-hexagon/htp/hvx-types.h +36 -0
- data/ext/sources/ggml/src/ggml-hexagon/htp/hvx-utils.h +18 -1348
- data/ext/sources/ggml/src/ggml-hexagon/htp/main.c +547 -635
- data/ext/sources/ggml/src/ggml-hexagon/htp/matmul-ops.c +3556 -1101
- data/ext/sources/ggml/src/ggml-hexagon/htp/pad-ops.c +547 -0
- data/ext/sources/ggml/src/ggml-hexagon/htp/repeat-ops.c +148 -0
- data/ext/sources/ggml/src/ggml-hexagon/htp/rope-ops.c +475 -269
- data/ext/sources/ggml/src/ggml-hexagon/htp/set-rows-ops.c +94 -72
- data/ext/sources/ggml/src/ggml-hexagon/htp/softmax-ops.c +222 -217
- data/ext/sources/ggml/src/ggml-hexagon/htp/solve-tri-ops.c +267 -0
- data/ext/sources/ggml/src/ggml-hexagon/htp/ssm-conv.c +432 -0
- data/ext/sources/ggml/src/ggml-hexagon/htp/sum-rows-ops.c +128 -0
- data/ext/sources/ggml/src/ggml-hexagon/htp/unary-ops.c +886 -117
- data/ext/sources/ggml/src/ggml-hexagon/htp/vtcm-utils.h +16 -0
- data/ext/sources/ggml/src/ggml-hexagon/htp/worker-pool.c +1 -5
- data/ext/sources/ggml/src/ggml-hexagon/htp-drv.cpp +418 -0
- data/ext/sources/ggml/src/ggml-hexagon/htp-drv.h +121 -0
- data/ext/sources/ggml/src/ggml-hexagon/htp-opnode.h +272 -0
- data/ext/sources/ggml/src/ggml-hexagon/libdl.h +79 -0
- data/ext/sources/ggml/src/ggml-hexagon/libggml-htp.inf +40 -0
- data/ext/sources/ggml/src/ggml-hip/CMakeLists.txt +28 -9
- data/ext/sources/ggml/src/ggml-impl.h +68 -1
- data/ext/sources/ggml/src/ggml-metal/CMakeLists.txt +10 -10
- data/ext/sources/ggml/src/ggml-metal/ggml-metal-common.cpp +13 -2
- data/ext/sources/ggml/src/ggml-metal/ggml-metal-context.h +8 -0
- data/ext/sources/ggml/src/ggml-metal/ggml-metal-context.m +147 -17
- data/ext/sources/ggml/src/ggml-metal/ggml-metal-device.cpp +409 -83
- data/ext/sources/ggml/src/ggml-metal/ggml-metal-device.h +54 -5
- data/ext/sources/ggml/src/ggml-metal/ggml-metal-device.m +254 -52
- data/ext/sources/ggml/src/ggml-metal/ggml-metal-impl.h +254 -23
- data/ext/sources/ggml/src/ggml-metal/ggml-metal-ops.cpp +756 -285
- data/ext/sources/ggml/src/ggml-metal/ggml-metal-ops.h +7 -4
- data/ext/sources/ggml/src/ggml-metal/ggml-metal.cpp +359 -133
- data/ext/sources/ggml/src/ggml-metal/ggml-metal.metal +1867 -1123
- data/ext/sources/ggml/src/ggml-musa/CMakeLists.txt +5 -6
- data/ext/sources/ggml/src/ggml-opencl/CMakeLists.txt +71 -4
- data/ext/sources/ggml/src/ggml-opencl/ggml-opencl.cpp +14127 -5314
- data/ext/sources/ggml/src/ggml-opencl/kernels/concat.cl +97 -88
- data/ext/sources/ggml/src/ggml-opencl/kernels/cpy.cl +104 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/cumsum.cl +139 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/cvt.cl +1978 -67
- data/ext/sources/ggml/src/ggml-opencl/kernels/diag.cl +27 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/exp.cl +125 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/expm1.cl +87 -56
- data/ext/sources/ggml/src/ggml-opencl/kernels/gated_delta_net.cl +249 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/gemm_moe_mxfp4_f32_ns.cl +306 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/gemm_moe_q4_0_f32_ns.cl +256 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/gemm_moe_q4_1_f32_ns.cl +258 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/gemm_moe_q4_k_f32_ns.cl +283 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/gemm_moe_q5_0_f32_ns.cl +260 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/gemm_moe_q5_1_f32_ns.cl +262 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/gemm_moe_q5_k_f32_ns.cl +288 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/gemm_moe_q6_k_f32_ns.cl +267 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/gemm_noshuffle_iq4_nl_f32.cl +150 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/{mul_mat_Ab_Bi_8x4.cl → gemm_noshuffle_q4_0_f32.cl} +1 -1
- data/ext/sources/ggml/src/ggml-opencl/kernels/gemm_noshuffle_q4_1_f32.cl +132 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/gemm_noshuffle_q4_k_f32.cl +172 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/gemm_noshuffle_q5_0_f32.cl +131 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/gemm_noshuffle_q5_1_f32.cl +134 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/gemm_noshuffle_q5_k_f32.cl +176 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/gemm_noshuffle_q6_k_f32.cl +140 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/gemm_noshuffle_q8_0_f32.cl +129 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/gemm_xmem_f16_f32_os8.cl +233 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/gemv_moe_mxfp4_f32_ns.cl +165 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/gemv_moe_q4_0_f32_ns.cl +120 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/gemv_moe_q4_1_f32_ns.cl +123 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/gemv_moe_q4_k_f32_ns.cl +155 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/gemv_moe_q5_0_f32_ns.cl +123 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/gemv_moe_q5_1_f32_ns.cl +125 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/gemv_moe_q5_k_f32_ns.cl +160 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/gemv_moe_q6_k_f32_ns.cl +141 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/gemv_noshuffle_iq4_nl_f32.cl +302 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/{gemv_noshuffle_general.cl → gemv_noshuffle_q4_0_f32.cl} +5 -5
- data/ext/sources/ggml/src/ggml-opencl/kernels/{gemv_noshuffle.cl → gemv_noshuffle_q4_0_f32_spec.cl} +5 -5
- data/ext/sources/ggml/src/ggml-opencl/kernels/gemv_noshuffle_q4_1_f32.cl +283 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/gemv_noshuffle_q4_k_f32.cl +318 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/gemv_noshuffle_q5_0_f32.cl +291 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/gemv_noshuffle_q5_1_f32.cl +294 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/gemv_noshuffle_q5_k_f32.cl +326 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/gemv_noshuffle_q6_k_f32.cl +293 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/gemv_noshuffle_q8_0_f32.cl +195 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/get_rows.cl +15 -9
- data/ext/sources/ggml/src/ggml-opencl/kernels/l2_norm.cl +71 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/mean.cl +114 -13
- data/ext/sources/ggml/src/ggml-opencl/kernels/moe_reorder_b.cl +30 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/moe_sort_by_expert.cl +82 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/mul_mm_iq4_nl_f32_l4_lm.cl +171 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/mul_mm_q4_0_f32_l4_lm.cl +163 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/mul_mm_q4_1_f32_l4_lm.cl +165 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/mul_mm_q4_k_f32_l4_lm.cl +179 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/mul_mm_q5_0_f32_l4_lm.cl +173 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/mul_mm_q5_1_f32_l4_lm.cl +175 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/mul_mm_q5_k_f32_l4_lm.cl +192 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/mul_mm_q6_k_f32_l4_lm.cl +158 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/mul_mv_iq4_nl_f32.cl +164 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/mul_mv_iq4_nl_f32_flat.cl +202 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/mul_mv_q4_1_f32.cl +219 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/mul_mv_q4_1_f32_flat.cl +229 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/mul_mv_q4_k_f32.cl +180 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/mul_mv_q4_k_f32_flat.cl +196 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/mul_mv_q5_0_f32.cl +241 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/mul_mv_q5_0_f32_flat.cl +243 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/mul_mv_q5_1_f32.cl +243 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/mul_mv_q5_1_f32_flat.cl +247 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/mul_mv_q5_k_f32.cl +187 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/mul_mv_q5_k_f32_flat.cl +203 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/{mul_mv_q6_k.cl → mul_mv_q6_k_f32.cl} +4 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/mul_mv_q6_k_f32_flat.cl +178 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/neg.cl +125 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/repeat.cl +31 -32
- data/ext/sources/ggml/src/ggml-opencl/kernels/scale.cl +14 -4
- data/ext/sources/ggml/src/ggml-opencl/kernels/softplus.cl +88 -60
- data/ext/sources/ggml/src/ggml-opencl/kernels/solve_tri.cl +51 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/sum_rows.cl +114 -13
- data/ext/sources/ggml/src/ggml-opencl/kernels/tanh.cl +94 -48
- data/ext/sources/ggml/src/ggml-opencl/kernels/transpose.cl +26 -0
- data/ext/sources/ggml/src/ggml-opencl/kernels/tri.cl +32 -0
- data/ext/sources/ggml/src/ggml-openvino/.clang-format +154 -0
- data/ext/sources/ggml/src/ggml-openvino/CMakeLists.txt +22 -0
- data/ext/sources/ggml/src/ggml-openvino/ggml-decoder.cpp +985 -0
- data/ext/sources/ggml/src/ggml-openvino/ggml-decoder.h +294 -0
- data/ext/sources/ggml/src/ggml-openvino/ggml-openvino-extra.cpp +380 -0
- data/ext/sources/ggml/src/ggml-openvino/ggml-openvino-extra.h +182 -0
- data/ext/sources/ggml/src/ggml-openvino/ggml-openvino.cpp +1132 -0
- data/ext/sources/ggml/src/ggml-openvino/ggml-quants.cpp +956 -0
- data/ext/sources/ggml/src/ggml-openvino/ggml-quants.h +153 -0
- data/ext/sources/ggml/src/ggml-openvino/openvino/decoder.h +74 -0
- data/ext/sources/ggml/src/ggml-openvino/openvino/frontend.cpp +27 -0
- data/ext/sources/ggml/src/ggml-openvino/openvino/frontend.h +23 -0
- data/ext/sources/ggml/src/ggml-openvino/openvino/input_model.cpp +17 -0
- data/ext/sources/ggml/src/ggml-openvino/openvino/input_model.h +29 -0
- data/ext/sources/ggml/src/ggml-openvino/openvino/node_context.h +112 -0
- data/ext/sources/ggml/src/ggml-openvino/openvino/op/cont.cpp +48 -0
- data/ext/sources/ggml/src/ggml-openvino/openvino/op/cpy.cpp +21 -0
- data/ext/sources/ggml/src/ggml-openvino/openvino/op/flash_attn_ext.cpp +90 -0
- data/ext/sources/ggml/src/ggml-openvino/openvino/op/get_rows.cpp +69 -0
- data/ext/sources/ggml/src/ggml-openvino/openvino/op/glu_geglu.cpp +61 -0
- data/ext/sources/ggml/src/ggml-openvino/openvino/op/glu_swiglu.cpp +62 -0
- data/ext/sources/ggml/src/ggml-openvino/openvino/op/mulmat.cpp +90 -0
- data/ext/sources/ggml/src/ggml-openvino/openvino/op/permute.cpp +102 -0
- data/ext/sources/ggml/src/ggml-openvino/openvino/op/reshape.cpp +83 -0
- data/ext/sources/ggml/src/ggml-openvino/openvino/op/rms_norm.cpp +46 -0
- data/ext/sources/ggml/src/ggml-openvino/openvino/op/rope.cpp +149 -0
- data/ext/sources/ggml/src/ggml-openvino/openvino/op/scale.cpp +41 -0
- data/ext/sources/ggml/src/ggml-openvino/openvino/op/set_rows.cpp +76 -0
- data/ext/sources/ggml/src/ggml-openvino/openvino/op/softmax.cpp +89 -0
- data/ext/sources/ggml/src/ggml-openvino/openvino/op/transpose.cpp +23 -0
- data/ext/sources/ggml/src/ggml-openvino/openvino/op/unary_gelu.cpp +25 -0
- data/ext/sources/ggml/src/ggml-openvino/openvino/op/unary_silu.cpp +27 -0
- data/ext/sources/ggml/src/ggml-openvino/openvino/op/view.cpp +53 -0
- data/ext/sources/ggml/src/ggml-openvino/openvino/op_table.cpp +47 -0
- data/ext/sources/ggml/src/ggml-openvino/openvino/op_table.h +40 -0
- data/ext/sources/ggml/src/ggml-openvino/openvino/pass/fuse_to_sdpa.cpp +60 -0
- data/ext/sources/ggml/src/ggml-openvino/openvino/pass/fuse_to_sdpa.h +17 -0
- data/ext/sources/ggml/src/ggml-openvino/openvino/pass/mark_decompression_convert_constant_folding.h +29 -0
- data/ext/sources/ggml/src/ggml-openvino/openvino/pass/squeeze_matmul.cpp +58 -0
- data/ext/sources/ggml/src/ggml-openvino/openvino/pass/squeeze_matmul.h +17 -0
- data/ext/sources/ggml/src/ggml-openvino/openvino/rt_info/weightless_caching_attributes.hpp +41 -0
- data/ext/sources/ggml/src/ggml-openvino/openvino/translate_session.cpp +317 -0
- data/ext/sources/ggml/src/ggml-openvino/openvino/translate_session.h +28 -0
- data/ext/sources/ggml/src/ggml-openvino/openvino/utils.cpp +257 -0
- data/ext/sources/ggml/src/ggml-openvino/openvino/utils.h +86 -0
- data/ext/sources/ggml/src/ggml-openvino/utils.cpp +880 -0
- data/ext/sources/ggml/src/ggml-openvino/utils.h +143 -0
- data/ext/sources/ggml/src/ggml-opt.cpp +1 -0
- data/ext/sources/ggml/src/ggml-quants.c +385 -119
- data/ext/sources/ggml/src/ggml-quants.h +6 -0
- data/ext/sources/ggml/src/ggml-rpc/CMakeLists.txt +24 -0
- data/ext/sources/ggml/src/ggml-rpc/ggml-rpc.cpp +167 -311
- data/ext/sources/ggml/src/ggml-rpc/transport.cpp +683 -0
- data/ext/sources/ggml/src/ggml-rpc/transport.h +34 -0
- data/ext/sources/ggml/src/ggml-sycl/CMakeLists.txt +64 -91
- data/ext/sources/ggml/src/ggml-sycl/add-id.cpp +5 -1
- data/ext/sources/ggml/src/ggml-sycl/backend.hpp +4 -1
- data/ext/sources/ggml/src/ggml-sycl/binbcast.cpp +21 -20
- data/ext/sources/ggml/src/ggml-sycl/common.cpp +74 -2
- data/ext/sources/ggml/src/ggml-sycl/common.hpp +356 -11
- data/ext/sources/ggml/src/ggml-sycl/convert.cpp +184 -14
- data/ext/sources/ggml/src/ggml-sycl/convert.hpp +31 -1
- data/ext/sources/ggml/src/ggml-sycl/count-equal.cpp +1 -1
- data/ext/sources/ggml/src/ggml-sycl/cumsum.cpp +148 -0
- data/ext/sources/ggml/src/ggml-sycl/cumsum.hpp +5 -0
- data/ext/sources/ggml/src/ggml-sycl/dequantize.hpp +663 -0
- data/ext/sources/ggml/src/ggml-sycl/diag.cpp +67 -0
- data/ext/sources/ggml/src/ggml-sycl/diag.hpp +5 -0
- data/ext/sources/ggml/src/ggml-sycl/dmmv.cpp +586 -6
- data/ext/sources/ggml/src/ggml-sycl/dpct/helper.hpp +791 -47
- data/ext/sources/ggml/src/ggml-sycl/element_wise.cpp +77 -156
- data/ext/sources/ggml/src/ggml-sycl/element_wise.hpp +2 -2
- data/ext/sources/ggml/src/ggml-sycl/fattn-buffers.cpp +56 -0
- data/ext/sources/ggml/src/ggml-sycl/fattn-buffers.hpp +63 -0
- data/ext/sources/ggml/src/ggml-sycl/fattn-common.hpp +1181 -0
- data/ext/sources/ggml/src/ggml-sycl/fattn-tile.cpp +59 -0
- data/ext/sources/ggml/src/ggml-sycl/fattn-tile.hpp +1246 -0
- data/ext/sources/ggml/src/ggml-sycl/fattn-vec.hpp +674 -0
- data/ext/sources/ggml/src/ggml-sycl/fattn.cpp +227 -0
- data/ext/sources/ggml/src/ggml-sycl/fattn.hpp +22 -0
- data/ext/sources/ggml/src/ggml-sycl/fill.cpp +55 -0
- data/ext/sources/ggml/src/ggml-sycl/fill.hpp +5 -0
- data/ext/sources/ggml/src/ggml-sycl/gated_delta_net.cpp +347 -0
- data/ext/sources/ggml/src/ggml-sycl/gated_delta_net.hpp +9 -0
- data/ext/sources/ggml/src/ggml-sycl/gemm.hpp +3 -0
- data/ext/sources/ggml/src/ggml-sycl/getrows.cpp +79 -3
- data/ext/sources/ggml/src/ggml-sycl/ggml-sycl.cpp +1134 -236
- data/ext/sources/ggml/src/ggml-sycl/im2col.cpp +353 -89
- data/ext/sources/ggml/src/ggml-sycl/im2col.hpp +5 -3
- data/ext/sources/ggml/src/ggml-sycl/mmvq.cpp +1344 -26
- data/ext/sources/ggml/src/ggml-sycl/mmvq.hpp +16 -0
- data/ext/sources/ggml/src/ggml-sycl/norm.cpp +65 -66
- data/ext/sources/ggml/src/ggml-sycl/outprod.cpp +3 -3
- data/ext/sources/ggml/src/ggml-sycl/pad.cpp +27 -27
- data/ext/sources/ggml/src/ggml-sycl/presets.hpp +3 -0
- data/ext/sources/ggml/src/ggml-sycl/quants.hpp +72 -1
- data/ext/sources/ggml/src/ggml-sycl/rope.cpp +450 -287
- data/ext/sources/ggml/src/ggml-sycl/rope.hpp +6 -0
- data/ext/sources/ggml/src/ggml-sycl/set_rows.cpp +7 -1
- data/ext/sources/ggml/src/ggml-sycl/softmax.cpp +6 -6
- data/ext/sources/ggml/src/ggml-sycl/solve_tri.cpp +172 -0
- data/ext/sources/ggml/src/ggml-sycl/solve_tri.hpp +8 -0
- data/ext/sources/ggml/src/ggml-sycl/ssm_conv.cpp +6 -1
- data/ext/sources/ggml/src/ggml-sycl/ssm_scan.cpp +156 -0
- data/ext/sources/ggml/src/ggml-sycl/ssm_scan.hpp +5 -0
- data/ext/sources/ggml/src/ggml-sycl/sycl_hw.cpp +62 -10
- data/ext/sources/ggml/src/ggml-sycl/sycl_hw.hpp +18 -6
- data/ext/sources/ggml/src/ggml-sycl/template-instances/fattn-tile-instance-dkq112-dv112.cpp +5 -0
- data/ext/sources/ggml/src/ggml-sycl/template-instances/fattn-tile-instance-dkq128-dv128.cpp +5 -0
- data/ext/sources/ggml/src/ggml-sycl/template-instances/fattn-tile-instance-dkq256-dv256.cpp +5 -0
- data/ext/sources/ggml/src/ggml-sycl/template-instances/fattn-tile-instance-dkq40-dv40.cpp +5 -0
- data/ext/sources/ggml/src/ggml-sycl/template-instances/fattn-tile-instance-dkq512-dv512.cpp +6 -0
- data/ext/sources/ggml/src/ggml-sycl/template-instances/fattn-tile-instance-dkq576-dv512.cpp +5 -0
- data/ext/sources/ggml/src/ggml-sycl/template-instances/fattn-tile-instance-dkq64-dv64.cpp +5 -0
- data/ext/sources/ggml/src/ggml-sycl/template-instances/fattn-tile-instance-dkq72-dv72.cpp +5 -0
- data/ext/sources/ggml/src/ggml-sycl/template-instances/fattn-tile-instance-dkq80-dv80.cpp +5 -0
- data/ext/sources/ggml/src/ggml-sycl/template-instances/fattn-tile-instance-dkq96-dv96.cpp +5 -0
- data/ext/sources/ggml/src/ggml-sycl/template-instances/fattn-vec-instance-f16-f16.cpp +8 -0
- data/ext/sources/ggml/src/ggml-sycl/template-instances/fattn-vec-instance-f16-q4_0.cpp +8 -0
- data/ext/sources/ggml/src/ggml-sycl/template-instances/fattn-vec-instance-f16-q4_1.cpp +8 -0
- data/ext/sources/ggml/src/ggml-sycl/template-instances/fattn-vec-instance-f16-q5_0.cpp +8 -0
- data/ext/sources/ggml/src/ggml-sycl/template-instances/fattn-vec-instance-f16-q5_1.cpp +8 -0
- data/ext/sources/ggml/src/ggml-sycl/template-instances/fattn-vec-instance-f16-q8_0.cpp +8 -0
- data/ext/sources/ggml/src/ggml-sycl/template-instances/fattn-vec-instance-q4_0-f16.cpp +8 -0
- data/ext/sources/ggml/src/ggml-sycl/template-instances/fattn-vec-instance-q4_0-q4_0.cpp +8 -0
- data/ext/sources/ggml/src/ggml-sycl/template-instances/fattn-vec-instance-q4_0-q4_1.cpp +8 -0
- data/ext/sources/ggml/src/ggml-sycl/template-instances/fattn-vec-instance-q4_0-q5_0.cpp +8 -0
- data/ext/sources/ggml/src/ggml-sycl/template-instances/fattn-vec-instance-q4_0-q5_1.cpp +8 -0
- data/ext/sources/ggml/src/ggml-sycl/template-instances/fattn-vec-instance-q4_0-q8_0.cpp +8 -0
- data/ext/sources/ggml/src/ggml-sycl/template-instances/fattn-vec-instance-q4_1-f16.cpp +8 -0
- data/ext/sources/ggml/src/ggml-sycl/template-instances/fattn-vec-instance-q4_1-q4_0.cpp +8 -0
- data/ext/sources/ggml/src/ggml-sycl/template-instances/fattn-vec-instance-q4_1-q4_1.cpp +8 -0
- data/ext/sources/ggml/src/ggml-sycl/template-instances/fattn-vec-instance-q4_1-q5_0.cpp +8 -0
- data/ext/sources/ggml/src/ggml-sycl/template-instances/fattn-vec-instance-q4_1-q5_1.cpp +8 -0
- data/ext/sources/ggml/src/ggml-sycl/template-instances/fattn-vec-instance-q4_1-q8_0.cpp +8 -0
- data/ext/sources/ggml/src/ggml-sycl/template-instances/fattn-vec-instance-q5_0-f16.cpp +8 -0
- data/ext/sources/ggml/src/ggml-sycl/template-instances/fattn-vec-instance-q5_0-q4_0.cpp +8 -0
- data/ext/sources/ggml/src/ggml-sycl/template-instances/fattn-vec-instance-q5_0-q4_1.cpp +8 -0
- data/ext/sources/ggml/src/ggml-sycl/template-instances/fattn-vec-instance-q5_0-q5_0.cpp +8 -0
- data/ext/sources/ggml/src/ggml-sycl/template-instances/fattn-vec-instance-q5_0-q5_1.cpp +8 -0
- data/ext/sources/ggml/src/ggml-sycl/template-instances/fattn-vec-instance-q5_0-q8_0.cpp +8 -0
- data/ext/sources/ggml/src/ggml-sycl/template-instances/fattn-vec-instance-q5_1-f16.cpp +8 -0
- data/ext/sources/ggml/src/ggml-sycl/template-instances/fattn-vec-instance-q5_1-q4_0.cpp +8 -0
- data/ext/sources/ggml/src/ggml-sycl/template-instances/fattn-vec-instance-q5_1-q4_1.cpp +8 -0
- data/ext/sources/ggml/src/ggml-sycl/template-instances/fattn-vec-instance-q5_1-q5_0.cpp +8 -0
- data/ext/sources/ggml/src/ggml-sycl/template-instances/fattn-vec-instance-q5_1-q5_1.cpp +8 -0
- data/ext/sources/ggml/src/ggml-sycl/template-instances/fattn-vec-instance-q5_1-q8_0.cpp +8 -0
- data/ext/sources/ggml/src/ggml-sycl/template-instances/fattn-vec-instance-q8_0-f16.cpp +8 -0
- data/ext/sources/ggml/src/ggml-sycl/template-instances/fattn-vec-instance-q8_0-q4_0.cpp +8 -0
- data/ext/sources/ggml/src/ggml-sycl/template-instances/fattn-vec-instance-q8_0-q4_1.cpp +8 -0
- data/ext/sources/ggml/src/ggml-sycl/template-instances/fattn-vec-instance-q8_0-q5_0.cpp +8 -0
- data/ext/sources/ggml/src/ggml-sycl/template-instances/fattn-vec-instance-q8_0-q5_1.cpp +8 -0
- data/ext/sources/ggml/src/ggml-sycl/template-instances/fattn-vec-instance-q8_0-q8_0.cpp +8 -0
- data/ext/sources/ggml/src/ggml-sycl/type.hpp +112 -0
- data/ext/sources/ggml/src/ggml-sycl/upscale.cpp +410 -0
- data/ext/sources/ggml/src/ggml-sycl/upscale.hpp +9 -0
- data/ext/sources/ggml/src/ggml-sycl/vecdotq.hpp +228 -53
- data/ext/sources/ggml/src/ggml-sycl/wkv.cpp +1 -1
- data/ext/sources/ggml/src/ggml-virtgpu/CMakeLists.txt +70 -0
- data/ext/sources/ggml/src/ggml-virtgpu/apir_cs_ggml-rpc-front.cpp +87 -0
- data/ext/sources/ggml/src/ggml-virtgpu/backend/CMakeLists.txt +21 -0
- data/ext/sources/ggml/src/ggml-virtgpu/backend/apir_cs_ggml-rpc-back.cpp +115 -0
- data/ext/sources/ggml/src/ggml-virtgpu/backend/backend-convert.h +13 -0
- data/ext/sources/ggml/src/ggml-virtgpu/backend/backend-dispatched-backend.cpp +102 -0
- data/ext/sources/ggml/src/ggml-virtgpu/backend/backend-dispatched-buffer-type.cpp +105 -0
- data/ext/sources/ggml/src/ggml-virtgpu/backend/backend-dispatched-buffer.cpp +179 -0
- data/ext/sources/ggml/src/ggml-virtgpu/backend/backend-dispatched-device.cpp +148 -0
- data/ext/sources/ggml/src/ggml-virtgpu/backend/backend-dispatched.cpp +51 -0
- data/ext/sources/ggml/src/ggml-virtgpu/backend/backend-dispatched.gen.h +73 -0
- data/ext/sources/ggml/src/ggml-virtgpu/backend/backend-dispatched.h +27 -0
- data/ext/sources/ggml/src/ggml-virtgpu/backend/backend-virgl-apir.h +32 -0
- data/ext/sources/ggml/src/ggml-virtgpu/backend/backend.cpp +144 -0
- data/ext/sources/ggml/src/ggml-virtgpu/backend/shared/api_remoting.h +95 -0
- data/ext/sources/ggml/src/ggml-virtgpu/backend/shared/apir_backend.gen.h +94 -0
- data/ext/sources/ggml/src/ggml-virtgpu/backend/shared/apir_backend.h +50 -0
- data/ext/sources/ggml/src/ggml-virtgpu/backend/shared/apir_cs.h +378 -0
- data/ext/sources/ggml/src/ggml-virtgpu/backend/shared/apir_cs_ggml.h +232 -0
- data/ext/sources/ggml/src/ggml-virtgpu/backend/shared/apir_cs_rpc.h +58 -0
- data/ext/sources/ggml/src/ggml-virtgpu/ggml-backend-buffer-type.cpp +81 -0
- data/ext/sources/ggml/src/ggml-virtgpu/ggml-backend-buffer.cpp +123 -0
- data/ext/sources/ggml/src/ggml-virtgpu/ggml-backend-device.cpp +160 -0
- data/ext/sources/ggml/src/ggml-virtgpu/ggml-backend-reg.cpp +213 -0
- data/ext/sources/ggml/src/ggml-virtgpu/ggml-backend.cpp +71 -0
- data/ext/sources/ggml/src/ggml-virtgpu/ggml-remoting.h +71 -0
- data/ext/sources/ggml/src/ggml-virtgpu/ggmlremoting_functions.yaml +166 -0
- data/ext/sources/ggml/src/ggml-virtgpu/include/apir_hw.h +9 -0
- data/ext/sources/ggml/src/ggml-virtgpu/virtgpu-apir.h +15 -0
- data/ext/sources/ggml/src/ggml-virtgpu/virtgpu-forward-backend.cpp +58 -0
- data/ext/sources/ggml/src/ggml-virtgpu/virtgpu-forward-buffer-type.cpp +110 -0
- data/ext/sources/ggml/src/ggml-virtgpu/virtgpu-forward-buffer.cpp +173 -0
- data/ext/sources/ggml/src/ggml-virtgpu/virtgpu-forward-device.cpp +192 -0
- data/ext/sources/ggml/src/ggml-virtgpu/virtgpu-forward-impl.h +36 -0
- data/ext/sources/ggml/src/ggml-virtgpu/virtgpu-forward.gen.h +53 -0
- data/ext/sources/ggml/src/ggml-virtgpu/virtgpu-shm.cpp +99 -0
- data/ext/sources/ggml/src/ggml-virtgpu/virtgpu-shm.h +23 -0
- data/ext/sources/ggml/src/ggml-virtgpu/virtgpu-utils.cpp +179 -0
- data/ext/sources/ggml/src/ggml-virtgpu/virtgpu-utils.h +86 -0
- data/ext/sources/ggml/src/ggml-virtgpu/virtgpu.cpp +545 -0
- data/ext/sources/ggml/src/ggml-virtgpu/virtgpu.h +115 -0
- data/ext/sources/ggml/src/ggml-vulkan/CMakeLists.txt +12 -1
- data/ext/sources/ggml/src/ggml-vulkan/ggml-vulkan.cpp +3250 -940
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/CMakeLists.txt +4 -0
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/acc.comp +16 -8
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/contig_copy.comp +6 -2
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/conv2d_mm.comp +146 -13
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/copy.comp +3 -1
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/copy_from_quant.comp +1 -1
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/copy_to_quant.comp +25 -1
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/dequant_funcs.glsl +88 -0
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/dequant_funcs_cm2.glsl +643 -1
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/dequant_nvfp4.comp +32 -0
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/dequant_q1_0.comp +29 -0
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/diag.comp +0 -1
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/dot_product_funcs.glsl +27 -0
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/elu.comp +27 -0
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/exp.comp +0 -1
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/feature-tests/coopmat2_decode_vector.comp +7 -0
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/flash_attn.comp +533 -180
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/flash_attn_base.glsl +113 -68
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/flash_attn_cm1.comp +412 -222
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/flash_attn_cm2.comp +222 -83
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/flash_attn_dequant.glsl +131 -0
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/flash_attn_mask_opt.comp +162 -0
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/flash_attn_mmq_funcs.glsl +203 -0
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/flash_attn_split_k_reduce.comp +9 -8
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/fwht.comp +115 -0
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/gated_delta_net.comp +189 -0
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/generic_binary_head.glsl +0 -1
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/glu_head.glsl +10 -1
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/glu_main.glsl +16 -6
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/im2col.comp +76 -54
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/im2col_3d.comp +0 -1
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/l2_norm.comp +12 -9
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/log.comp +0 -1
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/mul_mat_vec.comp +122 -27
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/mul_mat_vec_base.glsl +20 -17
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/mul_mat_vec_iface.glsl +6 -6
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/mul_mat_vec_q2_k.comp +1 -1
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/mul_mat_vec_q4_k.comp +1 -1
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/mul_mat_vec_q5_k.comp +1 -1
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/mul_mat_vecq.comp +1 -0
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/mul_mat_vecq_funcs.glsl +88 -55
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/mul_mm.comp +22 -20
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/mul_mm_cm2.comp +51 -14
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/mul_mm_funcs.glsl +159 -125
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/mul_mm_id_funcs.glsl +3 -1
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/mul_mmq.comp +5 -3
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/mul_mmq_funcs.glsl +8 -8
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/mul_mmq_shmem_types.glsl +24 -9
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/multi_add.comp +0 -1
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/rms_norm.comp +2 -3
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/rope_funcs.glsl +39 -63
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/rope_head.glsl +0 -1
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/rope_multi.comp +7 -4
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/rope_neox.comp +7 -4
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/rope_norm.comp +7 -4
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/rope_params.glsl +13 -7
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/rope_vision.comp +7 -4
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/sgn.comp +21 -0
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/snake.comp +49 -0
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/ssm_conv.comp +27 -11
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/tri.comp +0 -1
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/types.glsl +79 -2
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/vulkan-shaders-gen.cpp +193 -149
- data/ext/sources/ggml/src/ggml-webgpu/CMakeLists.txt +5 -2
- data/ext/sources/ggml/src/ggml-webgpu/ggml-webgpu-shader-lib.hpp +3221 -97
- data/ext/sources/ggml/src/ggml-webgpu/ggml-webgpu.cpp +3493 -1997
- data/ext/sources/ggml/src/ggml-webgpu/pre_wgsl.hpp +37 -7
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/add_id.wgsl +64 -0
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/argmax.wgsl +72 -0
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/argsort.wgsl +106 -0
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/argsort_merge.wgsl +134 -0
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/binary.wgsl +142 -0
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/common_decls.tmpl +115 -141
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/concat.wgsl +93 -0
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/conv2d.wgsl +165 -0
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/{cpy.tmpl.wgsl → cpy.wgsl} +25 -44
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/cumsum.wgsl +66 -0
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/flash_attn.wgsl +198 -230
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/flash_attn_quant_staging.tmpl +124 -0
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/flash_attn_tile.wgsl +397 -0
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/flash_attn_vec_blk.wgsl +101 -0
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/flash_attn_vec_reduce.wgsl +84 -0
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/flash_attn_vec_split.wgsl +619 -0
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/gated_delta_net.wgsl +149 -0
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/{get_rows.tmpl.wgsl → get_rows.wgsl} +234 -335
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/glu.wgsl +155 -0
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/im2col.wgsl +101 -0
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/mul_mat_decls.tmpl +871 -42
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/mul_mat_id.wgsl +195 -0
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/mul_mat_id_gather.wgsl +52 -0
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/mul_mat_id_vec.wgsl +154 -0
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/mul_mat_reg_tile.wgsl +149 -0
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/{mul_mat_subgroup_matrix.tmpl.wgsl → mul_mat_subgroup_matrix.wgsl} +36 -138
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/mul_mat_vec.wgsl +151 -0
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/mul_mat_vec_acc.tmpl +1432 -0
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/mul_mat_vec_q_acc.tmpl +303 -0
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/pad.wgsl +86 -0
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/quant_inner_loops.tmpl +21 -0
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/quantize_q8.wgsl +173 -0
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/repeat.wgsl +67 -0
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/rms_norm_mul.wgsl +152 -0
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/{rope.tmpl.wgsl → rope.wgsl} +71 -142
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/row_norm.wgsl +153 -0
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/{scale.tmpl.wgsl → scale.wgsl} +15 -40
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/set.wgsl +109 -0
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/set_rows.wgsl +39 -12
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/set_rows_quant.wgsl +224 -0
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/{soft_max.tmpl.wgsl → soft_max.wgsl} +106 -206
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/solve_tri.wgsl +121 -0
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/ssm_conv.wgsl +65 -0
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/ssm_scan.wgsl +193 -0
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/sum_rows.wgsl +55 -0
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/unary.wgsl +213 -0
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/upscale.wgsl +240 -0
- data/ext/sources/ggml/src/ggml-zdnn/ggml-zdnn.cpp +24 -15
- data/ext/sources/ggml/src/ggml-zendnn/CMakeLists.txt +31 -32
- data/ext/sources/ggml/src/ggml-zendnn/ggml-zendnn.cpp +253 -16
- data/ext/sources/ggml/src/ggml.c +268 -52
- data/ext/sources/ggml/src/gguf.cpp +377 -47
- data/ext/sources/include/parakeet.h +342 -0
- data/ext/sources/include/whisper.h +10 -0
- data/ext/sources/media/matmul.png +0 -0
- data/ext/sources/src/CMakeLists.txt +23 -0
- data/ext/sources/src/parakeet-arch.h +188 -0
- data/ext/sources/src/parakeet.cpp +3838 -0
- data/ext/sources/src/whisper.cpp +62 -40
- data/extsources.rb +26 -10
- data/lib/whisper/log_settable.rb +36 -0
- data/lib/whisper/model/uri.rb +13 -1
- data/lib/whisper/output.rb +74 -0
- data/sig/whisper.rbs +445 -55
- data/test/helper.rb +2 -0
- data/test/jfk_reader/jfk_reader.c +50 -7
- data/test/test_callback.rb +1 -0
- data/test/test_context_params.rb +82 -0
- data/test/test_package.rb +6 -5
- data/test/test_parakeet.rb +28 -0
- data/test/test_parakeet_callback.rb +107 -0
- data/test/test_parakeet_context.rb +116 -0
- data/test/test_parakeet_context_params.rb +24 -0
- data/test/test_parakeet_model.rb +21 -0
- data/test/test_parakeet_params.rb +78 -0
- data/test/test_parakeet_segment.rb +42 -0
- data/test/test_parakeet_token.rb +73 -0
- data/test/test_params.rb +2 -0
- data/test/test_token.rb +11 -0
- data/test/test_vad_context.rb +58 -8
- data/test/test_vad_segment.rb +1 -1
- data/test/test_whisper.rb +44 -6
- data/whispercpp.gemspec +2 -2
- metadata +426 -280
- data/ext/sources/bindings/javascript/CMakeLists.txt +0 -41
- data/ext/sources/bindings/javascript/emscripten.cpp +0 -93
- data/ext/sources/bindings/javascript/libwhisper.worker.js +0 -1
- data/ext/sources/bindings/javascript/package.json +0 -26
- data/ext/sources/bindings/javascript/whisper.js +0 -19
- data/ext/sources/examples/addon.node/CMakeLists.txt +0 -31
- data/ext/sources/examples/addon.node/__test__/whisper.spec.js +0 -133
- data/ext/sources/examples/addon.node/addon.cpp +0 -557
- data/ext/sources/examples/addon.node/index.js +0 -59
- data/ext/sources/examples/addon.node/package.json +0 -16
- data/ext/sources/examples/addon.node/vad-example.js +0 -132
- data/ext/sources/examples/bench.wasm/CMakeLists.txt +0 -49
- data/ext/sources/examples/bench.wasm/emscripten.cpp +0 -87
- data/ext/sources/examples/bench.wasm/index-tmpl.html +0 -285
- data/ext/sources/examples/coi-serviceworker.js +0 -146
- data/ext/sources/examples/command/CMakeLists.txt +0 -10
- data/ext/sources/examples/command/command.cpp +0 -802
- data/ext/sources/examples/command/commands.txt +0 -9
- data/ext/sources/examples/command.wasm/CMakeLists.txt +0 -50
- data/ext/sources/examples/command.wasm/emscripten.cpp +0 -327
- data/ext/sources/examples/command.wasm/index-tmpl.html +0 -415
- data/ext/sources/examples/generate-karaoke.sh +0 -57
- data/ext/sources/examples/helpers.js +0 -191
- data/ext/sources/examples/livestream.sh +0 -112
- data/ext/sources/examples/lsp/CMakeLists.txt +0 -10
- data/ext/sources/examples/lsp/lsp.cpp +0 -471
- data/ext/sources/examples/lsp/whisper.vim +0 -362
- data/ext/sources/examples/python/test_whisper_processor.py +0 -7
- data/ext/sources/examples/python/whisper_processor.py +0 -54
- data/ext/sources/examples/server/bench.js +0 -29
- data/ext/sources/examples/server.py +0 -120
- data/ext/sources/examples/stream/CMakeLists.txt +0 -10
- data/ext/sources/examples/stream/stream.cpp +0 -437
- data/ext/sources/examples/stream.wasm/CMakeLists.txt +0 -49
- data/ext/sources/examples/stream.wasm/emscripten.cpp +0 -216
- data/ext/sources/examples/stream.wasm/index-tmpl.html +0 -491
- data/ext/sources/examples/sycl/CMakeLists.txt +0 -9
- data/ext/sources/examples/sycl/build.sh +0 -22
- data/ext/sources/examples/sycl/ls-sycl-device.cpp +0 -11
- data/ext/sources/examples/sycl/run-whisper.sh +0 -17
- data/ext/sources/examples/talk-llama/CMakeLists.txt +0 -47
- data/ext/sources/examples/talk-llama/eleven-labs.py +0 -80
- data/ext/sources/examples/talk-llama/llama-adapter.cpp +0 -494
- data/ext/sources/examples/talk-llama/llama-adapter.h +0 -88
- data/ext/sources/examples/talk-llama/llama-arch.cpp +0 -2559
- data/ext/sources/examples/talk-llama/llama-arch.h +0 -586
- data/ext/sources/examples/talk-llama/llama-batch.cpp +0 -917
- data/ext/sources/examples/talk-llama/llama-batch.h +0 -173
- data/ext/sources/examples/talk-llama/llama-chat.cpp +0 -876
- data/ext/sources/examples/talk-llama/llama-chat.h +0 -70
- data/ext/sources/examples/talk-llama/llama-context.cpp +0 -3645
- data/ext/sources/examples/talk-llama/llama-context.h +0 -360
- data/ext/sources/examples/talk-llama/llama-cparams.cpp +0 -5
- data/ext/sources/examples/talk-llama/llama-cparams.h +0 -42
- data/ext/sources/examples/talk-llama/llama-grammar.cpp +0 -1464
- data/ext/sources/examples/talk-llama/llama-grammar.h +0 -194
- data/ext/sources/examples/talk-llama/llama-graph.cpp +0 -2282
- data/ext/sources/examples/talk-llama/llama-graph.h +0 -910
- data/ext/sources/examples/talk-llama/llama-hparams.cpp +0 -241
- data/ext/sources/examples/talk-llama/llama-hparams.h +0 -284
- data/ext/sources/examples/talk-llama/llama-impl.cpp +0 -171
- data/ext/sources/examples/talk-llama/llama-impl.h +0 -63
- data/ext/sources/examples/talk-llama/llama-io.cpp +0 -15
- data/ext/sources/examples/talk-llama/llama-io.h +0 -35
- data/ext/sources/examples/talk-llama/llama-kv-cache-iswa.cpp +0 -328
- data/ext/sources/examples/talk-llama/llama-kv-cache-iswa.h +0 -137
- data/ext/sources/examples/talk-llama/llama-kv-cache.cpp +0 -2100
- data/ext/sources/examples/talk-llama/llama-kv-cache.h +0 -390
- data/ext/sources/examples/talk-llama/llama-kv-cells.h +0 -533
- data/ext/sources/examples/talk-llama/llama-memory-hybrid.cpp +0 -268
- data/ext/sources/examples/talk-llama/llama-memory-hybrid.h +0 -139
- data/ext/sources/examples/talk-llama/llama-memory-recurrent.cpp +0 -1167
- data/ext/sources/examples/talk-llama/llama-memory-recurrent.h +0 -182
- data/ext/sources/examples/talk-llama/llama-memory.cpp +0 -59
- data/ext/sources/examples/talk-llama/llama-memory.h +0 -122
- data/ext/sources/examples/talk-llama/llama-mmap.cpp +0 -735
- data/ext/sources/examples/talk-llama/llama-mmap.h +0 -73
- data/ext/sources/examples/talk-llama/llama-model-loader.cpp +0 -1247
- data/ext/sources/examples/talk-llama/llama-model-loader.h +0 -176
- data/ext/sources/examples/talk-llama/llama-model-saver.cpp +0 -285
- data/ext/sources/examples/talk-llama/llama-model-saver.h +0 -37
- data/ext/sources/examples/talk-llama/llama-model.cpp +0 -8338
- data/ext/sources/examples/talk-llama/llama-model.h +0 -544
- data/ext/sources/examples/talk-llama/llama-quant.cpp +0 -1072
- data/ext/sources/examples/talk-llama/llama-quant.h +0 -1
- data/ext/sources/examples/talk-llama/llama-sampling.cpp +0 -3771
- data/ext/sources/examples/talk-llama/llama-sampling.h +0 -44
- data/ext/sources/examples/talk-llama/llama-vocab.cpp +0 -3900
- data/ext/sources/examples/talk-llama/llama-vocab.h +0 -182
- data/ext/sources/examples/talk-llama/llama.cpp +0 -1140
- data/ext/sources/examples/talk-llama/llama.h +0 -1540
- data/ext/sources/examples/talk-llama/models/afmoe.cpp +0 -191
- data/ext/sources/examples/talk-llama/models/apertus.cpp +0 -125
- data/ext/sources/examples/talk-llama/models/arcee.cpp +0 -135
- data/ext/sources/examples/talk-llama/models/arctic.cpp +0 -138
- data/ext/sources/examples/talk-llama/models/arwkv7.cpp +0 -86
- data/ext/sources/examples/talk-llama/models/baichuan.cpp +0 -122
- data/ext/sources/examples/talk-llama/models/bailingmoe.cpp +0 -144
- data/ext/sources/examples/talk-llama/models/bailingmoe2.cpp +0 -135
- data/ext/sources/examples/talk-llama/models/bert.cpp +0 -178
- data/ext/sources/examples/talk-llama/models/bitnet.cpp +0 -160
- data/ext/sources/examples/talk-llama/models/bloom.cpp +0 -101
- data/ext/sources/examples/talk-llama/models/chameleon.cpp +0 -178
- data/ext/sources/examples/talk-llama/models/chatglm.cpp +0 -132
- data/ext/sources/examples/talk-llama/models/codeshell.cpp +0 -111
- data/ext/sources/examples/talk-llama/models/cogvlm.cpp +0 -102
- data/ext/sources/examples/talk-llama/models/cohere2-iswa.cpp +0 -134
- data/ext/sources/examples/talk-llama/models/command-r.cpp +0 -122
- data/ext/sources/examples/talk-llama/models/dbrx.cpp +0 -123
- data/ext/sources/examples/talk-llama/models/deci.cpp +0 -135
- data/ext/sources/examples/talk-llama/models/deepseek.cpp +0 -144
- data/ext/sources/examples/talk-llama/models/deepseek2.cpp +0 -259
- data/ext/sources/examples/talk-llama/models/dots1.cpp +0 -134
- data/ext/sources/examples/talk-llama/models/dream.cpp +0 -105
- data/ext/sources/examples/talk-llama/models/ernie4-5-moe.cpp +0 -150
- data/ext/sources/examples/talk-llama/models/ernie4-5.cpp +0 -110
- data/ext/sources/examples/talk-llama/models/exaone.cpp +0 -114
- data/ext/sources/examples/talk-llama/models/exaone4.cpp +0 -123
- data/ext/sources/examples/talk-llama/models/falcon-h1.cpp +0 -113
- data/ext/sources/examples/talk-llama/models/falcon.cpp +0 -120
- data/ext/sources/examples/talk-llama/models/gemma-embedding.cpp +0 -116
- data/ext/sources/examples/talk-llama/models/gemma.cpp +0 -112
- data/ext/sources/examples/talk-llama/models/gemma2-iswa.cpp +0 -128
- data/ext/sources/examples/talk-llama/models/gemma3.cpp +0 -155
- data/ext/sources/examples/talk-llama/models/gemma3n-iswa.cpp +0 -384
- data/ext/sources/examples/talk-llama/models/glm4-moe.cpp +0 -170
- data/ext/sources/examples/talk-llama/models/glm4.cpp +0 -150
- data/ext/sources/examples/talk-llama/models/gpt2.cpp +0 -105
- data/ext/sources/examples/talk-llama/models/gptneox.cpp +0 -144
- data/ext/sources/examples/talk-llama/models/granite-hybrid.cpp +0 -196
- data/ext/sources/examples/talk-llama/models/granite.cpp +0 -211
- data/ext/sources/examples/talk-llama/models/graph-context-mamba.cpp +0 -283
- data/ext/sources/examples/talk-llama/models/grok.cpp +0 -159
- data/ext/sources/examples/talk-llama/models/grovemoe.cpp +0 -141
- data/ext/sources/examples/talk-llama/models/hunyuan-dense.cpp +0 -132
- data/ext/sources/examples/talk-llama/models/hunyuan-moe.cpp +0 -154
- data/ext/sources/examples/talk-llama/models/internlm2.cpp +0 -120
- data/ext/sources/examples/talk-llama/models/jais.cpp +0 -86
- data/ext/sources/examples/talk-llama/models/jamba.cpp +0 -106
- data/ext/sources/examples/talk-llama/models/lfm2.cpp +0 -175
- data/ext/sources/examples/talk-llama/models/llada-moe.cpp +0 -122
- data/ext/sources/examples/talk-llama/models/llada.cpp +0 -99
- data/ext/sources/examples/talk-llama/models/llama-iswa.cpp +0 -178
- data/ext/sources/examples/talk-llama/models/llama.cpp +0 -168
- data/ext/sources/examples/talk-llama/models/maincoder.cpp +0 -117
- data/ext/sources/examples/talk-llama/models/mamba.cpp +0 -55
- data/ext/sources/examples/talk-llama/models/mimo2-iswa.cpp +0 -123
- data/ext/sources/examples/talk-llama/models/minicpm3.cpp +0 -199
- data/ext/sources/examples/talk-llama/models/minimax-m2.cpp +0 -124
- data/ext/sources/examples/talk-llama/models/mistral3.cpp +0 -160
- data/ext/sources/examples/talk-llama/models/models.h +0 -569
- data/ext/sources/examples/talk-llama/models/modern-bert.cpp +0 -116
- data/ext/sources/examples/talk-llama/models/mpt.cpp +0 -126
- data/ext/sources/examples/talk-llama/models/nemotron-h.cpp +0 -150
- data/ext/sources/examples/talk-llama/models/nemotron.cpp +0 -122
- data/ext/sources/examples/talk-llama/models/neo-bert.cpp +0 -104
- data/ext/sources/examples/talk-llama/models/olmo.cpp +0 -121
- data/ext/sources/examples/talk-llama/models/olmo2.cpp +0 -150
- data/ext/sources/examples/talk-llama/models/olmoe.cpp +0 -124
- data/ext/sources/examples/talk-llama/models/openai-moe-iswa.cpp +0 -127
- data/ext/sources/examples/talk-llama/models/openelm.cpp +0 -124
- data/ext/sources/examples/talk-llama/models/orion.cpp +0 -123
- data/ext/sources/examples/talk-llama/models/pangu-embedded.cpp +0 -121
- data/ext/sources/examples/talk-llama/models/phi2.cpp +0 -121
- data/ext/sources/examples/talk-llama/models/phi3.cpp +0 -152
- data/ext/sources/examples/talk-llama/models/plamo.cpp +0 -110
- data/ext/sources/examples/talk-llama/models/plamo2.cpp +0 -316
- data/ext/sources/examples/talk-llama/models/plamo3.cpp +0 -128
- data/ext/sources/examples/talk-llama/models/plm.cpp +0 -168
- data/ext/sources/examples/talk-llama/models/qwen.cpp +0 -108
- data/ext/sources/examples/talk-llama/models/qwen2.cpp +0 -126
- data/ext/sources/examples/talk-llama/models/qwen2moe.cpp +0 -151
- data/ext/sources/examples/talk-llama/models/qwen2vl.cpp +0 -117
- data/ext/sources/examples/talk-llama/models/qwen3.cpp +0 -117
- data/ext/sources/examples/talk-llama/models/qwen3moe.cpp +0 -124
- data/ext/sources/examples/talk-llama/models/qwen3next.cpp +0 -873
- data/ext/sources/examples/talk-llama/models/qwen3vl-moe.cpp +0 -149
- data/ext/sources/examples/talk-llama/models/qwen3vl.cpp +0 -141
- data/ext/sources/examples/talk-llama/models/refact.cpp +0 -94
- data/ext/sources/examples/talk-llama/models/rnd1.cpp +0 -126
- data/ext/sources/examples/talk-llama/models/rwkv6-base.cpp +0 -162
- data/ext/sources/examples/talk-llama/models/rwkv6.cpp +0 -94
- data/ext/sources/examples/talk-llama/models/rwkv6qwen2.cpp +0 -86
- data/ext/sources/examples/talk-llama/models/rwkv7-base.cpp +0 -135
- data/ext/sources/examples/talk-llama/models/rwkv7.cpp +0 -90
- data/ext/sources/examples/talk-llama/models/seed-oss.cpp +0 -124
- data/ext/sources/examples/talk-llama/models/smallthinker.cpp +0 -126
- data/ext/sources/examples/talk-llama/models/smollm3.cpp +0 -128
- data/ext/sources/examples/talk-llama/models/stablelm.cpp +0 -146
- data/ext/sources/examples/talk-llama/models/starcoder.cpp +0 -100
- data/ext/sources/examples/talk-llama/models/starcoder2.cpp +0 -121
- data/ext/sources/examples/talk-llama/models/t5-dec.cpp +0 -166
- data/ext/sources/examples/talk-llama/models/t5-enc.cpp +0 -96
- data/ext/sources/examples/talk-llama/models/wavtokenizer-dec.cpp +0 -149
- data/ext/sources/examples/talk-llama/models/xverse.cpp +0 -108
- data/ext/sources/examples/talk-llama/prompts/talk-alpaca.txt +0 -23
- data/ext/sources/examples/talk-llama/speak +0 -40
- data/ext/sources/examples/talk-llama/speak.bat +0 -1
- data/ext/sources/examples/talk-llama/speak.ps1 +0 -14
- data/ext/sources/examples/talk-llama/talk-llama.cpp +0 -813
- data/ext/sources/examples/talk-llama/unicode-data.cpp +0 -7034
- data/ext/sources/examples/talk-llama/unicode-data.h +0 -20
- data/ext/sources/examples/talk-llama/unicode.cpp +0 -1147
- data/ext/sources/examples/talk-llama/unicode.h +0 -111
- data/ext/sources/examples/wchess/CMakeLists.txt +0 -10
- data/ext/sources/examples/wchess/libwchess/CMakeLists.txt +0 -19
- data/ext/sources/examples/wchess/libwchess/Chessboard.cpp +0 -803
- data/ext/sources/examples/wchess/libwchess/Chessboard.h +0 -33
- data/ext/sources/examples/wchess/libwchess/WChess.cpp +0 -193
- data/ext/sources/examples/wchess/libwchess/WChess.h +0 -63
- data/ext/sources/examples/wchess/libwchess/test-chessboard.cpp +0 -117
- data/ext/sources/examples/wchess/wchess.cmd/CMakeLists.txt +0 -8
- data/ext/sources/examples/wchess/wchess.cmd/wchess.cmd.cpp +0 -253
- data/ext/sources/examples/whisper.wasm/CMakeLists.txt +0 -50
- data/ext/sources/examples/whisper.wasm/emscripten.cpp +0 -118
- data/ext/sources/examples/whisper.wasm/index-tmpl.html +0 -659
- data/ext/sources/ggml/cmake/BuildTypes.cmake +0 -54
- data/ext/sources/ggml/src/ggml-cpu/llamafile/sgemm-ppc.h +0 -333
- data/ext/sources/ggml/src/ggml-cuda/template-instances/generate_cu_files.py +0 -99
- data/ext/sources/ggml/src/ggml-hexagon/htp/htp-dma.h +0 -157
- data/ext/sources/ggml/src/ggml-hexagon/htp/htp-msg.h +0 -165
- data/ext/sources/ggml/src/ggml-hexagon/htp/hvx-exp.c +0 -94
- data/ext/sources/ggml/src/ggml-hexagon/htp/hvx-inverse.c +0 -72
- data/ext/sources/ggml/src/ggml-hexagon/htp/hvx-sigmoid.c +0 -49
- data/ext/sources/ggml/src/ggml-hexagon/htp/hvx-utils.c +0 -1020
- data/ext/sources/ggml/src/ggml-hexagon/htp/ops-utils.h +0 -149
- data/ext/sources/ggml/src/ggml-hexagon/htp-utils.c +0 -454
- data/ext/sources/ggml/src/ggml-hexagon/htp-utils.h +0 -221
- data/ext/sources/ggml/src/ggml-hexagon/op-desc.h +0 -153
- data/ext/sources/ggml/src/ggml-opencl/kernels/embed_kernel.py +0 -26
- data/ext/sources/ggml/src/ggml-vulkan/vulkan-shaders/rte.glsl +0 -5
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/bin_op.tmpl.wgsl +0 -188
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/binary_head.tmpl +0 -45
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/embed_wgsl.py +0 -147
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/glu.tmpl.wgsl +0 -323
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/mul_mat.tmpl.wgsl +0 -907
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/mul_mat_reg_tile.tmpl.wgsl +0 -247
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/mul_mat_vec.tmpl.wgsl +0 -267
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/rms_norm.wgsl +0 -123
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/set_rows.tmpl.wgsl +0 -112
- data/ext/sources/ggml/src/ggml-webgpu/wgsl-shaders/unary_op.wgsl +0 -483
- data/ext/sources/tests/CMakeLists.txt +0 -112
- data/ext/sources/tests/earnings21/eval.mk +0 -58
- data/ext/sources/tests/earnings21/eval.py +0 -68
- data/ext/sources/tests/earnings21/normalizers/__init__.py +0 -2
- data/ext/sources/tests/earnings21/normalizers/basic.py +0 -80
- data/ext/sources/tests/earnings21/normalizers/english.json +0 -1741
- data/ext/sources/tests/earnings21/normalizers/english.py +0 -550
- data/ext/sources/tests/earnings21/requirements.txt +0 -6
- data/ext/sources/tests/en-0-ref.txt +0 -1
- data/ext/sources/tests/en-1-ref.txt +0 -1
- data/ext/sources/tests/en-2-ref.txt +0 -1
- data/ext/sources/tests/es-0-ref.txt +0 -1
- data/ext/sources/tests/librispeech/eval.mk +0 -39
- data/ext/sources/tests/librispeech/eval.py +0 -47
- data/ext/sources/tests/librispeech/normalizers/__init__.py +0 -2
- data/ext/sources/tests/librispeech/normalizers/basic.py +0 -80
- data/ext/sources/tests/librispeech/normalizers/english.json +0 -1741
- data/ext/sources/tests/librispeech/normalizers/english.py +0 -550
- data/ext/sources/tests/librispeech/requirements.txt +0 -6
- data/ext/sources/tests/run-tests.sh +0 -130
- data/ext/sources/tests/test-c.c +0 -3
- data/ext/sources/tests/test-vad-full.cpp +0 -56
- data/ext/sources/tests/test-vad.cpp +0 -83
- data/ext/sources/tests/test-whisper.js +0 -58
- data/lib/whisper/context.rb +0 -15
- data/lib/whisper/segment.rb +0 -58
|
@@ -0,0 +1,971 @@
|
|
|
1
|
+
#include "allreduce.cuh"
|
|
2
|
+
|
|
3
|
+
#if !defined(GGML_USE_HIP) && !defined(GGML_USE_MUSA)
|
|
4
|
+
|
|
5
|
+
#include "convert.cuh"
|
|
6
|
+
#include "ggml-impl.h"
|
|
7
|
+
|
|
8
|
+
#include <algorithm>
|
|
9
|
+
#include <cstdlib>
|
|
10
|
+
#include <cstring>
|
|
11
|
+
#include <limits>
|
|
12
|
+
|
|
13
|
+
// ---------------------------------------------------------------------------
|
|
14
|
+
// CUDA AllReduce for tensor-parallel inference across two GPUs.
|
|
15
|
+
//
|
|
16
|
+
// Provides an in-place sum reduction over matching tensors on two CUDA
|
|
17
|
+
// devices in the same process. Used by the tensor-split path alongside
|
|
18
|
+
// NCCL; targets setups without NVLink, where data is exchanged between the
|
|
19
|
+
// GPUs by staging it through pinned host memory over PCIe.
|
|
20
|
+
//
|
|
21
|
+
// Two reduction strategies are selected per call by tensor size:
|
|
22
|
+
//
|
|
23
|
+
// * Chunked kernel path (small reductions): a single CUDA kernel both
|
|
24
|
+
// stages data through pinned host memory and performs the local sum.
|
|
25
|
+
// Cross-GPU synchronization happens *inside the kernel* (busy-wait on
|
|
26
|
+
// a host-memory flag), which keeps launch overhead low for the
|
|
27
|
+
// latency-sensitive token-generation case.
|
|
28
|
+
//
|
|
29
|
+
// * Copy-engine path (large reductions): the transfer is split into
|
|
30
|
+
// D2H + H2D cudaMemcpyAsync chunks driven by the GPU's copy engine,
|
|
31
|
+
// followed by a small device-side add kernel. Cross-GPU
|
|
32
|
+
// synchronization happens *outside the kernel*, via CUDA events
|
|
33
|
+
// between streams. This keeps the compute engine free while large
|
|
34
|
+
// transfers are in flight, which matters for prefill-sized tensors.
|
|
35
|
+
// Reductions larger than the per-call inner cap are processed by an
|
|
36
|
+
// outer chunker that issues sequential inner calls.
|
|
37
|
+
// ---------------------------------------------------------------------------
|
|
38
|
+
|
|
39
|
+
// ---------------------------------------------------------------------------
|
|
40
|
+
// Cross-GPU signal mechanism
|
|
41
|
+
//
|
|
42
|
+
// One int per (slot, rank) pair in pinned host memory. Each AR call writes a
|
|
43
|
+
// strictly increasing token (= the AR call number) into its own arrival int.
|
|
44
|
+
// The peer spins until its read of the other's arrival int equals the token
|
|
45
|
+
// it expects for this call -- a mismatch means the peer hasn't arrived yet.
|
|
46
|
+
// Tokens never repeat over realistic call rates (32-bit int wraps in tens of
|
|
47
|
+
// days at thousands of ARs/sec), so arrival ints don't need to be reset
|
|
48
|
+
// between calls; we initialize once at pipeline init and let the values
|
|
49
|
+
// accumulate.
|
|
50
|
+
//
|
|
51
|
+
// There is exactly one writer (the owning GPU) and one reader (the peer), so
|
|
52
|
+
// we don't need atomics. A volatile store paired with __threadfence_system()
|
|
53
|
+
// provides the release ordering that makes the D2H writes visible system-wide
|
|
54
|
+
// before the arrival token is observed.
|
|
55
|
+
//
|
|
56
|
+
// atomicAdd_system() requires hostNativeAtomicSupported, which is unavailable
|
|
57
|
+
// on PCIe-attached consumer GPUs without NVLink, so the volatile path is the
|
|
58
|
+
// portable choice.
|
|
59
|
+
// ---------------------------------------------------------------------------
|
|
60
|
+
|
|
61
|
+
static __device__ __forceinline__ void ggml_cuda_ar_signal_set(int * p, int token) {
|
|
62
|
+
*(volatile int *)p = token;
|
|
63
|
+
}
|
|
64
|
+
static __device__ __forceinline__ int ggml_cuda_ar_signal_get(const int * p) {
|
|
65
|
+
return *(const volatile int *)p;
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
// Byte spacing between adjacent arrival ints. 64 bytes (one cache line)
|
|
69
|
+
// ensures each GPU/block's arrival slot lives on its own line, preventing
|
|
70
|
+
// false-sharing stalls on the polling GPU.
|
|
71
|
+
static constexpr size_t GGML_CUDA_AR_ARRIVAL_STRIDE = 64;
|
|
72
|
+
|
|
73
|
+
// Number of blocks the chunked kernel launches with. Each block stripes a
|
|
74
|
+
// disjoint slice of the data and synchronizes through its own arrival-token
|
|
75
|
+
// slot so multiple SMs can pump PCIe stores in parallel.
|
|
76
|
+
static constexpr int GGML_CUDA_AR_KERNEL_BLOCKS = 8;
|
|
77
|
+
|
|
78
|
+
// ---------------------------------------------------------------------------
|
|
79
|
+
// Chunked kernel AllReduce -- 2 GPUs, supports float, half, and bfloat16.
|
|
80
|
+
//
|
|
81
|
+
// Both GPUs run this kernel simultaneously on independent streams. sendbuf
|
|
82
|
+
// and recvbuf live in T_dst (the caller's tensor type); host_mine / host_other
|
|
83
|
+
// carry data in T_wire (the on-wire type, possibly narrower than T_dst -- e.g.
|
|
84
|
+
// T_dst=F32 with T_wire=BF16 halves the bytes pushed across PCIe). When
|
|
85
|
+
// T_dst == T_wire the casts below are no-ops.
|
|
86
|
+
//
|
|
87
|
+
// Each GPU runs three phases:
|
|
88
|
+
//
|
|
89
|
+
// Phase 1 (all threads): cast sendbuf (T_dst) -> T_wire and store as
|
|
90
|
+
// single-instruction-width vectors into host_mine.
|
|
91
|
+
// __threadfence_system() commits these writes to host
|
|
92
|
+
// memory.
|
|
93
|
+
// Phase 2 (thread 0): write token to arrival_mine; spin until
|
|
94
|
+
// arrival_other == token.
|
|
95
|
+
// Phase 3 (all threads): read T_wire vectors from host_other, cast
|
|
96
|
+
// each element to T_dst, and sum with the local
|
|
97
|
+
// sendbuf value (also rounded through T_wire so that
|
|
98
|
+
// both GPUs truncate identically -- this guarantees
|
|
99
|
+
// bit-equivalent results across the two devices).
|
|
100
|
+
//
|
|
101
|
+
// Multi-block: blocks stripe vectors across (gridDim.x * blockDim.x) global
|
|
102
|
+
// threads to keep multiple SMs issuing PCIe stores in parallel. Each block
|
|
103
|
+
// has its own arrival-token slot (offset by blockIdx.x * ARRIVAL_STRIDE);
|
|
104
|
+
// thread 0 of each block signals/spins on that slot independently of other
|
|
105
|
+
// blocks. Tail elements (the leftover < ELEMS_PER_VEC at the end) are
|
|
106
|
+
// handled only by block 0 to avoid cross-block writes to the same slots.
|
|
107
|
+
// ---------------------------------------------------------------------------
|
|
108
|
+
template <typename T_dst, typename T_wire>
|
|
109
|
+
static __global__ void ggml_cuda_ar_kernel(
|
|
110
|
+
const T_dst * sendbuf,
|
|
111
|
+
T_dst * recvbuf,
|
|
112
|
+
T_wire * __restrict__ host_mine,
|
|
113
|
+
const T_wire * __restrict__ host_other,
|
|
114
|
+
int count,
|
|
115
|
+
int * arrival_mine,
|
|
116
|
+
int * arrival_other,
|
|
117
|
+
int token) {
|
|
118
|
+
|
|
119
|
+
// Vector unit for the wire type, sized to the arch's widest single-instruction
|
|
120
|
+
// copy (16 B on Volta+). Each phase-1 iter writes one vector to host memory;
|
|
121
|
+
// each phase-3 iter reads one and produces ELEMS_PER_VEC sums.
|
|
122
|
+
constexpr int ELEMS_PER_VEC = ggml_cuda_get_max_cpy_bytes() / sizeof(T_wire);
|
|
123
|
+
constexpr int ARRIVAL_INTS = (int)(GGML_CUDA_AR_ARRIVAL_STRIDE / sizeof(int));
|
|
124
|
+
|
|
125
|
+
const int tid = threadIdx.x;
|
|
126
|
+
const int nt = blockDim.x;
|
|
127
|
+
const int bid = blockIdx.x;
|
|
128
|
+
const int gtid = bid * nt + tid;
|
|
129
|
+
const int gnt = gridDim.x * nt;
|
|
130
|
+
const int count_vec = count / ELEMS_PER_VEC;
|
|
131
|
+
const int tail = count_vec * ELEMS_PER_VEC;
|
|
132
|
+
|
|
133
|
+
// Phase 1: cast sendbuf (T_dst) -> host_mine (T_wire) and store as vectors.
|
|
134
|
+
{
|
|
135
|
+
for (int i = gtid; i < count_vec; i += gnt) {
|
|
136
|
+
const int off = i * ELEMS_PER_VEC;
|
|
137
|
+
T_wire wire[ELEMS_PER_VEC];
|
|
138
|
+
#pragma unroll
|
|
139
|
+
for (int k = 0; k < ELEMS_PER_VEC; ++k) {
|
|
140
|
+
wire[k] = ggml_cuda_cast<T_wire>(sendbuf[off + k]);
|
|
141
|
+
}
|
|
142
|
+
ggml_cuda_memcpy_1<sizeof(wire)>(&host_mine[off], wire);
|
|
143
|
+
}
|
|
144
|
+
if (bid == 0 && tid < count - tail) {
|
|
145
|
+
host_mine[tail + tid] = ggml_cuda_cast<T_wire>(sendbuf[tail + tid]);
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
|
|
149
|
+
// Commit this block's host writes before signalling.
|
|
150
|
+
__threadfence_system();
|
|
151
|
+
__syncthreads();
|
|
152
|
+
|
|
153
|
+
// Phase 2: thread 0 of each block signals on its own arrival slot, then
|
|
154
|
+
// spins for the matching slot from peer. Per-block tokens mean blocks
|
|
155
|
+
// proceed independently -- no inter-block barrier needed.
|
|
156
|
+
if (tid == 0) {
|
|
157
|
+
int * my_slot = arrival_mine + bid * ARRIVAL_INTS;
|
|
158
|
+
const int * other_slot = arrival_other + bid * ARRIVAL_INTS;
|
|
159
|
+
|
|
160
|
+
ggml_cuda_ar_signal_set(my_slot, token);
|
|
161
|
+
__threadfence_system(); // make our signal visible system-wide
|
|
162
|
+
|
|
163
|
+
while (ggml_cuda_ar_signal_get(other_slot) != token) {
|
|
164
|
+
#if __CUDA_ARCH__ >= GGML_CUDA_CC_VOLTA
|
|
165
|
+
__nanosleep(100);
|
|
166
|
+
#else
|
|
167
|
+
NO_DEVICE_CODE;
|
|
168
|
+
#endif // __CUDA_ARCH__ >= GGML_CUDA_CC_VOLTA
|
|
169
|
+
}
|
|
170
|
+
}
|
|
171
|
+
|
|
172
|
+
__syncthreads();
|
|
173
|
+
|
|
174
|
+
// Acquire peer's host_other writes (this block's stripe of them).
|
|
175
|
+
__threadfence_system();
|
|
176
|
+
|
|
177
|
+
// Phase 3: read peer's T_wire vector, cast both sides through T_wire for
|
|
178
|
+
// bit-equivalence, sum in T_dst precision, and write back to recvbuf.
|
|
179
|
+
{
|
|
180
|
+
for (int i = gtid; i < count_vec; i += gnt) {
|
|
181
|
+
const int off = i * ELEMS_PER_VEC;
|
|
182
|
+
T_wire wire[ELEMS_PER_VEC];
|
|
183
|
+
ggml_cuda_memcpy_1<sizeof(wire)>(wire, &host_other[off]);
|
|
184
|
+
#pragma unroll
|
|
185
|
+
for (int k = 0; k < ELEMS_PER_VEC; ++k) {
|
|
186
|
+
const T_wire d_low = ggml_cuda_cast<T_wire>(sendbuf[off + k]);
|
|
187
|
+
recvbuf[off + k] = ggml_cuda_cast<T_dst>(
|
|
188
|
+
ggml_cuda_cast<float>(d_low) + ggml_cuda_cast<float>(wire[k]));
|
|
189
|
+
}
|
|
190
|
+
}
|
|
191
|
+
if (bid == 0 && tid < count - tail) {
|
|
192
|
+
const T_wire d_low = ggml_cuda_cast<T_wire>(sendbuf[tail + tid]);
|
|
193
|
+
recvbuf[tail + tid] = ggml_cuda_cast<T_dst>(
|
|
194
|
+
ggml_cuda_cast<float>(d_low) +
|
|
195
|
+
ggml_cuda_cast<float>(host_other[tail + tid]));
|
|
196
|
+
}
|
|
197
|
+
}
|
|
198
|
+
}
|
|
199
|
+
|
|
200
|
+
// Combined load-convert-add kernel. The peer's contribution arrives as T_src
|
|
201
|
+
// (which may be a lower-precision type than T_dst when the BF16 round-trip is
|
|
202
|
+
// active). For bit-equivalence between the two GPUs, dst is first rounded
|
|
203
|
+
// through T_src's precision via ggml_cuda_cast -- peer already truncated its
|
|
204
|
+
// own value the same way before sending -- so both sides perform identical
|
|
205
|
+
// arithmetic. When T_dst == T_src the round-trip cast is a no-op.
|
|
206
|
+
template <typename T_dst, typename T_src>
|
|
207
|
+
static __global__ void ggml_cuda_ar_add_kernel(
|
|
208
|
+
T_dst * __restrict__ dst,
|
|
209
|
+
const T_src * __restrict__ src,
|
|
210
|
+
int count) {
|
|
211
|
+
const int tid = blockIdx.x * blockDim.x + threadIdx.x;
|
|
212
|
+
const int nt = gridDim.x * blockDim.x;
|
|
213
|
+
for (int i = tid; i < count; i += nt) {
|
|
214
|
+
const T_src d_low = ggml_cuda_cast<T_src>(dst[i]);
|
|
215
|
+
dst[i] = ggml_cuda_cast<T_dst>(
|
|
216
|
+
ggml_cuda_cast<float>(d_low) + ggml_cuda_cast<float>(src[i]));
|
|
217
|
+
}
|
|
218
|
+
}
|
|
219
|
+
|
|
220
|
+
// ---------------------------------------------------------------------------
|
|
221
|
+
// Pipeline structure
|
|
222
|
+
// ---------------------------------------------------------------------------
|
|
223
|
+
|
|
224
|
+
// Number of slots in the event / arrival ring. Two slots is sufficient:
|
|
225
|
+
// lockstep guarantees the two GPUs are at most one AR (or chunk) apart, so
|
|
226
|
+
// slot[N%2] is always safe to reuse -- peer has already consumed slot[N%2]
|
|
227
|
+
// from AR N-2 by the time we get to AR N. acquire_slot's
|
|
228
|
+
// cudaEventSynchronize on ev.ker for both devices makes that consumption
|
|
229
|
+
// explicit before we overwrite host_buf[slot] for the new AR.
|
|
230
|
+
static constexpr int GGML_CUDA_AR_POOL_SIZE = 2;
|
|
231
|
+
|
|
232
|
+
// Maximum chunk size (bytes per GPU) handled by one chunked kernel launch.
|
|
233
|
+
// Larger tensors are reduced by issuing multiple chunked launches.
|
|
234
|
+
static constexpr size_t GGML_CUDA_AR_MAX_BYTES = 1024 * 1024; // 1 MB
|
|
235
|
+
|
|
236
|
+
// Copy-engine path: largest tensor accepted on this path; sets host_large /
|
|
237
|
+
// dev_tmp allocation size.
|
|
238
|
+
static constexpr size_t GGML_CUDA_AR_COPY_MAX_BYTES = 32 * 1024 * 1024; // 32 MB
|
|
239
|
+
|
|
240
|
+
// AR wire size at which the copy-engine path takes over from the chunked-
|
|
241
|
+
// kernel path. Override via GGML_CUDA_AR_COPY_THRESHOLD.
|
|
242
|
+
static constexpr size_t GGML_CUDA_AR_COPY_THRESHOLD_DEFAULT = 1024 * 1024; // 1 MB
|
|
243
|
+
// Per-call CE chunk-size heuristic: chunk_bytes = clamp(nbytes / 4, MIN, MAX).
|
|
244
|
+
// The /4 keeps ~4 chunks in flight at any moment (good D2H/H2D overlap with
|
|
245
|
+
// the peer); the clamps cover the cases where nbytes/4 is too small (per-
|
|
246
|
+
// memcpy fixed cost dominates) or too large (chunk-level pipelining stalls).
|
|
247
|
+
// Env var GGML_CUDA_AR_COPY_CHUNK_BYTES can override with a fixed value.
|
|
248
|
+
static constexpr size_t GGML_CUDA_AR_COPY_CHUNK_BYTES_HEURISTIC_MIN = 512 * 1024; // 512 KB
|
|
249
|
+
static constexpr size_t GGML_CUDA_AR_COPY_CHUNK_BYTES_HEURISTIC_MAX = 2 * 1024 * 1024; // 2 MB
|
|
250
|
+
// Absolute floor that an env-var override is allowed to set; this caps the
|
|
251
|
+
// per-slot copy-event array. 256 KB -> up to 128 chunks per 32 MB tensor.
|
|
252
|
+
static constexpr size_t GGML_CUDA_AR_COPY_CHUNK_BYTES_MIN = 256 * 1024;
|
|
253
|
+
static constexpr int GGML_CUDA_AR_COPY_MAX_CHUNKS =
|
|
254
|
+
static_cast<int>((GGML_CUDA_AR_COPY_MAX_BYTES + GGML_CUDA_AR_COPY_CHUNK_BYTES_MIN - 1) /
|
|
255
|
+
GGML_CUDA_AR_COPY_CHUNK_BYTES_MIN);
|
|
256
|
+
|
|
257
|
+
struct ggml_cuda_ar_event_slot {
|
|
258
|
+
cudaEvent_t app = nullptr; // upstream computation complete
|
|
259
|
+
cudaEvent_t cpy[GGML_CUDA_AR_COPY_MAX_CHUNKS] = {}; // copy-engine D2H chunks complete
|
|
260
|
+
cudaEvent_t h2d = nullptr; // copy-engine H2Ds complete (handoff AR stream -> compute stream)
|
|
261
|
+
cudaEvent_t ker = nullptr; // AllReduce kernel complete
|
|
262
|
+
};
|
|
263
|
+
|
|
264
|
+
// Mapped pinned host allocation: cudaHostAlloc + cudaHostGetDevicePointer
|
|
265
|
+
// in one place, with the host handle preserved for cudaFreeHost. Used where
|
|
266
|
+
// the CPU never touches the buffer -- only the device reads/writes via the
|
|
267
|
+
// mapped device pointer. Required on systems where cudaDevAttrCanUseHost-
|
|
268
|
+
// PointerForRegisteredMem is 0 and the host pointer can't be used as a
|
|
269
|
+
// device pointer.
|
|
270
|
+
struct ggml_cuda_ar_host_mapping {
|
|
271
|
+
uint8_t * host = nullptr; // cudaFreeHost handle; also the H-side ptr for cudaMemcpyAsync
|
|
272
|
+
uint8_t * dev = nullptr; // device-side pointer for kernels / cudaMemset
|
|
273
|
+
|
|
274
|
+
cudaError_t alloc(size_t bytes) {
|
|
275
|
+
cudaError_t rc = cudaHostAlloc(reinterpret_cast<void **>(&host), bytes,
|
|
276
|
+
cudaHostAllocPortable | cudaHostAllocMapped);
|
|
277
|
+
if (rc != cudaSuccess) {
|
|
278
|
+
host = nullptr;
|
|
279
|
+
return rc;
|
|
280
|
+
}
|
|
281
|
+
rc = cudaHostGetDevicePointer(reinterpret_cast<void **>(&dev), host, 0);
|
|
282
|
+
if (rc != cudaSuccess) {
|
|
283
|
+
cudaFreeHost(host);
|
|
284
|
+
host = nullptr;
|
|
285
|
+
dev = nullptr;
|
|
286
|
+
}
|
|
287
|
+
return rc;
|
|
288
|
+
}
|
|
289
|
+
|
|
290
|
+
void free() {
|
|
291
|
+
if (host) {
|
|
292
|
+
cudaFreeHost(host);
|
|
293
|
+
host = nullptr;
|
|
294
|
+
dev = nullptr;
|
|
295
|
+
}
|
|
296
|
+
}
|
|
297
|
+
};
|
|
298
|
+
|
|
299
|
+
struct ggml_cuda_ar_pipeline {
|
|
300
|
+
int n_devices;
|
|
301
|
+
int devices[GGML_CUDA_MAX_DEVICES];
|
|
302
|
+
size_t buf_bytes; // bytes per device in host_buf[]
|
|
303
|
+
size_t copy_bytes; // bytes per device in host_large[] / dev_tmp[]
|
|
304
|
+
size_t copy_threshold;
|
|
305
|
+
size_t copy_chunk_bytes;
|
|
306
|
+
size_t bf16_threshold; // tensors >= this size (bytes) are reduced via FP32->BF16 round-trip; 0 disables
|
|
307
|
+
uint64_t call_count;
|
|
308
|
+
|
|
309
|
+
// Per-device resources.
|
|
310
|
+
ggml_cuda_ar_host_mapping host_buf[GGML_CUDA_MAX_DEVICES]; // pinned staging (chunked kernel)
|
|
311
|
+
ggml_cuda_ar_host_mapping host_large[GGML_CUDA_MAX_DEVICES]; // pinned staging (copy-engine)
|
|
312
|
+
char * dev_tmp[GGML_CUDA_MAX_DEVICES]; // device scratch for copy-engine path
|
|
313
|
+
cudaStream_t streams[GGML_CUDA_MAX_DEVICES]; // non-blocking
|
|
314
|
+
ggml_cuda_ar_event_slot ev_pool[GGML_CUDA_MAX_DEVICES][GGML_CUDA_AR_POOL_SIZE];
|
|
315
|
+
|
|
316
|
+
// Copy-engine: per-device "I finished reading my peer's host_large"
|
|
317
|
+
// event. Indexed by RECORDER device. Recorded same-device on streams[i]
|
|
318
|
+
// after stage 2's last H2D from host_large[peer]. Waited cross-device
|
|
319
|
+
// by peer's stage-1 stream before the next AR overwrites host_large[peer].
|
|
320
|
+
cudaEvent_t host_large_read_done[GGML_CUDA_MAX_DEVICES];
|
|
321
|
+
bool host_large_read_done_valid;
|
|
322
|
+
|
|
323
|
+
// Copy-engine: per-device "my add_kernel is done with dev_tmp" event.
|
|
324
|
+
// Recorded on the compute stream after each add_kernel; the AR stream
|
|
325
|
+
// waits on it before the next copy_impl's H2D overwrites dev_tmp. Lets us
|
|
326
|
+
// single-buffer dev_tmp despite add_kernel running on a separate stream.
|
|
327
|
+
cudaEvent_t dev_tmp_kernel_done[GGML_CUDA_MAX_DEVICES];
|
|
328
|
+
bool dev_tmp_kernel_done_valid;
|
|
329
|
+
|
|
330
|
+
// Arrival ring: ARRIVAL_STRIDE bytes between adjacent ints. Mapped pinned
|
|
331
|
+
// memory; CPU never reads/writes -- only the kernel and cudaMemset.
|
|
332
|
+
// Use ggml_cuda_ar_arrival_ptr() to index.
|
|
333
|
+
ggml_cuda_ar_host_mapping arrival;
|
|
334
|
+
};
|
|
335
|
+
|
|
336
|
+
// Base pointer for the (slot, rank) per-block token block. The kernel adds
|
|
337
|
+
// blockIdx.x * (ARRIVAL_STRIDE/sizeof(int)) internally to land on its own slot.
|
|
338
|
+
static int * ggml_cuda_ar_arrival_ptr(const ggml_cuda_ar_pipeline * p, int slot, int rank) {
|
|
339
|
+
const size_t offset = ((size_t)slot * p->n_devices + rank) *
|
|
340
|
+
GGML_CUDA_AR_KERNEL_BLOCKS * GGML_CUDA_AR_ARRIVAL_STRIDE;
|
|
341
|
+
return reinterpret_cast<int *>(p->arrival.dev + offset);
|
|
342
|
+
}
|
|
343
|
+
|
|
344
|
+
static uint64_t ggml_cuda_ar_env_u64(const char * name, uint64_t default_value) {
|
|
345
|
+
const char * value = getenv(name);
|
|
346
|
+
if (value == nullptr || value[0] == '\0') {
|
|
347
|
+
return default_value;
|
|
348
|
+
}
|
|
349
|
+
|
|
350
|
+
char * end = nullptr;
|
|
351
|
+
const unsigned long long parsed = strtoull(value, &end, 10);
|
|
352
|
+
return end != value ? (uint64_t) parsed : default_value;
|
|
353
|
+
}
|
|
354
|
+
|
|
355
|
+
struct ggml_cuda_ar_slot_info {
|
|
356
|
+
int slot;
|
|
357
|
+
int token;
|
|
358
|
+
};
|
|
359
|
+
|
|
360
|
+
static ggml_cuda_ar_slot_info ggml_cuda_ar_acquire_slot(ggml_cuda_ar_pipeline * p) {
|
|
361
|
+
const int slot = static_cast<int>(p->call_count % GGML_CUDA_AR_POOL_SIZE);
|
|
362
|
+
const bool pool_lapped = p->call_count >= GGML_CUDA_AR_POOL_SIZE;
|
|
363
|
+
p->call_count++;
|
|
364
|
+
|
|
365
|
+
if (pool_lapped) {
|
|
366
|
+
for (int i = 0; i < p->n_devices; ++i) {
|
|
367
|
+
ggml_cuda_set_device(p->devices[i]);
|
|
368
|
+
CUDA_CHECK(cudaEventSynchronize(p->ev_pool[i][slot].ker));
|
|
369
|
+
}
|
|
370
|
+
}
|
|
371
|
+
|
|
372
|
+
return { slot, (int) p->call_count };
|
|
373
|
+
}
|
|
374
|
+
|
|
375
|
+
// Per-AR copy-engine chunk size: env-var override if set, else heuristic
|
|
376
|
+
// (clamp(nbytes/4, HEURISTIC_MIN, HEURISTIC_MAX)).
|
|
377
|
+
static size_t ggml_cuda_ar_chunk_bytes(const ggml_cuda_ar_pipeline * p, size_t nbytes) {
|
|
378
|
+
if (p->copy_chunk_bytes > 0) {
|
|
379
|
+
return p->copy_chunk_bytes;
|
|
380
|
+
}
|
|
381
|
+
return std::min(GGML_CUDA_AR_COPY_CHUNK_BYTES_HEURISTIC_MAX,
|
|
382
|
+
std::max(GGML_CUDA_AR_COPY_CHUNK_BYTES_HEURISTIC_MIN, nbytes / 4));
|
|
383
|
+
}
|
|
384
|
+
|
|
385
|
+
static void ggml_cuda_ar_wait_for_compute(
|
|
386
|
+
ggml_cuda_ar_pipeline * p, ggml_backend_cuda_context * cuda_ctx, int rank, int slot) {
|
|
387
|
+
ggml_cuda_ar_event_slot & ev = p->ev_pool[rank][slot];
|
|
388
|
+
CUDA_CHECK(cudaEventRecord(ev.app, cuda_ctx->stream()));
|
|
389
|
+
CUDA_CHECK(cudaStreamWaitEvent(p->streams[rank], ev.app));
|
|
390
|
+
}
|
|
391
|
+
|
|
392
|
+
// ---------------------------------------------------------------------------
|
|
393
|
+
// Init / free
|
|
394
|
+
// ---------------------------------------------------------------------------
|
|
395
|
+
|
|
396
|
+
ggml_cuda_ar_pipeline * ggml_cuda_ar_pipeline_init(const int * devices, size_t n_devices) {
|
|
397
|
+
|
|
398
|
+
if (n_devices != 2) {
|
|
399
|
+
GGML_LOG_DEBUG("%s: internal AllReduce only supports n_devices=2 (got %zu); "
|
|
400
|
+
"falling back\n", __func__, n_devices);
|
|
401
|
+
return nullptr;
|
|
402
|
+
}
|
|
403
|
+
|
|
404
|
+
// The chunked kernel uses __nanosleep, which is sm70+ (Volta+).
|
|
405
|
+
for (size_t i = 0; i < n_devices; ++i) {
|
|
406
|
+
const int cc = ggml_cuda_info().devices[devices[i]].cc;
|
|
407
|
+
if (cc < GGML_CUDA_CC_VOLTA) {
|
|
408
|
+
GGML_LOG_DEBUG("%s: internal AllReduce requires compute capability >= %d "
|
|
409
|
+
"(device %d has cc=%d); falling back\n",
|
|
410
|
+
__func__, GGML_CUDA_CC_VOLTA, devices[i], cc);
|
|
411
|
+
return nullptr;
|
|
412
|
+
}
|
|
413
|
+
}
|
|
414
|
+
|
|
415
|
+
auto * p = new ggml_cuda_ar_pipeline{};
|
|
416
|
+
p->n_devices = n_devices;
|
|
417
|
+
p->copy_bytes = GGML_CUDA_AR_COPY_MAX_BYTES;
|
|
418
|
+
p->copy_threshold = ggml_cuda_ar_env_u64("GGML_CUDA_AR_COPY_THRESHOLD", GGML_CUDA_AR_COPY_THRESHOLD_DEFAULT);
|
|
419
|
+
// 0 = use the per-call heuristic (default). Non-zero env value forces a
|
|
420
|
+
// fixed chunk size for diagnostics, with a floor at COPY_CHUNK_BYTES_MIN.
|
|
421
|
+
p->copy_chunk_bytes = ggml_cuda_ar_env_u64("GGML_CUDA_AR_COPY_CHUNK_BYTES", 0);
|
|
422
|
+
if (p->copy_chunk_bytes > 0 && p->copy_chunk_bytes < GGML_CUDA_AR_COPY_CHUNK_BYTES_MIN) {
|
|
423
|
+
GGML_LOG_WARN("%s: GGML_CUDA_AR_COPY_CHUNK_BYTES=%zu below minimum %zu; clamping\n",
|
|
424
|
+
__func__, p->copy_chunk_bytes, GGML_CUDA_AR_COPY_CHUNK_BYTES_MIN);
|
|
425
|
+
p->copy_chunk_bytes = GGML_CUDA_AR_COPY_CHUNK_BYTES_MIN;
|
|
426
|
+
}
|
|
427
|
+
// Default 1: BF16 round-trip is always on for F32 inputs (any non-zero
|
|
428
|
+
// ne). Set GGML_CUDA_AR_BF16_THRESHOLD=0 to disable, or to a larger
|
|
429
|
+
// byte threshold to opt out for small tensors.
|
|
430
|
+
p->bf16_threshold = ggml_cuda_ar_env_u64("GGML_CUDA_AR_BF16_THRESHOLD", 1);
|
|
431
|
+
for (size_t i = 0; i < n_devices; ++i) {
|
|
432
|
+
p->devices[i] = devices[i];
|
|
433
|
+
}
|
|
434
|
+
|
|
435
|
+
// Per-device streams and event pools.
|
|
436
|
+
for (size_t i = 0; i < n_devices; ++i) {
|
|
437
|
+
ggml_cuda_set_device(p->devices[i]);
|
|
438
|
+
|
|
439
|
+
cudaStream_t stream = nullptr;
|
|
440
|
+
if (cudaStreamCreateWithFlags(&stream, cudaStreamNonBlocking) != cudaSuccess) {
|
|
441
|
+
GGML_LOG_ERROR("%s: cudaStreamCreateWithFlags failed for device %d\n",
|
|
442
|
+
__func__, p->devices[i]);
|
|
443
|
+
ggml_cuda_ar_pipeline_free(p);
|
|
444
|
+
return nullptr;
|
|
445
|
+
}
|
|
446
|
+
p->streams[i] = stream;
|
|
447
|
+
|
|
448
|
+
for (int s = 0; s < GGML_CUDA_AR_POOL_SIZE; ++s) {
|
|
449
|
+
bool ok =
|
|
450
|
+
cudaEventCreateWithFlags(&p->ev_pool[i][s].app, cudaEventDisableTiming) == cudaSuccess &&
|
|
451
|
+
cudaEventCreateWithFlags(&p->ev_pool[i][s].h2d, cudaEventDisableTiming) == cudaSuccess &&
|
|
452
|
+
cudaEventCreateWithFlags(&p->ev_pool[i][s].ker, cudaEventDisableTiming) == cudaSuccess;
|
|
453
|
+
for (int c = 0; ok && c < GGML_CUDA_AR_COPY_MAX_CHUNKS; ++c) {
|
|
454
|
+
ok = cudaEventCreateWithFlags(&p->ev_pool[i][s].cpy[c], cudaEventDisableTiming) == cudaSuccess;
|
|
455
|
+
}
|
|
456
|
+
if (!ok) {
|
|
457
|
+
GGML_LOG_ERROR("%s: cudaEventCreate failed for device %d slot %d\n",
|
|
458
|
+
__func__, p->devices[i], s);
|
|
459
|
+
ggml_cuda_ar_pipeline_free(p);
|
|
460
|
+
return nullptr;
|
|
461
|
+
}
|
|
462
|
+
}
|
|
463
|
+
|
|
464
|
+
if (cudaEventCreateWithFlags(&p->host_large_read_done[i], cudaEventDisableTiming) != cudaSuccess) {
|
|
465
|
+
GGML_LOG_ERROR("%s: cudaEventCreate for host_large_read_done failed for device %d\n",
|
|
466
|
+
__func__, p->devices[i]);
|
|
467
|
+
ggml_cuda_ar_pipeline_free(p);
|
|
468
|
+
return nullptr;
|
|
469
|
+
}
|
|
470
|
+
if (cudaEventCreateWithFlags(&p->dev_tmp_kernel_done[i], cudaEventDisableTiming) != cudaSuccess) {
|
|
471
|
+
GGML_LOG_ERROR("%s: cudaEventCreate for dev_tmp_kernel_done failed for device %d\n",
|
|
472
|
+
__func__, p->devices[i]);
|
|
473
|
+
ggml_cuda_ar_pipeline_free(p);
|
|
474
|
+
return nullptr;
|
|
475
|
+
}
|
|
476
|
+
}
|
|
477
|
+
|
|
478
|
+
// Arrival ring: cache-line padded so each GPU's int is on its own line.
|
|
479
|
+
const size_t arrival_bytes =
|
|
480
|
+
(size_t)GGML_CUDA_AR_POOL_SIZE * n_devices *
|
|
481
|
+
GGML_CUDA_AR_KERNEL_BLOCKS * GGML_CUDA_AR_ARRIVAL_STRIDE;
|
|
482
|
+
if (p->arrival.alloc(arrival_bytes) != cudaSuccess) {
|
|
483
|
+
GGML_LOG_ERROR("%s: alloc for arrival ring failed (%zu bytes)\n",
|
|
484
|
+
__func__, arrival_bytes);
|
|
485
|
+
ggml_cuda_ar_pipeline_free(p);
|
|
486
|
+
return nullptr;
|
|
487
|
+
}
|
|
488
|
+
ggml_cuda_set_device(p->devices[0]);
|
|
489
|
+
if (cudaMemset(p->arrival.dev, 0, arrival_bytes) != cudaSuccess) {
|
|
490
|
+
GGML_LOG_ERROR("%s: cudaMemset for arrival ring failed (%zu bytes)\n",
|
|
491
|
+
__func__, arrival_bytes);
|
|
492
|
+
ggml_cuda_ar_pipeline_free(p);
|
|
493
|
+
return nullptr;
|
|
494
|
+
}
|
|
495
|
+
|
|
496
|
+
// Per-device pinned staging buffers -- POOL_SIZE-deep ring so the chunked-
|
|
497
|
+
// kernel can write the next slot's data while the peer is still reading
|
|
498
|
+
// the previous slot's. Indexed by (slot * buf_bytes) at the call site.
|
|
499
|
+
p->buf_bytes = GGML_CUDA_AR_MAX_BYTES;
|
|
500
|
+
const size_t host_buf_total = (size_t) GGML_CUDA_AR_POOL_SIZE * p->buf_bytes;
|
|
501
|
+
for (size_t i = 0; i < n_devices; ++i) {
|
|
502
|
+
if (p->host_buf[i].alloc(host_buf_total) != cudaSuccess) {
|
|
503
|
+
GGML_LOG_ERROR("%s: alloc for staging failed (%zu bytes)\n",
|
|
504
|
+
__func__, host_buf_total);
|
|
505
|
+
ggml_cuda_ar_pipeline_free(p);
|
|
506
|
+
return nullptr;
|
|
507
|
+
}
|
|
508
|
+
}
|
|
509
|
+
|
|
510
|
+
// Copy-engine path: pinned host staging + device scratch, sized for the
|
|
511
|
+
// largest tensor we accept on this path (GGML_CUDA_AR_COPY_MAX_BYTES).
|
|
512
|
+
// dev_tmp is single-buffered; cross-AR safety is enforced by an explicit
|
|
513
|
+
// cross-stream wait in copy_impl on the prior AR's add_kernel-done event.
|
|
514
|
+
for (size_t i = 0; i < n_devices; ++i) {
|
|
515
|
+
ggml_cuda_set_device(p->devices[i]);
|
|
516
|
+
if (p->host_large[i].alloc(p->copy_bytes) != cudaSuccess) {
|
|
517
|
+
GGML_LOG_ERROR("%s: alloc for large staging failed (%zu bytes)\n",
|
|
518
|
+
__func__, p->copy_bytes);
|
|
519
|
+
ggml_cuda_ar_pipeline_free(p);
|
|
520
|
+
return nullptr;
|
|
521
|
+
}
|
|
522
|
+
if (cudaMalloc(reinterpret_cast<void **>(&p->dev_tmp[i]), p->copy_bytes) != cudaSuccess) {
|
|
523
|
+
GGML_LOG_ERROR("%s: cudaMalloc for copy scratch failed (%zu bytes) on device %d\n",
|
|
524
|
+
__func__, p->copy_bytes, p->devices[i]);
|
|
525
|
+
ggml_cuda_ar_pipeline_free(p);
|
|
526
|
+
return nullptr;
|
|
527
|
+
}
|
|
528
|
+
}
|
|
529
|
+
|
|
530
|
+
GGML_LOG_INFO("%s: initialized AllReduce pipeline: %zu GPUs, "
|
|
531
|
+
"%zu KB chunked kernel staging + %zu MB copy-engine staging per GPU\n",
|
|
532
|
+
__func__, n_devices, p->buf_bytes >> 10, p->copy_bytes >> 20);
|
|
533
|
+
|
|
534
|
+
return p;
|
|
535
|
+
}
|
|
536
|
+
|
|
537
|
+
void ggml_cuda_ar_pipeline_free(ggml_cuda_ar_pipeline * p) {
|
|
538
|
+
if (!p) {
|
|
539
|
+
return;
|
|
540
|
+
}
|
|
541
|
+
|
|
542
|
+
// Drain all in-flight kernels before tearing down resources.
|
|
543
|
+
for (int i = 0; i < p->n_devices; ++i) {
|
|
544
|
+
if (p->streams[i]) {
|
|
545
|
+
ggml_cuda_set_device(p->devices[i]);
|
|
546
|
+
cudaStreamSynchronize(p->streams[i]);
|
|
547
|
+
}
|
|
548
|
+
}
|
|
549
|
+
|
|
550
|
+
for (int i = 0; i < p->n_devices; ++i) {
|
|
551
|
+
p->host_buf[i].free();
|
|
552
|
+
p->host_large[i].free();
|
|
553
|
+
if (p->dev_tmp[i]) {
|
|
554
|
+
ggml_cuda_set_device(p->devices[i]);
|
|
555
|
+
cudaFree(p->dev_tmp[i]);
|
|
556
|
+
}
|
|
557
|
+
ggml_cuda_set_device(p->devices[i]);
|
|
558
|
+
for (int s = 0; s < GGML_CUDA_AR_POOL_SIZE; ++s) {
|
|
559
|
+
if (p->ev_pool[i][s].app) { cudaEventDestroy(p->ev_pool[i][s].app); }
|
|
560
|
+
for (int c = 0; c < GGML_CUDA_AR_COPY_MAX_CHUNKS; ++c) {
|
|
561
|
+
if (p->ev_pool[i][s].cpy[c]) { cudaEventDestroy(p->ev_pool[i][s].cpy[c]); }
|
|
562
|
+
}
|
|
563
|
+
if (p->ev_pool[i][s].h2d) { cudaEventDestroy(p->ev_pool[i][s].h2d); }
|
|
564
|
+
if (p->ev_pool[i][s].ker) { cudaEventDestroy(p->ev_pool[i][s].ker); }
|
|
565
|
+
}
|
|
566
|
+
if (p->host_large_read_done[i]) {
|
|
567
|
+
ggml_cuda_set_device(p->devices[i]);
|
|
568
|
+
cudaEventDestroy(p->host_large_read_done[i]);
|
|
569
|
+
}
|
|
570
|
+
if (p->dev_tmp_kernel_done[i]) {
|
|
571
|
+
ggml_cuda_set_device(p->devices[i]);
|
|
572
|
+
cudaEventDestroy(p->dev_tmp_kernel_done[i]);
|
|
573
|
+
}
|
|
574
|
+
if (p->streams[i]) {
|
|
575
|
+
ggml_cuda_set_device(p->devices[i]);
|
|
576
|
+
cudaStreamDestroy(p->streams[i]);
|
|
577
|
+
}
|
|
578
|
+
}
|
|
579
|
+
p->arrival.free();
|
|
580
|
+
delete p;
|
|
581
|
+
}
|
|
582
|
+
|
|
583
|
+
// ---------------------------------------------------------------------------
|
|
584
|
+
// Dispatch
|
|
585
|
+
// ---------------------------------------------------------------------------
|
|
586
|
+
|
|
587
|
+
// Asymmetric copy_impl: data sent over PCIe in T_src precision (one element of
|
|
588
|
+
// nbytes per ne element); accumulated locally into a T_dst buffer. When
|
|
589
|
+
// T_src == T_dst this is the original homogeneous reduction. When they differ
|
|
590
|
+
// (e.g. BF16 wire / F32 accumulator) the add kernel rounds dst through T_src
|
|
591
|
+
// for bit-equivalence between GPUs and we skip the otherwise-needed
|
|
592
|
+
// post-conversion entirely.
|
|
593
|
+
template <typename T_src, typename T_dst>
|
|
594
|
+
static bool ggml_cuda_ar_allreduce_copy_impl(
|
|
595
|
+
ggml_cuda_ar_pipeline * p,
|
|
596
|
+
ggml_backend_t * backends,
|
|
597
|
+
T_src * const src_buf[GGML_CUDA_MAX_DEVICES],
|
|
598
|
+
T_dst * const dst_buf[GGML_CUDA_MAX_DEVICES],
|
|
599
|
+
const bool compute[GGML_CUDA_MAX_DEVICES],
|
|
600
|
+
int64_t ne,
|
|
601
|
+
size_t nbytes) {
|
|
602
|
+
GGML_ASSERT(p->n_devices == 2);
|
|
603
|
+
GGML_ASSERT(nbytes <= p->copy_bytes);
|
|
604
|
+
GGML_ASSERT(ne <= std::numeric_limits<int>::max());
|
|
605
|
+
|
|
606
|
+
const size_t chunk_bytes = ggml_cuda_ar_chunk_bytes(p, nbytes);
|
|
607
|
+
GGML_ASSERT(chunk_bytes > 0);
|
|
608
|
+
|
|
609
|
+
const int slot = ggml_cuda_ar_acquire_slot(p).slot;
|
|
610
|
+
const size_t copy_chunks = (nbytes + chunk_bytes - 1) / chunk_bytes;
|
|
611
|
+
GGML_ASSERT(copy_chunks <= GGML_CUDA_AR_COPY_MAX_CHUNKS);
|
|
612
|
+
|
|
613
|
+
ggml_backend_cuda_context * cuda_ctx[2] = {};
|
|
614
|
+
|
|
615
|
+
// Stage 1: both GPUs copy their local contribution to pinned host memory.
|
|
616
|
+
for (int i = 0; i < 2; ++i) {
|
|
617
|
+
ggml_cuda_set_device(p->devices[i]);
|
|
618
|
+
cuda_ctx[i] = static_cast<ggml_backend_cuda_context *>(backends[i]->context);
|
|
619
|
+
GGML_ASSERT(cuda_ctx[i]->device == p->devices[i]);
|
|
620
|
+
|
|
621
|
+
ggml_cuda_ar_wait_for_compute(p, cuda_ctx[i], i, slot);
|
|
622
|
+
|
|
623
|
+
// Wait for peer's H2D from our host_large[i] (recorded in the
|
|
624
|
+
// previous AR's stage 2) to complete before we overwrite host_large[i].
|
|
625
|
+
// host_large_read_done[peer] = peer finished reading host_large[i].
|
|
626
|
+
// No-op on the first AR -- no prior record exists.
|
|
627
|
+
if (p->host_large_read_done_valid) {
|
|
628
|
+
const int peer = 1 - i;
|
|
629
|
+
CUDA_CHECK(cudaStreamWaitEvent(p->streams[i], p->host_large_read_done[peer]));
|
|
630
|
+
}
|
|
631
|
+
|
|
632
|
+
if (!compute[i]) {
|
|
633
|
+
CUDA_CHECK(cudaMemsetAsync(src_buf[i], 0, nbytes, p->streams[i]));
|
|
634
|
+
}
|
|
635
|
+
|
|
636
|
+
for (size_t c = 0; c < copy_chunks; ++c) {
|
|
637
|
+
const size_t offset = c * chunk_bytes;
|
|
638
|
+
const size_t this_bytes = (nbytes - offset) < chunk_bytes ?
|
|
639
|
+
(nbytes - offset) : chunk_bytes;
|
|
640
|
+
|
|
641
|
+
CUDA_CHECK(cudaMemcpyAsync(
|
|
642
|
+
p->host_large[i].host + offset, reinterpret_cast<char *>(src_buf[i]) + offset, this_bytes,
|
|
643
|
+
cudaMemcpyDeviceToHost, p->streams[i]));
|
|
644
|
+
CUDA_CHECK(cudaEventRecord(p->ev_pool[i][slot].cpy[c], p->streams[i]));
|
|
645
|
+
}
|
|
646
|
+
}
|
|
647
|
+
|
|
648
|
+
// Stage 2: each GPU waits for each peer D2H chunk, pulls that chunk back to
|
|
649
|
+
// local device scratch (dev_tmp), then performs one device-local add over
|
|
650
|
+
// the assembled peer tensor. The H2Ds run on the AR stream (copy engine)
|
|
651
|
+
// and the add_kernel runs on the caller's compute stream, so the AR stream
|
|
652
|
+
// stays pure-copy and avoids an in-stream copy->compute engine switch every
|
|
653
|
+
// AR. dev_tmp is single-buffered: the AR stream waits cross-stream on the
|
|
654
|
+
// prior AR's add_kernel-done event before overwriting it.
|
|
655
|
+
for (int i = 0; i < 2; ++i) {
|
|
656
|
+
const int peer = 1 - i;
|
|
657
|
+
ggml_cuda_set_device(p->devices[i]);
|
|
658
|
+
|
|
659
|
+
// Wait for the previous AR's add_kernel (on the compute stream) to
|
|
660
|
+
// finish reading dev_tmp before our H2D overwrites it. No-op on the
|
|
661
|
+
// first copy_impl call.
|
|
662
|
+
if (p->dev_tmp_kernel_done_valid) {
|
|
663
|
+
CUDA_CHECK(cudaStreamWaitEvent(p->streams[i], p->dev_tmp_kernel_done[i]));
|
|
664
|
+
}
|
|
665
|
+
|
|
666
|
+
for (size_t c = 0; c < copy_chunks; ++c) {
|
|
667
|
+
const size_t offset = c * chunk_bytes;
|
|
668
|
+
const size_t this_bytes = (nbytes - offset) < chunk_bytes ?
|
|
669
|
+
(nbytes - offset) : chunk_bytes;
|
|
670
|
+
|
|
671
|
+
CUDA_CHECK(cudaStreamWaitEvent(p->streams[i], p->ev_pool[peer][slot].cpy[c]));
|
|
672
|
+
CUDA_CHECK(cudaMemcpyAsync(
|
|
673
|
+
p->dev_tmp[i] + offset, p->host_large[peer].host + offset, this_bytes,
|
|
674
|
+
cudaMemcpyHostToDevice, p->streams[i]));
|
|
675
|
+
}
|
|
676
|
+
|
|
677
|
+
// Mark our reads of host_large[peer] complete so peer's next AR can
|
|
678
|
+
// safely overwrite it.
|
|
679
|
+
CUDA_CHECK(cudaEventRecord(p->host_large_read_done[i], p->streams[i]));
|
|
680
|
+
|
|
681
|
+
// Hand off from AR stream (copy engine) to compute stream: compute
|
|
682
|
+
// stream waits for all H2Ds to finish, then runs the add_kernel.
|
|
683
|
+
CUDA_CHECK(cudaEventRecord(p->ev_pool[i][slot].h2d, p->streams[i]));
|
|
684
|
+
CUDA_CHECK(cudaStreamWaitEvent(cuda_ctx[i]->stream(), p->ev_pool[i][slot].h2d));
|
|
685
|
+
|
|
686
|
+
const int block_size = 256;
|
|
687
|
+
int n_blocks = (int) ((ne + block_size - 1) / block_size);
|
|
688
|
+
if (n_blocks > 1024) {
|
|
689
|
+
n_blocks = 1024;
|
|
690
|
+
}
|
|
691
|
+
ggml_cuda_ar_add_kernel<T_dst, T_src><<<n_blocks, block_size, 0, cuda_ctx[i]->stream()>>>(
|
|
692
|
+
dst_buf[i],
|
|
693
|
+
reinterpret_cast<const T_src *>(p->dev_tmp[i]),
|
|
694
|
+
(int) ne);
|
|
695
|
+
CUDA_CHECK(cudaGetLastError());
|
|
696
|
+
|
|
697
|
+
// Record dev_tmp-released on the compute stream so the next copy_impl
|
|
698
|
+
// can wait for the kernel to finish before overwriting dev_tmp. Also
|
|
699
|
+
// record AR-done as ev.ker for acquire_slot's pool-wraparound sync.
|
|
700
|
+
CUDA_CHECK(cudaEventRecord(p->dev_tmp_kernel_done[i], cuda_ctx[i]->stream()));
|
|
701
|
+
CUDA_CHECK(cudaEventRecord(p->ev_pool[i][slot].ker, cuda_ctx[i]->stream()));
|
|
702
|
+
}
|
|
703
|
+
p->host_large_read_done_valid = true;
|
|
704
|
+
p->dev_tmp_kernel_done_valid = true;
|
|
705
|
+
|
|
706
|
+
return true;
|
|
707
|
+
}
|
|
708
|
+
|
|
709
|
+
// Outer-level chunker: copy_impl handles up to copy_bytes per call (limited by
|
|
710
|
+
// the host_large / dev_tmp allocation size). When the full AR exceeds that,
|
|
711
|
+
// slice the tensor into copy_bytes-sized pieces and call copy_impl repeatedly.
|
|
712
|
+
// Each slice goes through its own stage 1 -> stage 2 cycle and acquires its own
|
|
713
|
+
// slot, so cross-AR fences and pool wraparound work the same way as for any
|
|
714
|
+
// other sequence of small ARs.
|
|
715
|
+
template <typename T_src, typename T_dst>
|
|
716
|
+
static bool ggml_cuda_ar_allreduce_copy_outer(
|
|
717
|
+
ggml_cuda_ar_pipeline * p,
|
|
718
|
+
ggml_backend_t * backends,
|
|
719
|
+
T_src * const src_buf[GGML_CUDA_MAX_DEVICES],
|
|
720
|
+
T_dst * const dst_buf[GGML_CUDA_MAX_DEVICES],
|
|
721
|
+
const bool compute[GGML_CUDA_MAX_DEVICES],
|
|
722
|
+
int64_t ne) {
|
|
723
|
+
const int64_t outer_max_elems = (int64_t) (p->copy_bytes / sizeof(T_src));
|
|
724
|
+
GGML_ASSERT(outer_max_elems > 0);
|
|
725
|
+
|
|
726
|
+
bool ok = true;
|
|
727
|
+
for (int64_t outer_start = 0; outer_start < ne && ok; outer_start += outer_max_elems) {
|
|
728
|
+
const int64_t outer_ne = std::min(outer_max_elems, ne - outer_start);
|
|
729
|
+
const size_t outer_nbytes = (size_t) outer_ne * sizeof(T_src);
|
|
730
|
+
|
|
731
|
+
T_src * src[GGML_CUDA_MAX_DEVICES] = {};
|
|
732
|
+
T_dst * dst[GGML_CUDA_MAX_DEVICES] = {};
|
|
733
|
+
for (int i = 0; i < p->n_devices; ++i) {
|
|
734
|
+
src[i] = src_buf[i] + outer_start;
|
|
735
|
+
dst[i] = dst_buf[i] + outer_start;
|
|
736
|
+
}
|
|
737
|
+
ok = ggml_cuda_ar_allreduce_copy_impl<T_src, T_dst>(
|
|
738
|
+
p, backends, src, dst, compute, outer_ne, outer_nbytes);
|
|
739
|
+
}
|
|
740
|
+
return ok;
|
|
741
|
+
}
|
|
742
|
+
|
|
743
|
+
bool ggml_cuda_ar_allreduce(
|
|
744
|
+
ggml_cuda_ar_pipeline * p,
|
|
745
|
+
ggml_backend_t * backends,
|
|
746
|
+
ggml_tensor ** tensors) {
|
|
747
|
+
GGML_ASSERT(p != nullptr);
|
|
748
|
+
|
|
749
|
+
const int n = p->n_devices;
|
|
750
|
+
GGML_ASSERT(n == 2);
|
|
751
|
+
|
|
752
|
+
const ggml_type input_type = tensors[0]->type;
|
|
753
|
+
GGML_ASSERT(input_type == GGML_TYPE_F32 || input_type == GGML_TYPE_F16 || input_type == GGML_TYPE_BF16);
|
|
754
|
+
|
|
755
|
+
const int64_t ne = ggml_nelements(tensors[0]);
|
|
756
|
+
GGML_ASSERT(ne > 0);
|
|
757
|
+
|
|
758
|
+
const size_t input_nbytes = ggml_nbytes(tensors[0]);
|
|
759
|
+
|
|
760
|
+
// BF16 round-trip: F32 inputs >= bf16_threshold are converted to BF16 for
|
|
761
|
+
// the reduction (chunked or copy-engine), halving on-wire bytes. Matches
|
|
762
|
+
// NCCL's behaviour. The pre-conversion zeroes inactive shards so the
|
|
763
|
+
// inner paths see them as already-prepared compute tensors.
|
|
764
|
+
const bool use_bf16 =
|
|
765
|
+
input_type == GGML_TYPE_F32 &&
|
|
766
|
+
p->bf16_threshold > 0 &&
|
|
767
|
+
input_nbytes >= p->bf16_threshold;
|
|
768
|
+
|
|
769
|
+
const ggml_type kernel_type = use_bf16 ? GGML_TYPE_BF16 : input_type;
|
|
770
|
+
const size_t type_size = ggml_type_size(kernel_type);
|
|
771
|
+
GGML_ASSERT(p->buf_bytes >= type_size);
|
|
772
|
+
const size_t nbytes = (size_t) ne * type_size;
|
|
773
|
+
|
|
774
|
+
bool compute_flag[GGML_CUDA_MAX_DEVICES] = {};
|
|
775
|
+
for (int i = 0; i < n; ++i) {
|
|
776
|
+
compute_flag[i] = (tensors[i]->flags & GGML_TENSOR_FLAG_COMPUTE) != 0;
|
|
777
|
+
}
|
|
778
|
+
|
|
779
|
+
// Decide between copy-engine and chunked kernel paths based on the working
|
|
780
|
+
// type's actual byte count. No upper bound: copy_outer slices reductions
|
|
781
|
+
// larger than copy_bytes into copy_bytes-sized pieces.
|
|
782
|
+
const bool use_copy_engine =
|
|
783
|
+
p->copy_threshold > 0 &&
|
|
784
|
+
nbytes >= p->copy_threshold;
|
|
785
|
+
|
|
786
|
+
// BF16 inactive-shard zeroing: when use_bf16 is on, the combined kernel
|
|
787
|
+
// (chunked kernel path) and the combined add kernel (copy_engine path)
|
|
788
|
+
// both accumulate into the F32 tensor data directly, so an inactive
|
|
789
|
+
// shard's accumulator must start at zero.
|
|
790
|
+
if (use_bf16) {
|
|
791
|
+
for (int i = 0; i < n; ++i) {
|
|
792
|
+
if (!compute_flag[i]) {
|
|
793
|
+
auto * cuda_ctx = static_cast<ggml_backend_cuda_context *>(backends[i]->context);
|
|
794
|
+
GGML_ASSERT(cuda_ctx->device == p->devices[i]);
|
|
795
|
+
ggml_cuda_set_device(p->devices[i]);
|
|
796
|
+
CUDA_CHECK(cudaMemsetAsync(tensors[i]->data, 0, (size_t) ne * sizeof(float), cuda_ctx->stream()));
|
|
797
|
+
}
|
|
798
|
+
}
|
|
799
|
+
}
|
|
800
|
+
|
|
801
|
+
// Pre-convert F32 -> BF16 into bf16_tmp ONLY for the copy_engine + use_bf16
|
|
802
|
+
// path; the chunked kernel path's combined kernel does the conversion
|
|
803
|
+
// inline as it writes to host_buf.
|
|
804
|
+
ggml_cuda_pool_alloc<nv_bfloat16> bf16_tmp[GGML_CUDA_MAX_DEVICES];
|
|
805
|
+
void * copy_src_ptr[GGML_CUDA_MAX_DEVICES] = {};
|
|
806
|
+
|
|
807
|
+
if (use_copy_engine && use_bf16) {
|
|
808
|
+
to_bf16_cuda_t to_bf16 = ggml_get_to_bf16_cuda(GGML_TYPE_F32);
|
|
809
|
+
for (int i = 0; i < n; ++i) {
|
|
810
|
+
auto * cuda_ctx = static_cast<ggml_backend_cuda_context *>(backends[i]->context);
|
|
811
|
+
GGML_ASSERT(cuda_ctx->device == p->devices[i]);
|
|
812
|
+
bf16_tmp[i].pool = &cuda_ctx->pool();
|
|
813
|
+
bf16_tmp[i].alloc(ne);
|
|
814
|
+
ggml_cuda_set_device(p->devices[i]);
|
|
815
|
+
if (compute_flag[i]) {
|
|
816
|
+
to_bf16(tensors[i]->data, bf16_tmp[i].get(), ne, cuda_ctx->stream());
|
|
817
|
+
CUDA_CHECK(cudaGetLastError());
|
|
818
|
+
} else {
|
|
819
|
+
CUDA_CHECK(cudaMemsetAsync(bf16_tmp[i].get(), 0, nbytes, cuda_ctx->stream()));
|
|
820
|
+
}
|
|
821
|
+
copy_src_ptr[i] = bf16_tmp[i].get();
|
|
822
|
+
}
|
|
823
|
+
}
|
|
824
|
+
|
|
825
|
+
bool ok = true;
|
|
826
|
+
if (use_copy_engine) {
|
|
827
|
+
// After up-front BF16 conversion, the tmp buffers already hold the
|
|
828
|
+
// (possibly zeroed-for-inactive) data, so the inner path can treat
|
|
829
|
+
// every shard as compute.
|
|
830
|
+
bool inner_compute[GGML_CUDA_MAX_DEVICES];
|
|
831
|
+
for (int i = 0; i < n; ++i) {
|
|
832
|
+
inner_compute[i] = use_bf16 ? true : compute_flag[i];
|
|
833
|
+
}
|
|
834
|
+
|
|
835
|
+
// Dispatch into copy_impl with explicit src/dst types. When use_bf16
|
|
836
|
+
// is on, the wire type is BF16 (src = bf16_tmp) and the accumulator
|
|
837
|
+
// is F32 (dst = tensors[i]->data); the combined add kernel rounds dst
|
|
838
|
+
// through BF16 for bit-equivalence and writes F32 directly, so no
|
|
839
|
+
// post-conversion is needed. Otherwise src == dst (same native type).
|
|
840
|
+
if (use_bf16) {
|
|
841
|
+
GGML_ASSERT(kernel_type == GGML_TYPE_BF16);
|
|
842
|
+
nv_bfloat16 * src[GGML_CUDA_MAX_DEVICES] = {};
|
|
843
|
+
float * dst[GGML_CUDA_MAX_DEVICES] = {};
|
|
844
|
+
for (int i = 0; i < n; ++i) {
|
|
845
|
+
src[i] = static_cast<nv_bfloat16 *>(copy_src_ptr[i]);
|
|
846
|
+
dst[i] = static_cast<float *>(tensors[i]->data);
|
|
847
|
+
}
|
|
848
|
+
ok = ggml_cuda_ar_allreduce_copy_outer<nv_bfloat16, float>(
|
|
849
|
+
p, backends, src, dst, inner_compute, ne);
|
|
850
|
+
} else {
|
|
851
|
+
switch (kernel_type) {
|
|
852
|
+
case GGML_TYPE_F32: {
|
|
853
|
+
float * buf[GGML_CUDA_MAX_DEVICES] = {};
|
|
854
|
+
for (int i = 0; i < n; ++i) {
|
|
855
|
+
buf[i] = static_cast<float *>(tensors[i]->data);
|
|
856
|
+
}
|
|
857
|
+
ok = ggml_cuda_ar_allreduce_copy_outer<float, float>(
|
|
858
|
+
p, backends, buf, buf, inner_compute, ne);
|
|
859
|
+
break;
|
|
860
|
+
}
|
|
861
|
+
case GGML_TYPE_BF16: {
|
|
862
|
+
nv_bfloat16 * buf[GGML_CUDA_MAX_DEVICES] = {};
|
|
863
|
+
for (int i = 0; i < n; ++i) {
|
|
864
|
+
buf[i] = static_cast<nv_bfloat16 *>(tensors[i]->data);
|
|
865
|
+
}
|
|
866
|
+
ok = ggml_cuda_ar_allreduce_copy_outer<nv_bfloat16, nv_bfloat16>(
|
|
867
|
+
p, backends, buf, buf, inner_compute, ne);
|
|
868
|
+
break;
|
|
869
|
+
}
|
|
870
|
+
case GGML_TYPE_F16: {
|
|
871
|
+
half * buf[GGML_CUDA_MAX_DEVICES] = {};
|
|
872
|
+
for (int i = 0; i < n; ++i) {
|
|
873
|
+
buf[i] = static_cast<half *>(tensors[i]->data);
|
|
874
|
+
}
|
|
875
|
+
ok = ggml_cuda_ar_allreduce_copy_outer<half, half>(
|
|
876
|
+
p, backends, buf, buf, inner_compute, ne);
|
|
877
|
+
break;
|
|
878
|
+
}
|
|
879
|
+
default:
|
|
880
|
+
GGML_ASSERT(false);
|
|
881
|
+
}
|
|
882
|
+
}
|
|
883
|
+
} else {
|
|
884
|
+
// host_buf carries T_wire-typed data; max_chunk_elems is the count that
|
|
885
|
+
// fits in one host_buf at the wire size.
|
|
886
|
+
const size_t max_chunk_elems = p->buf_bytes / type_size;
|
|
887
|
+
const size_t input_type_size = ggml_type_size(input_type);
|
|
888
|
+
|
|
889
|
+
// Chunked kernel path runs entirely on the caller's compute stream:
|
|
890
|
+
// since AR is a barrier here, same-stream ordering subsumes any
|
|
891
|
+
// cross-stream event handshake that the copy-engine path needs, and
|
|
892
|
+
// skips the cross-stream scheduling overhead that was hurting the
|
|
893
|
+
// small-tensor (tg) latency on the AR-stream variant. Only ev.ker is
|
|
894
|
+
// still recorded at end-of-AR for acquire_slot's pool-wraparound check.
|
|
895
|
+
for (int64_t chunk_start = 0; chunk_start < ne; chunk_start += (int64_t) max_chunk_elems) {
|
|
896
|
+
const size_t remaining_elems = (size_t) (ne - chunk_start);
|
|
897
|
+
const size_t chunk_elems = remaining_elems < max_chunk_elems ? remaining_elems : max_chunk_elems;
|
|
898
|
+
const size_t chunk_dst_bytes = chunk_elems * input_type_size;
|
|
899
|
+
|
|
900
|
+
const auto [slot, token] = ggml_cuda_ar_acquire_slot(p);
|
|
901
|
+
const bool last_chunk = chunk_start + (int64_t) chunk_elems == ne;
|
|
902
|
+
|
|
903
|
+
for (int i = 0; i < n; ++i) {
|
|
904
|
+
const int peer = 1 - i; // valid for n == 2 only
|
|
905
|
+
ggml_cuda_set_device(p->devices[i]);
|
|
906
|
+
auto * cuda_ctx = static_cast<ggml_backend_cuda_context *>(backends[i]->context);
|
|
907
|
+
GGML_ASSERT(cuda_ctx->device == p->devices[i]);
|
|
908
|
+
cudaStream_t stream = cuda_ctx->stream();
|
|
909
|
+
|
|
910
|
+
char * data = static_cast<char *>(tensors[i]->data) + chunk_start * (int64_t) input_type_size;
|
|
911
|
+
|
|
912
|
+
// Match NCCL/meta-backend semantics: inactive shards contribute
|
|
913
|
+
// zeros. On the BF16 path the F32 tensor data was already
|
|
914
|
+
// zeroed up-front (above), so per-chunk zeroing isn't needed.
|
|
915
|
+
if (!compute_flag[i] && !use_bf16) {
|
|
916
|
+
CUDA_CHECK(cudaMemsetAsync(data, 0, chunk_dst_bytes, stream));
|
|
917
|
+
}
|
|
918
|
+
|
|
919
|
+
#define LAUNCH_AR_KERNEL(T_dst, T_wire) \
|
|
920
|
+
ggml_cuda_ar_kernel<T_dst, T_wire><<<dim3(GGML_CUDA_AR_KERNEL_BLOCKS), dim3(256), 0, stream>>>( \
|
|
921
|
+
reinterpret_cast<const T_dst *>(data), \
|
|
922
|
+
reinterpret_cast<T_dst *>(data), \
|
|
923
|
+
reinterpret_cast<T_wire *>(p->host_buf[i].dev + (size_t) slot * p->buf_bytes), \
|
|
924
|
+
reinterpret_cast<const T_wire *>(p->host_buf[peer].dev + (size_t) slot * p->buf_bytes), \
|
|
925
|
+
static_cast<int>(chunk_elems), \
|
|
926
|
+
ggml_cuda_ar_arrival_ptr(p, slot, i), \
|
|
927
|
+
ggml_cuda_ar_arrival_ptr(p, slot, peer), \
|
|
928
|
+
token)
|
|
929
|
+
|
|
930
|
+
if (use_bf16) {
|
|
931
|
+
GGML_ASSERT(input_type == GGML_TYPE_F32);
|
|
932
|
+
LAUNCH_AR_KERNEL(float, nv_bfloat16);
|
|
933
|
+
} else {
|
|
934
|
+
switch (input_type) {
|
|
935
|
+
case GGML_TYPE_F32: LAUNCH_AR_KERNEL(float, float); break;
|
|
936
|
+
case GGML_TYPE_F16: LAUNCH_AR_KERNEL(half, half); break;
|
|
937
|
+
case GGML_TYPE_BF16: LAUNCH_AR_KERNEL(nv_bfloat16, nv_bfloat16); break;
|
|
938
|
+
default: GGML_ASSERT(false);
|
|
939
|
+
}
|
|
940
|
+
}
|
|
941
|
+
|
|
942
|
+
#undef LAUNCH_AR_KERNEL
|
|
943
|
+
CUDA_CHECK(cudaGetLastError());
|
|
944
|
+
|
|
945
|
+
if (last_chunk) {
|
|
946
|
+
CUDA_CHECK(cudaEventRecord(p->ev_pool[i][slot].ker, stream));
|
|
947
|
+
}
|
|
948
|
+
}
|
|
949
|
+
}
|
|
950
|
+
}
|
|
951
|
+
|
|
952
|
+
return ok;
|
|
953
|
+
}
|
|
954
|
+
|
|
955
|
+
#else // defined(GGML_USE_HIP) || defined(GGML_USE_MUSA)
|
|
956
|
+
|
|
957
|
+
// HIP and MUSA lack the host-mapped pinned-memory APIs (cudaHostAllocPortable
|
|
958
|
+
// / cudaHostAllocMapped / cudaHostGetDevicePointer) and __nanosleep that this
|
|
959
|
+
// implementation relies on, so the internal AllReduce is a CUDA-only feature.
|
|
960
|
+
// The dispatcher in ggml-cuda.cu treats a nullptr pipeline as "init failed"
|
|
961
|
+
// and silently falls back to the meta backend's generic AllReduce.
|
|
962
|
+
ggml_cuda_ar_pipeline * ggml_cuda_ar_pipeline_init(const int *, size_t) {
|
|
963
|
+
return nullptr;
|
|
964
|
+
}
|
|
965
|
+
void ggml_cuda_ar_pipeline_free(ggml_cuda_ar_pipeline *) {
|
|
966
|
+
}
|
|
967
|
+
bool ggml_cuda_ar_allreduce(ggml_cuda_ar_pipeline *, ggml_backend_t *, ggml_tensor **) {
|
|
968
|
+
return false;
|
|
969
|
+
}
|
|
970
|
+
|
|
971
|
+
#endif // !defined(GGML_USE_HIP) && !defined(GGML_USE_MUSA)
|