uas.c 31.4 KB
Newer Older
M
Matthew Wilcox 已提交
1 2 3 4
/*
 * USB Attached SCSI
 * Note that this is not the same as the USB Mass Storage driver
 *
5
 * Copyright Hans de Goede <hdegoede@redhat.com> for Red Hat, Inc. 2013 - 2016
M
Matthew Wilcox 已提交
6 7 8 9 10 11 12 13 14
 * Copyright Matthew Wilcox for Intel Corp, 2010
 * Copyright Sarah Sharp for Intel Corp, 2010
 *
 * Distributed under the terms of the GNU GPL, version two.
 */

#include <linux/blkdev.h>
#include <linux/slab.h>
#include <linux/types.h>
15
#include <linux/module.h>
M
Matthew Wilcox 已提交
16
#include <linux/usb.h>
17
#include <linux/usb_usual.h>
18
#include <linux/usb/hcd.h>
M
Matthew Wilcox 已提交
19
#include <linux/usb/storage.h>
20
#include <linux/usb/uas.h>
M
Matthew Wilcox 已提交
21 22

#include <scsi/scsi.h>
23
#include <scsi/scsi_eh.h>
M
Matthew Wilcox 已提交
24 25 26 27 28 29
#include <scsi/scsi_dbg.h>
#include <scsi/scsi_cmnd.h>
#include <scsi/scsi_device.h>
#include <scsi/scsi_host.h>
#include <scsi/scsi_tcq.h>

30
#include "uas-detect.h"
31
#include "scsiglue.h"
32

33
#define MAX_CMNDS 256
M
Matthew Wilcox 已提交
34 35 36 37

struct uas_dev_info {
	struct usb_interface *intf;
	struct usb_device *udev;
38
	struct usb_anchor cmd_urbs;
39 40
	struct usb_anchor sense_urbs;
	struct usb_anchor data_urbs;
41
	unsigned long flags;
G
Gerd Hoffmann 已提交
42
	int qdepth, resetting;
M
Matthew Wilcox 已提交
43 44
	unsigned cmd_pipe, status_pipe, data_in_pipe, data_out_pipe;
	unsigned use_streams:1;
H
Hans de Goede 已提交
45
	unsigned shutdown:1;
46
	struct scsi_cmnd *cmnd[MAX_CMNDS];
G
Gerd Hoffmann 已提交
47
	spinlock_t lock;
G
Gerd Hoffmann 已提交
48
	struct work_struct work;
M
Matthew Wilcox 已提交
49 50 51
};

enum {
O
Oliver Neukum 已提交
52 53 54 55 56 57 58 59 60 61 62 63
	SUBMIT_STATUS_URB	= BIT(1),
	ALLOC_DATA_IN_URB	= BIT(2),
	SUBMIT_DATA_IN_URB	= BIT(3),
	ALLOC_DATA_OUT_URB	= BIT(4),
	SUBMIT_DATA_OUT_URB	= BIT(5),
	ALLOC_CMD_URB		= BIT(6),
	SUBMIT_CMD_URB		= BIT(7),
	COMMAND_INFLIGHT        = BIT(8),
	DATA_IN_URB_INFLIGHT    = BIT(9),
	DATA_OUT_URB_INFLIGHT   = BIT(10),
	COMMAND_ABORTED         = BIT(11),
	IS_IN_WORK_LIST         = BIT(12),
M
Matthew Wilcox 已提交
64 65 66 67 68
};

/* Overrides scsi_pointer */
struct uas_cmd_info {
	unsigned int state;
H
Hans de Goede 已提交
69
	unsigned int uas_tag;
M
Matthew Wilcox 已提交
70 71 72 73 74 75 76
	struct urb *cmd_urb;
	struct urb *data_in_urb;
	struct urb *data_out_urb;
};

/* I hate forward declarations, but I actually have a loop */
static int uas_submit_urbs(struct scsi_cmnd *cmnd,
77
				struct uas_dev_info *devinfo);
78
static void uas_do_work(struct work_struct *work);
G
Gerd Hoffmann 已提交
79
static int uas_try_complete(struct scsi_cmnd *cmnd, const char *caller);
80
static void uas_free_streams(struct uas_dev_info *devinfo);
81 82
static void uas_log_cmd_state(struct scsi_cmnd *cmnd, const char *prefix,
				int status);
83

M
Matthew Wilcox 已提交
84 85
static void uas_do_work(struct work_struct *work)
{
G
Gerd Hoffmann 已提交
86 87
	struct uas_dev_info *devinfo =
		container_of(work, struct uas_dev_info, work);
M
Matthew Wilcox 已提交
88
	struct uas_cmd_info *cmdinfo;
H
Hans de Goede 已提交
89
	struct scsi_cmnd *cmnd;
G
Gerd Hoffmann 已提交
90
	unsigned long flags;
H
Hans de Goede 已提交
91
	int i, err;
M
Matthew Wilcox 已提交
92

G
Gerd Hoffmann 已提交
93
	spin_lock_irqsave(&devinfo->lock, flags);
H
Hans de Goede 已提交
94 95 96 97

	if (devinfo->resetting)
		goto out;

H
Hans de Goede 已提交
98 99 100 101 102 103
	for (i = 0; i < devinfo->qdepth; i++) {
		if (!devinfo->cmnd[i])
			continue;

		cmnd = devinfo->cmnd[i];
		cmdinfo = (void *)&cmnd->SCp;
104 105 106 107

		if (!(cmdinfo->state & IS_IN_WORK_LIST))
			continue;

108
		err = uas_submit_urbs(cmnd, cmnd->device->hostdata);
109
		if (!err)
G
Gerd Hoffmann 已提交
110
			cmdinfo->state &= ~IS_IN_WORK_LIST;
111
		else
G
Gerd Hoffmann 已提交
112
			schedule_work(&devinfo->work);
M
Matthew Wilcox 已提交
113
	}
H
Hans de Goede 已提交
114
out:
G
Gerd Hoffmann 已提交
115 116 117
	spin_unlock_irqrestore(&devinfo->lock, flags);
}

G
Gerd Hoffmann 已提交
118 119 120 121 122 123
static void uas_add_work(struct uas_cmd_info *cmdinfo)
{
	struct scsi_pointer *scp = (void *)cmdinfo;
	struct scsi_cmnd *cmnd = container_of(scp, struct scsi_cmnd, SCp);
	struct uas_dev_info *devinfo = cmnd->device->hostdata;

124
	lockdep_assert_held(&devinfo->lock);
G
Gerd Hoffmann 已提交
125 126 127 128
	cmdinfo->state |= IS_IN_WORK_LIST;
	schedule_work(&devinfo->work);
}

129
static void uas_zap_pending(struct uas_dev_info *devinfo, int result)
G
Gerd Hoffmann 已提交
130 131
{
	struct uas_cmd_info *cmdinfo;
H
Hans de Goede 已提交
132
	struct scsi_cmnd *cmnd;
G
Gerd Hoffmann 已提交
133
	unsigned long flags;
H
Hans de Goede 已提交
134
	int i, err;
G
Gerd Hoffmann 已提交
135 136

	spin_lock_irqsave(&devinfo->lock, flags);
H
Hans de Goede 已提交
137 138 139 140 141 142
	for (i = 0; i < devinfo->qdepth; i++) {
		if (!devinfo->cmnd[i])
			continue;

		cmnd = devinfo->cmnd[i];
		cmdinfo = (void *)&cmnd->SCp;
143
		uas_log_cmd_state(cmnd, __func__, 0);
144 145
		/* Sense urbs were killed, clear COMMAND_INFLIGHT manually */
		cmdinfo->state &= ~COMMAND_INFLIGHT;
146
		cmnd->result = result << 16;
147 148
		err = uas_try_complete(cmnd, __func__);
		WARN_ON(err != 0);
G
Gerd Hoffmann 已提交
149 150 151 152
	}
	spin_unlock_irqrestore(&devinfo->lock, flags);
}

M
Matthew Wilcox 已提交
153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175
static void uas_sense(struct urb *urb, struct scsi_cmnd *cmnd)
{
	struct sense_iu *sense_iu = urb->transfer_buffer;
	struct scsi_device *sdev = cmnd->device;

	if (urb->actual_length > 16) {
		unsigned len = be16_to_cpup(&sense_iu->len);
		if (len + 16 != urb->actual_length) {
			int newlen = min(len + 16, urb->actual_length) - 16;
			if (newlen < 0)
				newlen = 0;
			sdev_printk(KERN_INFO, sdev, "%s: urb length %d "
				"disagrees with IU sense data length %d, "
				"using %d bytes of sense data\n", __func__,
					urb->actual_length, len, newlen);
			len = newlen;
		}
		memcpy(cmnd->sense_buffer, sense_iu->sense, len);
	}

	cmnd->result = sense_iu->status;
}

176 177
static void uas_log_cmd_state(struct scsi_cmnd *cmnd, const char *prefix,
			      int status)
178 179
{
	struct uas_cmd_info *ci = (void *)&cmnd->SCp;
H
Hans de Goede 已提交
180
	struct uas_cmd_info *cmdinfo = (void *)&cmnd->SCp;
181

182
	scmd_printk(KERN_INFO, cmnd,
H
Hans de Goede 已提交
183 184
		    "%s %d uas-tag %d inflight:%s%s%s%s%s%s%s%s%s%s%s%s ",
		    prefix, status, cmdinfo->uas_tag,
185 186 187 188 189 190 191 192 193 194
		    (ci->state & SUBMIT_STATUS_URB)     ? " s-st"  : "",
		    (ci->state & ALLOC_DATA_IN_URB)     ? " a-in"  : "",
		    (ci->state & SUBMIT_DATA_IN_URB)    ? " s-in"  : "",
		    (ci->state & ALLOC_DATA_OUT_URB)    ? " a-out" : "",
		    (ci->state & SUBMIT_DATA_OUT_URB)   ? " s-out" : "",
		    (ci->state & ALLOC_CMD_URB)         ? " a-cmd" : "",
		    (ci->state & SUBMIT_CMD_URB)        ? " s-cmd" : "",
		    (ci->state & COMMAND_INFLIGHT)      ? " CMD"   : "",
		    (ci->state & DATA_IN_URB_INFLIGHT)  ? " IN"    : "",
		    (ci->state & DATA_OUT_URB_INFLIGHT) ? " OUT"   : "",
G
Gerd Hoffmann 已提交
195
		    (ci->state & COMMAND_ABORTED)       ? " abort" : "",
G
Gerd Hoffmann 已提交
196
		    (ci->state & IS_IN_WORK_LIST)       ? " work"  : "");
H
Hans de Goede 已提交
197
	scsi_print_command(cmnd);
198 199
}

200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216
static void uas_free_unsubmitted_urbs(struct scsi_cmnd *cmnd)
{
	struct uas_cmd_info *cmdinfo;

	if (!cmnd)
		return;

	cmdinfo = (void *)&cmnd->SCp;

	if (cmdinfo->state & SUBMIT_CMD_URB)
		usb_free_urb(cmdinfo->cmd_urb);

	/* data urbs may have never gotten their submit flag set */
	if (!(cmdinfo->state & DATA_IN_URB_INFLIGHT))
		usb_free_urb(cmdinfo->data_in_urb);
	if (!(cmdinfo->state & DATA_OUT_URB_INFLIGHT))
		usb_free_urb(cmdinfo->data_out_urb);
217 218 219 220 221
}

static int uas_try_complete(struct scsi_cmnd *cmnd, const char *caller)
{
	struct uas_cmd_info *cmdinfo = (void *)&cmnd->SCp;
G
Gerd Hoffmann 已提交
222
	struct uas_dev_info *devinfo = (void *)cmnd->device->hostdata;
223

224
	lockdep_assert_held(&devinfo->lock);
225 226
	if (cmdinfo->state & (COMMAND_INFLIGHT |
			      DATA_IN_URB_INFLIGHT |
G
Gerd Hoffmann 已提交
227
			      DATA_OUT_URB_INFLIGHT |
228
			      COMMAND_ABORTED))
229
		return -EBUSY;
H
Hans de Goede 已提交
230
	devinfo->cmnd[cmdinfo->uas_tag - 1] = NULL;
231
	uas_free_unsubmitted_urbs(cmnd);
232
	cmnd->scsi_done(cmnd);
233
	return 0;
M
Matthew Wilcox 已提交
234 235 236
}

static void uas_xfer_data(struct urb *urb, struct scsi_cmnd *cmnd,
237
			  unsigned direction)
M
Matthew Wilcox 已提交
238 239 240 241
{
	struct uas_cmd_info *cmdinfo = (void *)&cmnd->SCp;
	int err;

242
	cmdinfo->state |= direction | SUBMIT_STATUS_URB;
243
	err = uas_submit_urbs(cmnd, cmnd->device->hostdata);
M
Matthew Wilcox 已提交
244
	if (err) {
G
Gerd Hoffmann 已提交
245
		uas_add_work(cmdinfo);
M
Matthew Wilcox 已提交
246 247 248
	}
}

249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271
static bool uas_evaluate_response_iu(struct response_iu *riu, struct scsi_cmnd *cmnd)
{
	u8 response_code = riu->response_code;

	switch (response_code) {
	case RC_INCORRECT_LUN:
		cmnd->result = DID_BAD_TARGET << 16;
		break;
	case RC_TMF_SUCCEEDED:
		cmnd->result = DID_OK << 16;
		break;
	case RC_TMF_NOT_SUPPORTED:
		cmnd->result = DID_TARGET_FAILURE << 16;
		break;
	default:
		uas_log_cmd_state(cmnd, "response iu", response_code);
		cmnd->result = DID_ERROR << 16;
		break;
	}

	return response_code == RC_TMF_SUCCEEDED;
}

