chiark / gitweb /
path_id: remove broken example
[elogind.git] / extras / path_id / path_id
index a6dfbf1a089dd644ea8e50923cf519b9f6463967..a7d650bf423b62b46cfd188d3b31c9814d370c53 100644 (file)
 #      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 version 2 of the License.
-#
-# to be called from a udev rule to return the name for a symlink
-#      DEVPATH=<devpath>; path_id
-#      path_id <devpath>
-
-# examples for all block devices on a system:
-#      for i in `find /sys/class/block`; do DEVPATH="`echo $i | sed -e 's@^/sys\|/dev@@g'`"; path_id; done
 
 SYSFS=/sys
 RESULT=1
@@ -220,7 +213,7 @@ handle_scsi () {
 }
 
 handle_firewire () {
-       :handle_firewire $*
+       : handle_firewire $*
        local DEV=$1
        if [ -f "$D/ieee1394_id" ] ; then
                read ieee1394_id < $D/ieee1394_id
@@ -252,6 +245,7 @@ handle_fc () {
        fi
        if [ -z "$wwpn" ] ; then
                : no WWPN
+               D=
                RESULT=1
                return
        fi
@@ -277,37 +271,51 @@ handle_sas () {
        local DEV=$1
        local cil adapter controller_dev
        # SAS device
-       sas_host_path="${DEV%%/phy*}"
+       sas_host_path="${DEV%%/port*}"
        sas_phy_path="${DEV#*/host*/}"
        sas_phy_path="${sas_phy_path%%/target*}"
        sas_phy_id="${sas_phy_path%%/*}"
-       sas_rphy_id="${sas_phy_path##*/}"
-       sas_phy_dev="/sys/class/sas_phy/${sas_phy_id}"
+       sas_phy_id="${sas_phy_id##*port-}"
+       sas_port_id="${sas_phy_path%%/end_device*}"
+       sas_port_id="${sas_port_id##*port-}"
+       sas_end_id="${sas_phy_path##*end_device-}"
+       sas_phy_dev="/sys/class/sas_phy/phy-${sas_phy_id}"
        if [ -e "$sas_phy_dev/sas_address" ]; then
                read phy_address < $sas_phy_dev/sas_address
-               read phy_port < $sas_phy_dev/port_identifier
                read phy_id < $sas_phy_dev/phy_identifier
        fi
        if [ -z "$phy_address" ] ; then
                : no initiator address
+               D=
+               RESULT=1
+               return
+       fi
+       sas_port_dev="/sys/class/sas_port/port-${sas_port_id}"
+       if [ -e "$sas_port_dev/num_phys" ] ; then
+               read phy_port < $sas_port_dev/num_phys
+       fi
+       if [ -z "$phy_port" ] ; then
+               : no initiator address
+               D=
                RESULT=1
                return
        fi
        sas_phy_address="$phy_address:$phy_port:$phy_id"
-       sas_rphy_dev="/sys/class/sas_device/${sas_rphy_id}"
-       if [ -e "$sas_rphy_dev/sas_address" ]; then
-               read rphy_address < $sas_rphy_dev/sas_address
-               read rphy_id < $sas_rphy_dev/phy_identifier
+       sas_end_dev="/sys/class/sas_device/end_device-${sas_end_id}"
+       if [ -e "$sas_end_dev/sas_address" ]; then
+               read end_address < $sas_end_dev/sas_address
+               read end_id < $sas_end_dev/phy_identifier
        fi
-       if [ -z "$rphy_address" ] ; then
+       if [ -z "$end_address" ] ; then
                : no initiator address
+               D=
                RESULT=1
                return
        fi
-       sas_rphy_address="$rphy_address:$rphy_id"
+       sas_end_address="$end_address:$end_id"
        controller_dev="${sas_host_path%/host[0-9]*}"
        # SAS devices are always endpoints
-       d="sas-${sas_phy_address}-${sas_rphy_address}"
+       d="sas-${sas_phy_address}-${sas_end_address}"
        D="$controller_dev"
        RESULT=0
 }
@@ -317,6 +325,7 @@ handle_iscsi() {
        local iscsi_session_dir
        local iscsi_session iscsi_session_path
        local iscsi_connection iscsi_connection_path
+       local iscsi_scsi_lun
        # iSCSI device
        iscsi_session_dir="${DEV%%/target*}"
        iscsi_session="${iscsi_session_dir##*/}"
@@ -363,7 +372,8 @@ handle_iscsi() {
        if [ -e "${iscsi_connection_path}/persistent_port" ] ; then
            read iscsi_port < ${iscsi_connection_path}/persistent_port
        fi
-       d="ip-${iscsi_address}:${iscsi_port}-iscsi-${iscsi_tgtname}"
+       iscsi_scsi_lun="${DEV##*:}"
+       d="ip-${iscsi_address}:${iscsi_port}-iscsi-${iscsi_tgtname}-lun-${iscsi_scsi_lun}"
        RESULT=0
 }
 
@@ -404,30 +414,35 @@ handle_usb () {
 
 handle_device () {
        full_sysfs_path="$SYSFS$DEVPATH"
-       if [ -L $full_sysfs_path/subsystem ]; then
-               # new sysfs block layout
-               full_sysfs_path="${full_sysfs_path%/*}"
-               cd "$full_sysfs_path/subsystem";
-               subsys="`pwd -P`"
-               cd "$OPWD"
-               subsys="${subsys##*/}"
-               if [ "$subsys" = "block" ]; then
-                       # parent is "block", it's a partition, move one up
-                       full_sysfs_path="${full_sysfs_path%/*}"
-               fi
-               cd $full_sysfs_path
-       else
-               # old sysfs block layout
-               if [ ! -L $full_sysfs_path/device ] ; then
-                       if [ -f $full_sysfs_path/range ] ; then return ; fi
-                       full_sysfs_path="${full_sysfs_path%/*}"
-                       : full_sysfs_path "$full_sysfs_path"
-                       if [ ! -L $full_sysfs_path/device -o ! -f $full_sysfs_path/dev ] ; then
-                               return
+       case "$DEVPATH" in
+               /devices/*)
+                       # new sysfs layout
+                       if [ -L $full_sysfs_path/subsystem ]; then
+                               full_sysfs_path="${full_sysfs_path%/*}"
+                               cd "$full_sysfs_path/subsystem";
+                               subsys="`pwd -P`"
+                               cd "$OPWD"
+                               subsys="${subsys##*/}"
+                               if [ "$subsys" = "block" ]; then
+                                       # parent is "block", it's a partition, move one up
+                               full_sysfs_path="${full_sysfs_path%/*}"
+                               fi
+                               cd $full_sysfs_path
                        fi
-               fi
-               cd $full_sysfs_path/device
-       fi
+                       ;;
+               *)
+                       # old sysfs layout
+                       if [ ! -L $full_sysfs_path/device ] ; then
+                               if [ -f $full_sysfs_path/range ] ; then return ; fi
+                               full_sysfs_path="${full_sysfs_path%/*}"
+                               : full_sysfs_path "$full_sysfs_path"
+                               if [ ! -L $full_sysfs_path/device -o ! -f $full_sysfs_path/dev ] ; then
+                                       return
+                               fi
+                       fi
+                       cd $full_sysfs_path/device
+                       ;;
+       esac
        full_sysfs_device_path="`pwd -P`"
        cd "$OPWD"
        D=$full_sysfs_device_path
@@ -462,7 +477,7 @@ handle_device () {
                        */rport-[0-9]*:[0-9]*-[0-9]*/*)
                                handle_fc "$D"
                                ;;
-                       */phy-[0-9]*:[0-9]*/*)
+                       */end_device-[0-9]*:[0-9]*:[0-9]*/*)
                                handle_sas "$D"
                                ;;
                        */fw-host[0-9]*/*)