Skip to content

build-oneapi

build-oneapi #42

Workflow file for this run

name: build-oneapi
on:
# Build file modifications
push:
branches: [ 'master' ]
paths: [ '.github/workflows/build-oneapi.yml', '.devops/**' ]
#pull_request:
# branches: [ 'master' ]
# Weekly rebuild
schedule:
- cron: "0 4 * * 3"
# Manual rebuild, in case of some important upstream change
workflow_dispatch:
jobs:
server:
runs-on: ubuntu-latest
strategy:
matrix:
ssl: [nossl]
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Checkout llama.cpp
uses: actions/checkout@v4
with:
repository: ggerganov/llama.cpp
path: repo
- name: Get number of CPU cores
uses: SimenB/github-actions-cpu-cores@v2
id: cpu-cores
- name: Setup Intel oneAPI compiler
run: |
#sudo apt-get update
#sudo apt-get install -y wget gpg
wget -q -O - https://apt.repos.intel.com/intel-gpg-keys/GPG-PUB-KEY-INTEL-SW-PRODUCTS.PUB | sudo gpg --dearmor --output /etc/apt/trusted.gpg.d/oneapi.gpg
echo 'deb [trusted=yes] https://apt.repos.intel.com/oneapi all main' | sudo tee /etc/apt/sources.list.d/oneapi.list >/dev/null
sudo apt-get update
sudo apt-get install -y intel-oneapi-compiler-dpcpp-cpp cmake git ccache
- name: CMake
run: |
. /opt/intel/oneapi/setvars.sh
cmake repo -B build -DCMAKE_BUILD_TYPE=Release -DCMAKE_C_COMPILER=icx -DCMAKE_CXX_COMPILER=icpx -DCMAKE_C_FLAGS="-Ofast -xCORE-AVX2" -DCMAKE_CXX_FLAGS="-Ofast -xCORE-AVX2" -DCMAKE_EXE_LINKER_FLAGS="-static" -DGGML_NATIVE=OFF -DGGML_STATIC=ON -DGGML_RPC=ON -DGGML_OPENMP=OFF -DLLAMA_BUILD_SERVER=ON -DBUILD_SHARED_LIBS=OFF
cmake --build build --config Release --target llama-server --target rpc-server -j ${{ steps.cpu-cores.outputs.count }}
strip build/bin/*
- name: Upload build artifact
uses: actions/upload-artifact@v4
with:
name: server-${{ matrix.ssl }}-oneapi
path: build/bin/*
if-no-files-found: error
- name: Build and push llama-server Docker image
uses: macbre/push-to-ghcr@v13
with:
dockerfile: .devops/llama-server.Dockerfile
context: build/bin
image_name: ${{ github.repository }}
image_tag: server-${{ matrix.ssl }}-oneapi
github_token: ${{ secrets.GHCR_ACCESS_TOKEN }}
docker_io_user: ${{ vars.DOCKER_IO_USER }}
docker_io_token: ${{ secrets.DOCKER_IO_ACCESS_TOKEN }}
- name: Build and push rpc-server Docker image
uses: macbre/push-to-ghcr@v13
with:
dockerfile: .devops/rpc-server.Dockerfile
context: build/bin
image_name: ${{ github.repository }}
image_tag: rpc-server-${{ matrix.ssl }}-oneapi
github_token: ${{ secrets.GHCR_ACCESS_TOKEN }}
docker_io_user: ${{ vars.DOCKER_IO_USER }}
docker_io_token: ${{ secrets.DOCKER_IO_ACCESS_TOKEN }}