M
Matthew Wilcox 已提交
272 273 274
static void uas_stat_cmplt(struct urb *urb)
{
	struct iu *iu = urb->transfer_buffer;
275
	struct Scsi_Host *shost = urb->context;
H
Hans de Goede 已提交
276
	struct uas_dev_info *devinfo = (struct uas_dev_info *)shost->hostdata;
277 278
	struct urb *data_in_urb = NULL;
	struct urb *data_out_urb = NULL;
M
Matthew Wilcox 已提交
279
	struct scsi_cmnd *cmnd;
280
	struct uas_cmd_info *cmdinfo;
G
Gerd Hoffmann 已提交
281
	unsigned long flags;
282
	unsigned int idx;
283
	int status = urb->status;
284
	bool success;
M
Matthew Wilcox 已提交
285

H
Hans de Goede 已提交
286 287 288 289
	spin_lock_irqsave(&devinfo->lock, flags);

	if (devinfo->resetting)
		goto out;
M
Matthew Wilcox 已提交
290

291 292 293
	if (status) {
		if (status != -ENOENT && status != -ECONNRESET && status != -ESHUTDOWN)
			dev_err(&urb->dev->dev, "stat urb: status %d\n", status);
H
Hans de Goede 已提交
294
		goto out;
M
Matthew Wilcox 已提交
295 296
	}

297 298 299
	idx = be16_to_cpup(&iu->tag) - 1;
	if (idx >= MAX_CMNDS || !devinfo->cmnd[idx]) {
		dev_err(&urb->dev->dev,
H
Hans de Goede 已提交
300
			"stat urb: no pending cmd for uas-tag %d\n", idx + 1);
H
Hans de Goede 已提交
301
		goto out;
G
Gerd Hoffmann 已提交
302 303
	}

304
	cmnd = devinfo->cmnd[idx];
G
Gerd Hoffmann 已提交
305
	cmdinfo = (void *)&cmnd->SCp;
306 307

	if (!(cmdinfo->state & COMMAND_INFLIGHT)) {
308
		uas_log_cmd_state(cmnd, "unexpected status cmplt", 0);
309
		goto out;
310
	}
M
Matthew Wilcox 已提交
311 312 313

	switch (iu->iu_id) {
	case IU_ID_STATUS:
314
		uas_sense(urb, cmnd);
G
Gerd Hoffmann 已提交
315 316
		if (cmnd->result != 0) {
			/* cancel data transfers on error */
317 318
			data_in_urb = usb_get_urb(cmdinfo->data_in_urb);
			data_out_urb = usb_get_urb(cmdinfo->data_out_urb);
G
Gerd Hoffmann 已提交
319
		}
320 321
		cmdinfo->state &= ~COMMAND_INFLIGHT;
		uas_try_complete(cmnd, __func__);
M
Matthew Wilcox 已提交
322 323
		break;
	case IU_ID_READ_READY:
324 325
		if (!cmdinfo->data_in_urb ||
				(cmdinfo->state & DATA_IN_URB_INFLIGHT)) {
326
			uas_log_cmd_state(cmnd, "unexpected read rdy", 0);
327 328
			break;
		}
M
Matthew Wilcox 已提交
329 330 331
		uas_xfer_data(urb, cmnd, SUBMIT_DATA_IN_URB);
		break;
	case IU_ID_WRITE_READY:
332 333
		if (!cmdinfo->data_out_urb ||
				(cmdinfo->state & DATA_OUT_URB_INFLIGHT)) {
334
			uas_log_cmd_state(cmnd, "unexpected write rdy", 0);
335 336
			break;
		}
M
Matthew Wilcox 已提交
337 338
		uas_xfer_data(urb, cmnd, SUBMIT_DATA_OUT_URB);
		break;
H
Hans de Goede 已提交
339 340
	case IU_ID_RESPONSE:
		cmdinfo->state &= ~COMMAND_INFLIGHT;
341 342 343 344 345 346
		success = uas_evaluate_response_iu((struct response_iu *)iu, cmnd);
		if (!success) {
			/* Error, cancel data transfers */
			data_in_urb = usb_get_urb(cmdinfo->data_in_urb);
			data_out_urb = usb_get_urb(cmdinfo->data_out_urb);
		}
H
Hans de Goede 已提交
347 348
		uas_try_complete(cmnd, __func__);
		break;
M
Matthew Wilcox 已提交
349
	default:
350
		uas_log_cmd_state(cmnd, "bogus IU", iu->iu_id);
M
Matthew Wilcox 已提交
351
	}
H
Hans de Goede 已提交
352
out:
G
Gerd Hoffmann 已提交
353
	usb_free_urb(urb);
G
Gerd Hoffmann 已提交
354
	spin_unlock_irqrestore(&devinfo->lock, flags);
355 356 357 358 359 360 361 362 363 364

	/* Unlinking of data urbs must be done without holding the lock */
	if (data_in_urb) {
		usb_unlink_urb(data_in_urb);
		usb_put_urb(data_in_urb);
	}
	if (data_out_urb) {
		usb_unlink_urb(data_out_urb);
		usb_put_urb(data_out_urb);
	}
M
Matthew Wilcox 已提交
365 366
}

367
static void uas_data_cmplt(struct urb *urb)
M
Matthew Wilcox 已提交
368
{
369 370
	struct scsi_cmnd *cmnd = urb->context;
	struct uas_cmd_info *cmdinfo = (void *)&cmnd->SCp;
G
Gerd Hoffmann 已提交
371
	struct uas_dev_info *devinfo = (void *)cmnd->device->hostdata;
372
	struct scsi_data_buffer *sdb = NULL;
G
Gerd Hoffmann 已提交
373
	unsigned long flags;
374
	int status = urb->status;
375

G
Gerd Hoffmann 已提交
376
	spin_lock_irqsave(&devinfo->lock, flags);
H
Hans de Goede 已提交
377

378 379 380
	if (cmdinfo->data_in_urb == urb) {
		sdb = scsi_in(cmnd);
		cmdinfo->state &= ~DATA_IN_URB_INFLIGHT;
381
		cmdinfo->data_in_urb = NULL;
382 383 384
	} else if (cmdinfo->data_out_urb == urb) {
		sdb = scsi_out(cmnd);
		cmdinfo->state &= ~DATA_OUT_URB_INFLIGHT;
385
		cmdinfo->data_out_urb = NULL;
386
	}
387 388
	if (sdb == NULL) {
		WARN_ON_ONCE(1);
H
Hans de Goede 已提交
389 390 391 392 393 394
		goto out;
	}

	if (devinfo->resetting)
		goto out;

395 396
	/* Data urbs should not complete before the cmd urb is submitted */
	if (cmdinfo->state & SUBMIT_CMD_URB) {
397
		uas_log_cmd_state(cmnd, "unexpected data cmplt", 0);
398 399 400
		goto out;
	}

401 402 403
	if (status) {
		if (status != -ENOENT && status != -ECONNRESET && status != -ESHUTDOWN)
			uas_log_cmd_state(cmnd, "data cmplt err", status);
G
Gerd Hoffmann 已提交
404 405 406 407 408
		/* error: no data transfered */
		sdb->resid = sdb->length;
	} else {
		sdb->resid = sdb->length - urb->actual_length;
	}
409
	uas_try_complete(cmnd, __func__);
H
Hans de Goede 已提交
410
out:
411
	usb_free_urb(urb);
G
Gerd Hoffmann 已提交
412
	spin_unlock_irqrestore(&devinfo->lock, flags);
M
Matthew Wilcox 已提交
413 414
}

H
Hans de Goede 已提交
415 416
static void uas_cmd_cmplt(struct urb *urb)
{
417 418
	if (urb->status)
		dev_err(&urb->dev->dev, "cmd cmplt err %d\n", urb->status);
H
Hans de Goede 已提交
419 420 421 422

	usb_free_urb(urb);
}

M
Matthew Wilcox 已提交
423
static struct urb *uas_alloc_data_urb(struct uas_dev_info *devinfo, gfp_t gfp,
424 425
				      struct scsi_cmnd *cmnd,
				      enum dma_data_direction dir)
M
Matthew Wilcox 已提交
426 427
{
	struct usb_device *udev = devinfo->udev;
428
	struct uas_cmd_info *cmdinfo = (void *)&cmnd->SCp;
M
Matthew Wilcox 已提交
429
	struct urb *urb = usb_alloc_urb(0, gfp);
430 431
	struct scsi_data_buffer *sdb = (dir == DMA_FROM_DEVICE)
		? scsi_in(cmnd) : scsi_out(cmnd);
432 433
	unsigned int pipe = (dir == DMA_FROM_DEVICE)
		? devinfo->data_in_pipe : devinfo->data_out_pipe;
M
Matthew Wilcox 已提交
434 435 436

	if (!urb)
		goto out;
437 438
	usb_fill_bulk_urb(urb, udev, pipe, NULL, sdb->length,
			  uas_data_cmplt, cmnd);
H
Hans de Goede 已提交
439 440
	if (devinfo->use_streams)
		urb->stream_id = cmdinfo->uas_tag;
M
Matthew Wilcox 已提交
441 442 443 444 445 446 447
	urb->num_sgs = udev->bus->sg_tablesize ? sdb->table.nents : 0;
	urb->sg = sdb->table.sgl;
 out:
	return urb;
}

static struct urb *uas_alloc_sense_urb(struct uas_dev_info *devinfo, gfp_t gfp,
448
				       struct scsi_cmnd *cmnd)
M
Matthew Wilcox 已提交
449 450
{
	struct usb_device *udev = devinfo->udev;
451
	struct uas_cmd_info *cmdinfo = (void *)&cmnd->SCp;
M
Matthew Wilcox 已提交
452 453 454 455 456 457
	struct urb *urb = usb_alloc_urb(0, gfp);
	struct sense_iu *iu;

	if (!urb)
		goto out;

458
	iu = kzalloc(sizeof(*iu), gfp);
M
Matthew Wilcox 已提交
459 460 461 462
	if (!iu)
		goto free;

	usb_fill_bulk_urb(urb, udev, devinfo->status_pipe, iu, sizeof(*iu),
463
			  uas_stat_cmplt, cmnd->device->host);
H
Hans de Goede 已提交
464 465
	if (devinfo->use_streams)
		urb->stream_id = cmdinfo->uas_tag;
M
Matthew Wilcox 已提交
466 467 468 469 470 471 472 473 474
	urb->transfer_flags |= URB_FREE_BUFFER;
 out:
	return urb;
 free:
	usb_free_urb(urb);
	return NULL;
}

static struct urb *uas_alloc_cmd_urb(struct uas_dev_info *devinfo, gfp_t gfp,
475
					struct scsi_cmnd *cmnd)
M
Matthew Wilcox 已提交
476 477 478
{
	struct usb_device *udev = devinfo->udev;
	struct scsi_device *sdev = cmnd->device;
H
Hans de Goede 已提交
479
	struct uas_cmd_info *cmdinfo = (void *)&cmnd->SCp;
M
Matthew Wilcox 已提交
480 481 482 483 484 485 486 487 488 489 490
	struct urb *urb = usb_alloc_urb(0, gfp);
	struct command_iu *iu;
	int len;

	if (!urb)
		goto out;

	len = cmnd->cmd_len - 16;
	if (len < 0)
		len = 0;
	len = ALIGN(len, 4);
491
	iu = kzalloc(sizeof(*iu) + len, gfp);
M
Matthew Wilcox 已提交
492 493 494 495
	if (!iu)
		goto free;

	iu->iu_id = IU_ID_COMMAND;
H
Hans de Goede 已提交
496
	iu->tag = cpu_to_be16(cmdinfo->uas_tag);
C
Christoph Hellwig 已提交
497
	iu->prio_attr = UAS_SIMPLE_TAG;
M
Matthew Wilcox 已提交
498 499 500 501 502
	iu->len = len;
	int_to_scsilun(sdev->lun, &iu->lun);
	memcpy(iu->cdb, cmnd->cmnd, cmnd->cmd_len);

	usb_fill_bulk_urb(urb, udev, devinfo->cmd_pipe, iu, sizeof(*iu) + len,
503
							uas_cmd_cmplt, NULL);
M
Matthew Wilcox 已提交
504 505 506 507 508 509 510 511 512 513 514 515 516 517
	urb->transfer_flags |= URB_FREE_BUFFER;
 out:
	return urb;
 free:
	usb_free_urb(urb);
	return NULL;
}

/*
 * Why should I request the Status IU before sending the Command IU?  Spec
 * says to, but also says the device may receive them in any order.  Seems
 * daft to me.
 */

518
static struct urb *uas_submit_sense_urb(struct scsi_cmnd *cmnd, gfp_t gfp)
M
Matthew Wilcox 已提交
519
{
520
	struct uas_dev_info *devinfo = cmnd->device->hostdata;
G
Gerd Hoffmann 已提交
521
	struct urb *urb;
H
Hans de Goede 已提交
522
	int err;
M
Matthew Wilcox 已提交
523

524
	urb = uas_alloc_sense_urb(devinfo, gfp, cmnd);
G
Gerd Hoffmann 已提交
525
	if (!urb)
526
		return NULL;
527
	usb_anchor_urb(urb, &devinfo->sense_urbs);
H
Hans de Goede 已提交
528 529
	err = usb_submit_urb(urb, gfp);
	if (err) {
530
		usb_unanchor_urb(urb);
531
		uas_log_cmd_state(cmnd, "sense submit err", err);
G
Gerd Hoffmann 已提交
532
		usb_free_urb(urb);
533
		return NULL;
M
Matthew Wilcox 已提交
534
	}
535
	return urb;
G
Gerd Hoffmann 已提交
536 537 538
}

static int uas_submit_urbs(struct scsi_cmnd *cmnd,
539
			   struct uas_dev_info *devinfo)
G
Gerd Hoffmann 已提交
540 541
{
	struct uas_cmd_info *cmdinfo = (void *)&cmnd->SCp;
542
	struct urb *urb;
H
Hans de Goede 已提交
543
	int err;
M
Matthew Wilcox 已提交
544

545
	lockdep_assert_held(&devinfo->lock);
546
	if (cmdinfo->state & SUBMIT_STATUS_URB) {
547
		urb = uas_submit_sense_urb(cmnd, GFP_ATOMIC);
548 549
		if (!urb)
			return SCSI_MLQUEUE_DEVICE_BUSY;
550
		cmdinfo->state &= ~SUBMIT_STATUS_URB;
M
Matthew Wilcox 已提交
551 552 553
	}

	if (cmdinfo->state & ALLOC_DATA_IN_URB) {
554
		cmdinfo->data_in_urb = uas_alloc_data_urb(devinfo, GFP_ATOMIC,
555
							cmnd, DMA_FROM_DEVICE);
M
Matthew Wilcox 已提交
556 557 558 559 560 561
		if (!cmdinfo->data_in_urb)
			return SCSI_MLQUEUE_DEVICE_BUSY;
		cmdinfo->state &= ~ALLOC_DATA_IN_URB;
	}

	if (cmdinfo->state & SUBMIT_DATA_IN_URB) {
562
		usb_anchor_urb(cmdinfo->data_in_urb, &devinfo->data_urbs);
563
		err = usb_submit_urb(cmdinfo->data_in_urb, GFP_ATOMIC);
H
Hans de Goede 已提交
564
		if (err) {
565
			usb_unanchor_urb(cmdinfo->data_in_urb);
566
			uas_log_cmd_state(cmnd, "data in submit err", err);
M
Matthew Wilcox 已提交
567 568 569
			return SCSI_MLQUEUE_DEVICE_BUSY;
		}
		cmdinfo->state &= ~SUBMIT_DATA_IN_URB;
570
		cmdinfo->state |= DATA_IN_URB_INFLIGHT;
M
Matthew Wilcox 已提交
571 572 573
	}

	if (cmdinfo->state & ALLOC_DATA_OUT_URB) {
574
		cmdinfo->data_out_urb = uas_alloc_data_urb(devinfo, GFP_ATOMIC,
575
							cmnd, DMA_TO_DEVICE);
M
Matthew Wilcox 已提交
576 577 578 579 580 581
		if (!cmdinfo->data_out_urb)
			return SCSI_MLQUEUE_DEVICE_BUSY;
		cmdinfo->state &= ~ALLOC_DATA_OUT_URB;
	}

	if (cmdinfo->state & SUBMIT_DATA_OUT_URB) {
582
		usb_anchor_urb(cmdinfo->data_out_urb, &devinfo->data_urbs);
583
		err = usb_submit_urb(cmdinfo->data_out_urb, GFP_ATOMIC);
H
Hans de Goede 已提交
584
		if (err) {
585
			usb_unanchor_urb(cmdinfo->data_out_urb);
586
			uas_log_cmd_state(cmnd, "data out submit err", err);
M
Matthew Wilcox 已提交
587 588 589
			return SCSI_MLQUEUE_DEVICE_BUSY;
		}
		cmdinfo->state &= ~SUBMIT_DATA_OUT_URB;
590
		cmdinfo->state |= DATA_OUT_URB_INFLIGHT;
M
Matthew Wilcox 已提交
591 592 593
	}

	if (cmdinfo->state & ALLOC_CMD_URB) {
594
		cmdinfo->cmd_urb = uas_alloc_cmd_urb(devinfo, GFP_ATOMIC, cmnd);
M
Matthew Wilcox 已提交
595 596 597 598 599 600
		if (!cmdinfo->cmd_urb)
			return SCSI_MLQUEUE_DEVICE_BUSY;
		cmdinfo->state &= ~ALLOC_CMD_URB;
	}

	if (cmdinfo->state & SUBMIT_CMD_URB) {
601
		usb_anchor_urb(cmdinfo->cmd_urb, &devinfo->cmd_urbs);
602
		err = usb_submit_urb(cmdinfo->cmd_urb, GFP_ATOMIC);
H
Hans de Goede 已提交
603
		if (err) {
604
			usb_unanchor_urb(cmdinfo->cmd_urb);
605
			uas_log_cmd_state(cmnd, "cmd submit err", err);
M
Matthew Wilcox 已提交
606 607
			return SCSI_MLQUEUE_DEVICE_BUSY;
		}
608
		cmdinfo->cmd_urb = NULL;
M
Matthew Wilcox 已提交
609
		cmdinfo->state &= ~SUBMIT_CMD_URB;
610
		cmdinfo->state |= COMMAND_INFLIGHT;
M
Matthew Wilcox 已提交
611 612 613 614 615
	}

	return 0;
}

