.. | .. |
---|
| 1 | +// SPDX-License-Identifier: GPL-2.0-only |
---|
1 | 2 | /* |
---|
2 | 3 | * sd.c Copyright (C) 1992 Drew Eckhardt |
---|
3 | 4 | * Copyright (C) 1993, 1994, 1995, 1999 Eric Youngdale |
---|
.. | .. |
---|
45 | 46 | #include <linux/init.h> |
---|
46 | 47 | #include <linux/blkdev.h> |
---|
47 | 48 | #include <linux/blkpg.h> |
---|
| 49 | +#include <linux/blk-pm.h> |
---|
48 | 50 | #include <linux/delay.h> |
---|
49 | 51 | #include <linux/mutex.h> |
---|
50 | 52 | #include <linux/string_helpers.h> |
---|
.. | .. |
---|
113 | 115 | static int sd_suspend_runtime(struct device *); |
---|
114 | 116 | static int sd_resume(struct device *); |
---|
115 | 117 | static void sd_rescan(struct device *); |
---|
116 | | -static int sd_init_command(struct scsi_cmnd *SCpnt); |
---|
| 118 | +static blk_status_t sd_init_command(struct scsi_cmnd *SCpnt); |
---|
117 | 119 | static void sd_uninit_command(struct scsi_cmnd *SCpnt); |
---|
118 | 120 | static int sd_done(struct scsi_cmnd *); |
---|
119 | 121 | static void sd_eh_reset(struct scsi_cmnd *); |
---|
120 | 122 | static int sd_eh_action(struct scsi_cmnd *, int); |
---|
121 | 123 | static void sd_read_capacity(struct scsi_disk *sdkp, unsigned char *buffer); |
---|
122 | 124 | static void scsi_disk_release(struct device *cdev); |
---|
123 | | -static void sd_print_sense_hdr(struct scsi_disk *, struct scsi_sense_hdr *); |
---|
124 | | -static void sd_print_result(const struct scsi_disk *, const char *, int); |
---|
125 | 125 | |
---|
126 | 126 | static DEFINE_IDA(sd_index_ida); |
---|
127 | 127 | |
---|
.. | .. |
---|
194 | 194 | } |
---|
195 | 195 | |
---|
196 | 196 | if (scsi_mode_sense(sdp, 0x08, 8, buffer, sizeof(buffer), SD_TIMEOUT, |
---|
197 | | - SD_MAX_RETRIES, &data, NULL)) |
---|
| 197 | + sdkp->max_retries, &data, NULL)) |
---|
198 | 198 | return -EINVAL; |
---|
199 | 199 | len = min_t(size_t, sizeof(buffer), data.length - data.header_length - |
---|
200 | 200 | data.block_descriptor_length); |
---|
.. | .. |
---|
212 | 212 | data.device_specific = 0; |
---|
213 | 213 | |
---|
214 | 214 | if (scsi_mode_select(sdp, 1, sp, 8, buffer_data, len, SD_TIMEOUT, |
---|
215 | | - SD_MAX_RETRIES, &data, &sshdr)) { |
---|
| 215 | + sdkp->max_retries, &data, &sshdr)) { |
---|
216 | 216 | if (scsi_sense_valid(&sshdr)) |
---|
217 | 217 | sd_print_sense_hdr(sdkp, &sshdr); |
---|
218 | 218 | return -EINVAL; |
---|
219 | 219 | } |
---|
220 | | - revalidate_disk(sdkp->disk); |
---|
| 220 | + sd_revalidate_disk(sdkp->disk); |
---|
221 | 221 | return count; |
---|
222 | 222 | } |
---|
223 | 223 | |
---|
.. | .. |
---|
528 | 528 | } |
---|
529 | 529 | static DEVICE_ATTR_RW(max_write_same_blocks); |
---|
530 | 530 | |
---|
| 531 | +static ssize_t |
---|
| 532 | +zoned_cap_show(struct device *dev, struct device_attribute *attr, char *buf) |
---|
| 533 | +{ |
---|
| 534 | + struct scsi_disk *sdkp = to_scsi_disk(dev); |
---|
| 535 | + |
---|
| 536 | + if (sdkp->device->type == TYPE_ZBC) |
---|
| 537 | + return sprintf(buf, "host-managed\n"); |
---|
| 538 | + if (sdkp->zoned == 1) |
---|
| 539 | + return sprintf(buf, "host-aware\n"); |
---|
| 540 | + if (sdkp->zoned == 2) |
---|
| 541 | + return sprintf(buf, "drive-managed\n"); |
---|
| 542 | + return sprintf(buf, "none\n"); |
---|
| 543 | +} |
---|
| 544 | +static DEVICE_ATTR_RO(zoned_cap); |
---|
| 545 | + |
---|
| 546 | +static ssize_t |
---|
| 547 | +max_retries_store(struct device *dev, struct device_attribute *attr, |
---|
| 548 | + const char *buf, size_t count) |
---|
| 549 | +{ |
---|
| 550 | + struct scsi_disk *sdkp = to_scsi_disk(dev); |
---|
| 551 | + struct scsi_device *sdev = sdkp->device; |
---|
| 552 | + int retries, err; |
---|
| 553 | + |
---|
| 554 | + err = kstrtoint(buf, 10, &retries); |
---|
| 555 | + if (err) |
---|
| 556 | + return err; |
---|
| 557 | + |
---|
| 558 | + if (retries == SCSI_CMD_RETRIES_NO_LIMIT || retries <= SD_MAX_RETRIES) { |
---|
| 559 | + sdkp->max_retries = retries; |
---|
| 560 | + return count; |
---|
| 561 | + } |
---|
| 562 | + |
---|
| 563 | + sdev_printk(KERN_ERR, sdev, "max_retries must be between -1 and %d\n", |
---|
| 564 | + SD_MAX_RETRIES); |
---|
| 565 | + return -EINVAL; |
---|
| 566 | +} |
---|
| 567 | + |
---|
| 568 | +static ssize_t |
---|
| 569 | +max_retries_show(struct device *dev, struct device_attribute *attr, |
---|
| 570 | + char *buf) |
---|
| 571 | +{ |
---|
| 572 | + struct scsi_disk *sdkp = to_scsi_disk(dev); |
---|
| 573 | + |
---|
| 574 | + return sprintf(buf, "%d\n", sdkp->max_retries); |
---|
| 575 | +} |
---|
| 576 | + |
---|
| 577 | +static DEVICE_ATTR_RW(max_retries); |
---|
| 578 | + |
---|
531 | 579 | static struct attribute *sd_disk_attrs[] = { |
---|
532 | 580 | &dev_attr_cache_type.attr, |
---|
533 | 581 | &dev_attr_FUA.attr, |
---|
.. | .. |
---|
541 | 589 | &dev_attr_zeroing_mode.attr, |
---|
542 | 590 | &dev_attr_max_write_same_blocks.attr, |
---|
543 | 591 | &dev_attr_max_medium_access_timeouts.attr, |
---|
| 592 | + &dev_attr_zoned_cap.attr, |
---|
| 593 | + &dev_attr_max_retries.attr, |
---|
544 | 594 | NULL, |
---|
545 | 595 | }; |
---|
546 | 596 | ATTRIBUTE_GROUPS(sd_disk); |
---|
.. | .. |
---|
566 | 616 | .name = "sd", |
---|
567 | 617 | .owner = THIS_MODULE, |
---|
568 | 618 | .probe = sd_probe, |
---|
| 619 | + .probe_type = PROBE_PREFER_ASYNCHRONOUS, |
---|
569 | 620 | .remove = sd_remove, |
---|
570 | 621 | .shutdown = sd_shutdown, |
---|
571 | 622 | .pm = &sd_pm_ops, |
---|
.. | .. |
---|
648 | 699 | static int sd_sec_submit(void *data, u16 spsp, u8 secp, void *buffer, |
---|
649 | 700 | size_t len, bool send) |
---|
650 | 701 | { |
---|
651 | | - struct scsi_device *sdev = data; |
---|
| 702 | + struct scsi_disk *sdkp = data; |
---|
| 703 | + struct scsi_device *sdev = sdkp->device; |
---|
652 | 704 | u8 cdb[12] = { 0, }; |
---|
653 | 705 | int ret; |
---|
654 | 706 | |
---|
.. | .. |
---|
657 | 709 | put_unaligned_be16(spsp, &cdb[2]); |
---|
658 | 710 | put_unaligned_be32(len, &cdb[6]); |
---|
659 | 711 | |
---|
660 | | - ret = scsi_execute_req(sdev, cdb, |
---|
661 | | - send ? DMA_TO_DEVICE : DMA_FROM_DEVICE, |
---|
662 | | - buffer, len, NULL, SD_TIMEOUT, SD_MAX_RETRIES, NULL); |
---|
| 712 | + ret = scsi_execute(sdev, cdb, send ? DMA_TO_DEVICE : DMA_FROM_DEVICE, |
---|
| 713 | + buffer, len, NULL, NULL, SD_TIMEOUT, sdkp->max_retries, 0, |
---|
| 714 | + RQF_PM, NULL); |
---|
663 | 715 | return ret <= 0 ? ret : -EIO; |
---|
664 | 716 | } |
---|
665 | 717 | #endif /* CONFIG_BLK_SED_OPAL */ |
---|
| 718 | + |
---|
| 719 | +/* |
---|
| 720 | + * Look up the DIX operation based on whether the command is read or |
---|
| 721 | + * write and whether dix and dif are enabled. |
---|
| 722 | + */ |
---|
| 723 | +static unsigned int sd_prot_op(bool write, bool dix, bool dif) |
---|
| 724 | +{ |
---|
| 725 | + /* Lookup table: bit 2 (write), bit 1 (dix), bit 0 (dif) */ |
---|
| 726 | + static const unsigned int ops[] = { /* wrt dix dif */ |
---|
| 727 | + SCSI_PROT_NORMAL, /* 0 0 0 */ |
---|
| 728 | + SCSI_PROT_READ_STRIP, /* 0 0 1 */ |
---|
| 729 | + SCSI_PROT_READ_INSERT, /* 0 1 0 */ |
---|
| 730 | + SCSI_PROT_READ_PASS, /* 0 1 1 */ |
---|
| 731 | + SCSI_PROT_NORMAL, /* 1 0 0 */ |
---|
| 732 | + SCSI_PROT_WRITE_INSERT, /* 1 0 1 */ |
---|
| 733 | + SCSI_PROT_WRITE_STRIP, /* 1 1 0 */ |
---|
| 734 | + SCSI_PROT_WRITE_PASS, /* 1 1 1 */ |
---|
| 735 | + }; |
---|
| 736 | + |
---|
| 737 | + return ops[write << 2 | dix << 1 | dif]; |
---|
| 738 | +} |
---|
| 739 | + |
---|
| 740 | +/* |
---|
| 741 | + * Returns a mask of the protection flags that are valid for a given DIX |
---|
| 742 | + * operation. |
---|
| 743 | + */ |
---|
| 744 | +static unsigned int sd_prot_flag_mask(unsigned int prot_op) |
---|
| 745 | +{ |
---|
| 746 | + static const unsigned int flag_mask[] = { |
---|
| 747 | + [SCSI_PROT_NORMAL] = 0, |
---|
| 748 | + |
---|
| 749 | + [SCSI_PROT_READ_STRIP] = SCSI_PROT_TRANSFER_PI | |
---|
| 750 | + SCSI_PROT_GUARD_CHECK | |
---|
| 751 | + SCSI_PROT_REF_CHECK | |
---|
| 752 | + SCSI_PROT_REF_INCREMENT, |
---|
| 753 | + |
---|
| 754 | + [SCSI_PROT_READ_INSERT] = SCSI_PROT_REF_INCREMENT | |
---|
| 755 | + SCSI_PROT_IP_CHECKSUM, |
---|
| 756 | + |
---|
| 757 | + [SCSI_PROT_READ_PASS] = SCSI_PROT_TRANSFER_PI | |
---|
| 758 | + SCSI_PROT_GUARD_CHECK | |
---|
| 759 | + SCSI_PROT_REF_CHECK | |
---|
| 760 | + SCSI_PROT_REF_INCREMENT | |
---|
| 761 | + SCSI_PROT_IP_CHECKSUM, |
---|
| 762 | + |
---|
| 763 | + [SCSI_PROT_WRITE_INSERT] = SCSI_PROT_TRANSFER_PI | |
---|
| 764 | + SCSI_PROT_REF_INCREMENT, |
---|
| 765 | + |
---|
| 766 | + [SCSI_PROT_WRITE_STRIP] = SCSI_PROT_GUARD_CHECK | |
---|
| 767 | + SCSI_PROT_REF_CHECK | |
---|
| 768 | + SCSI_PROT_REF_INCREMENT | |
---|
| 769 | + SCSI_PROT_IP_CHECKSUM, |
---|
| 770 | + |
---|
| 771 | + [SCSI_PROT_WRITE_PASS] = SCSI_PROT_TRANSFER_PI | |
---|
| 772 | + SCSI_PROT_GUARD_CHECK | |
---|
| 773 | + SCSI_PROT_REF_CHECK | |
---|
| 774 | + SCSI_PROT_REF_INCREMENT | |
---|
| 775 | + SCSI_PROT_IP_CHECKSUM, |
---|
| 776 | + }; |
---|
| 777 | + |
---|
| 778 | + return flag_mask[prot_op]; |
---|
| 779 | +} |
---|
666 | 780 | |
---|
667 | 781 | static unsigned char sd_setup_protect_cmnd(struct scsi_cmnd *scmd, |
---|
668 | 782 | unsigned int dix, unsigned int dif) |
---|
.. | .. |
---|
756 | 870 | blk_queue_flag_set(QUEUE_FLAG_DISCARD, q); |
---|
757 | 871 | } |
---|
758 | 872 | |
---|
759 | | -static int sd_setup_unmap_cmnd(struct scsi_cmnd *cmd) |
---|
| 873 | +static blk_status_t sd_setup_unmap_cmnd(struct scsi_cmnd *cmd) |
---|
760 | 874 | { |
---|
761 | 875 | struct scsi_device *sdp = cmd->device; |
---|
762 | 876 | struct request *rq = cmd->request; |
---|
763 | | - u64 sector = blk_rq_pos(rq) >> (ilog2(sdp->sector_size) - 9); |
---|
764 | | - u32 nr_sectors = blk_rq_sectors(rq) >> (ilog2(sdp->sector_size) - 9); |
---|
| 877 | + struct scsi_disk *sdkp = scsi_disk(rq->rq_disk); |
---|
| 878 | + u64 lba = sectors_to_logical(sdp, blk_rq_pos(rq)); |
---|
| 879 | + u32 nr_blocks = sectors_to_logical(sdp, blk_rq_sectors(rq)); |
---|
765 | 880 | unsigned int data_len = 24; |
---|
766 | 881 | char *buf; |
---|
767 | 882 | |
---|
768 | 883 | rq->special_vec.bv_page = mempool_alloc(sd_page_pool, GFP_ATOMIC); |
---|
769 | 884 | if (!rq->special_vec.bv_page) |
---|
770 | | - return BLKPREP_DEFER; |
---|
| 885 | + return BLK_STS_RESOURCE; |
---|
771 | 886 | clear_highpage(rq->special_vec.bv_page); |
---|
772 | 887 | rq->special_vec.bv_offset = 0; |
---|
773 | 888 | rq->special_vec.bv_len = data_len; |
---|
.. | .. |
---|
780 | 895 | buf = page_address(rq->special_vec.bv_page); |
---|
781 | 896 | put_unaligned_be16(6 + 16, &buf[0]); |
---|
782 | 897 | put_unaligned_be16(16, &buf[2]); |
---|
783 | | - put_unaligned_be64(sector, &buf[8]); |
---|
784 | | - put_unaligned_be32(nr_sectors, &buf[16]); |
---|
| 898 | + put_unaligned_be64(lba, &buf[8]); |
---|
| 899 | + put_unaligned_be32(nr_blocks, &buf[16]); |
---|
785 | 900 | |
---|
786 | | - cmd->allowed = SD_MAX_RETRIES; |
---|
| 901 | + cmd->allowed = sdkp->max_retries; |
---|
787 | 902 | cmd->transfersize = data_len; |
---|
788 | 903 | rq->timeout = SD_TIMEOUT; |
---|
789 | | - scsi_req(rq)->resid_len = data_len; |
---|
790 | 904 | |
---|
791 | | - return scsi_init_io(cmd); |
---|
| 905 | + return scsi_alloc_sgtables(cmd); |
---|
792 | 906 | } |
---|
793 | 907 | |
---|
794 | | -static int sd_setup_write_same16_cmnd(struct scsi_cmnd *cmd, bool unmap) |
---|
| 908 | +static blk_status_t sd_setup_write_same16_cmnd(struct scsi_cmnd *cmd, |
---|
| 909 | + bool unmap) |
---|
795 | 910 | { |
---|
796 | 911 | struct scsi_device *sdp = cmd->device; |
---|
797 | 912 | struct request *rq = cmd->request; |
---|
798 | | - u64 sector = blk_rq_pos(rq) >> (ilog2(sdp->sector_size) - 9); |
---|
799 | | - u32 nr_sectors = blk_rq_sectors(rq) >> (ilog2(sdp->sector_size) - 9); |
---|
| 913 | + struct scsi_disk *sdkp = scsi_disk(rq->rq_disk); |
---|
| 914 | + u64 lba = sectors_to_logical(sdp, blk_rq_pos(rq)); |
---|
| 915 | + u32 nr_blocks = sectors_to_logical(sdp, blk_rq_sectors(rq)); |
---|
800 | 916 | u32 data_len = sdp->sector_size; |
---|
801 | 917 | |
---|
802 | 918 | rq->special_vec.bv_page = mempool_alloc(sd_page_pool, GFP_ATOMIC); |
---|
803 | 919 | if (!rq->special_vec.bv_page) |
---|
804 | | - return BLKPREP_DEFER; |
---|
| 920 | + return BLK_STS_RESOURCE; |
---|
805 | 921 | clear_highpage(rq->special_vec.bv_page); |
---|
806 | 922 | rq->special_vec.bv_offset = 0; |
---|
807 | 923 | rq->special_vec.bv_len = data_len; |
---|
.. | .. |
---|
811 | 927 | cmd->cmnd[0] = WRITE_SAME_16; |
---|
812 | 928 | if (unmap) |
---|
813 | 929 | cmd->cmnd[1] = 0x8; /* UNMAP */ |
---|
814 | | - put_unaligned_be64(sector, &cmd->cmnd[2]); |
---|
815 | | - put_unaligned_be32(nr_sectors, &cmd->cmnd[10]); |
---|
| 930 | + put_unaligned_be64(lba, &cmd->cmnd[2]); |
---|
| 931 | + put_unaligned_be32(nr_blocks, &cmd->cmnd[10]); |
---|
816 | 932 | |
---|
817 | | - cmd->allowed = SD_MAX_RETRIES; |
---|
| 933 | + cmd->allowed = sdkp->max_retries; |
---|
818 | 934 | cmd->transfersize = data_len; |
---|
819 | 935 | rq->timeout = unmap ? SD_TIMEOUT : SD_WRITE_SAME_TIMEOUT; |
---|
820 | | - scsi_req(rq)->resid_len = data_len; |
---|
821 | 936 | |
---|
822 | | - return scsi_init_io(cmd); |
---|
| 937 | + return scsi_alloc_sgtables(cmd); |
---|
823 | 938 | } |
---|
824 | 939 | |
---|
825 | | -static int sd_setup_write_same10_cmnd(struct scsi_cmnd *cmd, bool unmap) |
---|
| 940 | +static blk_status_t sd_setup_write_same10_cmnd(struct scsi_cmnd *cmd, |
---|
| 941 | + bool unmap) |
---|
826 | 942 | { |
---|
827 | 943 | struct scsi_device *sdp = cmd->device; |
---|
828 | 944 | struct request *rq = cmd->request; |
---|
829 | | - u64 sector = blk_rq_pos(rq) >> (ilog2(sdp->sector_size) - 9); |
---|
830 | | - u32 nr_sectors = blk_rq_sectors(rq) >> (ilog2(sdp->sector_size) - 9); |
---|
| 945 | + struct scsi_disk *sdkp = scsi_disk(rq->rq_disk); |
---|
| 946 | + u64 lba = sectors_to_logical(sdp, blk_rq_pos(rq)); |
---|
| 947 | + u32 nr_blocks = sectors_to_logical(sdp, blk_rq_sectors(rq)); |
---|
831 | 948 | u32 data_len = sdp->sector_size; |
---|
832 | 949 | |
---|
833 | 950 | rq->special_vec.bv_page = mempool_alloc(sd_page_pool, GFP_ATOMIC); |
---|
834 | 951 | if (!rq->special_vec.bv_page) |
---|
835 | | - return BLKPREP_DEFER; |
---|
| 952 | + return BLK_STS_RESOURCE; |
---|
836 | 953 | clear_highpage(rq->special_vec.bv_page); |
---|
837 | 954 | rq->special_vec.bv_offset = 0; |
---|
838 | 955 | rq->special_vec.bv_len = data_len; |
---|
.. | .. |
---|
842 | 959 | cmd->cmnd[0] = WRITE_SAME; |
---|
843 | 960 | if (unmap) |
---|
844 | 961 | cmd->cmnd[1] = 0x8; /* UNMAP */ |
---|
845 | | - put_unaligned_be32(sector, &cmd->cmnd[2]); |
---|
846 | | - put_unaligned_be16(nr_sectors, &cmd->cmnd[7]); |
---|
| 962 | + put_unaligned_be32(lba, &cmd->cmnd[2]); |
---|
| 963 | + put_unaligned_be16(nr_blocks, &cmd->cmnd[7]); |
---|
847 | 964 | |
---|
848 | | - cmd->allowed = SD_MAX_RETRIES; |
---|
| 965 | + cmd->allowed = sdkp->max_retries; |
---|
849 | 966 | cmd->transfersize = data_len; |
---|
850 | 967 | rq->timeout = unmap ? SD_TIMEOUT : SD_WRITE_SAME_TIMEOUT; |
---|
851 | | - scsi_req(rq)->resid_len = data_len; |
---|
852 | 968 | |
---|
853 | | - return scsi_init_io(cmd); |
---|
| 969 | + return scsi_alloc_sgtables(cmd); |
---|
854 | 970 | } |
---|
855 | 971 | |
---|
856 | | -static int sd_setup_write_zeroes_cmnd(struct scsi_cmnd *cmd) |
---|
| 972 | +static blk_status_t sd_setup_write_zeroes_cmnd(struct scsi_cmnd *cmd) |
---|
857 | 973 | { |
---|
858 | 974 | struct request *rq = cmd->request; |
---|
859 | 975 | struct scsi_device *sdp = cmd->device; |
---|
860 | 976 | struct scsi_disk *sdkp = scsi_disk(rq->rq_disk); |
---|
861 | | - u64 sector = blk_rq_pos(rq) >> (ilog2(sdp->sector_size) - 9); |
---|
862 | | - u32 nr_sectors = blk_rq_sectors(rq) >> (ilog2(sdp->sector_size) - 9); |
---|
| 977 | + u64 lba = sectors_to_logical(sdp, blk_rq_pos(rq)); |
---|
| 978 | + u32 nr_blocks = sectors_to_logical(sdp, blk_rq_sectors(rq)); |
---|
863 | 979 | |
---|
864 | 980 | if (!(rq->cmd_flags & REQ_NOUNMAP)) { |
---|
865 | 981 | switch (sdkp->zeroing_mode) { |
---|
.. | .. |
---|
870 | 986 | } |
---|
871 | 987 | } |
---|
872 | 988 | |
---|
873 | | - if (sdp->no_write_same) |
---|
874 | | - return BLKPREP_INVALID; |
---|
| 989 | + if (sdp->no_write_same) { |
---|
| 990 | + rq->rq_flags |= RQF_QUIET; |
---|
| 991 | + return BLK_STS_TARGET; |
---|
| 992 | + } |
---|
875 | 993 | |
---|
876 | | - if (sdkp->ws16 || sector > 0xffffffff || nr_sectors > 0xffff) |
---|
| 994 | + if (sdkp->ws16 || lba > 0xffffffff || nr_blocks > 0xffff) |
---|
877 | 995 | return sd_setup_write_same16_cmnd(cmd, false); |
---|
878 | 996 | |
---|
879 | 997 | return sd_setup_write_same10_cmnd(cmd, false); |
---|
.. | .. |
---|
948 | 1066 | * Will set up either WRITE SAME(10) or WRITE SAME(16) depending on |
---|
949 | 1067 | * the preference indicated by the target device. |
---|
950 | 1068 | **/ |
---|
951 | | -static int sd_setup_write_same_cmnd(struct scsi_cmnd *cmd) |
---|
| 1069 | +static blk_status_t sd_setup_write_same_cmnd(struct scsi_cmnd *cmd) |
---|
952 | 1070 | { |
---|
953 | 1071 | struct request *rq = cmd->request; |
---|
954 | 1072 | struct scsi_device *sdp = cmd->device; |
---|
955 | 1073 | struct scsi_disk *sdkp = scsi_disk(rq->rq_disk); |
---|
956 | 1074 | struct bio *bio = rq->bio; |
---|
957 | | - sector_t sector = blk_rq_pos(rq); |
---|
958 | | - unsigned int nr_sectors = blk_rq_sectors(rq); |
---|
| 1075 | + u64 lba = sectors_to_logical(sdp, blk_rq_pos(rq)); |
---|
| 1076 | + u32 nr_blocks = sectors_to_logical(sdp, blk_rq_sectors(rq)); |
---|
959 | 1077 | unsigned int nr_bytes = blk_rq_bytes(rq); |
---|
960 | | - int ret; |
---|
| 1078 | + blk_status_t ret; |
---|
961 | 1079 | |
---|
962 | 1080 | if (sdkp->device->no_write_same) |
---|
963 | | - return BLKPREP_INVALID; |
---|
| 1081 | + return BLK_STS_TARGET; |
---|
964 | 1082 | |
---|
965 | 1083 | BUG_ON(bio_offset(bio) || bio_iovec(bio).bv_len != sdp->sector_size); |
---|
966 | 1084 | |
---|
967 | | - sector >>= ilog2(sdp->sector_size) - 9; |
---|
968 | | - nr_sectors >>= ilog2(sdp->sector_size) - 9; |
---|
| 1085 | + rq->timeout = SD_WRITE_SAME_TIMEOUT; |
---|
969 | 1086 | |
---|
970 | | - if (likely(!sdp->timeout_override)) |
---|
971 | | - rq->timeout = SD_WRITE_SAME_TIMEOUT; |
---|
972 | | - else |
---|
973 | | - rq->timeout = sdp->timeout_override; |
---|
974 | | - |
---|
975 | | - if (sdkp->ws16 || sector > 0xffffffff || nr_sectors > 0xffff) { |
---|
| 1087 | + if (sdkp->ws16 || lba > 0xffffffff || nr_blocks > 0xffff) { |
---|
976 | 1088 | cmd->cmd_len = 16; |
---|
977 | 1089 | cmd->cmnd[0] = WRITE_SAME_16; |
---|
978 | | - put_unaligned_be64(sector, &cmd->cmnd[2]); |
---|
979 | | - put_unaligned_be32(nr_sectors, &cmd->cmnd[10]); |
---|
| 1090 | + put_unaligned_be64(lba, &cmd->cmnd[2]); |
---|
| 1091 | + put_unaligned_be32(nr_blocks, &cmd->cmnd[10]); |
---|
980 | 1092 | } else { |
---|
981 | 1093 | cmd->cmd_len = 10; |
---|
982 | 1094 | cmd->cmnd[0] = WRITE_SAME; |
---|
983 | | - put_unaligned_be32(sector, &cmd->cmnd[2]); |
---|
984 | | - put_unaligned_be16(nr_sectors, &cmd->cmnd[7]); |
---|
| 1095 | + put_unaligned_be32(lba, &cmd->cmnd[2]); |
---|
| 1096 | + put_unaligned_be16(nr_blocks, &cmd->cmnd[7]); |
---|
985 | 1097 | } |
---|
986 | 1098 | |
---|
987 | 1099 | cmd->transfersize = sdp->sector_size; |
---|
988 | | - cmd->allowed = SD_MAX_RETRIES; |
---|
| 1100 | + cmd->allowed = sdkp->max_retries; |
---|
989 | 1101 | |
---|
990 | 1102 | /* |
---|
991 | 1103 | * For WRITE SAME the data transferred via the DATA OUT buffer is |
---|
.. | .. |
---|
998 | 1110 | * knows how much to actually write. |
---|
999 | 1111 | */ |
---|
1000 | 1112 | rq->__data_len = sdp->sector_size; |
---|
1001 | | - ret = scsi_init_io(cmd); |
---|
| 1113 | + ret = scsi_alloc_sgtables(cmd); |
---|
1002 | 1114 | rq->__data_len = nr_bytes; |
---|
1003 | 1115 | |
---|
1004 | 1116 | return ret; |
---|
1005 | 1117 | } |
---|
1006 | 1118 | |
---|
1007 | | -static int sd_setup_flush_cmnd(struct scsi_cmnd *cmd) |
---|
| 1119 | +static blk_status_t sd_setup_flush_cmnd(struct scsi_cmnd *cmd) |
---|
1008 | 1120 | { |
---|
1009 | 1121 | struct request *rq = cmd->request; |
---|
| 1122 | + struct scsi_disk *sdkp = scsi_disk(rq->rq_disk); |
---|
1010 | 1123 | |
---|
1011 | 1124 | /* flush requests don't perform I/O, zero the S/G table */ |
---|
1012 | 1125 | memset(&cmd->sdb, 0, sizeof(cmd->sdb)); |
---|
.. | .. |
---|
1014 | 1127 | cmd->cmnd[0] = SYNCHRONIZE_CACHE; |
---|
1015 | 1128 | cmd->cmd_len = 10; |
---|
1016 | 1129 | cmd->transfersize = 0; |
---|
1017 | | - cmd->allowed = SD_MAX_RETRIES; |
---|
| 1130 | + cmd->allowed = sdkp->max_retries; |
---|
1018 | 1131 | |
---|
1019 | 1132 | rq->timeout = rq->q->rq_timeout * SD_FLUSH_TIMEOUT_MULTIPLIER; |
---|
1020 | | - return BLKPREP_OK; |
---|
| 1133 | + return BLK_STS_OK; |
---|
1021 | 1134 | } |
---|
1022 | 1135 | |
---|
1023 | | -static int sd_setup_read_write_cmnd(struct scsi_cmnd *SCpnt) |
---|
| 1136 | +static blk_status_t sd_setup_rw32_cmnd(struct scsi_cmnd *cmd, bool write, |
---|
| 1137 | + sector_t lba, unsigned int nr_blocks, |
---|
| 1138 | + unsigned char flags) |
---|
1024 | 1139 | { |
---|
1025 | | - struct request *rq = SCpnt->request; |
---|
1026 | | - struct scsi_device *sdp = SCpnt->device; |
---|
1027 | | - struct gendisk *disk = rq->rq_disk; |
---|
1028 | | - struct scsi_disk *sdkp = scsi_disk(disk); |
---|
1029 | | - sector_t block = blk_rq_pos(rq); |
---|
1030 | | - sector_t threshold; |
---|
1031 | | - unsigned int this_count = blk_rq_sectors(rq); |
---|
1032 | | - unsigned int dif, dix; |
---|
1033 | | - int ret; |
---|
1034 | | - unsigned char protect; |
---|
| 1140 | + cmd->cmnd = mempool_alloc(sd_cdb_pool, GFP_ATOMIC); |
---|
| 1141 | + if (unlikely(cmd->cmnd == NULL)) |
---|
| 1142 | + return BLK_STS_RESOURCE; |
---|
1035 | 1143 | |
---|
1036 | | - ret = scsi_init_io(SCpnt); |
---|
1037 | | - if (ret != BLKPREP_OK) |
---|
1038 | | - return ret; |
---|
1039 | | - WARN_ON_ONCE(SCpnt != rq->special); |
---|
| 1144 | + cmd->cmd_len = SD_EXT_CDB_SIZE; |
---|
| 1145 | + memset(cmd->cmnd, 0, cmd->cmd_len); |
---|
1040 | 1146 | |
---|
1041 | | - /* from here on until we're complete, any goto out |
---|
1042 | | - * is used for a killable error condition */ |
---|
1043 | | - ret = BLKPREP_KILL; |
---|
| 1147 | + cmd->cmnd[0] = VARIABLE_LENGTH_CMD; |
---|
| 1148 | + cmd->cmnd[7] = 0x18; /* Additional CDB len */ |
---|
| 1149 | + cmd->cmnd[9] = write ? WRITE_32 : READ_32; |
---|
| 1150 | + cmd->cmnd[10] = flags; |
---|
| 1151 | + put_unaligned_be64(lba, &cmd->cmnd[12]); |
---|
| 1152 | + put_unaligned_be32(lba, &cmd->cmnd[20]); /* Expected Indirect LBA */ |
---|
| 1153 | + put_unaligned_be32(nr_blocks, &cmd->cmnd[28]); |
---|
1044 | 1154 | |
---|
1045 | | - SCSI_LOG_HLQUEUE(1, |
---|
1046 | | - scmd_printk(KERN_INFO, SCpnt, |
---|
1047 | | - "%s: block=%llu, count=%d\n", |
---|
1048 | | - __func__, (unsigned long long)block, this_count)); |
---|
| 1155 | + return BLK_STS_OK; |
---|
| 1156 | +} |
---|
1049 | 1157 | |
---|
1050 | | - if (!sdp || !scsi_device_online(sdp) || |
---|
1051 | | - block + blk_rq_sectors(rq) > get_capacity(disk)) { |
---|
1052 | | - SCSI_LOG_HLQUEUE(2, scmd_printk(KERN_INFO, SCpnt, |
---|
1053 | | - "Finishing %u sectors\n", |
---|
1054 | | - blk_rq_sectors(rq))); |
---|
1055 | | - SCSI_LOG_HLQUEUE(2, scmd_printk(KERN_INFO, SCpnt, |
---|
1056 | | - "Retry with 0x%p\n", SCpnt)); |
---|
1057 | | - goto out; |
---|
1058 | | - } |
---|
| 1158 | +static blk_status_t sd_setup_rw16_cmnd(struct scsi_cmnd *cmd, bool write, |
---|
| 1159 | + sector_t lba, unsigned int nr_blocks, |
---|
| 1160 | + unsigned char flags) |
---|
| 1161 | +{ |
---|
| 1162 | + cmd->cmd_len = 16; |
---|
| 1163 | + cmd->cmnd[0] = write ? WRITE_16 : READ_16; |
---|
| 1164 | + cmd->cmnd[1] = flags; |
---|
| 1165 | + cmd->cmnd[14] = 0; |
---|
| 1166 | + cmd->cmnd[15] = 0; |
---|
| 1167 | + put_unaligned_be64(lba, &cmd->cmnd[2]); |
---|
| 1168 | + put_unaligned_be32(nr_blocks, &cmd->cmnd[10]); |
---|
1059 | 1169 | |
---|
1060 | | - if (sdp->changed) { |
---|
| 1170 | + return BLK_STS_OK; |
---|
| 1171 | +} |
---|
| 1172 | + |
---|
| 1173 | +static blk_status_t sd_setup_rw10_cmnd(struct scsi_cmnd *cmd, bool write, |
---|
| 1174 | + sector_t lba, unsigned int nr_blocks, |
---|
| 1175 | + unsigned char flags) |
---|
| 1176 | +{ |
---|
| 1177 | + cmd->cmd_len = 10; |
---|
| 1178 | + cmd->cmnd[0] = write ? WRITE_10 : READ_10; |
---|
| 1179 | + cmd->cmnd[1] = flags; |
---|
| 1180 | + cmd->cmnd[6] = 0; |
---|
| 1181 | + cmd->cmnd[9] = 0; |
---|
| 1182 | + put_unaligned_be32(lba, &cmd->cmnd[2]); |
---|
| 1183 | + put_unaligned_be16(nr_blocks, &cmd->cmnd[7]); |
---|
| 1184 | + |
---|
| 1185 | + return BLK_STS_OK; |
---|
| 1186 | +} |
---|
| 1187 | + |
---|
| 1188 | +static blk_status_t sd_setup_rw6_cmnd(struct scsi_cmnd *cmd, bool write, |
---|
| 1189 | + sector_t lba, unsigned int nr_blocks, |
---|
| 1190 | + unsigned char flags) |
---|
| 1191 | +{ |
---|
| 1192 | + /* Avoid that 0 blocks gets translated into 256 blocks. */ |
---|
| 1193 | + if (WARN_ON_ONCE(nr_blocks == 0)) |
---|
| 1194 | + return BLK_STS_IOERR; |
---|
| 1195 | + |
---|
| 1196 | + if (unlikely(flags & 0x8)) { |
---|
1061 | 1197 | /* |
---|
1062 | | - * quietly refuse to do anything to a changed disc until |
---|
1063 | | - * the changed bit has been reset |
---|
| 1198 | + * This happens only if this drive failed 10byte rw |
---|
| 1199 | + * command with ILLEGAL_REQUEST during operation and |
---|
| 1200 | + * thus turned off use_10_for_rw. |
---|
1064 | 1201 | */ |
---|
1065 | | - /* printk("SCSI disk has been changed or is not present. Prohibiting further I/O.\n"); */ |
---|
1066 | | - goto out; |
---|
| 1202 | + scmd_printk(KERN_ERR, cmd, "FUA write on READ/WRITE(6) drive\n"); |
---|
| 1203 | + return BLK_STS_IOERR; |
---|
| 1204 | + } |
---|
| 1205 | + |
---|
| 1206 | + cmd->cmd_len = 6; |
---|
| 1207 | + cmd->cmnd[0] = write ? WRITE_6 : READ_6; |
---|
| 1208 | + cmd->cmnd[1] = (lba >> 16) & 0x1f; |
---|
| 1209 | + cmd->cmnd[2] = (lba >> 8) & 0xff; |
---|
| 1210 | + cmd->cmnd[3] = lba & 0xff; |
---|
| 1211 | + cmd->cmnd[4] = nr_blocks; |
---|
| 1212 | + cmd->cmnd[5] = 0; |
---|
| 1213 | + |
---|
| 1214 | + return BLK_STS_OK; |
---|
| 1215 | +} |
---|
| 1216 | + |
---|
| 1217 | +static blk_status_t sd_setup_read_write_cmnd(struct scsi_cmnd *cmd) |
---|
| 1218 | +{ |
---|
| 1219 | + struct request *rq = cmd->request; |
---|
| 1220 | + struct scsi_device *sdp = cmd->device; |
---|
| 1221 | + struct scsi_disk *sdkp = scsi_disk(rq->rq_disk); |
---|
| 1222 | + sector_t lba = sectors_to_logical(sdp, blk_rq_pos(rq)); |
---|
| 1223 | + sector_t threshold; |
---|
| 1224 | + unsigned int nr_blocks = sectors_to_logical(sdp, blk_rq_sectors(rq)); |
---|
| 1225 | + unsigned int mask = logical_to_sectors(sdp, 1) - 1; |
---|
| 1226 | + bool write = rq_data_dir(rq) == WRITE; |
---|
| 1227 | + unsigned char protect, fua; |
---|
| 1228 | + blk_status_t ret; |
---|
| 1229 | + unsigned int dif; |
---|
| 1230 | + bool dix; |
---|
| 1231 | + |
---|
| 1232 | + ret = scsi_alloc_sgtables(cmd); |
---|
| 1233 | + if (ret != BLK_STS_OK) |
---|
| 1234 | + return ret; |
---|
| 1235 | + |
---|
| 1236 | + ret = BLK_STS_IOERR; |
---|
| 1237 | + if (!scsi_device_online(sdp) || sdp->changed) { |
---|
| 1238 | + scmd_printk(KERN_ERR, cmd, "device offline or changed\n"); |
---|
| 1239 | + goto fail; |
---|
| 1240 | + } |
---|
| 1241 | + |
---|
| 1242 | + if (blk_rq_pos(rq) + blk_rq_sectors(rq) > get_capacity(rq->rq_disk)) { |
---|
| 1243 | + scmd_printk(KERN_ERR, cmd, "access beyond end of device\n"); |
---|
| 1244 | + goto fail; |
---|
| 1245 | + } |
---|
| 1246 | + |
---|
| 1247 | + if ((blk_rq_pos(rq) & mask) || (blk_rq_sectors(rq) & mask)) { |
---|
| 1248 | + scmd_printk(KERN_ERR, cmd, "request not aligned to the logical block size\n"); |
---|
| 1249 | + goto fail; |
---|
1067 | 1250 | } |
---|
1068 | 1251 | |
---|
1069 | 1252 | /* |
---|
1070 | | - * Some SD card readers can't handle multi-sector accesses which touch |
---|
1071 | | - * the last one or two hardware sectors. Split accesses as needed. |
---|
| 1253 | + * Some SD card readers can't handle accesses which touch the |
---|
| 1254 | + * last one or two logical blocks. Split accesses as needed. |
---|
1072 | 1255 | */ |
---|
1073 | | - threshold = get_capacity(disk) - SD_LAST_BUGGY_SECTORS * |
---|
1074 | | - (sdp->sector_size / 512); |
---|
| 1256 | + threshold = sdkp->capacity - SD_LAST_BUGGY_SECTORS; |
---|
1075 | 1257 | |
---|
1076 | | - if (unlikely(sdp->last_sector_bug && block + this_count > threshold)) { |
---|
1077 | | - if (block < threshold) { |
---|
| 1258 | + if (unlikely(sdp->last_sector_bug && lba + nr_blocks > threshold)) { |
---|
| 1259 | + if (lba < threshold) { |
---|
1078 | 1260 | /* Access up to the threshold but not beyond */ |
---|
1079 | | - this_count = threshold - block; |
---|
| 1261 | + nr_blocks = threshold - lba; |
---|
1080 | 1262 | } else { |
---|
1081 | | - /* Access only a single hardware sector */ |
---|
1082 | | - this_count = sdp->sector_size / 512; |
---|
| 1263 | + /* Access only a single logical block */ |
---|
| 1264 | + nr_blocks = 1; |
---|
1083 | 1265 | } |
---|
1084 | 1266 | } |
---|
1085 | 1267 | |
---|
1086 | | - SCSI_LOG_HLQUEUE(2, scmd_printk(KERN_INFO, SCpnt, "block=%llu\n", |
---|
1087 | | - (unsigned long long)block)); |
---|
1088 | | - |
---|
1089 | | - /* |
---|
1090 | | - * If we have a 1K hardware sectorsize, prevent access to single |
---|
1091 | | - * 512 byte sectors. In theory we could handle this - in fact |
---|
1092 | | - * the scsi cdrom driver must be able to handle this because |
---|
1093 | | - * we typically use 1K blocksizes, and cdroms typically have |
---|
1094 | | - * 2K hardware sectorsizes. Of course, things are simpler |
---|
1095 | | - * with the cdrom, since it is read-only. For performance |
---|
1096 | | - * reasons, the filesystems should be able to handle this |
---|
1097 | | - * and not force the scsi disk driver to use bounce buffers |
---|
1098 | | - * for this. |
---|
1099 | | - */ |
---|
1100 | | - if (sdp->sector_size == 1024) { |
---|
1101 | | - if ((block & 1) || (blk_rq_sectors(rq) & 1)) { |
---|
1102 | | - scmd_printk(KERN_ERR, SCpnt, |
---|
1103 | | - "Bad block number requested\n"); |
---|
1104 | | - goto out; |
---|
1105 | | - } else { |
---|
1106 | | - block = block >> 1; |
---|
1107 | | - this_count = this_count >> 1; |
---|
1108 | | - } |
---|
1109 | | - } |
---|
1110 | | - if (sdp->sector_size == 2048) { |
---|
1111 | | - if ((block & 3) || (blk_rq_sectors(rq) & 3)) { |
---|
1112 | | - scmd_printk(KERN_ERR, SCpnt, |
---|
1113 | | - "Bad block number requested\n"); |
---|
1114 | | - goto out; |
---|
1115 | | - } else { |
---|
1116 | | - block = block >> 2; |
---|
1117 | | - this_count = this_count >> 2; |
---|
1118 | | - } |
---|
1119 | | - } |
---|
1120 | | - if (sdp->sector_size == 4096) { |
---|
1121 | | - if ((block & 7) || (blk_rq_sectors(rq) & 7)) { |
---|
1122 | | - scmd_printk(KERN_ERR, SCpnt, |
---|
1123 | | - "Bad block number requested\n"); |
---|
1124 | | - goto out; |
---|
1125 | | - } else { |
---|
1126 | | - block = block >> 3; |
---|
1127 | | - this_count = this_count >> 3; |
---|
1128 | | - } |
---|
1129 | | - } |
---|
1130 | | - if (rq_data_dir(rq) == WRITE) { |
---|
1131 | | - SCpnt->cmnd[0] = WRITE_6; |
---|
1132 | | - |
---|
1133 | | - if (blk_integrity_rq(rq)) |
---|
1134 | | - t10_pi_prepare(SCpnt->request, sdkp->protection_type); |
---|
1135 | | - |
---|
1136 | | - } else if (rq_data_dir(rq) == READ) { |
---|
1137 | | - SCpnt->cmnd[0] = READ_6; |
---|
1138 | | - } else { |
---|
1139 | | - scmd_printk(KERN_ERR, SCpnt, "Unknown command %d\n", req_op(rq)); |
---|
1140 | | - goto out; |
---|
| 1268 | + if (req_op(rq) == REQ_OP_ZONE_APPEND) { |
---|
| 1269 | + ret = sd_zbc_prepare_zone_append(cmd, &lba, nr_blocks); |
---|
| 1270 | + if (ret) |
---|
| 1271 | + goto fail; |
---|
1141 | 1272 | } |
---|
1142 | 1273 | |
---|
1143 | | - SCSI_LOG_HLQUEUE(2, scmd_printk(KERN_INFO, SCpnt, |
---|
1144 | | - "%s %d/%u 512 byte blocks.\n", |
---|
1145 | | - (rq_data_dir(rq) == WRITE) ? |
---|
1146 | | - "writing" : "reading", this_count, |
---|
1147 | | - blk_rq_sectors(rq))); |
---|
1148 | | - |
---|
1149 | | - dix = scsi_prot_sg_count(SCpnt); |
---|
1150 | | - dif = scsi_host_dif_capable(SCpnt->device->host, sdkp->protection_type); |
---|
| 1274 | + fua = rq->cmd_flags & REQ_FUA ? 0x8 : 0; |
---|
| 1275 | + dix = scsi_prot_sg_count(cmd); |
---|
| 1276 | + dif = scsi_host_dif_capable(cmd->device->host, sdkp->protection_type); |
---|
1151 | 1277 | |
---|
1152 | 1278 | if (dif || dix) |
---|
1153 | | - protect = sd_setup_protect_cmnd(SCpnt, dix, dif); |
---|
| 1279 | + protect = sd_setup_protect_cmnd(cmd, dix, dif); |
---|
1154 | 1280 | else |
---|
1155 | 1281 | protect = 0; |
---|
1156 | 1282 | |
---|
1157 | 1283 | if (protect && sdkp->protection_type == T10_PI_TYPE2_PROTECTION) { |
---|
1158 | | - SCpnt->cmnd = mempool_alloc(sd_cdb_pool, GFP_ATOMIC); |
---|
1159 | | - |
---|
1160 | | - if (unlikely(SCpnt->cmnd == NULL)) { |
---|
1161 | | - ret = BLKPREP_DEFER; |
---|
1162 | | - goto out; |
---|
1163 | | - } |
---|
1164 | | - |
---|
1165 | | - SCpnt->cmd_len = SD_EXT_CDB_SIZE; |
---|
1166 | | - memset(SCpnt->cmnd, 0, SCpnt->cmd_len); |
---|
1167 | | - SCpnt->cmnd[0] = VARIABLE_LENGTH_CMD; |
---|
1168 | | - SCpnt->cmnd[7] = 0x18; |
---|
1169 | | - SCpnt->cmnd[9] = (rq_data_dir(rq) == READ) ? READ_32 : WRITE_32; |
---|
1170 | | - SCpnt->cmnd[10] = protect | ((rq->cmd_flags & REQ_FUA) ? 0x8 : 0); |
---|
1171 | | - |
---|
1172 | | - /* LBA */ |
---|
1173 | | - SCpnt->cmnd[12] = sizeof(block) > 4 ? (unsigned char) (block >> 56) & 0xff : 0; |
---|
1174 | | - SCpnt->cmnd[13] = sizeof(block) > 4 ? (unsigned char) (block >> 48) & 0xff : 0; |
---|
1175 | | - SCpnt->cmnd[14] = sizeof(block) > 4 ? (unsigned char) (block >> 40) & 0xff : 0; |
---|
1176 | | - SCpnt->cmnd[15] = sizeof(block) > 4 ? (unsigned char) (block >> 32) & 0xff : 0; |
---|
1177 | | - SCpnt->cmnd[16] = (unsigned char) (block >> 24) & 0xff; |
---|
1178 | | - SCpnt->cmnd[17] = (unsigned char) (block >> 16) & 0xff; |
---|
1179 | | - SCpnt->cmnd[18] = (unsigned char) (block >> 8) & 0xff; |
---|
1180 | | - SCpnt->cmnd[19] = (unsigned char) block & 0xff; |
---|
1181 | | - |
---|
1182 | | - /* Expected Indirect LBA */ |
---|
1183 | | - SCpnt->cmnd[20] = (unsigned char) (block >> 24) & 0xff; |
---|
1184 | | - SCpnt->cmnd[21] = (unsigned char) (block >> 16) & 0xff; |
---|
1185 | | - SCpnt->cmnd[22] = (unsigned char) (block >> 8) & 0xff; |
---|
1186 | | - SCpnt->cmnd[23] = (unsigned char) block & 0xff; |
---|
1187 | | - |
---|
1188 | | - /* Transfer length */ |
---|
1189 | | - SCpnt->cmnd[28] = (unsigned char) (this_count >> 24) & 0xff; |
---|
1190 | | - SCpnt->cmnd[29] = (unsigned char) (this_count >> 16) & 0xff; |
---|
1191 | | - SCpnt->cmnd[30] = (unsigned char) (this_count >> 8) & 0xff; |
---|
1192 | | - SCpnt->cmnd[31] = (unsigned char) this_count & 0xff; |
---|
1193 | | - } else if (sdp->use_16_for_rw || (this_count > 0xffff)) { |
---|
1194 | | - SCpnt->cmnd[0] += READ_16 - READ_6; |
---|
1195 | | - SCpnt->cmnd[1] = protect | ((rq->cmd_flags & REQ_FUA) ? 0x8 : 0); |
---|
1196 | | - SCpnt->cmnd[2] = sizeof(block) > 4 ? (unsigned char) (block >> 56) & 0xff : 0; |
---|
1197 | | - SCpnt->cmnd[3] = sizeof(block) > 4 ? (unsigned char) (block >> 48) & 0xff : 0; |
---|
1198 | | - SCpnt->cmnd[4] = sizeof(block) > 4 ? (unsigned char) (block >> 40) & 0xff : 0; |
---|
1199 | | - SCpnt->cmnd[5] = sizeof(block) > 4 ? (unsigned char) (block >> 32) & 0xff : 0; |
---|
1200 | | - SCpnt->cmnd[6] = (unsigned char) (block >> 24) & 0xff; |
---|
1201 | | - SCpnt->cmnd[7] = (unsigned char) (block >> 16) & 0xff; |
---|
1202 | | - SCpnt->cmnd[8] = (unsigned char) (block >> 8) & 0xff; |
---|
1203 | | - SCpnt->cmnd[9] = (unsigned char) block & 0xff; |
---|
1204 | | - SCpnt->cmnd[10] = (unsigned char) (this_count >> 24) & 0xff; |
---|
1205 | | - SCpnt->cmnd[11] = (unsigned char) (this_count >> 16) & 0xff; |
---|
1206 | | - SCpnt->cmnd[12] = (unsigned char) (this_count >> 8) & 0xff; |
---|
1207 | | - SCpnt->cmnd[13] = (unsigned char) this_count & 0xff; |
---|
1208 | | - SCpnt->cmnd[14] = SCpnt->cmnd[15] = 0; |
---|
1209 | | - } else if ((this_count > 0xff) || (block > 0x1fffff) || |
---|
1210 | | - scsi_device_protection(SCpnt->device) || |
---|
1211 | | - SCpnt->device->use_10_for_rw) { |
---|
1212 | | - SCpnt->cmnd[0] += READ_10 - READ_6; |
---|
1213 | | - SCpnt->cmnd[1] = protect | ((rq->cmd_flags & REQ_FUA) ? 0x8 : 0); |
---|
1214 | | - SCpnt->cmnd[2] = (unsigned char) (block >> 24) & 0xff; |
---|
1215 | | - SCpnt->cmnd[3] = (unsigned char) (block >> 16) & 0xff; |
---|
1216 | | - SCpnt->cmnd[4] = (unsigned char) (block >> 8) & 0xff; |
---|
1217 | | - SCpnt->cmnd[5] = (unsigned char) block & 0xff; |
---|
1218 | | - SCpnt->cmnd[6] = SCpnt->cmnd[9] = 0; |
---|
1219 | | - SCpnt->cmnd[7] = (unsigned char) (this_count >> 8) & 0xff; |
---|
1220 | | - SCpnt->cmnd[8] = (unsigned char) this_count & 0xff; |
---|
| 1284 | + ret = sd_setup_rw32_cmnd(cmd, write, lba, nr_blocks, |
---|
| 1285 | + protect | fua); |
---|
| 1286 | + } else if (sdp->use_16_for_rw || (nr_blocks > 0xffff)) { |
---|
| 1287 | + ret = sd_setup_rw16_cmnd(cmd, write, lba, nr_blocks, |
---|
| 1288 | + protect | fua); |
---|
| 1289 | + } else if ((nr_blocks > 0xff) || (lba > 0x1fffff) || |
---|
| 1290 | + sdp->use_10_for_rw || protect) { |
---|
| 1291 | + ret = sd_setup_rw10_cmnd(cmd, write, lba, nr_blocks, |
---|
| 1292 | + protect | fua); |
---|
1221 | 1293 | } else { |
---|
1222 | | - if (unlikely(rq->cmd_flags & REQ_FUA)) { |
---|
1223 | | - /* |
---|
1224 | | - * This happens only if this drive failed |
---|
1225 | | - * 10byte rw command with ILLEGAL_REQUEST |
---|
1226 | | - * during operation and thus turned off |
---|
1227 | | - * use_10_for_rw. |
---|
1228 | | - */ |
---|
1229 | | - scmd_printk(KERN_ERR, SCpnt, |
---|
1230 | | - "FUA write on READ/WRITE(6) drive\n"); |
---|
1231 | | - goto out; |
---|
1232 | | - } |
---|
1233 | | - |
---|
1234 | | - SCpnt->cmnd[1] |= (unsigned char) ((block >> 16) & 0x1f); |
---|
1235 | | - SCpnt->cmnd[2] = (unsigned char) ((block >> 8) & 0xff); |
---|
1236 | | - SCpnt->cmnd[3] = (unsigned char) block & 0xff; |
---|
1237 | | - SCpnt->cmnd[4] = (unsigned char) this_count; |
---|
1238 | | - SCpnt->cmnd[5] = 0; |
---|
| 1294 | + ret = sd_setup_rw6_cmnd(cmd, write, lba, nr_blocks, |
---|
| 1295 | + protect | fua); |
---|
1239 | 1296 | } |
---|
1240 | | - SCpnt->sdb.length = this_count * sdp->sector_size; |
---|
| 1297 | + |
---|
| 1298 | + if (unlikely(ret != BLK_STS_OK)) |
---|
| 1299 | + goto fail; |
---|
1241 | 1300 | |
---|
1242 | 1301 | /* |
---|
1243 | 1302 | * We shouldn't disconnect in the middle of a sector, so with a dumb |
---|
1244 | 1303 | * host adapter, it's safe to assume that we can at least transfer |
---|
1245 | 1304 | * this many bytes between each connect / disconnect. |
---|
1246 | 1305 | */ |
---|
1247 | | - SCpnt->transfersize = sdp->sector_size; |
---|
1248 | | - SCpnt->underflow = this_count << 9; |
---|
1249 | | - SCpnt->allowed = SD_MAX_RETRIES; |
---|
| 1306 | + cmd->transfersize = sdp->sector_size; |
---|
| 1307 | + cmd->underflow = nr_blocks << 9; |
---|
| 1308 | + cmd->allowed = sdkp->max_retries; |
---|
| 1309 | + cmd->sdb.length = nr_blocks * sdp->sector_size; |
---|
| 1310 | + |
---|
| 1311 | + SCSI_LOG_HLQUEUE(1, |
---|
| 1312 | + scmd_printk(KERN_INFO, cmd, |
---|
| 1313 | + "%s: block=%llu, count=%d\n", __func__, |
---|
| 1314 | + (unsigned long long)blk_rq_pos(rq), |
---|
| 1315 | + blk_rq_sectors(rq))); |
---|
| 1316 | + SCSI_LOG_HLQUEUE(2, |
---|
| 1317 | + scmd_printk(KERN_INFO, cmd, |
---|
| 1318 | + "%s %d/%u 512 byte blocks.\n", |
---|
| 1319 | + write ? "writing" : "reading", nr_blocks, |
---|
| 1320 | + blk_rq_sectors(rq))); |
---|
1250 | 1321 | |
---|
1251 | 1322 | /* |
---|
1252 | | - * This indicates that the command is ready from our end to be |
---|
1253 | | - * queued. |
---|
| 1323 | + * This indicates that the command is ready from our end to be queued. |
---|
1254 | 1324 | */ |
---|
1255 | | - ret = BLKPREP_OK; |
---|
1256 | | - out: |
---|
| 1325 | + return BLK_STS_OK; |
---|
| 1326 | +fail: |
---|
| 1327 | + scsi_free_sgtables(cmd); |
---|
1257 | 1328 | return ret; |
---|
1258 | 1329 | } |
---|
1259 | 1330 | |
---|
1260 | | -static int sd_init_command(struct scsi_cmnd *cmd) |
---|
| 1331 | +static blk_status_t sd_init_command(struct scsi_cmnd *cmd) |
---|
1261 | 1332 | { |
---|
1262 | 1333 | struct request *rq = cmd->request; |
---|
1263 | 1334 | |
---|
.. | .. |
---|
1273 | 1344 | case SD_LBP_ZERO: |
---|
1274 | 1345 | return sd_setup_write_same10_cmnd(cmd, false); |
---|
1275 | 1346 | default: |
---|
1276 | | - return BLKPREP_INVALID; |
---|
| 1347 | + return BLK_STS_TARGET; |
---|
1277 | 1348 | } |
---|
1278 | 1349 | case REQ_OP_WRITE_ZEROES: |
---|
1279 | 1350 | return sd_setup_write_zeroes_cmnd(cmd); |
---|
.. | .. |
---|
1283 | 1354 | return sd_setup_flush_cmnd(cmd); |
---|
1284 | 1355 | case REQ_OP_READ: |
---|
1285 | 1356 | case REQ_OP_WRITE: |
---|
| 1357 | + case REQ_OP_ZONE_APPEND: |
---|
1286 | 1358 | return sd_setup_read_write_cmnd(cmd); |
---|
1287 | | - case REQ_OP_ZONE_REPORT: |
---|
1288 | | - return sd_zbc_setup_report_cmnd(cmd); |
---|
1289 | 1359 | case REQ_OP_ZONE_RESET: |
---|
1290 | | - return sd_zbc_setup_reset_cmnd(cmd); |
---|
| 1360 | + return sd_zbc_setup_zone_mgmt_cmnd(cmd, ZO_RESET_WRITE_POINTER, |
---|
| 1361 | + false); |
---|
| 1362 | + case REQ_OP_ZONE_RESET_ALL: |
---|
| 1363 | + return sd_zbc_setup_zone_mgmt_cmnd(cmd, ZO_RESET_WRITE_POINTER, |
---|
| 1364 | + true); |
---|
| 1365 | + case REQ_OP_ZONE_OPEN: |
---|
| 1366 | + return sd_zbc_setup_zone_mgmt_cmnd(cmd, ZO_OPEN_ZONE, false); |
---|
| 1367 | + case REQ_OP_ZONE_CLOSE: |
---|
| 1368 | + return sd_zbc_setup_zone_mgmt_cmnd(cmd, ZO_CLOSE_ZONE, false); |
---|
| 1369 | + case REQ_OP_ZONE_FINISH: |
---|
| 1370 | + return sd_zbc_setup_zone_mgmt_cmnd(cmd, ZO_FINISH_ZONE, false); |
---|
1291 | 1371 | default: |
---|
1292 | 1372 | WARN_ON_ONCE(1); |
---|
1293 | | - return BLKPREP_KILL; |
---|
| 1373 | + return BLK_STS_NOTSUPP; |
---|
1294 | 1374 | } |
---|
1295 | 1375 | } |
---|
1296 | 1376 | |
---|
.. | .. |
---|
1308 | 1388 | SCpnt->cmd_len = 0; |
---|
1309 | 1389 | mempool_free(cmnd, sd_cdb_pool); |
---|
1310 | 1390 | } |
---|
| 1391 | +} |
---|
| 1392 | + |
---|
| 1393 | +static bool sd_need_revalidate(struct block_device *bdev, |
---|
| 1394 | + struct scsi_disk *sdkp) |
---|
| 1395 | +{ |
---|
| 1396 | + if (sdkp->device->removable || sdkp->write_prot) { |
---|
| 1397 | + if (bdev_check_media_change(bdev)) |
---|
| 1398 | + return true; |
---|
| 1399 | + } |
---|
| 1400 | + |
---|
| 1401 | + /* |
---|
| 1402 | + * Force a full rescan after ioctl(BLKRRPART). While the disk state has |
---|
| 1403 | + * nothing to do with partitions, BLKRRPART is used to force a full |
---|
| 1404 | + * revalidate after things like a format for historical reasons. |
---|
| 1405 | + */ |
---|
| 1406 | + return test_bit(GD_NEED_PART_SCAN, &bdev->bd_disk->state); |
---|
1311 | 1407 | } |
---|
1312 | 1408 | |
---|
1313 | 1409 | /** |
---|
.. | .. |
---|
1346 | 1442 | if (!scsi_block_when_processing_errors(sdev)) |
---|
1347 | 1443 | goto error_out; |
---|
1348 | 1444 | |
---|
1349 | | - if (sdev->removable || sdkp->write_prot) |
---|
1350 | | - check_disk_change(bdev); |
---|
| 1445 | + if (sd_need_revalidate(bdev, sdkp)) |
---|
| 1446 | + sd_revalidate_disk(bdev->bd_disk); |
---|
1351 | 1447 | |
---|
1352 | 1448 | /* |
---|
1353 | 1449 | * If the drive is empty, just let the open fail. |
---|
.. | .. |
---|
1444 | 1540 | * @bdev: target block device |
---|
1445 | 1541 | * @mode: FMODE_* mask |
---|
1446 | 1542 | * @cmd: ioctl command number |
---|
1447 | | - * @arg: this is third argument given to ioctl(2) system call. |
---|
| 1543 | + * @p: this is third argument given to ioctl(2) system call. |
---|
1448 | 1544 | * Often contains a pointer. |
---|
1449 | 1545 | * |
---|
1450 | 1546 | * Returns 0 if successful (some ioctls return positive numbers on |
---|
.. | .. |
---|
1453 | 1549 | * Note: most ioctls are forward onto the block subsystem or further |
---|
1454 | 1550 | * down in the scsi subsystem. |
---|
1455 | 1551 | **/ |
---|
1456 | | -static int sd_ioctl(struct block_device *bdev, fmode_t mode, |
---|
1457 | | - unsigned int cmd, unsigned long arg) |
---|
| 1552 | +static int sd_ioctl_common(struct block_device *bdev, fmode_t mode, |
---|
| 1553 | + unsigned int cmd, void __user *p) |
---|
1458 | 1554 | { |
---|
1459 | 1555 | struct gendisk *disk = bdev->bd_disk; |
---|
1460 | 1556 | struct scsi_disk *sdkp = scsi_disk(disk); |
---|
1461 | 1557 | struct scsi_device *sdp = sdkp->device; |
---|
1462 | | - void __user *p = (void __user *)arg; |
---|
1463 | 1558 | int error; |
---|
1464 | 1559 | |
---|
1465 | 1560 | SCSI_LOG_IOCTL(1, sd_printk(KERN_INFO, sdkp, "sd_ioctl: disk=%s, " |
---|
.. | .. |
---|
1495 | 1590 | break; |
---|
1496 | 1591 | default: |
---|
1497 | 1592 | error = scsi_cmd_blk_ioctl(bdev, mode, cmd, p); |
---|
1498 | | - if (error != -ENOTTY) |
---|
1499 | | - break; |
---|
1500 | | - error = scsi_ioctl(sdp, cmd, p); |
---|
1501 | 1593 | break; |
---|
1502 | 1594 | } |
---|
1503 | 1595 | out: |
---|
.. | .. |
---|
1578 | 1670 | if (scsi_block_when_processing_errors(sdp)) { |
---|
1579 | 1671 | struct scsi_sense_hdr sshdr = { 0, }; |
---|
1580 | 1672 | |
---|
1581 | | - retval = scsi_test_unit_ready(sdp, SD_TIMEOUT, SD_MAX_RETRIES, |
---|
| 1673 | + retval = scsi_test_unit_ready(sdp, SD_TIMEOUT, sdkp->max_retries, |
---|
1582 | 1674 | &sshdr); |
---|
1583 | 1675 | |
---|
1584 | 1676 | /* failed to execute TUR, assume media not present */ |
---|
.. | .. |
---|
1635 | 1727 | * flush everything. |
---|
1636 | 1728 | */ |
---|
1637 | 1729 | res = scsi_execute(sdp, cmd, DMA_NONE, NULL, 0, NULL, sshdr, |
---|
1638 | | - timeout, SD_MAX_RETRIES, 0, RQF_PM, NULL); |
---|
| 1730 | + timeout, sdkp->max_retries, 0, RQF_PM, NULL); |
---|
1639 | 1731 | if (res == 0) |
---|
1640 | 1732 | break; |
---|
1641 | 1733 | } |
---|
.. | .. |
---|
1675 | 1767 | static void sd_rescan(struct device *dev) |
---|
1676 | 1768 | { |
---|
1677 | 1769 | struct scsi_disk *sdkp = dev_get_drvdata(dev); |
---|
| 1770 | + int ret; |
---|
1678 | 1771 | |
---|
1679 | | - revalidate_disk(sdkp->disk); |
---|
| 1772 | + ret = sd_revalidate_disk(sdkp->disk); |
---|
| 1773 | + revalidate_disk_size(sdkp->disk, ret == 0); |
---|
1680 | 1774 | } |
---|
1681 | 1775 | |
---|
| 1776 | +static int sd_ioctl(struct block_device *bdev, fmode_t mode, |
---|
| 1777 | + unsigned int cmd, unsigned long arg) |
---|
| 1778 | +{ |
---|
| 1779 | + void __user *p = (void __user *)arg; |
---|
| 1780 | + int ret; |
---|
| 1781 | + |
---|
| 1782 | + ret = sd_ioctl_common(bdev, mode, cmd, p); |
---|
| 1783 | + if (ret != -ENOTTY) |
---|
| 1784 | + return ret; |
---|
| 1785 | + |
---|
| 1786 | + return scsi_ioctl(scsi_disk(bdev->bd_disk)->device, cmd, p); |
---|
| 1787 | +} |
---|
1682 | 1788 | |
---|
1683 | 1789 | #ifdef CONFIG_COMPAT |
---|
1684 | | -/* |
---|
1685 | | - * This gets directly called from VFS. When the ioctl |
---|
1686 | | - * is not recognized we go back to the other translation paths. |
---|
1687 | | - */ |
---|
1688 | 1790 | static int sd_compat_ioctl(struct block_device *bdev, fmode_t mode, |
---|
1689 | 1791 | unsigned int cmd, unsigned long arg) |
---|
1690 | 1792 | { |
---|
1691 | | - struct gendisk *disk = bdev->bd_disk; |
---|
1692 | | - struct scsi_disk *sdkp = scsi_disk(disk); |
---|
1693 | | - struct scsi_device *sdev = sdkp->device; |
---|
1694 | 1793 | void __user *p = compat_ptr(arg); |
---|
1695 | | - int error; |
---|
| 1794 | + int ret; |
---|
1696 | 1795 | |
---|
1697 | | - error = scsi_verify_blk_ioctl(bdev, cmd); |
---|
1698 | | - if (error < 0) |
---|
1699 | | - return error; |
---|
| 1796 | + ret = sd_ioctl_common(bdev, mode, cmd, p); |
---|
| 1797 | + if (ret != -ENOTTY) |
---|
| 1798 | + return ret; |
---|
1700 | 1799 | |
---|
1701 | | - error = scsi_ioctl_block_when_processing_errors(sdev, cmd, |
---|
1702 | | - (mode & FMODE_NDELAY) != 0); |
---|
1703 | | - if (error) |
---|
1704 | | - return error; |
---|
1705 | | - |
---|
1706 | | - if (is_sed_ioctl(cmd)) |
---|
1707 | | - return sed_ioctl(sdkp->opal_dev, cmd, p); |
---|
1708 | | - |
---|
1709 | | - /* |
---|
1710 | | - * Let the static ioctl translation table take care of it. |
---|
1711 | | - */ |
---|
1712 | | - if (!sdev->host->hostt->compat_ioctl) |
---|
1713 | | - return -ENOIOCTLCMD; |
---|
1714 | | - return sdev->host->hostt->compat_ioctl(sdev, cmd, p); |
---|
| 1800 | + return scsi_compat_ioctl(scsi_disk(bdev->bd_disk)->device, cmd, p); |
---|
1715 | 1801 | } |
---|
1716 | 1802 | #endif |
---|
1717 | 1803 | |
---|
.. | .. |
---|
1738 | 1824 | static int sd_pr_command(struct block_device *bdev, u8 sa, |
---|
1739 | 1825 | u64 key, u64 sa_key, u8 type, u8 flags) |
---|
1740 | 1826 | { |
---|
1741 | | - struct scsi_device *sdev = scsi_disk(bdev->bd_disk)->device; |
---|
| 1827 | + struct scsi_disk *sdkp = scsi_disk(bdev->bd_disk); |
---|
| 1828 | + struct scsi_device *sdev = sdkp->device; |
---|
1742 | 1829 | struct scsi_sense_hdr sshdr; |
---|
1743 | 1830 | int result; |
---|
1744 | 1831 | u8 cmd[16] = { 0, }; |
---|
.. | .. |
---|
1754 | 1841 | data[20] = flags; |
---|
1755 | 1842 | |
---|
1756 | 1843 | result = scsi_execute_req(sdev, cmd, DMA_TO_DEVICE, &data, sizeof(data), |
---|
1757 | | - &sshdr, SD_TIMEOUT, SD_MAX_RETRIES, NULL); |
---|
| 1844 | + &sshdr, SD_TIMEOUT, sdkp->max_retries, NULL); |
---|
1758 | 1845 | |
---|
1759 | 1846 | if (driver_byte(result) == DRIVER_SENSE && |
---|
1760 | 1847 | scsi_sense_valid(&sshdr)) { |
---|
.. | .. |
---|
1818 | 1905 | .compat_ioctl = sd_compat_ioctl, |
---|
1819 | 1906 | #endif |
---|
1820 | 1907 | .check_events = sd_check_events, |
---|
1821 | | - .revalidate_disk = sd_revalidate_disk, |
---|
1822 | 1908 | .unlock_native_capacity = sd_unlock_native_capacity, |
---|
| 1909 | + .report_zones = sd_zbc_report_zones, |
---|
1823 | 1910 | .pr_ops = &sd_pr_ops, |
---|
1824 | 1911 | }; |
---|
1825 | 1912 | |
---|
.. | .. |
---|
1963 | 2050 | case REQ_OP_WRITE_ZEROES: |
---|
1964 | 2051 | case REQ_OP_WRITE_SAME: |
---|
1965 | 2052 | case REQ_OP_ZONE_RESET: |
---|
| 2053 | + case REQ_OP_ZONE_RESET_ALL: |
---|
| 2054 | + case REQ_OP_ZONE_OPEN: |
---|
| 2055 | + case REQ_OP_ZONE_CLOSE: |
---|
| 2056 | + case REQ_OP_ZONE_FINISH: |
---|
1966 | 2057 | if (!result) { |
---|
1967 | 2058 | good_bytes = blk_rq_bytes(req); |
---|
1968 | | - scsi_set_resid(SCpnt, 0); |
---|
1969 | | - } else { |
---|
1970 | | - good_bytes = 0; |
---|
1971 | | - scsi_set_resid(SCpnt, blk_rq_bytes(req)); |
---|
1972 | | - } |
---|
1973 | | - break; |
---|
1974 | | - case REQ_OP_ZONE_REPORT: |
---|
1975 | | - /* To avoid that the block layer performs an incorrect |
---|
1976 | | - * bio_advance() call and restart of the remainder of |
---|
1977 | | - * incomplete report zone BIOs, always indicate a full |
---|
1978 | | - * completion of REQ_OP_ZONE_REPORT. |
---|
1979 | | - */ |
---|
1980 | | - if (!result) { |
---|
1981 | | - good_bytes = scsi_bufflen(SCpnt); |
---|
1982 | 2059 | scsi_set_resid(SCpnt, 0); |
---|
1983 | 2060 | } else { |
---|
1984 | 2061 | good_bytes = 0; |
---|
.. | .. |
---|
1996 | 2073 | sd_printk(KERN_INFO, sdkp, |
---|
1997 | 2074 | "Unaligned partial completion (resid=%u, sector_sz=%u)\n", |
---|
1998 | 2075 | resid, sector_size); |
---|
| 2076 | + scsi_print_command(SCpnt); |
---|
1999 | 2077 | resid = min(scsi_bufflen(SCpnt), |
---|
2000 | 2078 | round_up(resid, sector_size)); |
---|
2001 | 2079 | scsi_set_resid(SCpnt, resid); |
---|
.. | .. |
---|
2063 | 2141 | |
---|
2064 | 2142 | out: |
---|
2065 | 2143 | if (sd_is_zoned(sdkp)) |
---|
2066 | | - sd_zbc_complete(SCpnt, good_bytes, &sshdr); |
---|
| 2144 | + good_bytes = sd_zbc_complete(SCpnt, good_bytes, &sshdr); |
---|
2067 | 2145 | |
---|
2068 | 2146 | SCSI_LOG_HLCOMPLETE(1, scmd_printk(KERN_INFO, SCpnt, |
---|
2069 | 2147 | "sd_done: completed %d of %d bytes\n", |
---|
2070 | 2148 | good_bytes, scsi_bufflen(SCpnt))); |
---|
2071 | | - |
---|
2072 | | - if (rq_data_dir(SCpnt->request) == READ && scsi_prot_sg_count(SCpnt) && |
---|
2073 | | - good_bytes) |
---|
2074 | | - t10_pi_complete(SCpnt->request, sdkp->protection_type, |
---|
2075 | | - good_bytes / scsi_prot_interval(SCpnt)); |
---|
2076 | 2149 | |
---|
2077 | 2150 | return good_bytes; |
---|
2078 | 2151 | } |
---|
.. | .. |
---|
2104 | 2177 | the_result = scsi_execute_req(sdkp->device, cmd, |
---|
2105 | 2178 | DMA_NONE, NULL, 0, |
---|
2106 | 2179 | &sshdr, SD_TIMEOUT, |
---|
2107 | | - SD_MAX_RETRIES, NULL); |
---|
| 2180 | + sdkp->max_retries, NULL); |
---|
2108 | 2181 | |
---|
2109 | 2182 | /* |
---|
2110 | 2183 | * If the drive has indicated to us that it |
---|
.. | .. |
---|
2160 | 2233 | cmd[4] |= 1 << 4; |
---|
2161 | 2234 | scsi_execute_req(sdkp->device, cmd, DMA_NONE, |
---|
2162 | 2235 | NULL, 0, &sshdr, |
---|
2163 | | - SD_TIMEOUT, SD_MAX_RETRIES, |
---|
| 2236 | + SD_TIMEOUT, sdkp->max_retries, |
---|
2164 | 2237 | NULL); |
---|
2165 | 2238 | spintime_expire = jiffies + 100 * HZ; |
---|
2166 | 2239 | spintime = 1; |
---|
.. | .. |
---|
2278 | 2351 | |
---|
2279 | 2352 | #define READ_CAPACITY_RETRIES_ON_RESET 10 |
---|
2280 | 2353 | |
---|
2281 | | -/* |
---|
2282 | | - * Ensure that we don't overflow sector_t when CONFIG_LBDAF is not set |
---|
2283 | | - * and the reported logical block size is bigger than 512 bytes. Note |
---|
2284 | | - * that last_sector is a u64 and therefore logical_to_sectors() is not |
---|
2285 | | - * applicable. |
---|
2286 | | - */ |
---|
2287 | | -static bool sd_addressable_capacity(u64 lba, unsigned int sector_size) |
---|
2288 | | -{ |
---|
2289 | | - u64 last_sector = (lba + 1ULL) << (ilog2(sector_size) - 9); |
---|
2290 | | - |
---|
2291 | | - if (sizeof(sector_t) == 4 && last_sector > U32_MAX) |
---|
2292 | | - return false; |
---|
2293 | | - |
---|
2294 | | - return true; |
---|
2295 | | -} |
---|
2296 | | - |
---|
2297 | 2354 | static int read_capacity_16(struct scsi_disk *sdkp, struct scsi_device *sdp, |
---|
2298 | 2355 | unsigned char *buffer) |
---|
2299 | 2356 | { |
---|
.. | .. |
---|
2318 | 2375 | |
---|
2319 | 2376 | the_result = scsi_execute_req(sdp, cmd, DMA_FROM_DEVICE, |
---|
2320 | 2377 | buffer, RC16_LEN, &sshdr, |
---|
2321 | | - SD_TIMEOUT, SD_MAX_RETRIES, NULL); |
---|
| 2378 | + SD_TIMEOUT, sdkp->max_retries, NULL); |
---|
2322 | 2379 | |
---|
2323 | 2380 | if (media_not_present(sdkp, &sshdr)) |
---|
2324 | 2381 | return -ENODEV; |
---|
.. | .. |
---|
2357 | 2414 | if (sd_read_protection_type(sdkp, buffer) < 0) { |
---|
2358 | 2415 | sdkp->capacity = 0; |
---|
2359 | 2416 | return -ENODEV; |
---|
2360 | | - } |
---|
2361 | | - |
---|
2362 | | - if (!sd_addressable_capacity(lba, sector_size)) { |
---|
2363 | | - sd_printk(KERN_ERR, sdkp, "Too big for this kernel. Use a " |
---|
2364 | | - "kernel compiled with support for large block " |
---|
2365 | | - "devices.\n"); |
---|
2366 | | - sdkp->capacity = 0; |
---|
2367 | | - return -EOVERFLOW; |
---|
2368 | 2417 | } |
---|
2369 | 2418 | |
---|
2370 | 2419 | /* Logical blocks per physical block exponent */ |
---|
.. | .. |
---|
2411 | 2460 | |
---|
2412 | 2461 | the_result = scsi_execute_req(sdp, cmd, DMA_FROM_DEVICE, |
---|
2413 | 2462 | buffer, 8, &sshdr, |
---|
2414 | | - SD_TIMEOUT, SD_MAX_RETRIES, NULL); |
---|
| 2463 | + SD_TIMEOUT, sdkp->max_retries, NULL); |
---|
2415 | 2464 | |
---|
2416 | 2465 | if (media_not_present(sdkp, &sshdr)) |
---|
2417 | 2466 | return -ENODEV; |
---|
.. | .. |
---|
2446 | 2495 | sdkp->capacity = 0; |
---|
2447 | 2496 | sdkp->physical_block_size = sector_size; |
---|
2448 | 2497 | return sector_size; |
---|
2449 | | - } |
---|
2450 | | - |
---|
2451 | | - if (!sd_addressable_capacity(lba, sector_size)) { |
---|
2452 | | - sd_printk(KERN_ERR, sdkp, "Too big for this kernel. Use a " |
---|
2453 | | - "kernel compiled with support for large block " |
---|
2454 | | - "devices.\n"); |
---|
2455 | | - sdkp->capacity = 0; |
---|
2456 | | - return -EOVERFLOW; |
---|
2457 | 2498 | } |
---|
2458 | 2499 | |
---|
2459 | 2500 | sdkp->capacity = lba + 1; |
---|
.. | .. |
---|
2583 | 2624 | int sector_size = sdkp->device->sector_size; |
---|
2584 | 2625 | char cap_str_2[10], cap_str_10[10]; |
---|
2585 | 2626 | |
---|
| 2627 | + if (!sdkp->first_scan && old_capacity == sdkp->capacity) |
---|
| 2628 | + return; |
---|
| 2629 | + |
---|
2586 | 2630 | string_get_size(sdkp->capacity, sector_size, |
---|
2587 | 2631 | STRING_UNITS_2, cap_str_2, sizeof(cap_str_2)); |
---|
2588 | 2632 | string_get_size(sdkp->capacity, sector_size, |
---|
2589 | | - STRING_UNITS_10, cap_str_10, |
---|
2590 | | - sizeof(cap_str_10)); |
---|
| 2633 | + STRING_UNITS_10, cap_str_10, sizeof(cap_str_10)); |
---|
2591 | 2634 | |
---|
2592 | | - if (sdkp->first_scan || old_capacity != sdkp->capacity) { |
---|
| 2635 | + sd_printk(KERN_NOTICE, sdkp, |
---|
| 2636 | + "%llu %d-byte logical blocks: (%s/%s)\n", |
---|
| 2637 | + (unsigned long long)sdkp->capacity, |
---|
| 2638 | + sector_size, cap_str_10, cap_str_2); |
---|
| 2639 | + |
---|
| 2640 | + if (sdkp->physical_block_size != sector_size) |
---|
2593 | 2641 | sd_printk(KERN_NOTICE, sdkp, |
---|
2594 | | - "%llu %d-byte logical blocks: (%s/%s)\n", |
---|
2595 | | - (unsigned long long)sdkp->capacity, |
---|
2596 | | - sector_size, cap_str_10, cap_str_2); |
---|
2597 | | - |
---|
2598 | | - if (sdkp->physical_block_size != sector_size) |
---|
2599 | | - sd_printk(KERN_NOTICE, sdkp, |
---|
2600 | | - "%u-byte physical blocks\n", |
---|
2601 | | - sdkp->physical_block_size); |
---|
2602 | | - |
---|
2603 | | - sd_zbc_print_zones(sdkp); |
---|
2604 | | - } |
---|
| 2642 | + "%u-byte physical blocks\n", |
---|
| 2643 | + sdkp->physical_block_size); |
---|
2605 | 2644 | } |
---|
2606 | 2645 | |
---|
2607 | 2646 | /* called with buffer of length 512 */ |
---|
2608 | 2647 | static inline int |
---|
2609 | | -sd_do_mode_sense(struct scsi_device *sdp, int dbd, int modepage, |
---|
| 2648 | +sd_do_mode_sense(struct scsi_disk *sdkp, int dbd, int modepage, |
---|
2610 | 2649 | unsigned char *buffer, int len, struct scsi_mode_data *data, |
---|
2611 | 2650 | struct scsi_sense_hdr *sshdr) |
---|
2612 | 2651 | { |
---|
2613 | | - return scsi_mode_sense(sdp, dbd, modepage, buffer, len, |
---|
2614 | | - SD_TIMEOUT, SD_MAX_RETRIES, data, |
---|
| 2652 | + return scsi_mode_sense(sdkp->device, dbd, modepage, buffer, len, |
---|
| 2653 | + SD_TIMEOUT, sdkp->max_retries, data, |
---|
2615 | 2654 | sshdr); |
---|
2616 | 2655 | } |
---|
2617 | 2656 | |
---|
.. | .. |
---|
2634 | 2673 | } |
---|
2635 | 2674 | |
---|
2636 | 2675 | if (sdp->use_192_bytes_for_3f) { |
---|
2637 | | - res = sd_do_mode_sense(sdp, 0, 0x3F, buffer, 192, &data, NULL); |
---|
| 2676 | + res = sd_do_mode_sense(sdkp, 0, 0x3F, buffer, 192, &data, NULL); |
---|
2638 | 2677 | } else { |
---|
2639 | 2678 | /* |
---|
2640 | 2679 | * First attempt: ask for all pages (0x3F), but only 4 bytes. |
---|
2641 | 2680 | * We have to start carefully: some devices hang if we ask |
---|
2642 | 2681 | * for more than is available. |
---|
2643 | 2682 | */ |
---|
2644 | | - res = sd_do_mode_sense(sdp, 0, 0x3F, buffer, 4, &data, NULL); |
---|
| 2683 | + res = sd_do_mode_sense(sdkp, 0, 0x3F, buffer, 4, &data, NULL); |
---|
2645 | 2684 | |
---|
2646 | 2685 | /* |
---|
2647 | 2686 | * Second attempt: ask for page 0 When only page 0 is |
---|
.. | .. |
---|
2649 | 2688 | * 5: Illegal Request, Sense Code 24: Invalid field in |
---|
2650 | 2689 | * CDB. |
---|
2651 | 2690 | */ |
---|
2652 | | - if (!scsi_status_is_good(res)) |
---|
2653 | | - res = sd_do_mode_sense(sdp, 0, 0, buffer, 4, &data, NULL); |
---|
| 2691 | + if (res < 0) |
---|
| 2692 | + res = sd_do_mode_sense(sdkp, 0, 0, buffer, 4, &data, NULL); |
---|
2654 | 2693 | |
---|
2655 | 2694 | /* |
---|
2656 | 2695 | * Third attempt: ask 255 bytes, as we did earlier. |
---|
2657 | 2696 | */ |
---|
2658 | | - if (!scsi_status_is_good(res)) |
---|
2659 | | - res = sd_do_mode_sense(sdp, 0, 0x3F, buffer, 255, |
---|
| 2697 | + if (res < 0) |
---|
| 2698 | + res = sd_do_mode_sense(sdkp, 0, 0x3F, buffer, 255, |
---|
2660 | 2699 | &data, NULL); |
---|
2661 | 2700 | } |
---|
2662 | 2701 | |
---|
2663 | | - if (!scsi_status_is_good(res)) { |
---|
| 2702 | + if (res < 0) { |
---|
2664 | 2703 | sd_first_printk(KERN_WARNING, sdkp, |
---|
2665 | 2704 | "Test WP failed, assume Write Enabled\n"); |
---|
2666 | 2705 | } else { |
---|
.. | .. |
---|
2683 | 2722 | { |
---|
2684 | 2723 | int len = 0, res; |
---|
2685 | 2724 | struct scsi_device *sdp = sdkp->device; |
---|
2686 | | - struct Scsi_Host *host = sdp->host; |
---|
2687 | 2725 | |
---|
2688 | 2726 | int dbd; |
---|
2689 | 2727 | int modepage; |
---|
.. | .. |
---|
2715 | 2753 | dbd = 8; |
---|
2716 | 2754 | } else { |
---|
2717 | 2755 | modepage = 8; |
---|
2718 | | - if (host->set_dbd_for_caching) |
---|
2719 | | - dbd = 8; |
---|
2720 | | - else |
---|
2721 | | - dbd = 0; |
---|
| 2756 | + dbd = 0; |
---|
2722 | 2757 | } |
---|
2723 | 2758 | |
---|
2724 | 2759 | /* cautiously ask */ |
---|
2725 | | - res = sd_do_mode_sense(sdp, dbd, modepage, buffer, first_len, |
---|
| 2760 | + res = sd_do_mode_sense(sdkp, dbd, modepage, buffer, first_len, |
---|
2726 | 2761 | &data, &sshdr); |
---|
2727 | 2762 | |
---|
2728 | | - if (!scsi_status_is_good(res)) |
---|
| 2763 | + if (res < 0) |
---|
2729 | 2764 | goto bad_sense; |
---|
2730 | 2765 | |
---|
2731 | 2766 | if (!data.header_length) { |
---|
.. | .. |
---|
2754 | 2789 | |
---|
2755 | 2790 | /* Get the data */ |
---|
2756 | 2791 | if (len > first_len) |
---|
2757 | | - res = sd_do_mode_sense(sdp, dbd, modepage, buffer, len, |
---|
| 2792 | + res = sd_do_mode_sense(sdkp, dbd, modepage, buffer, len, |
---|
2758 | 2793 | &data, &sshdr); |
---|
2759 | 2794 | |
---|
2760 | | - if (scsi_status_is_good(res)) { |
---|
| 2795 | + if (!res) { |
---|
2761 | 2796 | int offset = data.header_length + data.block_descriptor_length; |
---|
2762 | 2797 | |
---|
2763 | 2798 | while (offset < len) { |
---|
.. | .. |
---|
2873 | 2908 | return; |
---|
2874 | 2909 | |
---|
2875 | 2910 | res = scsi_mode_sense(sdp, 1, 0x0a, buffer, 36, SD_TIMEOUT, |
---|
2876 | | - SD_MAX_RETRIES, &data, &sshdr); |
---|
| 2911 | + sdkp->max_retries, &data, &sshdr); |
---|
2877 | 2912 | |
---|
2878 | | - if (!scsi_status_is_good(res) || !data.header_length || |
---|
| 2913 | + if (res < 0 || !data.header_length || |
---|
2879 | 2914 | data.length < 6) { |
---|
2880 | 2915 | sd_first_printk(KERN_WARNING, sdkp, |
---|
2881 | 2916 | "getting Control mode page failed, assume no ATO\n"); |
---|
.. | .. |
---|
2992 | 3027 | |
---|
2993 | 3028 | if (sdkp->device->type == TYPE_ZBC) { |
---|
2994 | 3029 | /* Host-managed */ |
---|
2995 | | - q->limits.zoned = BLK_ZONED_HM; |
---|
| 3030 | + blk_queue_set_zoned(sdkp->disk, BLK_ZONED_HM); |
---|
2996 | 3031 | } else { |
---|
2997 | 3032 | sdkp->zoned = (buffer[8] >> 4) & 3; |
---|
2998 | | - if (sdkp->zoned == 1) |
---|
| 3033 | + if (sdkp->zoned == 1) { |
---|
2999 | 3034 | /* Host-aware */ |
---|
3000 | | - q->limits.zoned = BLK_ZONED_HA; |
---|
3001 | | - else |
---|
3002 | | - /* |
---|
3003 | | - * Treat drive-managed devices as |
---|
3004 | | - * regular block devices. |
---|
3005 | | - */ |
---|
3006 | | - q->limits.zoned = BLK_ZONED_NONE; |
---|
| 3035 | + blk_queue_set_zoned(sdkp->disk, BLK_ZONED_HA); |
---|
| 3036 | + } else { |
---|
| 3037 | + /* Regular disk or drive managed disk */ |
---|
| 3038 | + blk_queue_set_zoned(sdkp->disk, BLK_ZONED_NONE); |
---|
| 3039 | + } |
---|
3007 | 3040 | } |
---|
3008 | | - if (blk_queue_is_zoned(q) && sdkp->first_scan) |
---|
| 3041 | + |
---|
| 3042 | + if (!sdkp->first_scan) |
---|
| 3043 | + goto out; |
---|
| 3044 | + |
---|
| 3045 | + if (blk_queue_is_zoned(q)) { |
---|
3009 | 3046 | sd_printk(KERN_NOTICE, sdkp, "Host-%s zoned block device\n", |
---|
3010 | 3047 | q->limits.zoned == BLK_ZONED_HM ? "managed" : "aware"); |
---|
| 3048 | + } else { |
---|
| 3049 | + if (sdkp->zoned == 1) |
---|
| 3050 | + sd_printk(KERN_NOTICE, sdkp, |
---|
| 3051 | + "Host-aware SMR disk used as regular disk\n"); |
---|
| 3052 | + else if (sdkp->zoned == 2) |
---|
| 3053 | + sd_printk(KERN_NOTICE, sdkp, |
---|
| 3054 | + "Drive-managed SMR disk\n"); |
---|
| 3055 | + } |
---|
3011 | 3056 | |
---|
3012 | 3057 | out: |
---|
3013 | 3058 | kfree(buffer); |
---|
.. | .. |
---|
3237 | 3282 | |
---|
3238 | 3283 | sdkp->first_scan = 0; |
---|
3239 | 3284 | |
---|
3240 | | - set_capacity(disk, logical_to_sectors(sdp, sdkp->capacity)); |
---|
| 3285 | + set_capacity_revalidate_and_notify(disk, |
---|
| 3286 | + logical_to_sectors(sdp, sdkp->capacity), false); |
---|
3241 | 3287 | sd_config_write_same(sdkp); |
---|
3242 | 3288 | kfree(buffer); |
---|
| 3289 | + |
---|
| 3290 | + /* |
---|
| 3291 | + * For a zoned drive, revalidating the zones can be done only once |
---|
| 3292 | + * the gendisk capacity is set. So if this fails, set back the gendisk |
---|
| 3293 | + * capacity to 0. |
---|
| 3294 | + */ |
---|
| 3295 | + if (sd_zbc_revalidate_zones(sdkp)) |
---|
| 3296 | + set_capacity_revalidate_and_notify(disk, 0, false); |
---|
3243 | 3297 | |
---|
3244 | 3298 | out: |
---|
3245 | 3299 | return 0; |
---|
.. | .. |
---|
3311 | 3365 | return 0; |
---|
3312 | 3366 | } |
---|
3313 | 3367 | |
---|
3314 | | -/* |
---|
3315 | | - * The asynchronous part of sd_probe |
---|
3316 | | - */ |
---|
3317 | | -static void sd_probe_async(void *data, async_cookie_t cookie) |
---|
3318 | | -{ |
---|
3319 | | - struct scsi_disk *sdkp = data; |
---|
3320 | | - struct scsi_device *sdp; |
---|
3321 | | - struct gendisk *gd; |
---|
3322 | | - u32 index; |
---|
3323 | | - struct device *dev; |
---|
3324 | | - |
---|
3325 | | - sdp = sdkp->device; |
---|
3326 | | - gd = sdkp->disk; |
---|
3327 | | - index = sdkp->index; |
---|
3328 | | - dev = &sdp->sdev_gendev; |
---|
3329 | | - |
---|
3330 | | - gd->major = sd_major((index & 0xf0) >> 4); |
---|
3331 | | - gd->first_minor = ((index & 0xf) << 4) | (index & 0xfff00); |
---|
3332 | | - |
---|
3333 | | - gd->fops = &sd_fops; |
---|
3334 | | - gd->private_data = &sdkp->driver; |
---|
3335 | | - gd->queue = sdkp->device->request_queue; |
---|
3336 | | - |
---|
3337 | | - /* defaults, until the device tells us otherwise */ |
---|
3338 | | - sdp->sector_size = 512; |
---|
3339 | | - sdkp->capacity = 0; |
---|
3340 | | - sdkp->media_present = 1; |
---|
3341 | | - sdkp->write_prot = 0; |
---|
3342 | | - sdkp->cache_override = 0; |
---|
3343 | | - sdkp->WCE = 0; |
---|
3344 | | - sdkp->RCD = 0; |
---|
3345 | | - sdkp->ATO = 0; |
---|
3346 | | - sdkp->first_scan = 1; |
---|
3347 | | - sdkp->max_medium_access_timeouts = SD_MAX_MEDIUM_TIMEOUTS; |
---|
3348 | | - |
---|
3349 | | - sd_revalidate_disk(gd); |
---|
3350 | | - |
---|
3351 | | - gd->flags = GENHD_FL_EXT_DEVT; |
---|
3352 | | - if (sdp->removable) { |
---|
3353 | | - gd->flags |= GENHD_FL_REMOVABLE; |
---|
3354 | | - gd->events |= DISK_EVENT_MEDIA_CHANGE; |
---|
3355 | | - } |
---|
3356 | | - |
---|
3357 | | - blk_pm_runtime_init(sdp->request_queue, dev); |
---|
3358 | | - if (sdp->rpm_autosuspend) { |
---|
3359 | | - pm_runtime_set_autosuspend_delay(dev, |
---|
3360 | | - sdp->host->hostt->rpm_autosuspend_delay); |
---|
3361 | | - } |
---|
3362 | | - device_add_disk(dev, gd); |
---|
3363 | | - if (sdkp->capacity) |
---|
3364 | | - sd_dif_config_host(sdkp); |
---|
3365 | | - |
---|
3366 | | - sd_revalidate_disk(gd); |
---|
3367 | | - |
---|
3368 | | - if (sdkp->security) { |
---|
3369 | | - sdkp->opal_dev = init_opal_dev(sdp, &sd_sec_submit); |
---|
3370 | | - if (sdkp->opal_dev) |
---|
3371 | | - sd_printk(KERN_NOTICE, sdkp, "supports TCG Opal\n"); |
---|
3372 | | - } |
---|
3373 | | - |
---|
3374 | | - sd_printk(KERN_NOTICE, sdkp, "Attached SCSI %sdisk\n", |
---|
3375 | | - sdp->removable ? "removable " : ""); |
---|
3376 | | - scsi_autopm_put_device(sdp); |
---|
3377 | | - put_device(&sdkp->dev); |
---|
3378 | | -} |
---|
3379 | | - |
---|
3380 | 3368 | /** |
---|
3381 | 3369 | * sd_probe - called during driver initialization and whenever a |
---|
3382 | 3370 | * new scsi device is attached to the system. It is called once |
---|
.. | .. |
---|
3443 | 3431 | sdkp->driver = &sd_template; |
---|
3444 | 3432 | sdkp->disk = gd; |
---|
3445 | 3433 | sdkp->index = index; |
---|
| 3434 | + sdkp->max_retries = SD_MAX_RETRIES; |
---|
3446 | 3435 | atomic_set(&sdkp->openers, 0); |
---|
3447 | 3436 | atomic_set(&sdkp->device->ioerr_cnt, 0); |
---|
3448 | 3437 | |
---|
.. | .. |
---|
3466 | 3455 | } |
---|
3467 | 3456 | |
---|
3468 | 3457 | dev_set_drvdata(dev, sdkp); |
---|
| 3458 | + device_init_wakeup(dev, true); |
---|
3469 | 3459 | |
---|
3470 | | - get_device(&sdkp->dev); /* prevent release before async_schedule */ |
---|
3471 | | - async_schedule_domain(sd_probe_async, sdkp, &scsi_sd_probe_domain); |
---|
| 3460 | + gd->major = sd_major((index & 0xf0) >> 4); |
---|
| 3461 | + gd->first_minor = ((index & 0xf) << 4) | (index & 0xfff00); |
---|
| 3462 | + |
---|
| 3463 | + gd->fops = &sd_fops; |
---|
| 3464 | + gd->private_data = &sdkp->driver; |
---|
| 3465 | + gd->queue = sdkp->device->request_queue; |
---|
| 3466 | + |
---|
| 3467 | + /* defaults, until the device tells us otherwise */ |
---|
| 3468 | + sdp->sector_size = 512; |
---|
| 3469 | + sdkp->capacity = 0; |
---|
| 3470 | + sdkp->media_present = 1; |
---|
| 3471 | + sdkp->write_prot = 0; |
---|
| 3472 | + sdkp->cache_override = 0; |
---|
| 3473 | + sdkp->WCE = 0; |
---|
| 3474 | + sdkp->RCD = 0; |
---|
| 3475 | + sdkp->ATO = 0; |
---|
| 3476 | + sdkp->first_scan = 1; |
---|
| 3477 | + sdkp->max_medium_access_timeouts = SD_MAX_MEDIUM_TIMEOUTS; |
---|
| 3478 | + |
---|
| 3479 | + sd_revalidate_disk(gd); |
---|
| 3480 | + |
---|
| 3481 | + gd->flags = GENHD_FL_EXT_DEVT; |
---|
| 3482 | + if (sdp->removable) { |
---|
| 3483 | + gd->flags |= GENHD_FL_REMOVABLE; |
---|
| 3484 | + gd->events |= DISK_EVENT_MEDIA_CHANGE; |
---|
| 3485 | + gd->event_flags = DISK_EVENT_FLAG_POLL | DISK_EVENT_FLAG_UEVENT; |
---|
| 3486 | + } |
---|
| 3487 | + |
---|
| 3488 | + blk_pm_runtime_init(sdp->request_queue, dev); |
---|
| 3489 | + if (sdp->rpm_autosuspend) { |
---|
| 3490 | + pm_runtime_set_autosuspend_delay(dev, |
---|
| 3491 | + sdp->host->hostt->rpm_autosuspend_delay); |
---|
| 3492 | + } |
---|
| 3493 | + device_add_disk(dev, gd, NULL); |
---|
| 3494 | + if (sdkp->capacity) |
---|
| 3495 | + sd_dif_config_host(sdkp); |
---|
| 3496 | + |
---|
| 3497 | + sd_revalidate_disk(gd); |
---|
| 3498 | + |
---|
| 3499 | + if (sdkp->security) { |
---|
| 3500 | + sdkp->opal_dev = init_opal_dev(sdkp, &sd_sec_submit); |
---|
| 3501 | + if (sdkp->opal_dev) |
---|
| 3502 | + sd_printk(KERN_NOTICE, sdkp, "supports TCG Opal\n"); |
---|
| 3503 | + } |
---|
| 3504 | + |
---|
| 3505 | + sd_printk(KERN_NOTICE, sdkp, "Attached SCSI %sdisk\n", |
---|
| 3506 | + sdp->removable ? "removable " : ""); |
---|
| 3507 | + scsi_autopm_put_device(sdp); |
---|
3472 | 3508 | |
---|
3473 | 3509 | return 0; |
---|
3474 | 3510 | |
---|
.. | .. |
---|
3504 | 3540 | scsi_autopm_get_device(sdkp->device); |
---|
3505 | 3541 | |
---|
3506 | 3542 | async_synchronize_full_domain(&scsi_sd_pm_domain); |
---|
3507 | | - async_synchronize_full_domain(&scsi_sd_probe_domain); |
---|
3508 | 3543 | device_del(&sdkp->dev); |
---|
3509 | 3544 | del_gendisk(sdkp->disk); |
---|
3510 | 3545 | sd_shutdown(dev); |
---|
3511 | | - |
---|
3512 | | - sd_zbc_remove(sdkp); |
---|
3513 | 3546 | |
---|
3514 | 3547 | free_opal_dev(sdkp->opal_dev); |
---|
3515 | 3548 | |
---|
.. | .. |
---|
3556 | 3589 | put_disk(disk); |
---|
3557 | 3590 | put_device(&sdkp->device->sdev_gendev); |
---|
3558 | 3591 | |
---|
| 3592 | + sd_zbc_release_disk(sdkp); |
---|
| 3593 | + |
---|
3559 | 3594 | kfree(sdkp); |
---|
3560 | 3595 | } |
---|
3561 | 3596 | |
---|
.. | .. |
---|
3576 | 3611 | return -ENODEV; |
---|
3577 | 3612 | |
---|
3578 | 3613 | res = scsi_execute(sdp, cmd, DMA_NONE, NULL, 0, NULL, &sshdr, |
---|
3579 | | - SD_TIMEOUT, SD_MAX_RETRIES, 0, RQF_PM, NULL); |
---|
| 3614 | + SD_TIMEOUT, sdkp->max_retries, 0, RQF_PM, NULL); |
---|
3580 | 3615 | if (res) { |
---|
3581 | 3616 | sd_print_result(sdkp, "Start/Stop Unit failed", res); |
---|
3582 | 3617 | if (driver_byte(res) == DRIVER_SENSE) |
---|
.. | .. |
---|
3683 | 3718 | if (!sdkp->device->manage_start_stop) |
---|
3684 | 3719 | return 0; |
---|
3685 | 3720 | |
---|
| 3721 | + /* The wake-up process cannot allow the PM to enter sleep */ |
---|
| 3722 | + pm_stay_awake(dev); |
---|
| 3723 | + |
---|
3686 | 3724 | sd_printk(KERN_NOTICE, sdkp, "Starting disk\n"); |
---|
3687 | 3725 | ret = sd_start_stop_device(sdkp, 1); |
---|
3688 | 3726 | if (!ret) |
---|
3689 | 3727 | opal_unlock_from_suspend(sdkp->opal_dev); |
---|
| 3728 | + |
---|
| 3729 | + pm_relax(dev); |
---|
| 3730 | + |
---|
3690 | 3731 | return ret; |
---|
3691 | 3732 | } |
---|
3692 | 3733 | |
---|
.. | .. |
---|
3789 | 3830 | module_init(init_sd); |
---|
3790 | 3831 | module_exit(exit_sd); |
---|
3791 | 3832 | |
---|
3792 | | -static void sd_print_sense_hdr(struct scsi_disk *sdkp, |
---|
3793 | | - struct scsi_sense_hdr *sshdr) |
---|
| 3833 | +void sd_print_sense_hdr(struct scsi_disk *sdkp, struct scsi_sense_hdr *sshdr) |
---|
3794 | 3834 | { |
---|
3795 | 3835 | scsi_print_sense_hdr(sdkp->device, |
---|
3796 | 3836 | sdkp->disk ? sdkp->disk->disk_name : NULL, sshdr); |
---|
3797 | 3837 | } |
---|
3798 | 3838 | |
---|
3799 | | -static void sd_print_result(const struct scsi_disk *sdkp, const char *msg, |
---|
3800 | | - int result) |
---|
| 3839 | +void sd_print_result(const struct scsi_disk *sdkp, const char *msg, int result) |
---|
3801 | 3840 | { |
---|
3802 | 3841 | const char *hb_string = scsi_hostbyte_string(result); |
---|
3803 | 3842 | const char *db_string = scsi_driverbyte_string(result); |
---|
.. | .. |
---|
3812 | 3851 | "%s: Result: hostbyte=0x%02x driverbyte=0x%02x\n", |
---|
3813 | 3852 | msg, host_byte(result), driver_byte(result)); |
---|
3814 | 3853 | } |
---|
3815 | | - |
---|