Hi Christophe, hi Ben, the bulk of this series attempts to avoid unnecessary I/O for "multipath -u" calls from udev rules. I came up with it in a recent attempt to debug avoid "multipath -u" hangups during boot. I found that the detect_alua() call in the get_refwwid->pathinfo->scsi_ioctl_pathinfo call sequence would cause an sg ioctl to be sent for every "multipath -u" invocation. That's obvious nonsense, we don't need to detect ALUA capabilities to find out if a device is a potential multipath member. So, rather than setting pp->tpgs in pathinfo, I resorted to a "lazy" approach where ALUA capabilities are probed when they are needed, no sooner. I also cleaned up the ALUA code a bit (still some more to go), and made it attempt to read INQUIRY data from sysfs. Regards, Martin Changes v2->v3: - added 8/10 "tidy up do_set_from_hwe() with statement expression" (Hannes), renumber subsequent patches accordingly. - 9/10: cleanup ugly macro usage; do retrieve VPD for "unknown" SCSI storage devices Changes v1->v2: - 6/9: remove one remaining direct access to pp->tpgs - 9/9: use non-personal email address for maintainer Martin Wilck (10): libmultipath: add sysfs_get_inquiry() libmultipath: alua: make API more consistent libmultipath: alua: try to retrieve inquiry data from sysfs libmultipath: constify sysfs_get_timeout() libmultipath: detect_alua(): use system timeout libmultipath: lazy tpgs probing libmultipath: don't link alua_rtpg.o twice libmultipath: tidy up do_set_from_hwe() with statement expression libmultipath: check_rdac(): pre-check in hwtable libmultipath: hwtable: add Lenovo DE series libmultipath/discovery.c | 46 +++++++++++++++++------- libmultipath/discovery.h | 10 +++--- libmultipath/hwtable.c | 20 +++++++++++ libmultipath/prioritizers/Makefile | 3 -- libmultipath/prioritizers/alua.c | 4 +-- libmultipath/prioritizers/alua_rtpg.c | 45 +++++++++++++++++------ libmultipath/prioritizers/alua_rtpg.h | 7 ++-- libmultipath/propsel.c | 52 ++++++++++++++++++--------- multipathd/main.c | 7 ++-- 9 files changed, 139 insertions(+), 55 deletions(-) -- 2.21.0 -- dm-devel mailing list dm-devel@xxxxxxxxxx https://www.redhat.com/mailman/listinfo/dm-devel