2023-08-25 09:09:42 +00:00
|
|
|
ARG UBUNTU_VERSION=22.04
|
|
|
|
|
|
|
|
# This needs to generally match the container host's environment.
|
|
|
|
ARG ROCM_VERSION=5.6
|
|
|
|
|
|
|
|
# Target the CUDA build image
|
|
|
|
ARG BASE_ROCM_DEV_CONTAINER=rocm/dev-ubuntu-${UBUNTU_VERSION}:${ROCM_VERSION}-complete
|
|
|
|
|
|
|
|
FROM ${BASE_ROCM_DEV_CONTAINER} as build
|
|
|
|
|
|
|
|
# Unless otherwise specified, we make a fat build.
|
|
|
|
# List from https://github.com/ggerganov/llama.cpp/pull/1087#issuecomment-1682807878
|
|
|
|
# This is mostly tied to rocBLAS supported archs.
|
|
|
|
ARG ROCM_DOCKER_ARCH=\
|
|
|
|
gfx803 \
|
|
|
|
gfx900 \
|
|
|
|
gfx906 \
|
|
|
|
gfx908 \
|
|
|
|
gfx90a \
|
|
|
|
gfx1010 \
|
|
|
|
gfx1030 \
|
|
|
|
gfx1100 \
|
|
|
|
gfx1101 \
|
|
|
|
gfx1102
|
|
|
|
|
2023-12-29 14:50:29 +00:00
|
|
|
COPY requirements.txt requirements.txt
|
|
|
|
COPY requirements requirements
|
2023-08-25 09:09:42 +00:00
|
|
|
|
|
|
|
RUN pip install --upgrade pip setuptools wheel \
|
|
|
|
&& pip install -r requirements.txt
|
|
|
|
|
|
|
|
WORKDIR /app
|
|
|
|
|
|
|
|
COPY . .
|
|
|
|
|
|
|
|
# Set nvcc architecture
|
|
|
|
ENV GPU_TARGETS=${ROCM_DOCKER_ARCH}
|
|
|
|
# Enable ROCm
|
2024-06-26 16:32:07 +00:00
|
|
|
ENV GGML_HIPBLAS=1
|
2023-08-25 09:09:42 +00:00
|
|
|
ENV CC=/opt/rocm/llvm/bin/clang
|
|
|
|
ENV CXX=/opt/rocm/llvm/bin/clang++
|
|
|
|
|
2024-06-12 23:41:52 +00:00
|
|
|
RUN make -j$(nproc) llama-cli
|
2023-08-25 09:09:42 +00:00
|
|
|
|
2024-06-12 23:41:52 +00:00
|
|
|
ENTRYPOINT [ "/app/llama-cli" ]
|