diff options
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/scsi/device_handler/scsi_dh_emc.c | 59 |
1 files changed, 56 insertions, 3 deletions
diff --git a/drivers/scsi/device_handler/scsi_dh_emc.c b/drivers/scsi/device_handler/scsi_dh_emc.c index 0e572d2c5b0a..0cffe84976fe 100644 --- a/drivers/scsi/device_handler/scsi_dh_emc.c +++ b/drivers/scsi/device_handler/scsi_dh_emc.c | |||
@@ -561,6 +561,61 @@ done: | |||
561 | 561 | ||
562 | return result; | 562 | return result; |
563 | } | 563 | } |
564 | /* | ||
565 | * params - parameters in the following format | ||
566 | * "no_of_params\0param1\0param2\0param3\0...\0" | ||
567 | * for example, string for 2 parameters with value 10 and 21 | ||
568 | * is specified as "2\010\021\0". | ||
569 | */ | ||
570 | static int clariion_set_params(struct scsi_device *sdev, const char *params) | ||
571 | { | ||
572 | struct clariion_dh_data *csdev = get_clariion_data(sdev); | ||
573 | unsigned int hr = 0, st = 0, argc; | ||
574 | const char *p = params; | ||
575 | int result = SCSI_DH_OK; | ||
576 | |||
577 | if ((sscanf(params, "%u", &argc) != 1) || (argc != 2)) | ||
578 | return -EINVAL; | ||
579 | |||
580 | while (*p++) | ||
581 | ; | ||
582 | if ((sscanf(p, "%u", &st) != 1) || (st > 1)) | ||
583 | return -EINVAL; | ||
584 | |||
585 | while (*p++) | ||
586 | ; | ||
587 | if ((sscanf(p, "%u", &hr) != 1) || (hr > 1)) | ||
588 | return -EINVAL; | ||
589 | |||
590 | if (st) | ||
591 | csdev->flags |= CLARIION_SHORT_TRESPASS; | ||
592 | else | ||
593 | csdev->flags &= ~CLARIION_SHORT_TRESPASS; | ||
594 | |||
595 | if (hr) | ||
596 | csdev->flags |= CLARIION_HONOR_RESERVATIONS; | ||
597 | else | ||
598 | csdev->flags &= ~CLARIION_HONOR_RESERVATIONS; | ||
599 | |||
600 | /* | ||
601 | * If this path is owned, we have to send a trespass command | ||
602 | * with the new parameters. If not, simply return. Next trespass | ||
603 | * command would use the parameters. | ||
604 | */ | ||
605 | if (csdev->lun_state != CLARIION_LUN_OWNED) | ||
606 | goto done; | ||
607 | |||
608 | csdev->lun_state = CLARIION_LUN_UNINITIALIZED; | ||
609 | result = send_trespass_cmd(sdev, csdev); | ||
610 | if (result != SCSI_DH_OK) | ||
611 | goto done; | ||
612 | |||
613 | /* Update status */ | ||
614 | result = clariion_send_inquiry(sdev, csdev); | ||
615 | |||
616 | done: | ||
617 | return result; | ||
618 | } | ||
564 | 619 | ||
565 | static const struct scsi_dh_devlist clariion_dev_list[] = { | 620 | static const struct scsi_dh_devlist clariion_dev_list[] = { |
566 | {"DGC", "RAID"}, | 621 | {"DGC", "RAID"}, |
@@ -581,11 +636,9 @@ static struct scsi_device_handler clariion_dh = { | |||
581 | .check_sense = clariion_check_sense, | 636 | .check_sense = clariion_check_sense, |
582 | .activate = clariion_activate, | 637 | .activate = clariion_activate, |
583 | .prep_fn = clariion_prep_fn, | 638 | .prep_fn = clariion_prep_fn, |
639 | .set_params = clariion_set_params, | ||
584 | }; | 640 | }; |
585 | 641 | ||
586 | /* | ||
587 | * TODO: need some interface so we can set trespass values | ||
588 | */ | ||
589 | static int clariion_bus_attach(struct scsi_device *sdev) | 642 | static int clariion_bus_attach(struct scsi_device *sdev) |
590 | { | 643 | { |
591 | struct scsi_dh_data *scsi_dh_data; | 644 | struct scsi_dh_data *scsi_dh_data; |