2023-10-21 01:33:14 +00:00
|
|
|
#!/usr/bin/env bash
|
|
|
|
|
|
|
|
# Copyright (c) 2021-2023 tteck
|
|
|
|
# Author: tteck (tteckster)
|
|
|
|
# License: MIT
|
|
|
|
# https://github.com/tteck/Proxmox/raw/main/LICENSE
|
|
|
|
|
2023-12-21 01:54:09 +00:00
|
|
|
set -e
|
2023-10-21 01:33:14 +00:00
|
|
|
function header_info {
|
|
|
|
clear
|
|
|
|
cat <<"EOF"
|
|
|
|
|
|
|
|
__ ___ __ ___ __ __ _
|
|
|
|
/ // / | /| / / / _ |___________ / /__ _______ _/ /_(_)__ ___
|
|
|
|
/ _ /| |/ |/ / / __ / __/ __/ -_) / -_) __/ _ `/ __/ / _ \/ _ \
|
|
|
|
/_//_/ |__/|__/ /_/ |_\__/\__/\__/_/\__/_/ \_,_/\__/_/\___/_//_/
|
|
|
|
|
|
|
|
EOF
|
|
|
|
}
|
|
|
|
header_info
|
|
|
|
echo "Loading..."
|
2023-12-21 01:54:09 +00:00
|
|
|
whiptail --backtitle "Proxmox VE Helper Scripts" --title "Add Intel HW Acceleration" --yesno "This Will Add Intel HW Acceleration to an existing LXC Container. Proceed?" 8 72 || exit
|
2023-10-21 01:33:14 +00:00
|
|
|
NODE=$(hostname)
|
|
|
|
PREV_MENU=()
|
|
|
|
MSG_MAX_LENGTH=0
|
|
|
|
privileged_containers=$(pct list | awk 'NR>1 && system("grep -q \047unprivileged: 1\047 /etc/pve/lxc/" $1 ".conf")')
|
|
|
|
if [ -z "$privileged_containers" ]; then
|
|
|
|
whiptail --msgbox "No Privileged Containers Found." 10 58
|
|
|
|
exit
|
|
|
|
fi
|
|
|
|
while read -r TAG ITEM; do
|
|
|
|
OFFSET=2
|
|
|
|
((${#ITEM} + OFFSET > MSG_MAX_LENGTH)) && MSG_MAX_LENGTH=${#ITEM}+OFFSET
|
|
|
|
PREV_MENU+=("$TAG" "$ITEM " "OFF")
|
|
|
|
done < <(echo "$privileged_containers")
|
2023-12-21 01:54:09 +00:00
|
|
|
privileged_container=$(whiptail --backtitle "Proxmox VE Helper Scripts" --title "Privileged Containers on $NODE" --checklist "\nSelect a Container To Add Intel HW Acceleration:\n" 16 $((MSG_MAX_LENGTH + 23)) 6 "${PREV_MENU[@]}" 3>&1 1>&2 2>&3 | tr -d '"') || exit
|
2023-10-21 01:33:14 +00:00
|
|
|
header_info
|
|
|
|
cat <<EOF >>/etc/pve/lxc/${privileged_container}.conf
|
|
|
|
lxc.cgroup2.devices.allow: c 226:0 rwm
|
|
|
|
lxc.cgroup2.devices.allow: c 226:128 rwm
|
|
|
|
lxc.cgroup2.devices.allow: c 29:0 rwm
|
|
|
|
lxc.mount.entry: /dev/fb0 dev/fb0 none bind,optional,create=file
|
|
|
|
lxc.mount.entry: /dev/dri dev/dri none bind,optional,create=dir
|
|
|
|
lxc.mount.entry: /dev/dri/renderD128 dev/dri/renderD128 none bind,optional,create=file
|
|
|
|
EOF
|
2023-12-21 01:54:09 +00:00
|
|
|
read -r -p "Do you need the intel-media-va-driver-non-free driver (Sources change)? <y/N> " prompt
|
|
|
|
if [[ ${prompt,,} =~ ^(y|yes)$ ]]; then
|
|
|
|
header_info
|
|
|
|
pct exec ${privileged_container} -- bash -c "cat <<EOF >/etc/apt/sources.list
|
|
|
|
|
|
|
|
deb http://deb.debian.org/debian bookworm main contrib non-free non-free-firmware
|
|
|
|
deb-src http://deb.debian.org/debian bookworm main contrib non-free non-free-firmware
|
|
|
|
|
|
|
|
deb http://deb.debian.org/debian-security bookworm-security main contrib non-free non-free-firmware
|
|
|
|
deb-src http://deb.debian.org/debian-security bookworm-security main contrib non-free non-free-firmware
|
|
|
|
|
|
|
|
deb http://deb.debian.org/debian bookworm-updates main contrib non-free non-free-firmware
|
|
|
|
deb-src http://deb.debian.org/debian bookworm-updates main contrib non-free non-free-firmware
|
|
|
|
EOF"
|
|
|
|
|
|
|
|
pct exec ${privileged_container} -- bash -c "apt-get update && apt-get install -y intel-media-va-driver-non-free ocl-icd-libopencl1 intel-opencl-icd vainfo intel-gpu-tools && chgrp video /dev/dri && chmod 755 /dev/dri && adduser \$(id -u -n) video && adduser \$(id -u -n) render"
|
|
|
|
else
|
|
|
|
header_info
|
|
|
|
pct exec ${privileged_container} -- bash -c "apt-get install -y va-driver-all ocl-icd-libopencl1 intel-opencl-icd vainfo intel-gpu-tools && chgrp video /dev/dri && chmod 755 /dev/dri && adduser \$(id -u -n) video && adduser \$(id -u -n) render"
|
|
|
|
fi
|
|
|
|
whiptail --backtitle "Proxmox VE Helper Scripts" --msgbox --title "Added tools" "vainfo, execute command 'vainfo'\nintel-gpu-tools, execute command 'intel_gpu_top'" 8 58
|
2023-10-21 01:33:14 +00:00
|
|
|
header_info
|
|
|
|
echo -e "Completed Successfully!\n"
|
|
|
|
echo -e "Reboot container $privileged_container to apply the new settings\n"
|