Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux

scsi: device_handler: rdac: Have midlayer retry send_mode_select() errors

This has rdac have the SCSI midlayer retry errors instead of driving them
itself.

Signed-off-by: Mike Christie <michael.christie@oracle.com>
Link: https://lore.kernel.org/r/20240123002220.129141-8-michael.christie@oracle.com
Acked-by: Christoph Hellwig <hch@lst.de>
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>

authored by

Mike Christie and committed by
Martin K. Petersen
f316ff46 fabe3ee9

+46 -38
+46 -38
drivers/scsi/device_handler/scsi_dh_rdac.c
··· 485 485 static int mode_select_handle_sense(struct scsi_device *sdev, 486 486 struct scsi_sense_hdr *sense_hdr) 487 487 { 488 - int err = SCSI_DH_IO; 489 488 struct rdac_dh_data *h = sdev->handler_data; 490 489 491 490 if (!scsi_sense_valid(sense_hdr)) 492 - goto done; 493 - 494 - switch (sense_hdr->sense_key) { 495 - case NO_SENSE: 496 - case ABORTED_COMMAND: 497 - case UNIT_ATTENTION: 498 - err = SCSI_DH_RETRY; 499 - break; 500 - case NOT_READY: 501 - if (sense_hdr->asc == 0x04 && sense_hdr->ascq == 0x01) 502 - /* LUN Not Ready and is in the Process of Becoming 503 - * Ready 504 - */ 505 - err = SCSI_DH_RETRY; 506 - break; 507 - case ILLEGAL_REQUEST: 508 - if (sense_hdr->asc == 0x91 && sense_hdr->ascq == 0x36) 509 - /* 510 - * Command Lock contention 511 - */ 512 - err = SCSI_DH_IMM_RETRY; 513 - break; 514 - default: 515 - break; 516 - } 491 + return SCSI_DH_IO; 517 492 518 493 RDAC_LOG(RDAC_LOG_FAILOVER, sdev, "array %s, ctlr %d, " 519 494 "MODE_SELECT returned with sense %02x/%02x/%02x", 520 495 (char *) h->ctlr->array_name, h->ctlr->index, 521 496 sense_hdr->sense_key, sense_hdr->asc, sense_hdr->ascq); 522 497 523 - done: 524 - return err; 498 + return SCSI_DH_IO; 525 499 } 526 500 527 501 static void send_mode_select(struct work_struct *work) ··· 504 530 container_of(work, struct rdac_controller, ms_work); 505 531 struct scsi_device *sdev = ctlr->ms_sdev; 506 532 struct rdac_dh_data *h = sdev->handler_data; 507 - int rc, err, retry_cnt = RDAC_RETRY_COUNT; 533 + int rc, err; 508 534 struct rdac_queue_data *tmp, *qdata; 509 535 LIST_HEAD(list); 510 536 unsigned char cdb[MAX_COMMAND_SIZE]; ··· 512 538 unsigned int data_size; 513 539 blk_opf_t opf = REQ_OP_DRV_OUT | REQ_FAILFAST_DEV | 514 540 REQ_FAILFAST_TRANSPORT | REQ_FAILFAST_DRIVER; 541 + struct scsi_failure failure_defs[] = { 542 + { 543 + .sense = NO_SENSE, 544 + .asc = SCMD_FAILURE_ASC_ANY, 545 + .ascq = SCMD_FAILURE_ASCQ_ANY, 546 + .result = SAM_STAT_CHECK_CONDITION, 547 + }, 548 + { 549 + .sense = ABORTED_COMMAND, 550 + .asc = SCMD_FAILURE_ASC_ANY, 551 + .ascq = SCMD_FAILURE_ASCQ_ANY, 552 + .result = SAM_STAT_CHECK_CONDITION, 553 + }, 554 + { 555 + .sense = UNIT_ATTENTION, 556 + .asc = SCMD_FAILURE_ASC_ANY, 557 + .ascq = SCMD_FAILURE_ASCQ_ANY, 558 + .result = SAM_STAT_CHECK_CONDITION, 559 + }, 560 + /* LUN Not Ready and is in the Process of Becoming Ready */ 561 + { 562 + .sense = NOT_READY, 563 + .asc = 0x04, 564 + .ascq = 0x01, 565 + .result = SAM_STAT_CHECK_CONDITION, 566 + }, 567 + /* Command Lock contention */ 568 + { 569 + .sense = ILLEGAL_REQUEST, 570 + .asc = 0x91, 571 + .ascq = 0x36, 572 + .allowed = SCMD_FAILURE_NO_LIMIT, 573 + .result = SAM_STAT_CHECK_CONDITION, 574 + }, 575 + {} 576 + }; 577 + struct scsi_failures failures = { 578 + .total_allowed = RDAC_RETRY_COUNT, 579 + .failure_definitions = failure_defs, 580 + }; 515 581 const struct scsi_exec_args exec_args = { 516 582 .sshdr = &sshdr, 583 + .failures = &failures, 517 584 }; 518 585 519 586 spin_lock(&ctlr->ms_lock); ··· 563 548 ctlr->ms_sdev = NULL; 564 549 spin_unlock(&ctlr->ms_lock); 565 550 566 - retry: 567 551 memset(cdb, 0, sizeof(cdb)); 568 552 569 553 data_size = rdac_failover_get(ctlr, &list, cdb); 570 554 571 - RDAC_LOG(RDAC_LOG_FAILOVER, sdev, "array %s, ctlr %d, " 572 - "%s MODE_SELECT command", 573 - (char *) h->ctlr->array_name, h->ctlr->index, 574 - (retry_cnt == RDAC_RETRY_COUNT) ? "queueing" : "retrying"); 555 + RDAC_LOG(RDAC_LOG_FAILOVER, sdev, "array %s, ctlr %d, queueing MODE_SELECT command", 556 + (char *)h->ctlr->array_name, h->ctlr->index); 575 557 576 558 rc = scsi_execute_cmd(sdev, cdb, opf, &h->ctlr->mode_select, data_size, 577 559 RDAC_TIMEOUT * HZ, RDAC_RETRIES, &exec_args); ··· 582 570 err = SCSI_DH_IO; 583 571 } else { 584 572 err = mode_select_handle_sense(sdev, &sshdr); 585 - if (err == SCSI_DH_RETRY && retry_cnt--) 586 - goto retry; 587 - if (err == SCSI_DH_IMM_RETRY) 588 - goto retry; 589 573 } 590 574 591 575 list_for_each_entry_safe(qdata, tmp, &list, entry) {