aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJuergen Gross <jgross@suse.com>2015-02-17 02:02:48 -0500
committerDavid Vrabel <david.vrabel@citrix.com>2015-03-16 10:49:15 -0400
commit169e6cf0666fdbc67ea39220143fd6e38875b96e (patch)
treed1415532d53fae9152b464e425921a39036950db
parent785748788bafb1f286a73195c2c43ad3cda5234d (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.c19
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
992static void scsiback_do_add_lun(struct vscsibk_info *info, const char *state, 992static 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: