apparmor.d/apparmor.d/groups/children/child-modprobe-nvidia
2024-05-11 17:38:43 +01:00

81 lines
2.1 KiB
Text

# apparmor.d - Full set of apparmor profiles
# Copyright (C) 2023-2024 Alexandre Pujol <alexandre@pujol.io>
# SPDX-License-Identifier: GPL-2.0-only
# Personalised version of the upstream `nvidia_modprobe` profile as it had lead
# to some issues. All validated changes will be pushed upstream.
# nvidia-modprobe is a setuid executable that is used to create various device
# and load the the nvidia kernel module.
# Note: This profile does not specify an attachment path because it is
# intended to be used only via "Px -> child-modprobe-nvidia" exec transitions
# from other profiles.
abi <abi/3.0>,
include <tunables/global>
@{exec_path} = @{bin}/nvidia-modprobe
profile child-modprobe-nvidia flags=(attach_disconnected) {
include <abstractions/base>
include <abstractions/consoles>
capability chown,
capability fsetid,
capability mknod,
capability sys_admin,
capability syslog,
@{exec_path} mr,
@{bin}/kmod Cx -> kmod,
@{sys}/bus/pci/devices/ r,
@{sys}/devices/@{pci}/config r,
@{PROC}/sys/kernel/modprobe r,
@{PROC}/devices r,
@{PROC}/driver/nvidia/capabilities/mig/config r,
@{PROC}/driver/nvidia/capabilities/mig/monitor r,
@{PROC}/driver/nvidia/params r,
@{PROC}/modules r,
owner /dev/char/@{dynamic}:@{int} w, # For dynamic assignment range 234 to 254, 384 to 511
owner /dev/char/195:@{int} w, # Nvidia graphics devices
/dev/nvidia-modeset w,
/dev/nvidia-uvm w,
/dev/nvidia-uvm-tools w,
/dev/nvidia@{int} rw,
/dev/nvidiactl rw,
owner /dev/nvidia-caps/ w,
owner /dev/nvidia-caps/nvidia-cap@{int} w,
/dev/tty@{int} rw,
profile kmod {
include <abstractions/base>
include <abstractions/consoles>
capability mknod,
# capability sys_module,
@{bin}/kmod mr,
/etc/modprobe.d/{,*.conf} r,
/etc/nvidia/{current,legacy*,tesla*}/*.conf r,
# @{sys}/module/ipmi_devintf/initstate r,
# @{sys}/module/ipmi_msghandler/initstate r,
# @{sys}/module/{drm,nvidia}/initstate r,
@{sys}/module/compression r,
@{PROC}/cmdline r,
include if exists <local/child-modprobe-nvidia_kmod>
}
include if exists <local/child-modprobe-nvidia>
}