Commit 5ca01204 authored by Scott Benesh's avatar Scott Benesh Committed by James Bottomley

hpsa: add in new offline mode

prevent adding volumes that are not available.
Reviewed-by: default avatarKevin Barnett <kevin.barnett@pmcs.com>
Reviewed-by: default avatarScott Teel <scott.teel@pmcs.com>
Reviewed-by: default avatarJustin Lindley <justin.lindley@pmcs.com>
Reviewed-by: default avatarTomas Henzl <thenzl@redhat.com>
Signed-off-by: default avatarDon Brace <don.brace@pmcs.com>
Signed-off-by: default avatarJames Bottomley <JBottomley@Odin.com>
parent b9092b79
...@@ -1481,17 +1481,23 @@ static void hpsa_show_volume_status(struct ctlr_info *h, ...@@ -1481,17 +1481,23 @@ static void hpsa_show_volume_status(struct ctlr_info *h,
h->scsi_host->host_no, h->scsi_host->host_no,
sd->bus, sd->target, sd->lun); sd->bus, sd->target, sd->lun);
break; break;
case HPSA_LV_NOT_AVAILABLE:
dev_info(&h->pdev->dev,
"C%d:B%d:T%d:L%d Volume is waiting for transforming volume.\n",
h->scsi_host->host_no,
sd->bus, sd->target, sd->lun);
break;
case HPSA_LV_UNDERGOING_RPI: case HPSA_LV_UNDERGOING_RPI:
dev_info(&h->pdev->dev, dev_info(&h->pdev->dev,
"C%d:B%d:T%d:L%d Volume is undergoing rapid parity initialization process.\n", "C%d:B%d:T%d:L%d Volume is undergoing rapid parity init.\n",
h->scsi_host->host_no, h->scsi_host->host_no,
sd->bus, sd->target, sd->lun); sd->bus, sd->target, sd->lun);
break; break;
case HPSA_LV_PENDING_RPI: case HPSA_LV_PENDING_RPI:
dev_info(&h->pdev->dev, dev_info(&h->pdev->dev,
"C%d:B%d:T%d:L%d Volume is queued for rapid parity initialization process.\n", "C%d:B%d:T%d:L%d Volume is queued for rapid parity initialization process.\n",
h->scsi_host->host_no, h->scsi_host->host_no,
sd->bus, sd->target, sd->lun); sd->bus, sd->target, sd->lun);
break; break;
case HPSA_LV_ENCRYPTED_NO_KEY: case HPSA_LV_ENCRYPTED_NO_KEY:
dev_info(&h->pdev->dev, dev_info(&h->pdev->dev,
...@@ -3262,6 +3268,7 @@ static int hpsa_volume_offline(struct ctlr_info *h, ...@@ -3262,6 +3268,7 @@ static int hpsa_volume_offline(struct ctlr_info *h,
/* Keep volume offline in certain cases: */ /* Keep volume offline in certain cases: */
switch (ldstat) { switch (ldstat) {
case HPSA_LV_UNDERGOING_ERASE: case HPSA_LV_UNDERGOING_ERASE:
case HPSA_LV_NOT_AVAILABLE:
case HPSA_LV_UNDERGOING_RPI: case HPSA_LV_UNDERGOING_RPI:
case HPSA_LV_PENDING_RPI: case HPSA_LV_PENDING_RPI:
case HPSA_LV_ENCRYPTED_NO_KEY: case HPSA_LV_ENCRYPTED_NO_KEY:
......
...@@ -164,6 +164,7 @@ ...@@ -164,6 +164,7 @@
/* Logical volume states */ /* Logical volume states */
#define HPSA_VPD_LV_STATUS_UNSUPPORTED 0xff #define HPSA_VPD_LV_STATUS_UNSUPPORTED 0xff
#define HPSA_LV_OK 0x0 #define HPSA_LV_OK 0x0
#define HPSA_LV_NOT_AVAILABLE 0x0b
#define HPSA_LV_UNDERGOING_ERASE 0x0F #define HPSA_LV_UNDERGOING_ERASE 0x0F
#define HPSA_LV_UNDERGOING_RPI 0x12 #define HPSA_LV_UNDERGOING_RPI 0x12
#define HPSA_LV_PENDING_RPI 0x13 #define HPSA_LV_PENDING_RPI 0x13
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment