USB连接的SSD设备使用trim命令

为USB桥接的NVMe设备添加trim支持

Posted by wszqkzqk on April 27, 2023
本文字数:1423

前言

本文主要讨论USB连接的SSD设备使用trim命令的方法

trim命令是用于清除闪存设备上的无效数据的命令。trim可以将文件系统中的删除操作通知给闪存设备,以便闪存设备可以在后台擦除删除的数据。这样可以提高闪存设备的写入性能,也可以减小写放大,延长闪存设备的寿命。

对于USB桥接的NVMe设备,trim命令并不可用,然而,很多硬盘盒都支持类似的命令(unmap),可以通过UAS(USB Attached SCSI)发送。不过一般情况下,内核并不会自动开启这个功能,需要手动开启。

功能支持检查

trim命令支持检查

可以使用lsblk --discard检查设备是否支持trim命令,如果对应设备的DISC-GRANDISC-MAX字段不为0,则表示支持trim命令,反之则不支持,例如:

NAME        DISC-ALN DISC-GRAN DISC-MAX DISC-ZERO
sda                0        0B       0B         0
├─sda1             0        0B       0B         0
├─sda2             0        0B       0B         0
├─sda3             0        0B       0B         0
├─sda4             0        0B       0B         0
└─sda5             0        0B       0B         0
nvme0n1            0      512B       2T         0
├─nvme0n1p1        0      512B       2T         0
├─nvme0n1p2        0      512B       2T         0
├─nvme0n1p3        0      512B       2T         0
├─nvme0n1p4        0      512B       2T         0
├─nvme0n1p5        0      512B       2T         0
└─nvme0n1p6        0      512B       2T         0

这里可以看到,nvme0n1设备支持trim命令,而sda设备不支持。如果这里就已经显示支持trim命令,那么可以跳过后续的步骤,只要设置正确的discard挂载选项(或systemdtimer),文件系统和操作系统就会自动使用trim命令。

unmap命令支持检查

如果设备不支持trim命令,可以使用以下命令检查设备是否支持unmap命令:

sudo sg_vpd -a /dev/sda | grep "Unmap command supported"

如果输出为:

Unmap command supported (LBPU): 1

则表明设备支持unmap命令。

如果设备不支持,可以查询设备的主控是否能够实现unmap命令,并找售后更新固件解决问题。

映射trim命令到unmap命令

如果设备支持unmap命令但不支持trim命令,可以设定udev规则,将trim命令映射到unmap命令。

首先,应当获取设备的idVendoridProduct,可以使用lsusb命令获取,可以得到类似的输出:

Bus 004 Device 006: ID 174c:2362 ASMedia Technology Inc. wszqkzqk storage by ZQK

这里的idVendor174cidProduct2362

然后创建/etc/udev/rules.d/51-usb-ssd-trim.rules文件,添加以下内容:

ACTION=="add|change", ATTRS{idVendor}=="174c", ATTRS{idProduct}=="2362", SUBSYSTEM=="scsi_disk", ATTR{provisioning_mode}="unmap"

这里的ATTRS{idVendor}ATTRS{idProduct}应当替换为实际的idVendoridProduct

最后,重新加载udev规则(重启也可):

sudo udevadm control --reload-rules

这样USB存储设备就有trim支持了。