systemdテンプレートのudevルールパラメータ

systemdテンプレートのudevルールパラメータ

背景: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_SHORT60の規則に従って生成されたのですが、私のファイルは10-local.rulesありがとう@ゆわた。 (レビューされていません。)

答え2

別の解決策として、次のような場合システムサービスはその中でスクリプトを呼び出しています。実行開始udevadmステートメント、質問に示されているものと同じ呼び出しは、このスクリプトに含めてID_SERIAL_SHORTvia経由で抽出できます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行にする必要があります。)

あるいは、実際には文字列の直後に文字列を書きます@

しかし、これは必ずしも必要ではありません。

関連情報