J
Jeff Garzik 已提交
616
static int uas_queuecommand_lck(struct scsi_cmnd *cmnd,
M
Matthew Wilcox 已提交
617 618 619 620 621
					void (*done)(struct scsi_cmnd *))
{
	struct scsi_device *sdev = cmnd->device;
	struct uas_dev_info *devinfo = sdev->hostdata;
	struct uas_cmd_info *cmdinfo = (void *)&cmnd->SCp;
G
Gerd Hoffmann 已提交
622
	unsigned long flags;
H
Hans de Goede 已提交
623
	int idx, err;
M
Matthew Wilcox 已提交
624 625 626

	BUILD_BUG_ON(sizeof(struct uas_cmd_info) > sizeof(struct scsi_pointer));

627 628 629 630
	/* Re-check scsi_block_requests now that we've the host-lock */
	if (cmnd->device->host->host_self_blocked)
		return SCSI_MLQUEUE_DEVICE_BUSY;

631 632 633 634 635 636 637 638 639
	if ((devinfo->flags & US_FL_NO_ATA_1X) &&
			(cmnd->cmnd[0] == ATA_12 || cmnd->cmnd[0] == ATA_16)) {
		memcpy(cmnd->sense_buffer, usb_stor_sense_invalidCDB,
		       sizeof(usb_stor_sense_invalidCDB));
		cmnd->result = SAM_STAT_CHECK_CONDITION;
		cmnd->scsi_done(cmnd);
		return 0;
	}

640 641
	spin_lock_irqsave(&devinfo->lock, flags);

642 643 644
	if (devinfo->resetting) {
		cmnd->result = DID_ERROR << 16;
		cmnd->scsi_done(cmnd);
645
		spin_unlock_irqrestore(&devinfo->lock, flags);
646 647 648
		return 0;
	}

H
Hans de Goede 已提交
649 650 651 652 653 654
	/* Find a free uas-tag */
	for (idx = 0; idx < devinfo->qdepth; idx++) {
		if (!devinfo->cmnd[idx])
			break;
	}
	if (idx == devinfo->qdepth) {
G
Gerd Hoffmann 已提交
655
		spin_unlock_irqrestore(&devinfo->lock, flags);
M
Matthew Wilcox 已提交
656
		return SCSI_MLQUEUE_DEVICE_BUSY;
G
Gerd Hoffmann 已提交
657
	}
M
Matthew Wilcox 已提交
658 659 660

	cmnd->scsi_done = done;

661
	memset(cmdinfo, 0, sizeof(*cmdinfo));
H
Hans de Goede 已提交
662
	cmdinfo->uas_tag = idx + 1; /* uas-tag == usb-stream-id, so 1 based */
663
	cmdinfo->state = SUBMIT_STATUS_URB | ALLOC_CMD_URB | SUBMIT_CMD_URB;
M
Matthew Wilcox 已提交
664 665 666 667 668 669 670 671 672 673 674 675 676

	switch (cmnd->sc_data_direction) {
	case DMA_FROM_DEVICE:
		cmdinfo->state |= ALLOC_DATA_IN_URB | SUBMIT_DATA_IN_URB;
		break;
	case DMA_BIDIRECTIONAL:
		cmdinfo->state |= ALLOC_DATA_IN_URB | SUBMIT_DATA_IN_URB;
	case DMA_TO_DEVICE:
		cmdinfo->state |= ALLOC_DATA_OUT_URB | SUBMIT_DATA_OUT_URB;
	case DMA_NONE:
		break;
	}

H
Hans de Goede 已提交
677
	if (!devinfo->use_streams)
678
		cmdinfo->state &= ~(SUBMIT_DATA_IN_URB | SUBMIT_DATA_OUT_URB);
M
Matthew Wilcox 已提交
679

680
	err = uas_submit_urbs(cmnd, devinfo);
M
Matthew Wilcox 已提交
681 682
	if (err) {
		/* If we did nothing, give up now */
683
		if (cmdinfo->state & SUBMIT_STATUS_URB) {
G
Gerd Hoffmann 已提交
684
			spin_unlock_irqrestore(&devinfo->lock, flags);
M
Matthew Wilcox 已提交
685 686
			return SCSI_MLQUEUE_DEVICE_BUSY;
		}
G
Gerd Hoffmann 已提交
687
		uas_add_work(cmdinfo);
M
Matthew Wilcox 已提交
688 689
	}

H
Hans de Goede 已提交
690
	devinfo->cmnd[idx] = cmnd;
G
Gerd Hoffmann 已提交
691
	spin_unlock_irqrestore(&devinfo->lock, flags);
M
Matthew Wilcox 已提交
692 693 694
	return 0;
}

J
Jeff Garzik 已提交
695 696
static DEF_SCSI_QCMD(uas_queuecommand)

697 698 699 700 701 702
/*
 * For now we do not support actually sending an abort to the device, so
 * this eh always fails. Still we must define it to make sure that we've
 * dropped all references to the cmnd in question once this function exits.
 */
