背景:USB-UARTデバイスが接続されたら、ロギングスクリプトを起動したいと思います。
私のもの/etc/udev/rules.d/10-local.rules
:
SUBSYSTEM=="tty", ATTRS{idVendor}=="1366", ATTRS{idProduct}=="1015", ATTRS{serial}=="000621000000", SYMLINK+="ttymkw", TAG+="systemd", ENV{SYSTEMD_USER_WANTS}+="offnet-uart-log@$env{ID_SERIAL_SHORT}.service"
私のもの:~/.config/systemd/user/[email protected]
[Unit]
Description=Start log of UART
[Service]
ExecStart=sh -c "echo %I >> /tmp/systemd.test"
これは私に期待される価値を提供しませんID_SERIAL_SHORT
。代わりに、非常に長いシステムパスを取得します。
sys/devices/pci0000:00/0000:00:1c.0/0000:01:00.0/0000:02:02.0/0000:39:00.0/usb3/3-1/3-1.7/3-1.7.2/3-1.7.2:1.0/tty/ttyACM0
このパスの属性を取得しようとすると(先行を削除する必要がある場合sys
)、次のようになりますID_SERIAL_SHORT
。
$ udevadm info --query=property --path /devices/pci0000:00/0000:00:1c.0/0000:01:00.0/0000:02:02.0/0000:39:00.0/usb3/3-1/3-1.7/3-1.7.2/3-1.7.2:1.0/tty/ttyACM0DEVPATH=//devices/pci0000:00/0000:00:1c.0/0000:01:00.0/0000:02:02.0/0000:39:00.0/usb3/3-1/3-1.7/3-1.7.2/3-1.7.2:1.0/tty/ttyACM0
DEVNAME=/dev/ttyACM0
MAJOR=166
MINOR=0
SUBSYSTEM=tty
USEC_INITIALIZED=1633350773062
[email protected]
ID_BUS=usb
ID_VENDOR_ID=1366
ID_MODEL_ID=1015
ID_PCI_CLASS_FROM_DATABASE=Serial bus controller
ID_PCI_SUBCLASS_FROM_DATABASE=USB controller
ID_PCI_INTERFACE_FROM_DATABASE=XHCI
ID_VENDOR_FROM_DATABASE=SEGGER
ID_MODEL_FROM_DATABASE=DSL6340 USB 3.1 Controller [Alpine Ridge]
ID_VENDOR=SEGGER
ID_VENDOR_ENC=SEGGER
ID_MODEL=J-Link
ID_MODEL_ENC=J-Link
ID_REVISION=0100
ID_SERIAL=SEGGER_J-Link_000621000000
ID_SERIAL_SHORT=000621000000 ### <--- here
ID_TYPE=generic
ID_USB_INTERFACES=:020201:0a0000:ffffff:080650:
ID_USB_INTERFACE_NUM=00
ID_USB_DRIVER=cdc_acm
ID_USB_CLASS_FROM_DATABASE=Miscellaneous Device
ID_USB_PROTOCOL_FROM_DATABASE=Interface Association
ID_PATH=pci-0000:39:00.0-usb-0:1.7.2:1.0
ID_PATH_TAG=pci-0000_39_00_0-usb-0_1_7_2_1_0
ID_MM_CANDIDATE=1
DEVLINKS=/dev/ttymkw /dev/serial/by-id/usb-SEGGER_J-Link_000621000000-if00 /dev/serial/by-path/pci-0000:39:00.0-usb-0:1.7.2:1.0
TAGS=:systemd:
$env{ID_SERIAL_SHORT}
私のudevルールの属性値に置き換えられないようです。
udev のマニュアルページには、$env{key}
置換が NAME、SYMLINK、PROGRAM、OWNER、GROUP、MODE、SECLABEL、および RUN フィールドにのみ適用されることが示されています。
しかし、私は見たことがないそれを使う人の例存在するENV{SYSTEMD_USER_WANTS}
。明らかにこれは私には効果がありません。
デバイスのシリアル番号をsystemdテンプレートに渡すには?
編集:私も試したこれしかし、:
SUBSYSTEM=="tty", ATTRS{idVendor}=="1366", ATTRS{idProduct}=="1015", ATTRS{serial}=="000621000000", SYMLINK+="ttymkw", PROGRAM="/bin/systemd-escape -p [email protected] $env{ID_SERIAL_SHORT}", ENV{SYSTEMD_WANTS}+="%c"
答え1
私が探しているパラメータは$attr{serial}
。 10-)が作成されました。環境変数ID_SERIALのルールファイルは、60-)から始まり、以前に読み込まれました。これは次のようになります。
udevルール:
SUBSYSTEM=="tty", ATTRS{idVendor}=="1366", SYMLINK+="ttymkw", ENV{SYSTEMD_WANTS}+="offnet-uart-log@$attr{serial}"
システムテンプレート:
[Unit]
Description=Start log of UART for a Offnet unit
[Service]
ExecStart=/bin/sh -c "/bin/echo %i >> /tmp/asdf.log"
明らかにそれは必要ではなく、使用する必要がありますTAG
。$attr
$env
システムバージョンは241です。
これQ&Aこれは私に役立ちます。
編集:うまくいかない理由の1つは、$env
レベルID_SERIAL_SHORT
60の規則に従って生成されたのですが、私のファイルは10-local.rules
。ありがとう@ゆわた。 (レビューされていません。)
答え2
別の解決策として、次のような場合システムサービスはその中でスクリプトを呼び出しています。実行開始udevadm
ステートメント、質問に示されているものと同じ呼び出しは、このスクリプトに含めてID_SERIAL_SHORT
via経由で抽出できますgrep
。
答え3
回避策として、udevルールに独自の環境変数を作成できます。
SUBSYSTEM=="tty", ATTRS{idVendor}=="1366", ATTRS{idProduct}=="1015", \
ATTRS{serial}=="000621000000", SYMLINK+="ttymkw", TAG+="systemd", \
ENV{MY_ID}="000621000000", \
ENV{SYSTEMD_USER_WANTS}+="offnet-uart-log@$env{MY_ID}.service"
(読みやすくするために、バックスラッシュは1行にする必要があります。)
あるいは、実際には文字列の直後に文字列を書きます@
。
しかし、これは必ずしも必要ではありません。