mirror of
https://github.com/community-scripts/ProxmoxVE.git
synced 2026-04-18 16:32:17 +00:00
rocm
This commit is contained in:
@@ -20,10 +20,33 @@ $STD apt install -y \
|
|||||||
zstd
|
zstd
|
||||||
msg_ok "Installed Dependencies"
|
msg_ok "Installed Dependencies"
|
||||||
|
|
||||||
msg_info "Setting up Intel® Repositories"
|
# ══════════════════════════════════════════════════════════════════════════════
|
||||||
mkdir -p /usr/share/keyrings
|
# GPU Detection - determine which GPU backend to configure
|
||||||
curl -fsSL https://repositories.intel.com/gpu/intel-graphics.key | gpg --dearmor -o /usr/share/keyrings/intel-graphics.gpg
|
# ══════════════════════════════════════════════════════════════════════════════
|
||||||
cat <<EOF >/etc/apt/sources.list.d/intel-gpu.sources
|
GPU_BACKEND="cpu"
|
||||||
|
|
||||||
|
if [[ -e /dev/kfd ]]; then
|
||||||
|
GPU_BACKEND="rocm"
|
||||||
|
msg_ok "Detected AMD GPU (/dev/kfd present) - will configure ROCm backend"
|
||||||
|
elif [[ -d /dev/dri ]]; then
|
||||||
|
# Check if Intel GPU is available (default for this script)
|
||||||
|
if lspci 2>/dev/null | grep -iE 'VGA|3D|Display' | grep -qi 'Intel'; then
|
||||||
|
GPU_BACKEND="intel"
|
||||||
|
msg_ok "Detected Intel GPU - will configure SYCL/oneAPI backend"
|
||||||
|
elif [[ -e /dev/dri/renderD128 ]]; then
|
||||||
|
GPU_BACKEND="intel"
|
||||||
|
msg_ok "Detected GPU (assuming Intel) - will configure SYCL/oneAPI backend"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
# ══════════════════════════════════════════════════════════════════════════════
|
||||||
|
# Intel GPU Setup
|
||||||
|
# ══════════════════════════════════════════════════════════════════════════════
|
||||||
|
if [[ "$GPU_BACKEND" == "intel" ]]; then
|
||||||
|
msg_info "Setting up Intel® Repositories"
|
||||||
|
mkdir -p /usr/share/keyrings
|
||||||
|
curl -fsSL https://repositories.intel.com/gpu/intel-graphics.key | gpg --dearmor -o /usr/share/keyrings/intel-graphics.gpg
|
||||||
|
cat <<EOF >/etc/apt/sources.list.d/intel-gpu.sources
|
||||||
Types: deb
|
Types: deb
|
||||||
URIs: https://repositories.intel.com/gpu/ubuntu
|
URIs: https://repositories.intel.com/gpu/ubuntu
|
||||||
Suites: jammy
|
Suites: jammy
|
||||||
@@ -31,37 +54,56 @@ Components: client
|
|||||||
Architectures: amd64 i386
|
Architectures: amd64 i386
|
||||||
Signed-By: /usr/share/keyrings/intel-graphics.gpg
|
Signed-By: /usr/share/keyrings/intel-graphics.gpg
|
||||||
EOF
|
EOF
|
||||||
curl -fsSL https://apt.repos.intel.com/intel-gpg-keys/GPG-PUB-KEY-INTEL-SW-PRODUCTS.PUB | gpg --dearmor -o /usr/share/keyrings/oneapi-archive-keyring.gpg
|
curl -fsSL https://apt.repos.intel.com/intel-gpg-keys/GPG-PUB-KEY-INTEL-SW-PRODUCTS.PUB | gpg --dearmor -o /usr/share/keyrings/oneapi-archive-keyring.gpg
|
||||||
cat <<EOF >/etc/apt/sources.list.d/oneAPI.sources
|
cat <<EOF >/etc/apt/sources.list.d/oneAPI.sources
|
||||||
Types: deb
|
Types: deb
|
||||||
URIs: https://apt.repos.intel.com/oneapi
|
URIs: https://apt.repos.intel.com/oneapi
|
||||||
Suites: all
|
Suites: all
|
||||||
Components: main
|
Components: main
|
||||||
Signed-By: /usr/share/keyrings/oneapi-archive-keyring.gpg
|
Signed-By: /usr/share/keyrings/oneapi-archive-keyring.gpg
|
||||||
EOF
|
EOF
|
||||||
$STD apt update
|
$STD apt update
|
||||||
msg_ok "Set up Intel® Repositories"
|
msg_ok "Set up Intel® Repositories"
|
||||||
|
fi
|
||||||
|
|
||||||
setup_hwaccel
|
setup_hwaccel
|
||||||
|
|
||||||
msg_info "Installing Intel® Level Zero"
|
# ══════════════════════════════════════════════════════════════════════════════
|
||||||
# Debian 13+ has newer Level Zero packages in system repos that conflict with Intel repo packages
|
# Intel-specific: Level Zero + oneAPI
|
||||||
if is_debian && [[ "$(get_os_version_major)" -ge 13 ]]; then
|
# ══════════════════════════════════════════════════════════════════════════════
|
||||||
# Use system packages on Debian 13+ (avoid conflicts with libze1)
|
if [[ "$GPU_BACKEND" == "intel" ]]; then
|
||||||
$STD apt -y install libze1 libze-dev intel-level-zero-gpu 2>/dev/null || {
|
msg_info "Installing Intel® Level Zero"
|
||||||
msg_warn "Failed to install some Level Zero packages, continuing anyway"
|
if is_debian && [[ "$(get_os_version_major)" -ge 13 ]]; then
|
||||||
}
|
$STD apt -y install libze1 libze-dev intel-level-zero-gpu 2>/dev/null || {
|
||||||
else
|
msg_warn "Failed to install some Level Zero packages, continuing anyway"
|
||||||
# Use Intel repository packages for older systems
|
}
|
||||||
$STD apt -y install intel-level-zero-gpu level-zero level-zero-dev 2>/dev/null || {
|
else
|
||||||
msg_warn "Failed to install Intel Level Zero packages, continuing anyway"
|
$STD apt -y install intel-level-zero-gpu level-zero level-zero-dev 2>/dev/null || {
|
||||||
}
|
msg_warn "Failed to install Intel Level Zero packages, continuing anyway"
|
||||||
fi
|
}
|
||||||
msg_ok "Installed Intel® Level Zero"
|
fi
|
||||||
|
msg_ok "Installed Intel® Level Zero"
|
||||||
|
|
||||||
msg_info "Installing Intel® oneAPI Base Toolkit (Patience)"
|
msg_info "Installing Intel® oneAPI Base Toolkit (Patience)"
|
||||||
$STD apt install -y --no-install-recommends intel-basekit-2024.1
|
$STD apt install -y --no-install-recommends intel-basekit-2024.1
|
||||||
msg_ok "Installed Intel® oneAPI Base Toolkit"
|
msg_ok "Installed Intel® oneAPI Base Toolkit"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# ══════════════════════════════════════════════════════════════════════════════
|
||||||
|
# AMD ROCm-specific: ensure ROCm libraries are present for Ollama
|
||||||
|
# ══════════════════════════════════════════════════════════════════════════════
|
||||||
|
if [[ "$GPU_BACKEND" == "rocm" ]]; then
|
||||||
|
msg_info "Verifying ROCm runtime for Ollama"
|
||||||
|
# ROCm base libraries should already be installed by setup_hwaccel -> _setup_amd_gpu
|
||||||
|
# Ensure the ollama-relevant pieces are present
|
||||||
|
if ! ldconfig -p 2>/dev/null | grep -q libamdhip64; then
|
||||||
|
msg_warn "ROCm HIP runtime not found - Ollama may fall back to CPU"
|
||||||
|
msg_info "You can manually install ROCm following: https://rocm.docs.amd.com/projects/install-on-linux/en/latest/"
|
||||||
|
else
|
||||||
|
msg_ok "ROCm HIP runtime available"
|
||||||
|
fi
|
||||||
|
msg_ok "Verified ROCm runtime"
|
||||||
|
fi
|
||||||
|
|
||||||
msg_info "Installing Ollama (Patience)"
|
msg_info "Installing Ollama (Patience)"
|
||||||
RELEASE=$(curl -fsSL https://api.github.com/repos/ollama/ollama/releases/latest | grep "tag_name" | awk -F '"' '{print $4}')
|
RELEASE=$(curl -fsSL https://api.github.com/repos/ollama/ollama/releases/latest | grep "tag_name" | awk -F '"' '{print $4}')
|
||||||
@@ -104,11 +146,24 @@ After=network-online.target
|
|||||||
Type=exec
|
Type=exec
|
||||||
ExecStart=/usr/local/bin/ollama serve
|
ExecStart=/usr/local/bin/ollama serve
|
||||||
Environment=HOME=$HOME
|
Environment=HOME=$HOME
|
||||||
Environment=OLLAMA_INTEL_GPU=true
|
|
||||||
Environment=OLLAMA_HOST=0.0.0.0
|
Environment=OLLAMA_HOST=0.0.0.0
|
||||||
Environment=OLLAMA_NUM_GPU=999
|
Environment=OLLAMA_NUM_GPU=999
|
||||||
|
EOF
|
||||||
|
|
||||||
|
# Add GPU-specific environment variables
|
||||||
|
if [[ "$GPU_BACKEND" == "intel" ]]; then
|
||||||
|
cat <<EOF >>/etc/systemd/system/ollama.service
|
||||||
|
Environment=OLLAMA_INTEL_GPU=true
|
||||||
Environment=SYCL_CACHE_PERSISTENT=1
|
Environment=SYCL_CACHE_PERSISTENT=1
|
||||||
Environment=ZES_ENABLE_SYSMAN=1
|
Environment=ZES_ENABLE_SYSMAN=1
|
||||||
|
EOF
|
||||||
|
elif [[ "$GPU_BACKEND" == "rocm" ]]; then
|
||||||
|
cat <<EOF >>/etc/systemd/system/ollama.service
|
||||||
|
Environment=HSA_OVERRIDE_GFX_VERSION=11.0.0
|
||||||
|
EOF
|
||||||
|
fi
|
||||||
|
|
||||||
|
cat <<EOF >>/etc/systemd/system/ollama.service
|
||||||
Restart=always
|
Restart=always
|
||||||
RestartSec=3
|
RestartSec=3
|
||||||
|
|
||||||
|
|||||||
@@ -3738,6 +3738,11 @@ $PCT_OPTIONS_STRING"
|
|||||||
done
|
done
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
# /dev/kfd is required for AMD ROCm compute (GPU inference in Ollama, etc.)
|
||||||
|
if [[ -e /dev/kfd ]]; then
|
||||||
|
AMD_DEVICES+=("/dev/kfd")
|
||||||
|
msg_custom "🎮" "${RD}" "Detected /dev/kfd (ROCm compute device)"
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Check for NVIDIA GPU - look for NVIDIA vendor ID [10de]
|
# Check for NVIDIA GPU - look for NVIDIA vendor ID [10de]
|
||||||
|
|||||||
@@ -4451,9 +4451,36 @@ _setup_amd_gpu() {
|
|||||||
fi
|
fi
|
||||||
# Ubuntu includes AMD firmware in linux-firmware by default
|
# Ubuntu includes AMD firmware in linux-firmware by default
|
||||||
|
|
||||||
# ROCm for compute (optional - large download)
|
# ROCm for GPU compute (needed for AI/ML workloads like Ollama)
|
||||||
# Uncomment if needed:
|
if [[ -e /dev/kfd ]]; then
|
||||||
# $STD apt -y install rocm-opencl-runtime 2>/dev/null || true
|
msg_info "Installing ROCm runtime (AMD GPU compute)"
|
||||||
|
if [[ "$os_id" == "ubuntu" ]]; then
|
||||||
|
# Official AMD ROCm repo for Ubuntu
|
||||||
|
mkdir -p /usr/share/keyrings
|
||||||
|
curl -fsSL https://repo.radeon.com/rocm/rocm.gpg.key | gpg --dearmor -o /usr/share/keyrings/rocm-archive-keyring.gpg 2>/dev/null || true
|
||||||
|
local rocm_version="6.4.1"
|
||||||
|
cat <<EOF >/etc/apt/sources.list.d/rocm.sources
|
||||||
|
Types: deb
|
||||||
|
URIs: https://repo.radeon.com/rocm/apt/${rocm_version}
|
||||||
|
Suites: noble
|
||||||
|
Components: main
|
||||||
|
Signed-By: /usr/share/keyrings/rocm-archive-keyring.gpg
|
||||||
|
EOF
|
||||||
|
cat <<EOF >/etc/apt/sources.list.d/amdgpu.sources
|
||||||
|
Types: deb
|
||||||
|
URIs: https://repo.radeon.com/amdgpu/${rocm_version}/ubuntu
|
||||||
|
Suites: noble
|
||||||
|
Components: main
|
||||||
|
Signed-By: /usr/share/keyrings/rocm-archive-keyring.gpg
|
||||||
|
EOF
|
||||||
|
$STD apt update 2>/dev/null || true
|
||||||
|
$STD apt -y install rocm-opencl-runtime rocm-hip-runtime 2>/dev/null || msg_warn "ROCm install failed - GPU compute may not work"
|
||||||
|
elif [[ "$os_id" == "debian" ]]; then
|
||||||
|
# Debian: use distro ROCm packages if available
|
||||||
|
$STD apt -y install rocm-opencl-runtime 2>/dev/null || msg_warn "ROCm not available in Debian repos"
|
||||||
|
fi
|
||||||
|
msg_ok "Installed ROCm runtime"
|
||||||
|
fi
|
||||||
|
|
||||||
msg_ok "AMD GPU configured"
|
msg_ok "AMD GPU configured"
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user