static int uas_eh_abort_handler(struct scsi_cmnd *cmnd)
M
Matthew Wilcox 已提交
703
{
704 705 706 707
	struct uas_cmd_info *cmdinfo = (void *)&cmnd->SCp;
	struct uas_dev_info *devinfo = (void *)cmnd->device->hostdata;
	struct urb *data_in_urb = NULL;
	struct urb *data_out_urb = NULL;
G
Gerd Hoffmann 已提交
708
	unsigned long flags;
M
Matthew Wilcox 已提交
709

G
Gerd Hoffmann 已提交
710
	spin_lock_irqsave(&devinfo->lock, flags);
711

712
	uas_log_cmd_state(cmnd, __func__, 0);
713

714 715
	/* Ensure that try_complete does not call scsi_done */
	cmdinfo->state |= COMMAND_ABORTED;
716

717
	/* Drop all refs to this cmnd, kill data urbs to break their ref */
H
Hans de Goede 已提交
718
	devinfo->cmnd[cmdinfo->uas_tag - 1] = NULL;
719 720 721 722
	if (cmdinfo->state & DATA_IN_URB_INFLIGHT)
		data_in_urb = usb_get_urb(cmdinfo->data_in_urb);
	if (cmdinfo->state & DATA_OUT_URB_INFLIGHT)
		data_out_urb = usb_get_urb(cmdinfo->data_out_urb);
G
Gerd Hoffmann 已提交
723

724
	uas_free_unsubmitted_urbs(cmnd);
725 726 727

	spin_unlock_irqrestore(&devinfo->lock, flags);

728 729 730
	if (data_in_urb) {
		usb_kill_urb(data_in_urb);
		usb_put_urb(data_in_urb);
731
	}
732 733 734
	if (data_out_urb) {
		usb_kill_urb(data_out_urb);
		usb_put_urb(data_out_urb);
G
Gerd Hoffmann 已提交
735
	}
M
Matthew Wilcox 已提交
736

737
	return FAILED;
M
Matthew Wilcox 已提交
738 739 740 741 742 743 744
}

static int uas_eh_bus_reset_handler(struct scsi_cmnd *cmnd)
{
	struct scsi_device *sdev = cmnd->device;
	struct uas_dev_info *devinfo = sdev->hostdata;
	struct usb_device *udev = devinfo->udev;
H
Hans de Goede 已提交
745
	unsigned long flags;
G
Gerd Hoffmann 已提交
746
	int err;
M
Matthew Wilcox 已提交
747

H
Hans de Goede 已提交
748 749 750 751 752 753 754
	err = usb_lock_device_for_reset(udev, devinfo->intf);
	if (err) {
		shost_printk(KERN_ERR, sdev->host,
			     "%s FAILED to get lock err %d\n", __func__, err);
		return FAILED;
	}

G
Gerd Hoffmann 已提交
755
	shost_printk(KERN_INFO, sdev->host, "%s start\n", __func__);
H
Hans de Goede 已提交
756 757

	spin_lock_irqsave(&devinfo->lock, flags);
G
Gerd Hoffmann 已提交
758
	devinfo->resetting = 1;
H
Hans de Goede 已提交
759 760
	spin_unlock_irqrestore(&devinfo->lock, flags);

761
	usb_kill_anchored_urbs(&devinfo->cmd_urbs);
G
Gerd Hoffmann 已提交
762 763
	usb_kill_anchored_urbs(&devinfo->sense_urbs);
	usb_kill_anchored_urbs(&devinfo->data_urbs);
764 765
	uas_zap_pending(devinfo, DID_RESET);

G
Gerd Hoffmann 已提交
766
	err = usb_reset_device(udev);
H
Hans de Goede 已提交
767 768

	spin_lock_irqsave(&devinfo->lock, flags);
G
Gerd Hoffmann 已提交
769
	devinfo->resetting = 0;
H
Hans de Goede 已提交
770
	spin_unlock_irqrestore(&devinfo->lock, flags);
M
Matthew Wilcox 已提交
771

H
Hans de Goede 已提交
772 773
	usb_unlock_device(udev);

G
Gerd Hoffmann 已提交
774
	if (err) {
775 776
		shost_printk(KERN_INFO, sdev->host, "%s FAILED err %d\n",
			     __func__, err);
G
Gerd Hoffmann 已提交
777 778
		return FAILED;
	}
M
Matthew Wilcox 已提交
779

G
Gerd Hoffmann 已提交
780 781
	shost_printk(KERN_INFO, sdev->host, "%s success\n", __func__);
	return SUCCESS;
M
Matthew Wilcox 已提交
782 783
}

784 785 786 787 788 789 790 791 792 793 794
static int uas_target_alloc(struct scsi_target *starget)
{
	struct uas_dev_info *devinfo = (struct uas_dev_info *)
			dev_to_shost(starget->dev.parent)->hostdata;

	if (devinfo->flags & US_FL_NO_REPORT_LUNS)
		starget->no_report_luns = 1;

	return 0;
}

M
Matthew Wilcox 已提交
795 796
static int uas_slave_alloc(struct scsi_device *sdev)
{
797 798 799 800
	struct uas_dev_info *devinfo =
		(struct uas_dev_info *)sdev->host->hostdata;

	sdev->hostdata = devinfo;
801

802 803
	/*
	 * USB has unusual DMA-alignment requirements: Although the
804 805 806 807 808 809 810 811 812 813 814 815 816 817 818 819
	 * starting address of each scatter-gather element doesn't matter,
	 * the length of each element except the last must be divisible
	 * by the Bulk maxpacket value.  There's currently no way to
	 * express this by block-layer constraints, so we'll cop out
	 * and simply require addresses to be aligned at 512-byte
	 * boundaries.  This is okay since most block I/O involves
	 * hardware sectors that are multiples of 512 bytes in length,
	 * and since host controllers up through USB 2.0 have maxpacket
	 * values no larger than 512.
	 *
	 * But it doesn't suffice for Wireless USB, where Bulk maxpacket
	 * values can be as large as 2048.  To make that work properly
	 * will require changes to the block layer.
	 */
	blk_queue_update_dma_alignment(sdev->request_queue, (512 - 1));

820 821 822 823 824
	if (devinfo->flags & US_FL_MAX_SECTORS_64)
		blk_queue_max_hw_sectors(sdev->request_queue, 64);
	else if (devinfo->flags & US_FL_MAX_SECTORS_240)
		blk_queue_max_hw_sectors(sdev->request_queue, 240);

M
Matthew Wilcox 已提交
825 826 827 828 829 830
	return 0;
}

static int uas_slave_configure(struct scsi_device *sdev)
{
	struct uas_dev_info *devinfo = sdev->hostdata;
H
Hans de Goede 已提交
831 832 833 834

	if (devinfo->flags & US_FL_NO_REPORT_OPCODES)
		sdev->no_report_opcodes = 1;

835 836 837 838
	/* A few buggy USB-ATA bridges don't understand FUA */
	if (devinfo->flags & US_FL_BROKEN_FUA)
		sdev->broken_fua = 1;

839
	scsi_change_queue_depth(sdev, devinfo->qdepth - 2);
M
Matthew Wilcox 已提交
840 841 842 843 844 845 846
	return 0;
}

static struct scsi_host_template uas_host_template = {
	.module = THIS_MODULE,
	.name = "uas",
	.queuecommand = uas_queuecommand,
847
	.target_alloc = uas_target_alloc,
M
Matthew Wilcox 已提交
848 849 850 851 852 853 854 855 856
	.slave_alloc = uas_slave_alloc,
	.slave_configure = uas_slave_configure,
	.eh_abort_handler = uas_eh_abort_handler,
	.eh_bus_reset_handler = uas_eh_bus_reset_handler,
	.this_id = -1,
	.sg_tablesize = SG_NONE,
	.skip_settle_delay = 1,
};

857 858 859 860 861 862
#define UNUSUAL_DEV(id_vendor, id_product, bcdDeviceMin, bcdDeviceMax, \
		    vendorName, productName, useProtocol, useTransport, \
		    initFunction, flags) \
{ USB_DEVICE_VER(id_vendor, id_product, bcdDeviceMin, bcdDeviceMax), \
	.driver_info = (flags) }

