为什么 udev 会自动将我的 RAID 卡列入白名单?此白名单的作用是什么?

为什么 udev 会自动将我的 RAID 卡列入白名单?此白名单的作用是什么?

我一直在学习使用 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 设备(某些目标除外,此处不适用)时使用的。
  • 本教程介绍如何编写 udev 脚本但它没有回答我有关白名单的任何问题。
  • udev 维基百科虽然这让我对架构有了更好的理解,但它并没有帮助我列入白名单
  • udev 的手册页- 有帮助,但没有提及白名单。

一般来说,我尝试在谷歌上搜索与 udev 白名单相关的结果,但我能找到的唯一结果都是关于白名单 USB 设备,而不是白名单通常如何运作。

答案1

--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

相关内容