Ming Lei 1194b5ce57 scsi: usb: image: microtek: use sg helper to iterate over scatterlist
Unlike the legacy I/O path, scsi-mq preallocates a large array to hold
the scatterlist for each request. This static allocation can consume
substantial amounts of memory on modern controllers which support a
large number of concurrently outstanding requests.

To facilitate a switch to a smaller static allocation combined with a
dynamic allocation for requests that need it, we need to make sure all
SCSI drivers handle chained scatterlists correctly.

Convert remaining drivers that directly dereference the scatterlist
array to using the iterator functions.

[mkp: clarified commit message]

Cc: Oliver Neukum <oliver@neukum.org>
Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Cc: linux-usb@vger.kernel.org
Reviewed-by: Bart Van Assche <bvanassche@acm.org>
Reviewed-by: Christoph Hellwig <hch@lst.de>
Signed-off-by: Ming Lei <ming.lei@redhat.com>
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
2019-06-20 15:21:32 -04:00

56 lines
1.0 KiB
C

/* SPDX-License-Identifier: GPL-2.0 */
/*
* Driver for Microtek Scanmaker X6 USB scanner and possibly others.
*
* (C) Copyright 2000 John Fremlin <vii@penguinpowered.com>
* (C) Copyright 2000 Oliver Neukum <Oliver.Neukum@lrz.uni-muenchen.de>
*
* See microtek.c for history
*
*/
typedef void (*mts_scsi_cmnd_callback)(struct scsi_cmnd *);
struct mts_transfer_context
{
struct mts_desc *instance;
mts_scsi_cmnd_callback final_callback;
struct scsi_cmnd *srb;
void *data;
unsigned data_length;
int data_pipe;
struct scatterlist *curr_sg;
u8 *scsi_status; /* status returned from ep_response after command completion */
};
struct mts_desc {
struct mts_desc *next;
struct mts_desc *prev;
struct usb_device *usb_dev;
struct usb_interface *usb_intf;
/* Endpoint addresses */
u8 ep_out;
u8 ep_response;
u8 ep_image;
struct Scsi_Host *host;
struct urb *urb;
struct mts_transfer_context context;
};
#define MTS_EP_OUT 0x1
#define MTS_EP_RESPONSE 0x2
#define MTS_EP_IMAGE 0x3
#define MTS_EP_TOTAL 0x3
#define MTS_SCSI_ERR_MASK ~0x3fu