M
Matthew Wilcox 已提交
863
static struct usb_device_id uas_usb_ids[] = {
864
#	include "unusual_uas.h"
M
Matthew Wilcox 已提交
865 866 867 868 869 870
	{ USB_INTERFACE_INFO(USB_CLASS_MASS_STORAGE, USB_SC_SCSI, USB_PR_BULK) },
	{ USB_INTERFACE_INFO(USB_CLASS_MASS_STORAGE, USB_SC_SCSI, USB_PR_UAS) },
	{ }
};
MODULE_DEVICE_TABLE(usb, uas_usb_ids);

871 872
#undef UNUSUAL_DEV

873 874 875 876 877 878 879 880 881 882 883 884 885
static int uas_switch_interface(struct usb_device *udev,
				struct usb_interface *intf)
{
	int alt;

	alt = uas_find_uas_alt_setting(intf);
	if (alt < 0)
		return alt;

	return usb_set_interface(udev,
			intf->altsetting[0].desc.bInterfaceNumber, alt);
}

886
static int uas_configure_endpoints(struct uas_dev_info *devinfo)
887 888 889 890 891 892
{
	struct usb_host_endpoint *eps[4] = { };
	struct usb_device *udev = devinfo->udev;
	int r;

	r = uas_find_endpoints(devinfo->intf->cur_altsetting, eps);
893 894 895 896 897 898 899 900 901 902 903
	if (r)
		return r;

	devinfo->cmd_pipe = usb_sndbulkpipe(udev,
					    usb_endpoint_num(&eps[0]->desc));
	devinfo->status_pipe = usb_rcvbulkpipe(udev,
					    usb_endpoint_num(&eps[1]->desc));
	devinfo->data_in_pipe = usb_rcvbulkpipe(udev,
					    usb_endpoint_num(&eps[2]->desc));
	devinfo->data_out_pipe = usb_sndbulkpipe(udev,
					    usb_endpoint_num(&eps[3]->desc));
M
Matthew Wilcox 已提交
904

905
	if (udev->speed < USB_SPEED_SUPER) {
906
		devinfo->qdepth = 32;
M
Matthew Wilcox 已提交
907 908
		devinfo->use_streams = 0;
	} else {
909
		devinfo->qdepth = usb_alloc_streams(devinfo->intf, eps + 1,
910
						    3, MAX_CMNDS, GFP_NOIO);
911 912
		if (devinfo->qdepth < 0)
			return devinfo->qdepth;
M
Matthew Wilcox 已提交
913 914
		devinfo->use_streams = 1;
	}
915 916

	return 0;
M
Matthew Wilcox 已提交
917 918
}

919 920 921 922 923 924 925 926
static void uas_free_streams(struct uas_dev_info *devinfo)
{
	struct usb_device *udev = devinfo->udev;
	struct usb_host_endpoint *eps[3];

	eps[0] = usb_pipe_endpoint(udev, devinfo->status_pipe);
	eps[1] = usb_pipe_endpoint(udev, devinfo->data_in_pipe);
	eps[2] = usb_pipe_endpoint(udev, devinfo->data_out_pipe);
927
	usb_free_streams(devinfo->intf, eps, 3, GFP_NOIO);
928 929
}

M
Matthew Wilcox 已提交
930 931
static int uas_probe(struct usb_interface *intf, const struct usb_device_id *id)
{
932 933
	int result = -ENOMEM;
	struct Scsi_Host *shost = NULL;
M
Matthew Wilcox 已提交
934 935
	struct uas_dev_info *devinfo;
	struct usb_device *udev = interface_to_usbdev(intf);
936
	unsigned long dev_flags;
M
Matthew Wilcox 已提交
937

938
	if (!uas_use_uas_driver(intf, id, &dev_flags))
939 940
		return -ENODEV;

941 942
	if (uas_switch_interface(udev, intf))
		return -ENODEV;
M
Matthew Wilcox 已提交
943

H
Hans de Goede 已提交
944 945
	shost = scsi_host_alloc(&uas_host_template,
				sizeof(struct uas_dev_info));
M
Matthew Wilcox 已提交
946
	if (!shost)
947
		goto set_alt0;
M
Matthew Wilcox 已提交
948 949 950

	shost->max_cmd_len = 16 + 252;
	shost->max_id = 1;
951 952
	shost->max_lun = 256;
	shost->max_channel = 0;
M
Matthew Wilcox 已提交
953 954
	shost->sg_tablesize = udev->bus->sg_tablesize;

H
Hans de Goede 已提交
955
	devinfo = (struct uas_dev_info *)shost->hostdata;
M
Matthew Wilcox 已提交
956 957
	devinfo->intf = intf;
	devinfo->udev = udev;
G
Gerd Hoffmann 已提交
958
	devinfo->resetting = 0;
H
Hans de Goede 已提交
959
	devinfo->shutdown = 0;
960
	devinfo->flags = dev_flags;
961
	init_usb_anchor(&devinfo->cmd_urbs);
962 963
	init_usb_anchor(&devinfo->sense_urbs);
	init_usb_anchor(&devinfo->data_urbs);
G
Gerd Hoffmann 已提交
964
	spin_lock_init(&devinfo->lock);
G
Gerd Hoffmann 已提交
965
	INIT_WORK(&devinfo->work, uas_do_work);
966 967 968 969

	result = uas_configure_endpoints(devinfo);
	if (result)
		goto set_alt0;
M
Matthew Wilcox 已提交
970

971 972 973 974 975 976
	/*
	 * 1 tag is reserved for untagged commands +
	 * 1 tag to avoid off by one errors in some bridge firmwares
	 */
	shost->can_queue = devinfo->qdepth - 2;

977
	usb_set_intfdata(intf, shost);
978 979
	result = scsi_add_host(shost, &intf->dev);
	if (result)
980
		goto free_streams;
981

M
Matthew Wilcox 已提交
982 983
	scsi_scan_host(shost);
	return result;
984

985
free_streams:
986
	uas_free_streams(devinfo);
987
	usb_set_intfdata(intf, NULL);
988 989
set_alt0:
	usb_set_interface(udev, intf->altsetting[0].desc.bInterfaceNumber, 0);
M
Matthew Wilcox 已提交
990 991 992 993 994
	if (shost)
		scsi_host_put(shost);
	return result;
}

995 996 997 998 999 1000 1001 1002 1003 1004 1005 1006 1007 1008 1009 1010 1011 1012 1013 1014 1015 1016 1017 1018 1019 1020 1021 1022 1023 1024 1025 1026 1027 1028 1029 1030 1031 1032 1033 1034 1035 1036 1037 1038 1039 1040 1041 1042
static int uas_cmnd_list_empty(struct uas_dev_info *devinfo)
{
	unsigned long flags;
	int i, r = 1;

	spin_lock_irqsave(&devinfo->lock, flags);

	for (i = 0; i < devinfo->qdepth; i++) {
		if (devinfo->cmnd[i]) {
			r = 0; /* Not empty */
			break;
		}
	}

	spin_unlock_irqrestore(&devinfo->lock, flags);

	return r;
}

/*
 * Wait for any pending cmnds to complete, on usb-2 sense_urbs may temporarily
 * get empty while there still is more work to do due to sense-urbs completing
 * with a READ/WRITE_READY iu code, so keep waiting until the list gets empty.
 */
static int uas_wait_for_pending_cmnds(struct uas_dev_info *devinfo)
{
	unsigned long start_time;
	int r;

	start_time = jiffies;
	do {
		flush_work(&devinfo->work);

		r = usb_wait_anchor_empty_timeout(&devinfo->sense_urbs, 5000);
		if (r == 0)
			return -ETIME;

		r = usb_wait_anchor_empty_timeout(&devinfo->data_urbs, 500);
		if (r == 0)
			return -ETIME;

		if (time_after(jiffies, start_time + 5 * HZ))
			return -ETIME;
	} while (!uas_cmnd_list_empty(devinfo));

	return 0;
}

