diff options
author | Juergen Gross <jgross@suse.com> | 2015-02-17 02:02:48 -0500 |
---|---|---|
committer | David Vrabel <david.vrabel@citrix.com> | 2015-03-16 10:49:15 -0400 |
commit | 169e6cf0666fdbc67ea39220143fd6e38875b96e (patch) | |
tree | d1415532d53fae9152b464e425921a39036950db | |
parent | 785748788bafb1f286a73195c2c43ad3cda5234d (diff) |
xen: scsiback: add LUN of restored domain
When a xen domain is being restored the LUN state of a pvscsi device
is "Connected" and not "Initialising" as in case of attaching a new
pvscsi LUN.
This must be taken into account when adding a new pvscsi device for
a domain as otherwise the pvscsi LUN won't be connected to the
SCSI target associated with it.
Signed-off-by: Juergen Gross <jgross@suse.com>
Reviewed-by: Boris Ostrovsky <boris.ostrovsky@oracle.com>
Signed-off-by: David Vrabel <david.vrabel@citrix.com>
-rw-r--r-- | drivers/xen/xen-scsiback.c | 19 |
1 files changed, 14 insertions, 5 deletions
diff --git a/drivers/xen/xen-scsiback.c b/drivers/xen/xen-scsiback.c index d0b0bc549355..2eab75892c23 100644 --- a/drivers/xen/xen-scsiback.c +++ b/drivers/xen/xen-scsiback.c | |||
@@ -990,7 +990,7 @@ found: | |||
990 | } | 990 | } |
991 | 991 | ||
992 | static void scsiback_do_add_lun(struct vscsibk_info *info, const char *state, | 992 | static void scsiback_do_add_lun(struct vscsibk_info *info, const char *state, |
993 | char *phy, struct ids_tuple *vir) | 993 | char *phy, struct ids_tuple *vir, int try) |
994 | { | 994 | { |
995 | if (!scsiback_add_translation_entry(info, phy, vir)) { | 995 | if (!scsiback_add_translation_entry(info, phy, vir)) { |
996 | if (xenbus_printf(XBT_NIL, info->dev->nodename, state, | 996 | if (xenbus_printf(XBT_NIL, info->dev->nodename, state, |
@@ -998,7 +998,7 @@ static void scsiback_do_add_lun(struct vscsibk_info *info, const char *state, | |||
998 | pr_err("xenbus_printf error %s\n", state); | 998 | pr_err("xenbus_printf error %s\n", state); |
999 | scsiback_del_translation_entry(info, vir); | 999 | scsiback_del_translation_entry(info, vir); |
1000 | } | 1000 | } |
1001 | } else { | 1001 | } else if (!try) { |
1002 | xenbus_printf(XBT_NIL, info->dev->nodename, state, | 1002 | xenbus_printf(XBT_NIL, info->dev->nodename, state, |
1003 | "%d", XenbusStateClosed); | 1003 | "%d", XenbusStateClosed); |
1004 | } | 1004 | } |
@@ -1058,10 +1058,19 @@ static void scsiback_do_1lun_hotplug(struct vscsibk_info *info, int op, | |||
1058 | 1058 | ||
1059 | switch (op) { | 1059 | switch (op) { |
1060 | case VSCSIBACK_OP_ADD_OR_DEL_LUN: | 1060 | case VSCSIBACK_OP_ADD_OR_DEL_LUN: |
1061 | if (device_state == XenbusStateInitialising) | 1061 | switch (device_state) { |
1062 | scsiback_do_add_lun(info, state, phy, &vir); | 1062 | case XenbusStateInitialising: |
1063 | if (device_state == XenbusStateClosing) | 1063 | scsiback_do_add_lun(info, state, phy, &vir, 0); |
1064 | break; | ||
1065 | case XenbusStateConnected: | ||
1066 | scsiback_do_add_lun(info, state, phy, &vir, 1); | ||
1067 | break; | ||
1068 | case XenbusStateClosing: | ||
1064 | scsiback_do_del_lun(info, state, &vir); | 1069 | scsiback_do_del_lun(info, state, &vir); |
1070 | break; | ||
1071 | default: | ||
1072 | break; | ||
1073 | } | ||
1065 | break; | 1074 | break; |
1066 | 1075 | ||
1067 | case VSCSIBACK_OP_UPDATEDEV_STATE: | 1076 | case VSCSIBACK_OP_UPDATEDEV_STATE: |