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

scsi: scsi_ioctl: Consolidate the START STOP UNIT handling

Factor out a helper for the various flavors of START STOP UNIT command
ioctls.

Link: https://lore.kernel.org/r/20210724072033.1284840-22-hch@lst.de
Signed-off-by: Christoph Hellwig <hch@lst.de>
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>

authored by

Christoph Hellwig and committed by
Martin K. Petersen
51476187 a9705477

+10 -38
+10 -38
drivers/scsi/scsi_ioctl.c
··· 218 218 return put_user(1, p); 219 219 } 220 220 221 - /* Send basic block requests */ 222 - static int __blk_send_generic(struct request_queue *q, struct gendisk *bd_disk, 223 - int cmd, int data) 221 + static int scsi_send_start_stop(struct scsi_device *sdev, int data) 224 222 { 225 - struct request *rq; 226 - int err; 223 + u8 cdb[MAX_COMMAND_SIZE] = { }; 227 224 228 - rq = blk_get_request(q, REQ_OP_DRV_OUT, 0); 229 - if (IS_ERR(rq)) 230 - return PTR_ERR(rq); 231 - rq->timeout = BLK_DEFAULT_SG_TIMEOUT; 232 - scsi_req(rq)->cmd[0] = cmd; 233 - scsi_req(rq)->cmd[4] = data; 234 - scsi_req(rq)->cmd_len = 6; 235 - blk_execute_rq(bd_disk, rq, 0); 236 - err = scsi_req(rq)->result ? -EIO : 0; 237 - blk_put_request(rq); 238 - 239 - return err; 240 - } 241 - 242 - static inline int blk_send_start_stop(struct request_queue *q, 243 - struct gendisk *bd_disk, int data) 244 - { 245 - return __blk_send_generic(q, bd_disk, GPCMD_START_STOP_UNIT, data); 225 + cdb[0] = START_STOP; 226 + cdb[4] = data; 227 + return ioctl_internal_command(sdev, cdb, START_STOP_TIMEOUT, 228 + NORMAL_RETRIES); 246 229 } 247 230 248 231 /* ··· 866 883 int cmd, void __user *arg) 867 884 { 868 885 struct request_queue *q = sdev->request_queue; 869 - char scsi_cmd[MAX_COMMAND_SIZE]; 870 886 struct scsi_sense_hdr sense_hdr; 871 887 int error; 872 888 ··· 918 936 case CDROM_SEND_PACKET: 919 937 return scsi_cdrom_send_packet(q, disk, mode, arg); 920 938 case CDROMCLOSETRAY: 921 - return blk_send_start_stop(q, disk, 0x03); 939 + return scsi_send_start_stop(sdev, 3); 922 940 case CDROMEJECT: 923 - return blk_send_start_stop(q, disk, 0x02); 941 + return scsi_send_start_stop(sdev, 2); 924 942 case SCSI_IOCTL_GET_IDLUN: { 925 943 struct scsi_idlun v = { 926 944 .dev_id = (sdev->id & 0xff) ··· 945 963 return scsi_test_unit_ready(sdev, IOCTL_NORMAL_TIMEOUT, 946 964 NORMAL_RETRIES, &sense_hdr); 947 965 case SCSI_IOCTL_START_UNIT: 948 - scsi_cmd[0] = START_STOP; 949 - scsi_cmd[1] = 0; 950 - scsi_cmd[2] = scsi_cmd[3] = scsi_cmd[5] = 0; 951 - scsi_cmd[4] = 1; 952 - return ioctl_internal_command(sdev, scsi_cmd, 953 - START_STOP_TIMEOUT, NORMAL_RETRIES); 966 + return scsi_send_start_stop(sdev, 1); 954 967 case SCSI_IOCTL_STOP_UNIT: 955 - scsi_cmd[0] = START_STOP; 956 - scsi_cmd[1] = 0; 957 - scsi_cmd[2] = scsi_cmd[3] = scsi_cmd[5] = 0; 958 - scsi_cmd[4] = 0; 959 - return ioctl_internal_command(sdev, scsi_cmd, 960 - START_STOP_TIMEOUT, NORMAL_RETRIES); 968 + return scsi_send_start_stop(sdev, 0); 961 969 case SCSI_IOCTL_GET_PCI: 962 970 return scsi_ioctl_get_pci(sdev, arg); 963 971 case SG_SCSI_RESET: