@@ -28,13 +28,25 @@ jobs:
28
28
include :
29
29
- build : ' noavx'
30
30
defines : ' -DGGML_AVX=OFF -DGGML_AVX2=OFF -DGGML_FMA=OFF'
31
+ os : ubuntu-22.04
32
+ arch : x64
31
33
- build : ' avx2'
32
34
defines : ' '
35
+ os : ubuntu-22.04
36
+ arch : x64
33
37
- build : ' avx'
34
38
defines : ' -DGGML_AVX2=OFF'
39
+ os : ubuntu-22.04
40
+ arch : x64
35
41
- build : ' avx512'
36
42
defines : ' -DGGML_AVX512=ON'
37
- runs-on : ubuntu-24.04
43
+ os : ubuntu-22.04
44
+ arch : x64
45
+ - build : ' aarch64'
46
+ defines : ' -DGGML_NATIVE=OFF -DGGML_CPU_AARCH64=ON -DGGML_CPU_ARM_ARCH=armv8-a'
47
+ os : ubuntu-24.04-arm
48
+ arch : arm64
49
+ runs-on : ${{ matrix.os }}
38
50
steps :
39
51
- uses : actions/checkout@v4
40
52
with :
@@ -52,28 +64,28 @@ jobs:
52
64
- uses : actions/upload-artifact@v4
53
65
with :
54
66
path : ./build/bin/libllama.so
55
- name : llama-bin-linux-${{ matrix.build }}-x64 .so
67
+ name : llama-bin-linux-${{ matrix.build }}-${{ matrix.arch }} .so
56
68
if-no-files-found : error
57
69
- uses : actions/upload-artifact@v4
58
70
with :
59
71
path : ./build/bin/libggml.so
60
- name : ggml-bin-linux-${{ matrix.build }}-x64 .so
72
+ name : ggml-bin-linux-${{ matrix.build }}-${{ matrix.arch }} .so
61
73
if-no-files-found : error
62
74
- uses : actions/upload-artifact@v4
63
75
with :
64
76
path : ./build/bin/libggml-base.so
65
- name : ggml-base-bin-linux-${{ matrix.build }}-x64 .so
77
+ name : ggml-base-bin-linux-${{ matrix.build }}-${{ matrix.arch }} .so
66
78
if-no-files-found : error
67
79
- uses : actions/upload-artifact@v4
68
80
with :
69
81
path : ./build/bin/libggml-cpu.so
70
- name : ggml-cpu-bin-linux-${{ matrix.build }}-x64 .so
82
+ name : ggml-cpu-bin-linux-${{ matrix.build }}-${{ matrix.arch }} .so
71
83
if-no-files-found : error
72
84
- name : Upload Llava
73
85
uses : actions/upload-artifact@v4
74
86
with :
75
87
path : ./build/bin/libllava_shared.so
76
- name : llava-bin-linux-${{ matrix.build }}-x64 .so
88
+ name : llava-bin-linux-${{ matrix.build }}-${{ matrix.arch }} .so
77
89
if-no-files-found : error
78
90
79
91
compile-musl :
@@ -527,19 +539,15 @@ jobs:
527
539
if-no-files-found : error
528
540
529
541
compile-android :
530
- # Disable android build
531
- if : false
532
-
542
+ name : Compile (Android)
533
543
strategy :
534
544
fail-fast : true
535
545
matrix :
536
546
include :
537
- - build : ' x86'
538
- defines : ' -DANDROID_ABI=x86'
539
547
- build : ' x86_64'
540
- defines : ' -DANDROID_ABI=x86_64'
548
+ defines : ' -DANDROID_ABI=x86_64 -DCMAKE_C_FLAGS=-march=x86-64 -DCMAKE_CXX_FLAGS=-march=x86-64 '
541
549
- build : ' arm64-v8a'
542
- defines : ' -DANDROID_ABI=arm64-v8a'
550
+ defines : ' -DANDROID_ABI=arm64-v8a -DCMAKE_C_FLAGS=-march=armv8.7a -DCMAKE_C_FLAGS=-march=armv8.7a '
543
551
runs-on : ubuntu-24.04
544
552
steps :
545
553
- uses : actions/checkout@v4
@@ -555,28 +563,39 @@ jobs:
555
563
- name : Build
556
564
id : cmake_build
557
565
env :
558
- CMAKE_FLAGS : ' -DCMAKE_TOOLCHAIN_FILE=${{ steps.setup-ndk.outputs.ndk-path }}/build/cmake/android.toolchain.cmake -DANDROID_PLATFORM=android-23'
566
+ CMAKE_FLAGS : ' -DCMAKE_TOOLCHAIN_FILE=${{ steps.setup-ndk.outputs.ndk-path }}/build/cmake/android.toolchain.cmake -DANDROID_PLATFORM=android-23 -DGGML_OPENMP=OFF -DGGML_LLAMAFILE=OFF '
559
567
run : |
560
- mkdir build
561
- cd build
562
- cmake .. ${{ env.COMMON_DEFINE }} ${{ env.CMAKE_FLAGS }} ${{ matrix.defines }}
563
- cmake --build . --config Release -j ${env:NUMBER_OF_PROCESSORS}
564
- cd ..
565
- ls -R
568
+ # export-lora not supported on 32 bit machines hence breaks x86 build
569
+ sed -i '/add_subdirectory(export-lora)/d' examples/CMakeLists.txt # remove export-lora from examples
570
+ cmake ${{ env.COMMON_DEFINE }} ${{ env.CMAKE_FLAGS }} ${{ matrix.defines }} -B build
571
+ cmake --build build --config Release -j ${env:NUMBER_OF_PROCESSORS}
566
572
- name : Upload Llama
567
573
uses : actions/upload-artifact@v4
568
574
with :
569
- path : ./build/src /libllama.so
575
+ path : ./build/bin /libllama.so
570
576
name : llama-bin-android-${{ matrix.build }}.so
571
- - uses : actions/upload-artifact@v4
577
+ - name : Upload GGML
578
+ uses : actions/upload-artifact@v4
572
579
with :
573
- path : ./build/ggml/src /libggml.so
580
+ path : ./build/bin /libggml.so
574
581
name : ggml-bin-android-${{ matrix.build }}.so
575
582
if-no-files-found : error
583
+ - name : Upload GGML Base
584
+ uses : actions/upload-artifact@v4
585
+ with :
586
+ path : ./build/bin/libggml-base.so
587
+ name : ggml-base-bin-android-${{ matrix.build }}.so
588
+ if-no-files-found : error
589
+ - name : Upload GGML CPU
590
+ uses : actions/upload-artifact@v4
591
+ with :
592
+ path : ./build/bin/libggml-cpu.so
593
+ name : ggml-cpu-bin-android-${{ matrix.build }}.so
594
+ if-no-files-found : error
576
595
- name : Upload Llava
577
596
uses : actions/upload-artifact@v4
578
597
with :
579
- path : ./build/examples/llava /libllava_shared.so
598
+ path : ./build/bin /libllava_shared.so
580
599
name : llava-bin-android-${{ matrix.build }}.so
581
600
582
601
build-deps :
@@ -601,7 +620,7 @@ jobs:
601
620
- name : Rearrange Files
602
621
run : |
603
622
# Make all directories at once
604
- mkdir --parents deps/{noavx,avx,avx2,avx512,musl-noavx,musl-avx,musl-avx2,musl-avx512,osx-arm64,osx-x64,osx-x64-rosetta2,cu11.7.1,cu12.2.0,vulkan,android-arm64-v8a,android-x86,android-x86_64}
623
+ mkdir --parents deps/{noavx,avx,avx2,avx512,linux-arm64, musl-noavx,musl-avx,musl-avx2,musl-avx512,osx-arm64,osx-x64,osx-x64-rosetta2,cu11.7.1,cu12.2.0,vulkan,android-arm64-v8a,android-x86,android-x86_64}
605
624
606
625
# Linux
607
626
cp artifacts/ggml-bin-linux-noavx-x64.so/libggml.so deps/noavx/libggml.so
@@ -628,6 +647,13 @@ jobs:
628
647
cp artifacts/llama-bin-linux-avx512-x64.so/libllama.so deps/avx512/libllama.so
629
648
cp artifacts/llava-bin-linux-avx512-x64.so/libllava_shared.so deps/avx512/libllava_shared.so
630
649
650
+ # Arm64
651
+ cp artifacts/ggml-bin-linux-aarch64-arm64.so/libggml.so deps/linux-arm64/libggml.so
652
+ cp artifacts/ggml-base-bin-linux-aarch64-arm64.so/libggml-base.so deps/linux-arm64/libggml-base.so
653
+ cp artifacts/ggml-cpu-bin-linux-aarch64-arm64.so/libggml-cpu.so deps/linux-arm64/libggml-cpu.so
654
+ cp artifacts/llama-bin-linux-aarch64-arm64.so/libllama.so deps/linux-arm64/libllama.so
655
+ cp artifacts/llava-bin-linux-aarch64-arm64.so/libllava_shared.so deps/linux-arm64/libllava_shared.so
656
+
631
657
# Musl
632
658
cp artifacts/ggml-bin-musl-noavx-x64.so/libggml.so deps/musl-noavx/libggml.so
633
659
cp artifacts/ggml-base-bin-musl-noavx-x64.so/libggml-base.so deps/musl-noavx/libggml-base.so
@@ -703,17 +729,17 @@ jobs:
703
729
cp artifacts/llava-bin-osx-x64-rosetta2.dylib/libllava_shared.dylib deps/osx-x64-rosetta2/libllava_shared.dylib
704
730
705
731
# Android
706
- # cp artifacts/ggml-bin-android-arm64-v8a.so/libggml.so deps/android-arm64-v8a/libggml.so
707
- # cp artifacts/llama- bin-android-arm64-v8a.so/libllama .so deps/android-arm64-v8a/libllama .so
708
- # cp artifacts/llava- bin-android-arm64-v8a.so/libllava_shared .so deps/android-arm64-v8a/libllava_shared .so
709
-
710
- # cp artifacts/ggml -bin-android-x86 .so/libggml .so deps/android-x86/libggml .so
711
- #cp artifacts/llama-bin-android-x86.so/libllama.so deps/android-x86/libllama.so
712
- # cp artifacts/llava -bin-android-x86 .so/libllava_shared .so deps/android-x86/libllava_shared .so
713
-
714
- # cp artifacts/ggml-bin-android-x86_64.so/libggml.so deps/android-x86_64/libggml.so
715
- # cp artifacts/llama-bin-android-x86_64.so/libllama.so deps/android-x86_64/libllama.so
716
- # cp artifacts/llava-bin-android-x86_64.so/libllava_shared.so deps/android-x86_64/libllava_shared.so
732
+ cp artifacts/ggml-bin-android-arm64-v8a.so/libggml.so deps/android-arm64-v8a/libggml.so
733
+ cp artifacts/ggml-base- bin-android-arm64-v8a.so/libggml-base .so deps/android-arm64-v8a/libggml-base .so
734
+ cp artifacts/ggml-cpu- bin-android-arm64-v8a.so/libggml-cpu .so deps/android-arm64-v8a/libggml-cpu .so
735
+ cp artifacts/llama-bin-android-arm64-v8a.so/libllama.so deps/android-arm64-v8a/libllama.so
736
+ cp artifacts/llava -bin-android-arm64-v8a .so/libllava_shared .so deps/android-arm64-v8a/libllava_shared .so
737
+
738
+ cp artifacts/ggml -bin-android-x86_64 .so/libggml .so deps/android-x86_64/libggml .so
739
+ cp artifacts/ggml-base-bin-android-x86_64.so/libggml-base.so deps/android-x86_64/libggml-base.so
740
+ cp artifacts/ggml-cpu- bin-android-x86_64.so/libggml-cpu .so deps/android-x86_64/libggml-cpu .so
741
+ cp artifacts/llama-bin-android-x86_64.so/libllama.so deps/android-x86_64/libllama.so
742
+ cp artifacts/llava-bin-android-x86_64.so/libllava_shared.so deps/android-x86_64/libllava_shared.so
717
743
718
744
# Windows CUDA
719
745
cp artifacts/ggml-bin-win-cublas-cu11.7.1-x64.dll/ggml.dll deps/cu11.7.1/ggml.dll
0 commit comments