qemu-pr: fixed ioctl failed for multipath disk
We use ioctl to detect multipath devices. However, we only set flags in struct dm_ioctl (the argument to ioctl) and left other fields in random, which may cause the failure of calling ioctl. Hence, we set other fields to 0 to avoid the failure. Signed-off-by: wangjian161 <wangjian161@huawei.com>
This commit is contained in:
parent
5f9b6047bd
commit
95206472cc
36
qemu-pr-fixed-ioctl-failed-for-multipath-disk.patch
Normal file
36
qemu-pr-fixed-ioctl-failed-for-multipath-disk.patch
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
From 56f59125707c0222bbb5d7f820792aba17c3db08 Mon Sep 17 00:00:00 2001
|
||||||
|
From: WangJian <wangjian161@huawei.com>
|
||||||
|
Date: Wed, 9 Feb 2022 11:10:42 +0800
|
||||||
|
Subject: [PATCH] qemu-pr: fixed ioctl failed for multipath disk
|
||||||
|
|
||||||
|
We use ioctl to detect multipath devices. However, we only set flags in
|
||||||
|
struct dm_ioctl (the argument to ioctl) and left other fields in random,
|
||||||
|
which may cause the failure of calling ioctl. Hence, we set other
|
||||||
|
fields to 0 to avoid the failure.
|
||||||
|
|
||||||
|
Signed-off-by: wangjian161 <wangjian161@huawei.com>
|
||||||
|
---
|
||||||
|
scsi/qemu-pr-helper.c | 5 ++++-
|
||||||
|
1 file changed, 4 insertions(+), 1 deletion(-)
|
||||||
|
|
||||||
|
diff --git a/scsi/qemu-pr-helper.c b/scsi/qemu-pr-helper.c
|
||||||
|
index f281daeced..bbb9b57741 100644
|
||||||
|
--- a/scsi/qemu-pr-helper.c
|
||||||
|
+++ b/scsi/qemu-pr-helper.c
|
||||||
|
@@ -288,9 +288,12 @@ static void multipath_pr_init(void)
|
||||||
|
|
||||||
|
static int is_mpath(int fd)
|
||||||
|
{
|
||||||
|
- struct dm_ioctl dm = { .flags = DM_NOFLUSH_FLAG };
|
||||||
|
+ struct dm_ioctl dm;
|
||||||
|
struct dm_target_spec *tgt;
|
||||||
|
|
||||||
|
+ memset(&dm, 0, sizeof(struct dm_ioctl));
|
||||||
|
+ dm.flags = DM_NOFLUSH_FLAG;
|
||||||
|
+
|
||||||
|
tgt = dm_dev_ioctl(fd, DM_TABLE_STATUS, &dm);
|
||||||
|
if (!tgt) {
|
||||||
|
if (errno == ENXIO) {
|
||||||
|
--
|
||||||
|
2.27.0
|
||||||
|
|
||||||
Loading…
x
Reference in New Issue
Block a user