M
Matthew Wilcox 已提交
1043 1044
static int uas_pre_reset(struct usb_interface *intf)
{
1045
	struct Scsi_Host *shost = usb_get_intfdata(intf);
H
Hans de Goede 已提交
1046
	struct uas_dev_info *devinfo = (struct uas_dev_info *)shost->hostdata;
1047 1048
	unsigned long flags;

H
Hans de Goede 已提交
1049 1050 1051
	if (devinfo->shutdown)
		return 0;

1052 1053 1054 1055 1056
	/* Block new requests */
	spin_lock_irqsave(shost->host_lock, flags);
	scsi_block_requests(shost);
	spin_unlock_irqrestore(shost->host_lock, flags);

1057
	if (uas_wait_for_pending_cmnds(devinfo) != 0) {
1058
		shost_printk(KERN_ERR, shost, "%s: timed out\n", __func__);
1059
		scsi_unblock_requests(shost);
1060 1061 1062 1063 1064
		return 1;
	}

	uas_free_streams(devinfo);

M
Matthew Wilcox 已提交
1065 1066 1067 1068 1069
	return 0;
}

static int uas_post_reset(struct usb_interface *intf)
{
1070
	struct Scsi_Host *shost = usb_get_intfdata(intf);
H
Hans de Goede 已提交
1071
	struct uas_dev_info *devinfo = (struct uas_dev_info *)shost->hostdata;
1072
	unsigned long flags;
1073
	int err;
1074

H
Hans de Goede 已提交
1075 1076 1077
	if (devinfo->shutdown)
		return 0;

1078 1079
	err = uas_configure_endpoints(devinfo);
	if (err) {
1080
		shost_printk(KERN_ERR, shost,
1081 1082
			     "%s: alloc streams error %d after reset",
			     __func__, err);
1083 1084
		return 1;
	}
1085 1086 1087 1088 1089 1090 1091

	spin_lock_irqsave(shost->host_lock, flags);
	scsi_report_bus_reset(shost, 0);
	spin_unlock_irqrestore(shost->host_lock, flags);

	scsi_unblock_requests(shost);

M
Matthew Wilcox 已提交
1092 1093 1094
	return 0;
}

H
Hans de Goede 已提交
1095 1096 1097
static int uas_suspend(struct usb_interface *intf, pm_message_t message)
{
	struct Scsi_Host *shost = usb_get_intfdata(intf);
H
Hans de Goede 已提交
1098
	struct uas_dev_info *devinfo = (struct uas_dev_info *)shost->hostdata;
H
Hans de Goede 已提交
1099

1100
	if (uas_wait_for_pending_cmnds(devinfo) != 0) {
H
Hans de Goede 已提交
1101 1102 1103 1104 1105 1106 1107 1108 1109 1110 1111 1112 1113 1114 1115
		shost_printk(KERN_ERR, shost, "%s: timed out\n", __func__);
		return -ETIME;
	}

	return 0;
}

static int uas_resume(struct usb_interface *intf)
{
	return 0;
}

static int uas_reset_resume(struct usb_interface *intf)
{
	struct Scsi_Host *shost = usb_get_intfdata(intf);
H
Hans de Goede 已提交
1116
	struct uas_dev_info *devinfo = (struct uas_dev_info *)shost->hostdata;
H
Hans de Goede 已提交
1117
	unsigned long flags;
1118
	int err;
H
Hans de Goede 已提交
1119

1120 1121
	err = uas_configure_endpoints(devinfo);
	if (err) {
H
Hans de Goede 已提交
1122
		shost_printk(KERN_ERR, shost,
1123 1124
			     "%s: alloc streams error %d after reset",
			     __func__, err);
H
Hans de Goede 已提交
1125 1126 1127 1128 1129 1130 1131 1132 1133 1134
		return -EIO;
	}

	spin_lock_irqsave(shost->host_lock, flags);
	scsi_report_bus_reset(shost, 0);
	spin_unlock_irqrestore(shost->host_lock, flags);

	return 0;
}

M
Matthew Wilcox 已提交
1135 1136 1137
static void uas_disconnect(struct usb_interface *intf)
{
	struct Scsi_Host *shost = usb_get_intfdata(intf);
H
Hans de Goede 已提交
1138
	struct uas_dev_info *devinfo = (struct uas_dev_info *)shost->hostdata;
H
Hans de Goede 已提交
1139
	unsigned long flags;
M
Matthew Wilcox 已提交
1140

H
Hans de Goede 已提交
1141
	spin_lock_irqsave(&devinfo->lock, flags);
G
Gerd Hoffmann 已提交
1142
	devinfo->resetting = 1;
H
Hans de Goede 已提交
1143 1144
	spin_unlock_irqrestore(&devinfo->lock, flags);

G
Gerd Hoffmann 已提交
1145
	cancel_work_sync(&devinfo->work);
1146
	usb_kill_anchored_urbs(&devinfo->cmd_urbs);
1147 1148
	usb_kill_anchored_urbs(&devinfo->sense_urbs);
	usb_kill_anchored_urbs(&devinfo->data_urbs);
1149 1150
	uas_zap_pending(devinfo, DID_NO_CONNECT);

G
Gerd Hoffmann 已提交
1151
	scsi_remove_host(shost);
1152
	uas_free_streams(devinfo);
H
Hans de Goede 已提交
1153
	scsi_host_put(shost);
M
Matthew Wilcox 已提交
1154 1155
}

H
Hans de Goede 已提交
1156 1157 1158 1159 1160 1161 1162 1163 1164 1165
/*
 * Put the device back in usb-storage mode on shutdown, as some BIOS-es
 * hang on reboot when the device is still in uas mode. Note the reset is
 * necessary as some devices won't revert to usb-storage mode without it.
 */
static void uas_shutdown(struct device *dev)
{
	struct usb_interface *intf = to_usb_interface(dev);
	struct usb_device *udev = interface_to_usbdev(intf);
	struct Scsi_Host *shost = usb_get_intfdata(intf);
H
Hans de Goede 已提交
1166
	struct uas_dev_info *devinfo = (struct uas_dev_info *)shost->hostdata;
H
Hans de Goede 已提交
1167 1168 1169 1170 1171 1172 1173 1174 1175 1176

	if (system_state != SYSTEM_RESTART)
		return;

	devinfo->shutdown = 1;
	uas_free_streams(devinfo);
	usb_set_interface(udev, intf->altsetting[0].desc.bInterfaceNumber, 0);
	usb_reset_device(udev);
}

M
Matthew Wilcox 已提交
1177 1178 1179 1180 1181 1182
static struct usb_driver uas_driver = {
	.name = "uas",
	.probe = uas_probe,
	.disconnect = uas_disconnect,
	.pre_reset = uas_pre_reset,
	.post_reset = uas_post_reset,
H
Hans de Goede 已提交
1183 1184 1185
	.suspend = uas_suspend,
	.resume = uas_resume,
	.reset_resume = uas_reset_resume,
H
Hans de Goede 已提交
1186
	.drvwrap.driver.shutdown = uas_shutdown,
M
Matthew Wilcox 已提交
1187 1188 1189
	.id_table = uas_usb_ids,
};

1190
module_usb_driver(uas_driver);
M
Matthew Wilcox 已提交
1191 1192

MODULE_LICENSE("GPL");
1193 1194
MODULE_AUTHOR(
	"Hans de Goede <hdegoede@redhat.com>, Matthew Wilcox and Sarah Sharp");