X7ROOT File Manager
Current Path:
/usr/lib/udev/rules.d
usr
/
lib
/
udev
/
rules.d
/
📁
..
📄
10-dm.rules
(7.1 KB)
📄
13-dm-disk.rules
(1.75 KB)
📄
40-redhat-disable-dell-ir-camera.rules
(135 B)
📄
40-redhat-disable-lenovo-ir-camera.rules
(496 B)
📄
40-redhat.rules
(1.74 KB)
📄
42-usb-hid-pm.rules
(2.16 KB)
📄
50-udev-default.rules
(3.21 KB)
📄
60-alias-kmsg.rules
(357 B)
📄
60-cdrom_id.rules
(910 B)
📄
60-drm.rules
(153 B)
📄
60-evdev.rules
(532 B)
📄
60-keyboard.rules
(821 B)
📄
60-net.rules
(129 B)
📄
60-persistent-alsa.rules
(616 B)
📄
60-persistent-input.rules
(2.41 KB)
📄
60-persistent-serial.rules
(947 B)
📄
60-persistent-storage-tape.rules
(1.53 KB)
📄
60-persistent-storage.rules
(7.1 KB)
📄
60-persistent-v4l.rules
(769 B)
📄
60-raw.rules
(326 B)
📄
61-accelerometer.rules
(166 B)
📄
63-fc-wwpn-id.rules
(624 B)
📄
64-btrfs-dm.rules
(387 B)
📄
64-btrfs.rules
(418 B)
📄
66-azure-ephemeral.rules
(1.91 KB)
📄
70-mouse.rules
(734 B)
📄
70-power-switch.rules
(706 B)
📄
70-touchpad.rules
(345 B)
📄
70-uaccess.rules
(2.53 KB)
📄
71-seat.rules
(2.3 KB)
📄
73-idrac.rules
(316 B)
📄
73-seat-late.rules
(596 B)
📄
75-net-description.rules
(452 B)
📄
75-probe_mtd.rules
(174 B)
📄
75-tty-description.rules
(426 B)
📄
76-phys-port-name.rules
(473 B)
📄
78-sound-card.rules
(4.3 KB)
📄
80-drivers.rules
(618 B)
📄
80-net-name-slot.rules
(491 B)
📄
80-net-setup-link.rules
(292 B)
📄
81-kvm-rhel.rules
(92 B)
📄
90-vconsole.rules
(441 B)
📄
91-drm-modeset.rules
(56 B)
📄
95-dm-notify.rules
(483 B)
📄
95-udev-late.rules
(155 B)
📄
98-kexec.rules
(689 B)
📄
99-qemu-guest-agent.rules
(130 B)
📄
99-systemd.rules
(3.98 KB)
Editing: 78-sound-card.rules
# do not edit this file, it will be overwritten on update SUBSYSTEM!="sound", GOTO="sound_end" ACTION=="add|change", KERNEL=="controlC*", ATTR{../uevent}="change" ACTION!="change", GOTO="sound_end" # Ok, we probably need a little explanation here for what the two lines above # are good for. # # The story goes like this: when ALSA registers a new sound card it emits a # series of 'add' events to userspace, for the main card device and for all the # child device nodes that belong to it. udev relays those to applications, # however only maintains the order between father and child, but not between # the siblings. The control device node creation can be used as synchronization # point. All other devices that belong to a card are created in the kernel # before it. However unfortunately due to the fact that siblings are forwarded # out of order by udev this fact is lost to applications. # # OTOH before an application can open a device it needs to make sure that all # its device nodes are completely created and set up. # # As a workaround for this issue we have added the udev rule above which will # generate a 'change' event on the main card device from the 'add' event of the # card's control device. Due to the ordering semantics of udev this event will # only be relayed after all child devices have finished processing properly. # When an application needs to listen for appearing devices it can hence look # for 'change' events only, and ignore the actual 'add' events. # # When the application is initialized at the same time as a device is plugged # in it may need to figure out if the 'change' event has already been triggered # or not for a card. To find that out we store the flag environment variable # SOUND_INITIALIZED on the device which simply tells us if the card 'change' # event has already been processed. KERNEL!="card*", GOTO="sound_end" ENV{SOUND_INITIALIZED}="1" IMPORT{builtin}="hwdb" SUBSYSTEMS=="usb", IMPORT{builtin}="usb_id" SUBSYSTEMS=="usb", GOTO="skip_pci" SUBSYSTEMS=="firewire", ATTRS{vendor_name}=="?*", ATTRS{model_name}=="?*", \ ENV{ID_BUS}="firewire", ENV{ID_VENDOR}="$attr{vendor_name}", ENV{ID_MODEL}="$attr{model_name}" SUBSYSTEMS=="firewire", ATTRS{guid}=="?*", ENV{ID_ID}="firewire-$attr{guid}" SUBSYSTEMS=="firewire", GOTO="skip_pci" SUBSYSTEMS=="pci", ENV{ID_BUS}="pci", ENV{ID_VENDOR_ID}="$attr{vendor}", ENV{ID_MODEL_ID}="$attr{device}" LABEL="skip_pci" ENV{ID_SERIAL}=="?*", ENV{ID_USB_INTERFACE_NUM}=="?*", ENV{ID_ID}="$env{ID_BUS}-$env{ID_SERIAL}-$env{ID_USB_INTERFACE_NUM}-$attr{id}" ENV{ID_SERIAL}=="?*", ENV{ID_USB_INTERFACE_NUM}=="", ENV{ID_ID}="$env{ID_BUS}-$env{ID_SERIAL}-$attr{id}" IMPORT{builtin}="path_id" # The values used here for $SOUND_FORM_FACTOR and $SOUND_CLASS should be kept # in sync with those defined for PulseAudio's src/pulse/proplist.h # PA_PROP_DEVICE_FORM_FACTOR, PA_PROP_DEVICE_CLASS properties. # If the first PCM device of this card has the pcm class 'modem', then the card is a modem ATTR{pcmC%nD0p/pcm_class}=="modem", ENV{SOUND_CLASS}="modem", GOTO="sound_end" # Identify cards on the internal PCI bus as internal SUBSYSTEMS=="pci", DEVPATH=="*/0000:00:??.?/sound/*", ENV{SOUND_FORM_FACTOR}="internal", GOTO="sound_end" # Devices that also support Image/Video interfaces are most likely webcams SUBSYSTEMS=="usb", ENV{ID_USB_INTERFACES}=="*:0e????:*", ENV{SOUND_FORM_FACTOR}="webcam", GOTO="sound_end" # Matching on the model strings is a bit ugly, I admit ENV{ID_MODEL}=="*[Ss]peaker*", ENV{SOUND_FORM_FACTOR}="speaker", GOTO="sound_end" ENV{ID_MODEL_FROM_DATABASE}=="*[Ss]peaker*", ENV{SOUND_FORM_FACTOR}="speaker", GOTO="sound_end" ENV{ID_MODEL}=="*[Hh]eadphone*", ENV{SOUND_FORM_FACTOR}="headphone", GOTO="sound_end" ENV{ID_MODEL_FROM_DATABASE}=="*[Hh]eadphone*", ENV{SOUND_FORM_FACTOR}="headphone", GOTO="sound_end" ENV{ID_MODEL}=="*[Hh]eadset*", ENV{SOUND_FORM_FACTOR}="headset", GOTO="sound_end" ENV{ID_MODEL_FROM_DATABASE}=="*[Hh]eadset*", ENV{SOUND_FORM_FACTOR}="headset", GOTO="sound_end" ENV{ID_MODEL}=="*[Hh]andset*", ENV{SOUND_FORM_FACTOR}="handset", GOTO="sound_end" ENV{ID_MODEL_FROM_DATABASE}=="*[Hh]andset*", ENV{SOUND_FORM_FACTOR}="handset", GOTO="sound_end" ENV{ID_MODEL}=="*[Mm]icrophone*", ENV{SOUND_FORM_FACTOR}="microphone", GOTO="sound_end" ENV{ID_MODEL_FROM_DATABASE}=="*[Mm]icrophone*", ENV{SOUND_FORM_FACTOR}="microphone", GOTO="sound_end" LABEL="sound_end"
Upload File
Create Folder