2024-01-23 08:11:39 +01:00
ARG ONEAPI_VERSION = 2024 .0.1-devel-ubuntu22.04
2024-02-02 08:56:31 +01:00
FROM intel/oneapi-basekit:$ONEAPI_VERSION as build
2024-01-23 08:11:39 +01:00
2024-05-30 14:19:08 +08:00
RUN wget -O- https://apt.repos.intel.com/intel-gpg-keys/GPG-PUB-KEY-INTEL-SW-PRODUCTS.PUB | gpg --dearmor | tee /usr/share/keyrings/intel-oneapi-archive-keyring.gpg > /dev/null && \
echo "deb [signed-by=/usr/share/keyrings/intel-oneapi-archive-keyring.gpg] https://apt.repos.intel.com/oneapi all main " | tee /etc/apt/sources.list.d/oneAPI.list && \
chmod 644 /usr/share/keyrings/intel-oneapi-archive-keyring.gpg && \
rm /etc/apt/sources.list.d/intel-graphics.list && \
wget -O- https://repositories.intel.com/graphics/intel-graphics.key | gpg --dearmor | tee /usr/share/keyrings/intel-graphics.gpg > /dev/null && \
echo "deb [arch=amd64,i386 signed-by=/usr/share/keyrings/intel-graphics.gpg] https://repositories.intel.com/graphics/ubuntu jammy arc" | tee /etc/apt/sources.list.d/intel.gpu.jammy.list && \
chmod 644 /usr/share/keyrings/intel-graphics.gpg
2024-02-02 08:56:31 +01:00
ARG LLAMA_SYCL_F16 = OFF
2024-01-23 08:11:39 +01:00
RUN apt-get update && \
apt-get install -y git
WORKDIR /app
COPY . .
2024-04-29 17:02:45 +01:00
RUN if [ " ${ LLAMA_SYCL_F16 } " = "ON" ] ; then \
2024-02-02 08:56:31 +01:00
echo "LLAMA_SYCL_F16 is set" && \
export OPT_SYCL_F16 = "-DLLAMA_SYCL_F16=ON" ; \
fi && \
2024-04-29 17:02:45 +01:00
cmake -B build -DLLAMA_SYCL= ON -DCMAKE_C_COMPILER= icx -DCMAKE_CXX_COMPILER= icpx ${ OPT_SYCL_F16 } && \
2024-06-08 12:50:35 +01:00
cmake --build build --config Release --target llama-cli
2024-01-23 08:11:39 +01:00
2024-02-02 08:56:31 +01:00
FROM intel/oneapi-basekit:$ONEAPI_VERSION as runtime
2024-01-23 08:11:39 +01:00
2024-06-10 15:34:14 +01:00
COPY --from= build /app/build/bin/llama-cli /llama-cli
2024-01-23 08:11:39 +01:00
ENV LC_ALL = C.utf8
2024-06-10 15:34:14 +01:00
ENTRYPOINT [ "/llama-cli" ]