]> git.ipfire.org Git - thirdparty/systemd.git/blob - rules.d/50-udev-default.rules.in
Merge pull request #28360 from keszybz/pointingstick-accel-drop
[thirdparty/systemd.git] / rules.d / 50-udev-default.rules.in
1 # do not edit this file, it will be overwritten on update
2
3 # run a command on remove events
4 ACTION=="remove", ENV{REMOVE_CMD}!="", RUN+="$env{REMOVE_CMD}"
5 ACTION=="remove", GOTO="default_end"
6
7 # The md driver increments diskseq *after* emitting 'change' uevent.
8 # Drop the line below if it is fixed on the kernel side.
9 SUBSYSTEM=="block", KERNEL=="md*", ENV{ID_IGNORE_DISKSEQ}="1"
10
11 SUBSYSTEM=="virtio-ports", KERNEL=="vport*", ATTR{name}=="?*", SYMLINK+="virtio-ports/$attr{name}"
12
13 # select "system RTC" or just use the first one
14 SUBSYSTEM=="rtc", ATTR{hctosys}=="1", SYMLINK+="rtc"
15 SUBSYSTEM=="rtc", KERNEL=="rtc0", SYMLINK+="rtc", OPTIONS+="link_priority=-100"
16
17 SUBSYSTEM=="usb", ENV{DEVTYPE}=="usb_device", IMPORT{builtin}="usb_id", IMPORT{builtin}="hwdb --subsystem=usb"
18 ENV{MODALIAS}!="", IMPORT{builtin}="hwdb --subsystem=$env{SUBSYSTEM}"
19
20 # Before c43ff248f94266cfc93e300a2d3d163ed805e55b, the following line in
21 # 60-drm.rules also sets ID_PATH for all pci, usb, and platform devices:
22 ####
23 # ACTION!="remove", SUBSYSTEM=="drm", SUBSYSTEMS=="pci|usb|platform", IMPORT{builtin}="path_id"
24 ####
25 # Unfortunately, some existing rules already rely on the unexpected behavior.
26 # To keep the backward compatibility, let's set ID_PATH for them.
27 SUBSYSTEM=="pci|usb|platform", IMPORT{builtin}="path_id"
28
29 ACTION!="add", GOTO="default_end"
30
31 SUBSYSTEM=="tty", KERNEL=="ptmx", GROUP="tty", MODE="0666"
32 SUBSYSTEM=="tty", KERNEL=="tty", GROUP="tty", MODE="0666"
33 SUBSYSTEM=="tty", KERNEL=="tty[0-9]*", GROUP="tty", MODE="0620"
34 SUBSYSTEM=="tty", KERNEL=="sclp_line[0-9]*", GROUP="tty", MODE="0620"
35 SUBSYSTEM=="tty", KERNEL=="ttysclp[0-9]*", GROUP="tty", MODE="0620"
36 SUBSYSTEM=="tty", KERNEL=="3270/tty[0-9]*", GROUP="tty", MODE="0620"
37 SUBSYSTEM=="vc", KERNEL=="vcs*|vcsa*", GROUP="tty"
38 KERNEL=="tty[A-Z]*[0-9]|ttymxc[0-9]*|pppox[0-9]*|ircomm[0-9]*|noz[0-9]*|rfcomm[0-9]*", GROUP="dialout"
39
40 SUBSYSTEM=="mem", KERNEL=="mem|kmem|port", GROUP="kmem", MODE="0640"
41
42 SUBSYSTEM=="input", GROUP="input"
43 SUBSYSTEM=="input", KERNEL=="js[0-9]*", MODE="0664"
44
45 SUBSYSTEM=="video4linux", GROUP="video"
46 SUBSYSTEM=="graphics", GROUP="video"
47 SUBSYSTEM=="drm", KERNEL!="renderD*", GROUP="video"
48 SUBSYSTEM=="dvb", GROUP="video"
49 SUBSYSTEM=="media", GROUP="video"
50 SUBSYSTEM=="cec", GROUP="video"
51
52 SUBSYSTEM=="drm", KERNEL=="renderD*", GROUP="render", MODE="{{GROUP_RENDER_MODE}}"
53 SUBSYSTEM=="kfd", GROUP="render", MODE="{{GROUP_RENDER_MODE}}"
54 SUBSYSTEM=="accel", GROUP="render", MODE="{{GROUP_RENDER_MODE}}"
55
56 SUBSYSTEM=="misc", KERNEL=="sgx_enclave", GROUP="sgx", MODE="0660"
57 SUBSYSTEM=="misc", KERNEL=="sgx_vepc", GROUP="sgx", MODE="0660"
58
59 # When using static_node= with non-default permissions, also update
60 # tmpfiles.d/static-nodes-permissions.conf.in to keep permissions synchronized.
61
62 SUBSYSTEM=="sound", GROUP="audio", \
63 OPTIONS+="static_node=snd/seq", OPTIONS+="static_node=snd/timer"
64
65 SUBSYSTEM=="usb", ENV{DEVTYPE}=="usb_device", MODE="0664"
66
67 SUBSYSTEM=="firewire", TEST=="units", TEST=="model", \
68 IMPORT{builtin}="hwdb 'ieee1394:node:ven$attr{vendor}mo$attr{model}units$attr{units}'"
69
70 SUBSYSTEM=="firewire", TEST=="units", TEST!="model", \
71 IMPORT{builtin}="hwdb 'ieee1394:node:ven$attr{vendor}units$attr{units}'"
72
73 SUBSYSTEM=="firewire", TEST=="units", ENV{IEEE1394_UNIT_FUNCTION_MIDI}=="1", GROUP="audio"
74 SUBSYSTEM=="firewire", TEST=="units", ENV{IEEE1394_UNIT_FUNCTION_AUDIO}=="1", GROUP="audio"
75 SUBSYSTEM=="firewire", TEST=="units", ENV{IEEE1394_UNIT_FUNCTION_VIDEO}=="1", GROUP="video"
76
77 KERNEL=="parport[0-9]*", GROUP="lp"
78 SUBSYSTEM=="printer", KERNEL=="lp*", GROUP="lp"
79 SUBSYSTEM=="ppdev", GROUP="lp"
80 KERNEL=="lp[0-9]*", GROUP="lp"
81 KERNEL=="irlpt[0-9]*", GROUP="lp"
82 SUBSYSTEM=="usb", ENV{DEVTYPE}=="usb_device", ENV{ID_USB_INTERFACES}=="*:0701??:*", GROUP="lp"
83
84 SUBSYSTEM=="block", GROUP="disk"
85 SUBSYSTEM=="block", KERNEL=="sr[0-9]*", GROUP="cdrom"
86 SUBSYSTEM=="scsi_generic", SUBSYSTEMS=="scsi", ATTRS{type}=="4|5", GROUP="cdrom"
87 KERNEL=="sch[0-9]*", GROUP="cdrom"
88 KERNEL=="pktcdvd[0-9]*", GROUP="cdrom"
89 KERNEL=="pktcdvd", GROUP="cdrom"
90
91 SUBSYSTEM=="scsi_generic|scsi_tape", SUBSYSTEMS=="scsi", ATTRS{type}=="1|8", GROUP="tape"
92 SUBSYSTEM=="scsi_generic", SUBSYSTEMS=="scsi", ATTRS{type}=="0", GROUP="disk"
93 KERNEL=="qft[0-9]*|nqft[0-9]*|zqft[0-9]*|nzqft[0-9]*|rawqft[0-9]*|nrawqft[0-9]*", GROUP="disk"
94 KERNEL=="loop-control", GROUP="disk", OPTIONS+="static_node=loop-control"
95 KERNEL=="btrfs-control", GROUP="disk"
96 KERNEL=="rawctl", GROUP="disk"
97 SUBSYSTEM=="raw", KERNEL=="raw[0-9]*", GROUP="disk"
98 SUBSYSTEM=="aoe", GROUP="disk", MODE="0220"
99 SUBSYSTEM=="aoe", KERNEL=="err", MODE="0440"
100
101 KERNEL=="rfkill", MODE="0664"
102 KERNEL=="tun", MODE="0666", OPTIONS+="static_node=net/tun"
103
104 KERNEL=="fuse", MODE="0666", OPTIONS+="static_node=fuse"
105
106 # The static_node is required on s390x and ppc (they are using MODULE_ALIAS)
107 KERNEL=="kvm", GROUP="kvm", MODE="{{DEV_KVM_MODE}}", OPTIONS+="static_node=kvm"
108
109 KERNEL=="vfio", MODE="0666", OPTIONS+="static_node=vfio/vfio"
110
111 KERNEL=="vsock", MODE="0666"
112 KERNEL=="vhost-vsock", GROUP="kvm", MODE="{{DEV_KVM_MODE}}", OPTIONS+="static_node=vhost-vsock"
113
114 KERNEL=="vhost-net", GROUP="kvm", MODE="{{DEV_KVM_MODE}}", OPTIONS+="static_node=vhost-net"
115
116 KERNEL=="udmabuf", GROUP="kvm"
117
118 SUBSYSTEM=="ptp", ATTR{clock_name}=="KVM virtual PTP", SYMLINK+="ptp_kvm"
119 SUBSYSTEM=="ptp", ATTR{clock_name}=="hyperv", SYMLINK+="ptp_hyperv"
120
121 LABEL="default_end"