Udev

為什麼udev會自動將我的RAID卡列入白名單,這個白名單的作用是什麼?

  • September 16, 2022

我一直在學習使用 udev 並註意到當我執行時udevadm test --action="add" /sys/block/sdc我看到以下內容:

GROUP 6 /usr/lib/udev/rules.d/50-udev-default.rules:59
IMPORT 'scsi_id --export --whitelisted -d /dev/sdc' /usr/lib/udev/rules.d/60-persistent-storage.rules:50
starting 'scsi_id --export --whitelisted -d /dev/sdc'
'scsi_id --export --whitelisted -d /dev/sdc'(out) 'ID_SCSI=1'
'scsi_id --export --whitelisted -d /dev/sdc'(out) 'ID_VENDOR=NVMe'
'scsi_id --export --whitelisted -d /dev/sdc'(out) 'ID_VENDOR_ENC=NVMe\x20\x20\x20\x20'
'scsi_id --export --whitelisted -d /dev/sdc'(out) 'ID_MODEL=Dell_Ent_NVMe_v2'
'scsi_id --export --whitelisted -d /dev/sdc'(out) 'ID_MODEL_ENC=Dell\x20Ent\x20NVMe\x20v2'
'scsi_id --export --whitelisted -d /dev/sdc'(out) 'ID_REVISION=.2.0'
'scsi_id --export --whitelisted -d /dev/sdc'(out) 'ID_TYPE=disk'
'scsi_id --export --whitelisted -d /dev/sdc'(out) 'ID_SERIAL=236435330529024120025384100000002'
'scsi_id --export --whitelisted -d /dev/sdc'(out) 'ID_SERIAL_SHORT=36435330529024120025384100000002'
'scsi_id --export --whitelisted -d /dev/sdc'(out) 'ID_SCSI_SERIAL=S6CSNA0R902412      '
Process 'scsi_id --export --whitelisted -d /dev/sdc' succeeded.

在這種情況下,sdc 是位於 PERC H755 上的虛擬磁碟。我還沒有改變 udev 中的任何內容。

以上是您在使用 RAID0(直通/JBOD 模式)時看到的內容。如果您創建 RAID 5,您會看到

probe /dev/sda raid offset=0
LINK 'disk/by-id/wwn-0x6f4ee080160bd5002ab7652100a1691a' /usr/lib/udev/rules.d/60-persistent-storage.rules:97
IMPORT '/usr/bin/sg_inq --export --inhex=/sys/block/sda/device/inquiry --raw' /usr/lib/udev/rules.d/61-scsi-sg3_id.rules:17
starting '/usr/bin/sg_inq --export --inhex=/sys/block/sda/device/inquiry --raw'
'/usr/bin/sg_inq --export --inhex=/sys/block/sda/device/inquiry --raw'(out) 'SCSI_TPGS=0'
'/usr/bin/sg_inq --export --inhex=/sys/block/sda/device/inquiry --raw'(out) 'SCSI_TYPE=disk'
'/usr/bin/sg_inq --export --inhex=/sys/block/sda/device/inquiry --raw'(out) 'SCSI_VENDOR=DELL'
'/usr/bin/sg_inq --export --inhex=/sys/block/sda/device/inquiry --raw'(out) 'SCSI_VENDOR_ENC=DELL\x20\x20\x20\x20'
'/usr/bin/sg_inq --export --inhex=/sys/block/sda/device/inquiry --raw'(out) 'SCSI_MODEL=PERC_H755N_Front'
'/usr/bin/sg_inq --export --inhex=/sys/block/sda/device/inquiry --raw'(out) 'SCSI_MODEL_ENC=PERC\x20H755N\x20Front'
'/usr/bin/sg_inq --export --inhex=/sys/block/sda/device/inquiry --raw'(out) 'SCSI_REVISION=5.16'

我的問題是 udev 如何“決定”將 PERC 列入白名單,白名單的功能是什麼?

研究完成

  • 通讀這篇關於 USB 驅動器白名單的文章,但這似乎在有人決定手動禁止所有 USB 設備時使用,但某些目標除外,這些目標在此處不適用。
  • This tutorial on writing udev scripts但它沒有回答我關於白名單的任何問題。
  • udev Wikipedia但是雖然這讓我對架構有了更好的理解,但它並沒有幫助我加入白名單
  • udev 的手冊頁- 有用但沒有提及白名單。

一般來說,我嘗試使用Google搜尋與 udev 白名單相關的結果,但我能找到的唯一結果都是關於將 USB 設備列入白名單而不是白名單的一般功能。

–whitelisted 選項似乎執行“濕執行”(而不是“幹執行”),因為沒有它scsi_id似乎根本沒有做任何事情。

見來源:https ://github.com/systemd/systemd/blob/bab787396444466e5a71e5f01b1924646959f6e0/src/udev/scsi_id/scsi_id.c#L407

static int scsi_id(char *maj_min_dev) {
       int good_dev;
       (...)

       per_dev_options(&dev_scsi, &good_dev, &page_code);
       if (!good_dev) {
               retval = 1;
               goto out;
       }
       (...)
out:
       return retval;


static int per_dev_options(struct scsi_id_device *dev_scsi, int *good_bad, int *page_code) {

       (...)

       while (retval == 0) {
               option = getopt_long(newargc, newargv, "bgp:", options, NULL);
               if (option == -1)
                       break;

               switch (option) {
               case 'b':
                       *good_bad = 0;
                       break;

               case 'g':
                       *good_bad = 1;
                       break;


static void help(void) {
              (...)
              "  -b --blacklisted                 Treat device as blacklisted\n"
              "  -g --whitelisted                 Treat device as whitelisted\n"
              (...)

這是來自 ubuntu 22 系統:

root@trybase:~# /usr/lib/udev/scsi_id /dev/sdc 
root@trybase:~# /usr/lib/udev/scsi_id  --whitelisted /dev/sdc 
35000c500c7869d5b

引用自:https://unix.stackexchange.com/questions/717551