为什么“fatrace”无法检测到某些打开事件(udisks /dev/sda)?

为什么“fatrace”无法检测到某些打开事件(udisks /dev/sda)?

为什么 `ioerr_cnt` 不断上升,但日志中没有显示任何消息?

我正在努力弄清楚什么过程是这样做的。sudo lsof +D /dev/似乎没有显示当前打开的 SCSI 设备的任何进程,但在发生错误时我也没有看到任何相关的 open() 调用 ( cd /dev && sudo fatrace -c)...

[答案:] udisks 每十分钟轮询一次驱动器,例如 SMART 数据。

$ ps -ax|grep udisksd
  810 ?        Ssl    0:13 /usr/libexec/udisks2/udisksd
$ sudo strace -t -f -p 810
[pid   810] 14:11:09 clone(strace: Process 26543 attached
child_stack=0x7f8fc551ddf0, flags=CLONE_VM|CLONE_FS|CLONE_FILES|CLONE_SIGHAND|CLONE_THREAD|CLONE_SYSVSEM|CLONE_SETTLS|CLONE_PARENT_SETTID|CLONE_CHILD_CLEARTID, parent_tidptr=0x7f8fc551e9d0, tls=0x7f8fc551e700, child_tidptr=0x7f8fc551e9d0) = 26543
[pid 26543] 14:11:09 set_robust_list(0x7f8fc551e9e0, 24 <unfinished ...>
[pid   810] 14:11:09 poll([{fd=4, events=POLLIN}, {fd=8, events=0}, {fd=9, events=0}, {fd=11, events=POLLIN}, {fd=13, events=POLLIN}], 5, 599968 <unfinished ...>
[pid 26543] 14:11:09 <... set_robust_list resumed> ) = 0
[pid 26543] 14:11:09 prctl(PR_SET_NAME, "pool") = 0
[pid 26543] 14:11:09 openat(AT_FDCWD, "/dev/sda", O_RDONLY|O_NONBLOCK) = 14
[pid 26543] 14:11:09 ioctl(14, SG_IO, {guard='Q', protocol=BSG_PROTOCOL_SCSI, subprotocol=BSG_SUB_PROTOCOL_SCSI_CMD, ...

我不知道为什么fatrace似乎没有显示该设备被 udisks 打开。它设法显示其他设备打开(例如当我运行 lsof 时,或者当我启动 firefox 时它打开了 /dev/dri/card0 )。

^ 有人知道吗?

答案1

好像fatrace不显示任何设备打开。您可以使用它来查看进程打开情况目录/dev,喜欢/dev/dri,但不是设备节点喜欢/dev/dri/card0

相关内容