| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126 | #!/bin/sh -e# This script is run if an optical drive lacks a rule for persistent naming.## It adds symlinks for optical drives based on the device class determined# by cdrom_id and used ID_PATH to identify the device.# (C) 2006 Marco d'Itri <md@Linux.IT>## This program is free software: you can redistribute it and/or modify# it under the terms of the GNU General Public License as published by# the Free Software Foundation, either version 2 of the License, or# (at your option) any later version.# This program is distributed in the hope that it will be useful,# but WITHOUT ANY WARRANTY; without even the implied warranty of# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the# GNU General Public License for more details.# You should have received a copy of the GNU General Public License# along with this program.  If not, see <http://www.gnu.org/licenses/>.# debug, if UDEV_LOG=<debug>if [ -n "$UDEV_LOG" ]; then        if [ "$UDEV_LOG" -ge 7 ]; then                set -x        fifiRULES_FILE="/etc/udev/rules.d/70-persistent-cd.rules". /lib/udev/rule_generator.functionsfind_next_available() {        raw_find_next_available "$(find_all_rules 'SYMLINK\+=' "$1")"}write_rule() {        local match="$1"        local link="$2"        local comment="$3"        {        if [ "$PRINT_HEADER" ]; then                PRINT_HEADER=                echo "# This file was automatically generated by the $0"                echo "# program, run by the cd-aliases-generator.rules rules file."                echo "#"                echo "# You can modify it, as long as you keep each rule on a single"                echo "# line, and set the \$GENERATED variable."                echo ""        fi        [ "$comment" ] && echo "# $comment"        echo "$match, SYMLINK+=\"$link\", ENV{GENERATED}=\"1\""        } >> $RULES_FILE        SYMLINKS="$SYMLINKS $link"}if [ -z "$DEVPATH" ]; then        echo "Missing \$DEVPATH." >&2        exit 1fiif [ -z "$ID_CDROM" ]; then        echo "$DEVPATH is not a CD reader." >&2        exit 1fiif [ "$1" ]; then        METHOD="$1"else        METHOD='by-path'ficase "$METHOD" in        by-path)        if [ -z "$ID_PATH" ]; then                echo "$DEVPATH not supported by path_id. by-id may work." >&2                exit 1        fi        RULE="ENV{ID_PATH}==\"$ID_PATH\""        ;;        by-id)        if [ "$ID_SERIAL" ]; then                RULE="ENV{ID_SERIAL}==\"$ID_SERIAL\""        elif [ "$ID_MODEL" -a "$ID_REVISION" ]; then                RULE="ENV{ID_MODEL}==\"$ID_MODEL\", ENV{ID_REVISION}==\"$ID_REVISION\""        else                echo "$DEVPATH not supported by ata_id. by-path may work." >&2                exit 1        fi        ;;        *)        echo "Invalid argument (must be either by-path or by-id)." >&2        exit 1        ;;esac# Prevent concurrent processes from modifying the file at the same time.lock_rules_file# Check if the rules file is writeable.choose_rules_filelink_num=$(find_next_available 'cdrom[0-9]*')match="SUBSYSTEM==\"block\", ENV{ID_CDROM}==\"?*\", $RULE"comment="$ID_MODEL ($ID_PATH)"        write_rule "$match" "cdrom$link_num" "$comment"[ "$ID_CDROM_CD_R" -o "$ID_CDROM_CD_RW" ] && \        write_rule "$match" "cdrw$link_num"[ "$ID_CDROM_DVD" ] && \        write_rule "$match" "dvd$link_num"[ "$ID_CDROM_DVD_R" -o "$ID_CDROM_DVD_RW" -o "$ID_CDROM_DVD_RAM" ] && \        write_rule "$match" "dvdrw$link_num"echo >> $RULES_FILEunlock_rules_fileecho $SYMLINKSexit 0
 |