diff options
| -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: |
