]> git.ipfire.org Git - thirdparty/systemd.git/blame - rules/99-systemd.rules.in
Merge pull request #417 from ssahani/ipv6-private
[thirdparty/systemd.git] / rules / 99-systemd.rules.in
CommitLineData
dec1c02a
LP
1# This file is part of systemd.
2#
dec1c02a 3# systemd is free software; you can redistribute it and/or modify it
5430f7f2
LP
4# under the terms of the GNU Lesser General Public License as published by
5# the Free Software Foundation; either version 2.1 of the License, or
dec1c02a 6# (at your option) any later version.
5cc5d790 7
c9f09cda 8ACTION=="remove", GOTO="systemd_end"
5cc5d790 9
fc6c7fe9 10SUBSYSTEM=="tty", KERNEL=="tty[a-zA-Z]*|hvc*|xvc*|hvsi*|ttysclp*|sclp_line*|3270/tty[0-9]*", TAG+="systemd"
d5762cf5
LP
11KERNEL=="vport*", TAG+="systemd"
12
ea7b5237
KS
13SUBSYSTEM=="block", TAG+="systemd"
14SUBSYSTEM=="block", ENV{DM_UDEV_DISABLE_OTHER_RULES_FLAG}=="1", ENV{SYSTEMD_READY}="0"
90e6abae
LP
15
16# Ignore encrypted devices with no identified superblock on it, since
17# we are probably still calling mke2fs or mkswap on it.
ea7b5237 18SUBSYSTEM=="block", ENV{DM_UUID}=="CRYPT-*", ENV{ID_PART_TABLE_TYPE}=="", ENV{ID_FS_USAGE}=="", ENV{SYSTEMD_READY}="0"
afb757b1 19
a96e4839 20# Ignore raid devices that are not yet assembled and started
d2fff1ce
KS
21SUBSYSTEM=="block", ENV{DEVTYPE}=="disk", KERNEL=="md*", TEST!="md/array_state", ENV{SYSTEMD_READY}="0"
22SUBSYSTEM=="block", ENV{DEVTYPE}=="disk", KERNEL=="md*", ATTR{md/array_state}=="|clear|inactive", ENV{SYSTEMD_READY}="0"
a96e4839 23
ebc54302 24# Ignore loop devices that don't have any file attached
b5df2eab 25SUBSYSTEM=="block", KERNEL=="loop[0-9]*", ENV{DEVTYPE}=="disk", TEST!="loop/backing_file", ENV{SYSTEMD_READY}="0"
ebc54302 26
45646bb0
HH
27# Ignore nbd devices in the "add" event, with "change" the nbd is ready
28ACTION=="add", SUBSYSTEM=="block", KERNEL=="nbd*", ENV{SYSTEMD_READY}="0"
29
a1d82102 30# We need a hardware independent way to identify network devices. We
ea7b5237
KS
31# use the /sys/subsystem/ path for this. Kernel "bus" and "class" names
32# should be treated as one namespace, like udev handles it. This is mostly
33# just an identification string for systemd, so whether the path actually is
afb757b1
LP
34# accessible or not does not matter as long as it is unique and in the
35# filesystem namespace.
36#
ea7b5237 37# http://cgit.freedesktop.org/systemd/systemd/tree/src/libudev/libudev-enumerate.c#n955
afb757b1 38
07845c14
KS
39SUBSYSTEM=="net", KERNEL!="lo", TAG+="systemd", ENV{SYSTEMD_ALIAS}+="/sys/subsystem/net/devices/$name"
40SUBSYSTEM=="bluetooth", TAG+="systemd", ENV{SYSTEMD_ALIAS}+="/sys/subsystem/bluetooth/devices/%k"
5cc5d790 41
07845c14 42SUBSYSTEM=="bluetooth", TAG+="systemd", ENV{SYSTEMD_WANTS}+="bluetooth.target"
64dfe7b7 43ENV{ID_SMARTCARD_READER}=="?*", TAG+="systemd", ENV{SYSTEMD_WANTS}+="smartcard.target"
07845c14 44SUBSYSTEM=="sound", KERNEL=="card*", TAG+="systemd", ENV{SYSTEMD_WANTS}+="sound.target"
da78e1b4 45
07845c14
KS
46SUBSYSTEM=="printer", TAG+="systemd", ENV{SYSTEMD_WANTS}+="printer.target"
47SUBSYSTEM=="usb", KERNEL=="lp*", TAG+="systemd", ENV{SYSTEMD_WANTS}+="printer.target"
48SUBSYSTEM=="usb", ENV{DEVTYPE}=="usb_device", ENV{ID_USB_INTERFACES}=="*:0701??:*", TAG+="systemd", ENV{SYSTEMD_WANTS}+="printer.target"
5db35d06 49
a65f4aeb 50# Apply sysctl variables to network devices (and only to those) as they appear.
1b600437 51ACTION=="add", SUBSYSTEM=="net", KERNEL!="lo", RUN+="@rootlibexecdir@/systemd-sysctl --prefix=/net/ipv4/conf/$name --prefix=/net/ipv4/neigh/$name --prefix=/net/ipv6/conf/$name --prefix=/net/ipv6/neigh/$name"
41e4d6e9 52
0f4ba83c
LP
53# Pull in backlight save/restore for all backlight devices and
54# keyboard backlights
e0d856dd
LP
55SUBSYSTEM=="backlight", TAG+="systemd", IMPORT{builtin}="path_id", ENV{SYSTEMD_WANTS}+="systemd-backlight@backlight:$name.service"
56SUBSYSTEM=="leds", KERNEL=="*kbd_backlight", TAG+="systemd", IMPORT{builtin}="path_id", ENV{SYSTEMD_WANTS}+="systemd-backlight@leds:$name.service"
3731acf1 57
3990f247
LP
58# Pull in rfkill save/restore for all rfkill devices
59
812bd1e6 60SUBSYSTEM=="rfkill", TAG+="systemd", IMPORT{builtin}="path_id", ENV{SYSTEMD_ALIAS}+="/sys/subsystem/rfkill/devices/%k", ENV{SYSTEMD_WANTS}+="systemd-rfkill@$name.service"
3990f247 61
ea7b5237 62# Asynchronously mount file systems implemented by these modules as soon as they are loaded.
e0d856dd
LP
63SUBSYSTEM=="module", KERNEL=="fuse", TAG+="systemd", ENV{SYSTEMD_WANTS}+="sys-fs-fuse-connections.mount"
64SUBSYSTEM=="module", KERNEL=="configfs", TAG+="systemd", ENV{SYSTEMD_WANTS}+="sys-kernel-config.mount"
a65f4aeb 65
5cc5d790 66LABEL="systemd_end"