1 /* $FreeBSD$ */ 2 /*- 3 * Copyright (C) 2003-2005 Alan Stern 4 * Copyright (C) 2008 Hans Petter Selasky 5 * All rights reserved. 6 * 7 * Redistribution and use in source and binary forms, with or without 8 * modification, are permitted provided that the following conditions 9 * are met: 10 * 1. Redistributions of source code must retain the above copyright 11 * notice, this list of conditions, and the following disclaimer, 12 * without modification. 13 * 2. Redistributions in binary form must reproduce the above copyright 14 * notice, this list of conditions and the following disclaimer in the 15 * documentation and/or other materials provided with the distribution. 16 * 3. The names of the above-listed copyright holders may not be used 17 * to endorse or promote products derived from this software without 18 * specific prior written permission. 19 * 20 * 21 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS 22 * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, 23 * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 24 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR 25 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, 26 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, 27 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR 28 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF 29 * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING 30 * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS 31 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 32 */ 33 34 /* 35 * NOTE: Much of the SCSI statemachine handling code derives from the 36 * Linux USB gadget stack. 37 */ 38 39 #include <sys/stdint.h> 40 #include <sys/stddef.h> 41 #include <sys/param.h> 42 #include <sys/queue.h> 43 #include <sys/types.h> 44 #include <sys/systm.h> 45 #include <sys/kernel.h> 46 #include <sys/bus.h> 47 #include <sys/module.h> 48 #include <sys/lock.h> 49 #include <sys/mutex.h> 50 #include <sys/condvar.h> 51 #include <sys/sysctl.h> 52 #include <sys/sx.h> 53 #include <sys/unistd.h> 54 #include <sys/callout.h> 55 #include <sys/malloc.h> 56 #include <sys/priv.h> 57 58 #include <dev/usb/usb.h> 59 #include <dev/usb/usbdi.h> 60 #include "usbdevs.h" 61 #include "usb_if.h" 62 63 #define USB_DEBUG_VAR ustorage_fs_debug 64 #include <dev/usb/usb_debug.h> 65 66 #ifdef USB_DEBUG 67 static int ustorage_fs_debug = 0; 68 69 SYSCTL_NODE(_hw_usb, OID_AUTO, ustorage_fs, CTLFLAG_RW, 0, "USB ustorage_fs"); 70 SYSCTL_INT(_hw_usb_ustorage_fs, OID_AUTO, debug, CTLFLAG_RW, 71 &ustorage_fs_debug, 0, "ustorage_fs debug level"); 72 #endif 73 74 /* Define some limits */ 75 76 #ifndef USTORAGE_FS_BULK_SIZE 77 #define USTORAGE_FS_BULK_SIZE (1UL << 17) /* bytes */ 78 #endif 79 80 #ifndef USTORAGE_FS_MAX_LUN 81 #define USTORAGE_FS_MAX_LUN 8 /* units */ 82 #endif 83 84 #ifndef USTORAGE_QDATA_MAX 85 #define USTORAGE_QDATA_MAX 40 /* bytes */ 86 #endif 87 88 #define sc_cmd_data sc_cbw.CBWCDB 89 90 /* 91 * The SCSI ID string must be exactly 28 characters long 92 * exluding the terminating zero. 93 */ 94 #ifndef USTORAGE_FS_ID_STRING 95 #define USTORAGE_FS_ID_STRING \ 96 "FreeBSD " /* 8 */ \ 97 "File-Stor Gadget" /* 16 */ \ 98 "0101" /* 4 */ 99 #endif 100 101 /* 102 * The following macro defines the number of 103 * sectors to be allocated for the RAM disk: 104 */ 105 #ifndef USTORAGE_FS_RAM_SECT 106 #define USTORAGE_FS_RAM_SECT (1UL << 13) 107 #endif 108 109 static uint8_t *ustorage_fs_ramdisk; 110 111 /* USB transfer definitions */ 112 113 #define USTORAGE_FS_T_BBB_COMMAND 0 114 #define USTORAGE_FS_T_BBB_DATA_DUMP 1 115 #define USTORAGE_FS_T_BBB_DATA_READ 2 116 #define USTORAGE_FS_T_BBB_DATA_WRITE 3 117 #define USTORAGE_FS_T_BBB_STATUS 4 118 #define USTORAGE_FS_T_BBB_MAX 5 119 120 /* USB data stage direction */ 121 122 #define DIR_NONE 0 123 #define DIR_READ 1 124 #define DIR_WRITE 2 125 126 /* USB interface specific control request */ 127 128 #define UR_BBB_RESET 0xff /* Bulk-Only reset */ 129 #define UR_BBB_GET_MAX_LUN 0xfe /* Get maximum lun */ 130 131 /* Command Block Wrapper */ 132 typedef struct { 133 uDWord dCBWSignature; 134 #define CBWSIGNATURE 0x43425355 135 uDWord dCBWTag; 136 uDWord dCBWDataTransferLength; 137 uByte bCBWFlags; 138 #define CBWFLAGS_OUT 0x00 139 #define CBWFLAGS_IN 0x80 140 uByte bCBWLUN; 141 uByte bCDBLength; 142 #define CBWCDBLENGTH 16 143 uByte CBWCDB[CBWCDBLENGTH]; 144 } __packed ustorage_fs_bbb_cbw_t; 145 146 #define USTORAGE_FS_BBB_CBW_SIZE 31 147 148 /* Command Status Wrapper */ 149 typedef struct { 150 uDWord dCSWSignature; 151 #define CSWSIGNATURE 0x53425355 152 uDWord dCSWTag; 153 uDWord dCSWDataResidue; 154 uByte bCSWStatus; 155 #define CSWSTATUS_GOOD 0x0 156 #define CSWSTATUS_FAILED 0x1 157 #define CSWSTATUS_PHASE 0x2 158 } __packed ustorage_fs_bbb_csw_t; 159 160 #define USTORAGE_FS_BBB_CSW_SIZE 13 161 162 struct ustorage_fs_lun { 163 164 uint8_t *memory_image; 165 166 uint32_t num_sectors; 167 uint32_t sense_data; 168 uint32_t sense_data_info; 169 uint32_t unit_attention_data; 170 171 uint8_t read_only:1; 172 uint8_t prevent_medium_removal:1; 173 uint8_t info_valid:1; 174 uint8_t removable:1; 175 }; 176 177 struct ustorage_fs_softc { 178 179 ustorage_fs_bbb_cbw_t sc_cbw; /* Command Wrapper Block */ 180 ustorage_fs_bbb_csw_t sc_csw; /* Command Status Block */ 181 182 struct mtx sc_mtx; 183 184 struct ustorage_fs_lun sc_lun[USTORAGE_FS_MAX_LUN]; 185 186 struct { 187 uint8_t *data_ptr; 188 struct ustorage_fs_lun *currlun; 189 190 uint32_t data_rem; /* bytes, as reported by the command 191 * block wrapper */ 192 uint32_t offset; /* bytes */ 193 194 uint8_t cbw_dir; 195 uint8_t cmd_dir; 196 uint8_t lun; 197 uint8_t cmd_len; 198 uint8_t data_short:1; 199 uint8_t data_error:1; 200 } sc_transfer; 201 202 device_t sc_dev; 203 struct usb_device *sc_udev; 204 struct usb_xfer *sc_xfer[USTORAGE_FS_T_BBB_MAX]; 205 206 uint8_t sc_iface_no; /* interface number */ 207 uint8_t sc_last_lun; 208 uint8_t sc_last_xfer_index; 209 uint8_t sc_qdata[USTORAGE_QDATA_MAX]; 210 }; 211 212 /* prototypes */ 213 214 static device_probe_t ustorage_fs_probe; 215 static device_attach_t ustorage_fs_attach; 216 static device_detach_t ustorage_fs_detach; 217 static device_suspend_t ustorage_fs_suspend; 218 static device_resume_t ustorage_fs_resume; 219 static usb_handle_request_t ustorage_fs_handle_request; 220 221 static usb_callback_t ustorage_fs_t_bbb_command_callback; 222 static usb_callback_t ustorage_fs_t_bbb_data_dump_callback; 223 static usb_callback_t ustorage_fs_t_bbb_data_read_callback; 224 static usb_callback_t ustorage_fs_t_bbb_data_write_callback; 225 static usb_callback_t ustorage_fs_t_bbb_status_callback; 226 227 static void ustorage_fs_transfer_start(struct ustorage_fs_softc *sc, uint8_t xfer_index); 228 static void ustorage_fs_transfer_stop(struct ustorage_fs_softc *sc); 229 230 static uint8_t ustorage_fs_verify(struct ustorage_fs_softc *sc); 231 static uint8_t ustorage_fs_inquiry(struct ustorage_fs_softc *sc); 232 static uint8_t ustorage_fs_request_sense(struct ustorage_fs_softc *sc); 233 static uint8_t ustorage_fs_read_capacity(struct ustorage_fs_softc *sc); 234 static uint8_t ustorage_fs_mode_sense(struct ustorage_fs_softc *sc); 235 static uint8_t ustorage_fs_start_stop(struct ustorage_fs_softc *sc); 236 static uint8_t ustorage_fs_prevent_allow(struct ustorage_fs_softc *sc); 237 static uint8_t ustorage_fs_read_format_capacities(struct ustorage_fs_softc *sc); 238 static uint8_t ustorage_fs_mode_select(struct ustorage_fs_softc *sc); 239 static uint8_t ustorage_fs_min_len(struct ustorage_fs_softc *sc, uint32_t len, uint32_t mask); 240 static uint8_t ustorage_fs_read(struct ustorage_fs_softc *sc); 241 static uint8_t ustorage_fs_write(struct ustorage_fs_softc *sc); 242 static uint8_t ustorage_fs_check_cmd(struct ustorage_fs_softc *sc, uint8_t cmd_size, uint16_t mask, uint8_t needs_medium); 243 static uint8_t ustorage_fs_do_cmd(struct ustorage_fs_softc *sc); 244 245 static device_method_t ustorage_fs_methods[] = { 246 /* USB interface */ 247 DEVMETHOD(usb_handle_request, ustorage_fs_handle_request), 248 249 /* Device interface */ 250 DEVMETHOD(device_probe, ustorage_fs_probe), 251 DEVMETHOD(device_attach, ustorage_fs_attach), 252 DEVMETHOD(device_detach, ustorage_fs_detach), 253 DEVMETHOD(device_suspend, ustorage_fs_suspend), 254 DEVMETHOD(device_resume, ustorage_fs_resume), 255 256 {0, 0} 257 }; 258 259 static driver_t ustorage_fs_driver = { 260 .name = "ustorage_fs", 261 .methods = ustorage_fs_methods, 262 .size = sizeof(struct ustorage_fs_softc), 263 }; 264 265 static devclass_t ustorage_fs_devclass; 266 267 DRIVER_MODULE(ustorage_fs, uhub, ustorage_fs_driver, ustorage_fs_devclass, NULL, 0); 268 MODULE_VERSION(ustorage_fs, 0); 269 MODULE_DEPEND(ustorage_fs, usb, 1, 1, 1); 270 271 static struct usb_config ustorage_fs_bbb_config[USTORAGE_FS_T_BBB_MAX] = { 272 273 [USTORAGE_FS_T_BBB_COMMAND] = { 274 .type = UE_BULK, 275 .endpoint = UE_ADDR_ANY, 276 .direction = UE_DIR_OUT, 277 .bufsize = sizeof(ustorage_fs_bbb_cbw_t), 278 .flags = {.ext_buffer = 1,}, 279 .callback = &ustorage_fs_t_bbb_command_callback, 280 .usb_mode = USB_MODE_DEVICE, 281 }, 282 283 [USTORAGE_FS_T_BBB_DATA_DUMP] = { 284 .type = UE_BULK, 285 .endpoint = UE_ADDR_ANY, 286 .direction = UE_DIR_OUT, 287 .bufsize = 0, /* use wMaxPacketSize */ 288 .flags = {.proxy_buffer = 1,.short_xfer_ok = 1,}, 289 .callback = &ustorage_fs_t_bbb_data_dump_callback, 290 .usb_mode = USB_MODE_DEVICE, 291 }, 292 293 [USTORAGE_FS_T_BBB_DATA_READ] = { 294 .type = UE_BULK, 295 .endpoint = UE_ADDR_ANY, 296 .direction = UE_DIR_OUT, 297 .bufsize = USTORAGE_FS_BULK_SIZE, 298 .flags = {.proxy_buffer = 1,.short_xfer_ok = 1,.ext_buffer = 1}, 299 .callback = &ustorage_fs_t_bbb_data_read_callback, 300 .usb_mode = USB_MODE_DEVICE, 301 }, 302 303 [USTORAGE_FS_T_BBB_DATA_WRITE] = { 304 .type = UE_BULK, 305 .endpoint = UE_ADDR_ANY, 306 .direction = UE_DIR_IN, 307 .bufsize = USTORAGE_FS_BULK_SIZE, 308 .flags = {.proxy_buffer = 1,.short_xfer_ok = 1,.ext_buffer = 1}, 309 .callback = &ustorage_fs_t_bbb_data_write_callback, 310 .usb_mode = USB_MODE_DEVICE, 311 }, 312 313 [USTORAGE_FS_T_BBB_STATUS] = { 314 .type = UE_BULK, 315 .endpoint = UE_ADDR_ANY, 316 .direction = UE_DIR_IN, 317 .bufsize = sizeof(ustorage_fs_bbb_csw_t), 318 .flags = {.short_xfer_ok = 1,.ext_buffer = 1,}, 319 .callback = &ustorage_fs_t_bbb_status_callback, 320 .usb_mode = USB_MODE_DEVICE, 321 }, 322 }; 323 324 /* 325 * USB device probe/attach/detach 326 */ 327 328 static int 329 ustorage_fs_probe(device_t dev) 330 { 331 struct usb_attach_arg *uaa = device_get_ivars(dev); 332 struct usb_interface_descriptor *id; 333 334 if (uaa->usb_mode != USB_MODE_DEVICE) { 335 return (ENXIO); 336 } 337 /* Check for a standards compliant device */ 338 id = usbd_get_interface_descriptor(uaa->iface); 339 if ((id == NULL) || 340 (id->bInterfaceClass != UICLASS_MASS) || 341 (id->bInterfaceSubClass != UISUBCLASS_SCSI) || 342 (id->bInterfaceProtocol != UIPROTO_MASS_BBB)) { 343 return (ENXIO); 344 } 345 return (BUS_PROBE_GENERIC); 346 } 347 348 static int 349 ustorage_fs_attach(device_t dev) 350 { 351 struct ustorage_fs_softc *sc = device_get_softc(dev); 352 struct usb_attach_arg *uaa = device_get_ivars(dev); 353 struct usb_interface_descriptor *id; 354 int err; 355 int unit; 356 357 /* 358 * NOTE: the softc struct is cleared in device_set_driver. 359 * We can safely call ustorage_fs_detach without specifically 360 * initializing the struct. 361 */ 362 363 sc->sc_dev = dev; 364 sc->sc_udev = uaa->device; 365 unit = device_get_unit(dev); 366 367 /* enable power saving mode */ 368 usbd_set_power_mode(uaa->device, USB_POWER_MODE_SAVE); 369 370 if (unit == 0) { 371 if (ustorage_fs_ramdisk == NULL) { 372 /* 373 * allocate a memory image for our ramdisk until 374 * further 375 */ 376 ustorage_fs_ramdisk = 377 malloc(USTORAGE_FS_RAM_SECT << 9, M_USB, 378 M_ZERO | M_WAITOK); 379 380 if (ustorage_fs_ramdisk == NULL) { 381 return (ENOMEM); 382 } 383 } 384 sc->sc_lun[0].memory_image = ustorage_fs_ramdisk; 385 sc->sc_lun[0].num_sectors = USTORAGE_FS_RAM_SECT; 386 sc->sc_lun[0].removable = 1; 387 } 388 389 device_set_usb_desc(dev); 390 391 mtx_init(&sc->sc_mtx, "USTORAGE_FS lock", 392 NULL, (MTX_DEF | MTX_RECURSE)); 393 394 /* get interface index */ 395 396 id = usbd_get_interface_descriptor(uaa->iface); 397 if (id == NULL) { 398 device_printf(dev, "failed to get " 399 "interface number\n"); 400 goto detach; 401 } 402 sc->sc_iface_no = id->bInterfaceNumber; 403 404 err = usbd_transfer_setup(uaa->device, 405 &uaa->info.bIfaceIndex, sc->sc_xfer, ustorage_fs_bbb_config, 406 USTORAGE_FS_T_BBB_MAX, sc, &sc->sc_mtx); 407 if (err) { 408 device_printf(dev, "could not setup required " 409 "transfers, %s\n", usbd_errstr(err)); 410 goto detach; 411 } 412 /* start Mass Storage State Machine */ 413 414 mtx_lock(&sc->sc_mtx); 415 ustorage_fs_transfer_start(sc, USTORAGE_FS_T_BBB_COMMAND); 416 mtx_unlock(&sc->sc_mtx); 417 418 return (0); /* success */ 419 420 detach: 421 ustorage_fs_detach(dev); 422 return (ENXIO); /* failure */ 423 } 424 425 static int 426 ustorage_fs_detach(device_t dev) 427 { 428 struct ustorage_fs_softc *sc = device_get_softc(dev); 429 430 /* teardown our statemachine */ 431 432 usbd_transfer_unsetup(sc->sc_xfer, USTORAGE_FS_T_BBB_MAX); 433 434 mtx_destroy(&sc->sc_mtx); 435 436 return (0); /* success */ 437 } 438 439 static int 440 ustorage_fs_suspend(device_t dev) 441 { 442 device_printf(dev, "suspending\n"); 443 return (0); /* success */ 444 } 445 446 static int 447 ustorage_fs_resume(device_t dev) 448 { 449 device_printf(dev, "resuming\n"); 450 return (0); /* success */ 451 } 452 453 /* 454 * Generic functions to handle transfers 455 */ 456 457 static void 458 ustorage_fs_transfer_start(struct ustorage_fs_softc *sc, uint8_t xfer_index) 459 { 460 if (sc->sc_xfer[xfer_index]) { 461 sc->sc_last_xfer_index = xfer_index; 462 usbd_transfer_start(sc->sc_xfer[xfer_index]); 463 } 464 } 465 466 static void 467 ustorage_fs_transfer_stop(struct ustorage_fs_softc *sc) 468 { 469 usbd_transfer_stop(sc->sc_xfer[sc->sc_last_xfer_index]); 470 mtx_unlock(&sc->sc_mtx); 471 usbd_transfer_drain(sc->sc_xfer[sc->sc_last_xfer_index]); 472 mtx_lock(&sc->sc_mtx); 473 } 474 475 static int 476 ustorage_fs_handle_request(device_t dev, 477 const void *preq, void **pptr, uint16_t *plen, 478 uint16_t offset, uint8_t *pstate) 479 { 480 struct ustorage_fs_softc *sc = device_get_softc(dev); 481 const struct usb_device_request *req = preq; 482 uint8_t is_complete = *pstate; 483 484 if (!is_complete) { 485 if ((req->bmRequestType == UT_WRITE_CLASS_INTERFACE) && 486 (req->bRequest == UR_BBB_RESET)) { 487 *plen = 0; 488 mtx_lock(&sc->sc_mtx); 489 ustorage_fs_transfer_stop(sc); 490 sc->sc_transfer.data_error = 1; 491 ustorage_fs_transfer_start(sc, 492 USTORAGE_FS_T_BBB_COMMAND); 493 mtx_unlock(&sc->sc_mtx); 494 return (0); 495 } else if ((req->bmRequestType == UT_READ_CLASS_INTERFACE) && 496 (req->bRequest == UR_BBB_GET_MAX_LUN)) { 497 if (offset == 0) { 498 *plen = 1; 499 *pptr = &sc->sc_last_lun; 500 } else { 501 *plen = 0; 502 } 503 return (0); 504 } 505 } 506 return (ENXIO); /* use builtin handler */ 507 } 508 509 static void 510 ustorage_fs_t_bbb_command_callback(struct usb_xfer *xfer, usb_error_t error) 511 { 512 struct ustorage_fs_softc *sc = usbd_xfer_softc(xfer); 513 uint32_t tag; 514 uint8_t err = 0; 515 516 DPRINTF("\n"); 517 518 switch (USB_GET_STATE(xfer)) { 519 case USB_ST_TRANSFERRED: 520 521 tag = UGETDW(sc->sc_cbw.dCBWSignature); 522 523 if (tag != CBWSIGNATURE) { 524 /* do nothing */ 525 DPRINTF("invalid signature 0x%08x\n", tag); 526 break; 527 } 528 tag = UGETDW(sc->sc_cbw.dCBWTag); 529 530 /* echo back tag */ 531 USETDW(sc->sc_csw.dCSWTag, tag); 532 533 /* reset status */ 534 sc->sc_csw.bCSWStatus = 0; 535 536 /* reset data offset, data length and data remainder */ 537 sc->sc_transfer.offset = 0; 538 sc->sc_transfer.data_rem = 539 UGETDW(sc->sc_cbw.dCBWDataTransferLength); 540 541 /* reset data flags */ 542 sc->sc_transfer.data_short = 0; 543 544 /* extract LUN */ 545 sc->sc_transfer.lun = sc->sc_cbw.bCBWLUN; 546 547 if (sc->sc_transfer.data_rem == 0) { 548 sc->sc_transfer.cbw_dir = DIR_NONE; 549 } else { 550 if (sc->sc_cbw.bCBWFlags & CBWFLAGS_IN) { 551 sc->sc_transfer.cbw_dir = DIR_WRITE; 552 } else { 553 sc->sc_transfer.cbw_dir = DIR_READ; 554 } 555 } 556 557 sc->sc_transfer.cmd_len = sc->sc_cbw.bCDBLength; 558 if ((sc->sc_transfer.cmd_len > sizeof(sc->sc_cbw.CBWCDB)) || 559 (sc->sc_transfer.cmd_len == 0)) { 560 /* just halt - this is invalid */ 561 DPRINTF("invalid command length %d bytes\n", 562 sc->sc_transfer.cmd_len); 563 break; 564 } 565 566 err = ustorage_fs_do_cmd(sc); 567 if (err) { 568 /* got an error */ 569 DPRINTF("command failed\n"); 570 break; 571 } 572 if ((sc->sc_transfer.data_rem > 0) && 573 (sc->sc_transfer.cbw_dir != sc->sc_transfer.cmd_dir)) { 574 /* contradicting data transfer direction */ 575 err = 1; 576 DPRINTF("data direction mismatch\n"); 577 break; 578 } 579 switch (sc->sc_transfer.cbw_dir) { 580 case DIR_READ: 581 ustorage_fs_transfer_start(sc, USTORAGE_FS_T_BBB_DATA_READ); 582 break; 583 case DIR_WRITE: 584 ustorage_fs_transfer_start(sc, USTORAGE_FS_T_BBB_DATA_WRITE); 585 break; 586 default: 587 ustorage_fs_transfer_start(sc, 588 USTORAGE_FS_T_BBB_STATUS); 589 break; 590 } 591 break; 592 593 case USB_ST_SETUP: 594 tr_setup: 595 if (sc->sc_transfer.data_error) { 596 sc->sc_transfer.data_error = 0; 597 usbd_xfer_set_stall(xfer); 598 DPRINTF("stall pipe\n"); 599 } 600 601 usbd_xfer_set_frame_data(xfer, 0, &sc->sc_cbw, 602 sizeof(sc->sc_cbw)); 603 usbd_transfer_submit(xfer); 604 break; 605 606 default: /* Error */ 607 DPRINTF("error\n"); 608 if (error == USB_ERR_CANCELLED) { 609 break; 610 } 611 /* If the pipe is already stalled, don't do another stall */ 612 if (!usbd_xfer_is_stalled(xfer)) 613 sc->sc_transfer.data_error = 1; 614 615 /* try again */ 616 goto tr_setup; 617 } 618 if (err) { 619 if (sc->sc_csw.bCSWStatus == 0) { 620 /* set some default error code */ 621 sc->sc_csw.bCSWStatus = CSWSTATUS_FAILED; 622 } 623 if (sc->sc_transfer.cbw_dir == DIR_READ) { 624 /* dump all data */ 625 ustorage_fs_transfer_start(sc, 626 USTORAGE_FS_T_BBB_DATA_DUMP); 627 return; 628 } 629 if (sc->sc_transfer.cbw_dir == DIR_WRITE) { 630 /* need to stall before status */ 631 sc->sc_transfer.data_error = 1; 632 } 633 ustorage_fs_transfer_start(sc, USTORAGE_FS_T_BBB_STATUS); 634 } 635 } 636 637 static void 638 ustorage_fs_t_bbb_data_dump_callback(struct usb_xfer *xfer, usb_error_t error) 639 { 640 struct ustorage_fs_softc *sc = usbd_xfer_softc(xfer); 641 uint32_t max_bulk = usbd_xfer_max_len(xfer); 642 int actlen, sumlen; 643 644 usbd_xfer_status(xfer, &actlen, &sumlen, NULL, NULL); 645 646 DPRINTF("\n"); 647 648 switch (USB_GET_STATE(xfer)) { 649 case USB_ST_TRANSFERRED: 650 sc->sc_transfer.data_rem -= actlen; 651 sc->sc_transfer.offset += actlen; 652 653 if (actlen != sumlen || sc->sc_transfer.data_rem == 0) { 654 /* short transfer or end of data */ 655 ustorage_fs_transfer_start(sc, 656 USTORAGE_FS_T_BBB_STATUS); 657 break; 658 } 659 /* Fallthrough */ 660 661 case USB_ST_SETUP: 662 tr_setup: 663 if (max_bulk > sc->sc_transfer.data_rem) { 664 max_bulk = sc->sc_transfer.data_rem; 665 } 666 if (sc->sc_transfer.data_error) { 667 sc->sc_transfer.data_error = 0; 668 usbd_xfer_set_stall(xfer); 669 } 670 usbd_xfer_set_frame_len(xfer, 0, max_bulk); 671 usbd_transfer_submit(xfer); 672 break; 673 674 default: /* Error */ 675 if (error == USB_ERR_CANCELLED) { 676 break; 677 } 678 /* 679 * If the pipe is already stalled, don't do another stall: 680 */ 681 if (!usbd_xfer_is_stalled(xfer)) 682 sc->sc_transfer.data_error = 1; 683 684 /* try again */ 685 goto tr_setup; 686 } 687 } 688 689 static void 690 ustorage_fs_t_bbb_data_read_callback(struct usb_xfer *xfer, usb_error_t error) 691 { 692 struct ustorage_fs_softc *sc = usbd_xfer_softc(xfer); 693 uint32_t max_bulk = usbd_xfer_max_len(xfer); 694 int actlen, sumlen; 695 696 usbd_xfer_status(xfer, &actlen, &sumlen, NULL, NULL); 697 698 DPRINTF("\n"); 699 700 switch (USB_GET_STATE(xfer)) { 701 case USB_ST_TRANSFERRED: 702 sc->sc_transfer.data_rem -= actlen; 703 sc->sc_transfer.data_ptr += actlen; 704 sc->sc_transfer.offset += actlen; 705 706 if (actlen != sumlen || sc->sc_transfer.data_rem == 0) { 707 /* short transfer or end of data */ 708 ustorage_fs_transfer_start(sc, 709 USTORAGE_FS_T_BBB_STATUS); 710 break; 711 } 712 /* Fallthrough */ 713 714 case USB_ST_SETUP: 715 tr_setup: 716 if (max_bulk > sc->sc_transfer.data_rem) { 717 max_bulk = sc->sc_transfer.data_rem; 718 } 719 if (sc->sc_transfer.data_error) { 720 sc->sc_transfer.data_error = 0; 721 usbd_xfer_set_stall(xfer); 722 } 723 724 usbd_xfer_set_frame_data(xfer, 0, sc->sc_transfer.data_ptr, 725 max_bulk); 726 usbd_transfer_submit(xfer); 727 break; 728 729 default: /* Error */ 730 if (error == USB_ERR_CANCELLED) { 731 break; 732 } 733 /* If the pipe is already stalled, don't do another stall */ 734 if (!usbd_xfer_is_stalled(xfer)) 735 sc->sc_transfer.data_error = 1; 736 737 /* try again */ 738 goto tr_setup; 739 } 740 } 741 742 static void 743 ustorage_fs_t_bbb_data_write_callback(struct usb_xfer *xfer, usb_error_t error) 744 { 745 struct ustorage_fs_softc *sc = usbd_xfer_softc(xfer); 746 uint32_t max_bulk = usbd_xfer_max_len(xfer); 747 int actlen, sumlen; 748 749 usbd_xfer_status(xfer, &actlen, &sumlen, NULL, NULL); 750 751 DPRINTF("\n"); 752 753 switch (USB_GET_STATE(xfer)) { 754 case USB_ST_TRANSFERRED: 755 sc->sc_transfer.data_rem -= actlen; 756 sc->sc_transfer.data_ptr += actlen; 757 sc->sc_transfer.offset += actlen; 758 759 if (actlen != sumlen || sc->sc_transfer.data_rem == 0) { 760 /* short transfer or end of data */ 761 ustorage_fs_transfer_start(sc, 762 USTORAGE_FS_T_BBB_STATUS); 763 break; 764 } 765 case USB_ST_SETUP: 766 tr_setup: 767 if (max_bulk >= sc->sc_transfer.data_rem) { 768 max_bulk = sc->sc_transfer.data_rem; 769 if (sc->sc_transfer.data_short) 770 usbd_xfer_set_flag(xfer, USB_FORCE_SHORT_XFER); 771 else 772 usbd_xfer_clr_flag(xfer, USB_FORCE_SHORT_XFER); 773 } else 774 usbd_xfer_clr_flag(xfer, USB_FORCE_SHORT_XFER); 775 776 if (sc->sc_transfer.data_error) { 777 sc->sc_transfer.data_error = 0; 778 usbd_xfer_set_stall(xfer); 779 } 780 781 usbd_xfer_set_frame_data(xfer, 0, sc->sc_transfer.data_ptr, 782 max_bulk); 783 usbd_transfer_submit(xfer); 784 break; 785 786 default: /* Error */ 787 if (error == USB_ERR_CANCELLED) { 788 break; 789 } 790 /* 791 * If the pipe is already stalled, don't do another 792 * stall 793 */ 794 if (!usbd_xfer_is_stalled(xfer)) 795 sc->sc_transfer.data_error = 1; 796 797 /* try again */ 798 goto tr_setup; 799 } 800 } 801 802 static void 803 ustorage_fs_t_bbb_status_callback(struct usb_xfer *xfer, usb_error_t error) 804 { 805 struct ustorage_fs_softc *sc = usbd_xfer_softc(xfer); 806 807 DPRINTF("\n"); 808 809 switch (USB_GET_STATE(xfer)) { 810 case USB_ST_TRANSFERRED: 811 ustorage_fs_transfer_start(sc, USTORAGE_FS_T_BBB_COMMAND); 812 break; 813 814 case USB_ST_SETUP: 815 tr_setup: 816 USETDW(sc->sc_csw.dCSWSignature, CSWSIGNATURE); 817 USETDW(sc->sc_csw.dCSWDataResidue, sc->sc_transfer.data_rem); 818 819 if (sc->sc_transfer.data_error) { 820 sc->sc_transfer.data_error = 0; 821 usbd_xfer_set_stall(xfer); 822 } 823 824 usbd_xfer_set_frame_data(xfer, 0, &sc->sc_csw, 825 sizeof(sc->sc_csw)); 826 usbd_transfer_submit(xfer); 827 break; 828 829 default: 830 if (error == USB_ERR_CANCELLED) { 831 break; 832 } 833 /* If the pipe is already stalled, don't do another stall */ 834 if (!usbd_xfer_is_stalled(xfer)) 835 sc->sc_transfer.data_error = 1; 836 837 /* try again */ 838 goto tr_setup; 839 } 840 } 841 842 /* SCSI commands that we recognize */ 843 #define SC_FORMAT_UNIT 0x04 844 #define SC_INQUIRY 0x12 845 #define SC_MODE_SELECT_6 0x15 846 #define SC_MODE_SELECT_10 0x55 847 #define SC_MODE_SENSE_6 0x1a 848 #define SC_MODE_SENSE_10 0x5a 849 #define SC_PREVENT_ALLOW_MEDIUM_REMOVAL 0x1e 850 #define SC_READ_6 0x08 851 #define SC_READ_10 0x28 852 #define SC_READ_12 0xa8 853 #define SC_READ_CAPACITY 0x25 854 #define SC_READ_FORMAT_CAPACITIES 0x23 855 #define SC_RELEASE 0x17 856 #define SC_REQUEST_SENSE 0x03 857 #define SC_RESERVE 0x16 858 #define SC_SEND_DIAGNOSTIC 0x1d 859 #define SC_START_STOP_UNIT 0x1b 860 #define SC_SYNCHRONIZE_CACHE 0x35 861 #define SC_TEST_UNIT_READY 0x00 862 #define SC_VERIFY 0x2f 863 #define SC_WRITE_6 0x0a 864 #define SC_WRITE_10 0x2a 865 #define SC_WRITE_12 0xaa 866 867 /* SCSI Sense Key/Additional Sense Code/ASC Qualifier values */ 868 #define SS_NO_SENSE 0 869 #define SS_COMMUNICATION_FAILURE 0x040800 870 #define SS_INVALID_COMMAND 0x052000 871 #define SS_INVALID_FIELD_IN_CDB 0x052400 872 #define SS_LOGICAL_BLOCK_ADDRESS_OUT_OF_RANGE 0x052100 873 #define SS_LOGICAL_UNIT_NOT_SUPPORTED 0x052500 874 #define SS_MEDIUM_NOT_PRESENT 0x023a00 875 #define SS_MEDIUM_REMOVAL_PREVENTED 0x055302 876 #define SS_NOT_READY_TO_READY_TRANSITION 0x062800 877 #define SS_RESET_OCCURRED 0x062900 878 #define SS_SAVING_PARAMETERS_NOT_SUPPORTED 0x053900 879 #define SS_UNRECOVERED_READ_ERROR 0x031100 880 #define SS_WRITE_ERROR 0x030c02 881 #define SS_WRITE_PROTECTED 0x072700 882 883 #define SK(x) ((uint8_t) ((x) >> 16)) /* Sense Key byte, etc. */ 884 #define ASC(x) ((uint8_t) ((x) >> 8)) 885 #define ASCQ(x) ((uint8_t) (x)) 886 887 /* Routines for unaligned data access */ 888 889 static uint16_t 890 get_be16(uint8_t *buf) 891 { 892 return ((uint16_t)buf[0] << 8) | ((uint16_t)buf[1]); 893 } 894 895 static uint32_t 896 get_be32(uint8_t *buf) 897 { 898 return ((uint32_t)buf[0] << 24) | ((uint32_t)buf[1] << 16) | 899 ((uint32_t)buf[2] << 8) | ((uint32_t)buf[3]); 900 } 901 902 static void 903 put_be16(uint8_t *buf, uint16_t val) 904 { 905 buf[0] = val >> 8; 906 buf[1] = val; 907 } 908 909 static void 910 put_be32(uint8_t *buf, uint32_t val) 911 { 912 buf[0] = val >> 24; 913 buf[1] = val >> 16; 914 buf[2] = val >> 8; 915 buf[3] = val & 0xff; 916 } 917 918 /*------------------------------------------------------------------------* 919 * ustorage_fs_verify 920 * 921 * Returns: 922 * 0: Success 923 * Else: Failure 924 *------------------------------------------------------------------------*/ 925 static uint8_t 926 ustorage_fs_verify(struct ustorage_fs_softc *sc) 927 { 928 struct ustorage_fs_lun *currlun = sc->sc_transfer.currlun; 929 uint32_t lba; 930 uint32_t vlen; 931 uint64_t file_offset; 932 uint64_t amount_left; 933 934 /* 935 * Get the starting Logical Block Address 936 */ 937 lba = get_be32(&sc->sc_cmd_data[2]); 938 939 /* 940 * We allow DPO (Disable Page Out = don't save data in the cache) 941 * but we don't implement it. 942 */ 943 if ((sc->sc_cmd_data[1] & ~0x10) != 0) { 944 currlun->sense_data = SS_INVALID_FIELD_IN_CDB; 945 return (1); 946 } 947 vlen = get_be16(&sc->sc_cmd_data[7]); 948 if (vlen == 0) { 949 goto done; 950 } 951 /* No default reply */ 952 953 /* Prepare to carry out the file verify */ 954 amount_left = vlen; 955 amount_left <<= 9; 956 file_offset = lba; 957 file_offset <<= 9; 958 959 /* Range check */ 960 vlen += lba; 961 962 if ((vlen < lba) || 963 (vlen > currlun->num_sectors) || 964 (lba >= currlun->num_sectors)) { 965 currlun->sense_data = SS_LOGICAL_BLOCK_ADDRESS_OUT_OF_RANGE; 966 return (1); 967 } 968 /* XXX TODO: verify that data is readable */ 969 done: 970 return (ustorage_fs_min_len(sc, 0, 0 - 1)); 971 } 972 973 /*------------------------------------------------------------------------* 974 * ustorage_fs_inquiry 975 * 976 * Returns: 977 * 0: Success 978 * Else: Failure 979 *------------------------------------------------------------------------*/ 980 static uint8_t 981 ustorage_fs_inquiry(struct ustorage_fs_softc *sc) 982 { 983 uint8_t *buf = sc->sc_transfer.data_ptr; 984 985 struct ustorage_fs_lun *currlun = sc->sc_transfer.currlun; 986 987 if (!sc->sc_transfer.currlun) { 988 /* Unsupported LUNs are okay */ 989 memset(buf, 0, 36); 990 buf[0] = 0x7f; 991 /* Unsupported, no device - type */ 992 return (ustorage_fs_min_len(sc, 36, 0 - 1)); 993 } 994 memset(buf, 0, 8); 995 /* Non - removable, direct - access device */ 996 if (currlun->removable) 997 buf[1] = 0x80; 998 buf[2] = 2; 999 /* ANSI SCSI level 2 */ 1000 buf[3] = 2; 1001 /* SCSI - 2 INQUIRY data format */ 1002 buf[4] = 31; 1003 /* Additional length */ 1004 /* No special options */ 1005 /* Copy in ID string */ 1006 memcpy(buf + 8, USTORAGE_FS_ID_STRING, 28); 1007 1008 #if (USTORAGE_QDATA_MAX < 36) 1009 #error "(USTORAGE_QDATA_MAX < 36)" 1010 #endif 1011 return (ustorage_fs_min_len(sc, 36, 0 - 1)); 1012 } 1013 1014 /*------------------------------------------------------------------------* 1015 * ustorage_fs_request_sense 1016 * 1017 * Returns: 1018 * 0: Success 1019 * Else: Failure 1020 *------------------------------------------------------------------------*/ 1021 static uint8_t 1022 ustorage_fs_request_sense(struct ustorage_fs_softc *sc) 1023 { 1024 uint8_t *buf = sc->sc_transfer.data_ptr; 1025 struct ustorage_fs_lun *currlun = sc->sc_transfer.currlun; 1026 uint32_t sd; 1027 uint32_t sdinfo; 1028 uint8_t valid; 1029 1030 /* 1031 * From the SCSI-2 spec., section 7.9 (Unit attention condition): 1032 * 1033 * If a REQUEST SENSE command is received from an initiator 1034 * with a pending unit attention condition (before the target 1035 * generates the contingent allegiance condition), then the 1036 * target shall either: 1037 * a) report any pending sense data and preserve the unit 1038 * attention condition on the logical unit, or, 1039 * b) report the unit attention condition, may discard any 1040 * pending sense data, and clear the unit attention 1041 * condition on the logical unit for that initiator. 1042 * 1043 * FSG normally uses option a); enable this code to use option b). 1044 */ 1045 #if 0 1046 if (currlun && currlun->unit_attention_data != SS_NO_SENSE) { 1047 currlun->sense_data = currlun->unit_attention_data; 1048 currlun->unit_attention_data = SS_NO_SENSE; 1049 } 1050 #endif 1051 1052 if (!currlun) { 1053 /* Unsupported LUNs are okay */ 1054 sd = SS_LOGICAL_UNIT_NOT_SUPPORTED; 1055 sdinfo = 0; 1056 valid = 0; 1057 } else { 1058 sd = currlun->sense_data; 1059 sdinfo = currlun->sense_data_info; 1060 valid = currlun->info_valid << 7; 1061 currlun->sense_data = SS_NO_SENSE; 1062 currlun->sense_data_info = 0; 1063 currlun->info_valid = 0; 1064 } 1065 1066 memset(buf, 0, 18); 1067 buf[0] = valid | 0x70; 1068 /* Valid, current error */ 1069 buf[2] = SK(sd); 1070 put_be32(&buf[3], sdinfo); 1071 /* Sense information */ 1072 buf[7] = 18 - 8; 1073 /* Additional sense length */ 1074 buf[12] = ASC(sd); 1075 buf[13] = ASCQ(sd); 1076 1077 #if (USTORAGE_QDATA_MAX < 18) 1078 #error "(USTORAGE_QDATA_MAX < 18)" 1079 #endif 1080 return (ustorage_fs_min_len(sc, 18, 0 - 1)); 1081 } 1082 1083 /*------------------------------------------------------------------------* 1084 * ustorage_fs_read_capacity 1085 * 1086 * Returns: 1087 * 0: Success 1088 * Else: Failure 1089 *------------------------------------------------------------------------*/ 1090 static uint8_t 1091 ustorage_fs_read_capacity(struct ustorage_fs_softc *sc) 1092 { 1093 uint8_t *buf = sc->sc_transfer.data_ptr; 1094 struct ustorage_fs_lun *currlun = sc->sc_transfer.currlun; 1095 uint32_t lba = get_be32(&sc->sc_cmd_data[2]); 1096 uint8_t pmi = sc->sc_cmd_data[8]; 1097 1098 /* Check the PMI and LBA fields */ 1099 if ((pmi > 1) || ((pmi == 0) && (lba != 0))) { 1100 currlun->sense_data = SS_INVALID_FIELD_IN_CDB; 1101 return (1); 1102 } 1103 /* Max logical block */ 1104 put_be32(&buf[0], currlun->num_sectors - 1); 1105 /* Block length */ 1106 put_be32(&buf[4], 512); 1107 1108 #if (USTORAGE_QDATA_MAX < 8) 1109 #error "(USTORAGE_QDATA_MAX < 8)" 1110 #endif 1111 return (ustorage_fs_min_len(sc, 8, 0 - 1)); 1112 } 1113 1114 /*------------------------------------------------------------------------* 1115 * ustorage_fs_mode_sense 1116 * 1117 * Returns: 1118 * 0: Success 1119 * Else: Failure 1120 *------------------------------------------------------------------------*/ 1121 static uint8_t 1122 ustorage_fs_mode_sense(struct ustorage_fs_softc *sc) 1123 { 1124 uint8_t *buf = sc->sc_transfer.data_ptr; 1125 struct ustorage_fs_lun *currlun = sc->sc_transfer.currlun; 1126 uint8_t *buf0; 1127 uint16_t len; 1128 uint16_t limit; 1129 uint8_t mscmnd = sc->sc_cmd_data[0]; 1130 uint8_t pc; 1131 uint8_t page_code; 1132 uint8_t changeable_values; 1133 uint8_t all_pages; 1134 1135 buf0 = buf; 1136 1137 if ((sc->sc_cmd_data[1] & ~0x08) != 0) { 1138 /* Mask away DBD */ 1139 currlun->sense_data = SS_INVALID_FIELD_IN_CDB; 1140 return (1); 1141 } 1142 pc = sc->sc_cmd_data[2] >> 6; 1143 page_code = sc->sc_cmd_data[2] & 0x3f; 1144 if (pc == 3) { 1145 currlun->sense_data = SS_SAVING_PARAMETERS_NOT_SUPPORTED; 1146 return (1); 1147 } 1148 changeable_values = (pc == 1); 1149 all_pages = (page_code == 0x3f); 1150 1151 /* 1152 * Write the mode parameter header. Fixed values are: default 1153 * medium type, no cache control (DPOFUA), and no block descriptors. 1154 * The only variable value is the WriteProtect bit. We will fill in 1155 * the mode data length later. 1156 */ 1157 memset(buf, 0, 8); 1158 if (mscmnd == SC_MODE_SENSE_6) { 1159 buf[2] = (currlun->read_only ? 0x80 : 0x00); 1160 /* WP, DPOFUA */ 1161 buf += 4; 1162 limit = 255; 1163 } else { 1164 /* SC_MODE_SENSE_10 */ 1165 buf[3] = (currlun->read_only ? 0x80 : 0x00); 1166 /* WP, DPOFUA */ 1167 buf += 8; 1168 limit = 65535; 1169 /* Should really be mod_data.buflen */ 1170 } 1171 1172 /* No block descriptors */ 1173 1174 /* 1175 * The mode pages, in numerical order. 1176 */ 1177 if ((page_code == 0x08) || all_pages) { 1178 buf[0] = 0x08; 1179 /* Page code */ 1180 buf[1] = 10; 1181 /* Page length */ 1182 memset(buf + 2, 0, 10); 1183 /* None of the fields are changeable */ 1184 1185 if (!changeable_values) { 1186 buf[2] = 0x04; 1187 /* Write cache enable, */ 1188 /* Read cache not disabled */ 1189 /* No cache retention priorities */ 1190 put_be16(&buf[4], 0xffff); 1191 /* Don 't disable prefetch */ 1192 /* Minimum prefetch = 0 */ 1193 put_be16(&buf[8], 0xffff); 1194 /* Maximum prefetch */ 1195 put_be16(&buf[10], 0xffff); 1196 /* Maximum prefetch ceiling */ 1197 } 1198 buf += 12; 1199 } 1200 /* 1201 * Check that a valid page was requested and the mode data length 1202 * isn't too long. 1203 */ 1204 len = buf - buf0; 1205 if (len > limit) { 1206 currlun->sense_data = SS_INVALID_FIELD_IN_CDB; 1207 return (1); 1208 } 1209 /* Store the mode data length */ 1210 if (mscmnd == SC_MODE_SENSE_6) 1211 buf0[0] = len - 1; 1212 else 1213 put_be16(buf0, len - 2); 1214 1215 #if (USTORAGE_QDATA_MAX < 24) 1216 #error "(USTORAGE_QDATA_MAX < 24)" 1217 #endif 1218 return (ustorage_fs_min_len(sc, len, 0 - 1)); 1219 } 1220 1221 /*------------------------------------------------------------------------* 1222 * ustorage_fs_start_stop 1223 * 1224 * Returns: 1225 * 0: Success 1226 * Else: Failure 1227 *------------------------------------------------------------------------*/ 1228 static uint8_t 1229 ustorage_fs_start_stop(struct ustorage_fs_softc *sc) 1230 { 1231 struct ustorage_fs_lun *currlun = sc->sc_transfer.currlun; 1232 uint8_t loej; 1233 uint8_t start; 1234 uint8_t immed; 1235 1236 if (!currlun->removable) { 1237 currlun->sense_data = SS_INVALID_COMMAND; 1238 return (1); 1239 } 1240 immed = sc->sc_cmd_data[1] & 0x01; 1241 loej = sc->sc_cmd_data[4] & 0x02; 1242 start = sc->sc_cmd_data[4] & 0x01; 1243 1244 if (immed || loej || start) { 1245 /* compile fix */ 1246 } 1247 return (0); 1248 } 1249 1250 /*------------------------------------------------------------------------* 1251 * ustorage_fs_prevent_allow 1252 * 1253 * Returns: 1254 * 0: Success 1255 * Else: Failure 1256 *------------------------------------------------------------------------*/ 1257 static uint8_t 1258 ustorage_fs_prevent_allow(struct ustorage_fs_softc *sc) 1259 { 1260 struct ustorage_fs_lun *currlun = sc->sc_transfer.currlun; 1261 uint8_t prevent; 1262 1263 if (!currlun->removable) { 1264 currlun->sense_data = SS_INVALID_COMMAND; 1265 return (1); 1266 } 1267 prevent = sc->sc_cmd_data[4] & 0x01; 1268 if ((sc->sc_cmd_data[4] & ~0x01) != 0) { 1269 /* Mask away Prevent */ 1270 currlun->sense_data = SS_INVALID_FIELD_IN_CDB; 1271 return (1); 1272 } 1273 if (currlun->prevent_medium_removal && !prevent) { 1274 //fsync_sub(currlun); 1275 } 1276 currlun->prevent_medium_removal = prevent; 1277 return (0); 1278 } 1279 1280 /*------------------------------------------------------------------------* 1281 * ustorage_fs_read_format_capacities 1282 * 1283 * Returns: 1284 * 0: Success 1285 * Else: Failure 1286 *------------------------------------------------------------------------*/ 1287 static uint8_t 1288 ustorage_fs_read_format_capacities(struct ustorage_fs_softc *sc) 1289 { 1290 uint8_t *buf = sc->sc_transfer.data_ptr; 1291 struct ustorage_fs_lun *currlun = sc->sc_transfer.currlun; 1292 1293 buf[0] = buf[1] = buf[2] = 0; 1294 buf[3] = 8; 1295 /* Only the Current / Maximum Capacity Descriptor */ 1296 buf += 4; 1297 1298 /* Number of blocks */ 1299 put_be32(&buf[0], currlun->num_sectors); 1300 /* Block length */ 1301 put_be32(&buf[4], 512); 1302 /* Current capacity */ 1303 buf[4] = 0x02; 1304 1305 #if (USTORAGE_QDATA_MAX < 12) 1306 #error "(USTORAGE_QDATA_MAX < 12)" 1307 #endif 1308 return (ustorage_fs_min_len(sc, 12, 0 - 1)); 1309 } 1310 1311 /*------------------------------------------------------------------------* 1312 * ustorage_fs_mode_select 1313 * 1314 * Return values: 1315 * 0: Success 1316 * Else: Failure 1317 *------------------------------------------------------------------------*/ 1318 static uint8_t 1319 ustorage_fs_mode_select(struct ustorage_fs_softc *sc) 1320 { 1321 struct ustorage_fs_lun *currlun = sc->sc_transfer.currlun; 1322 1323 /* We don't support MODE SELECT */ 1324 currlun->sense_data = SS_INVALID_COMMAND; 1325 return (1); 1326 } 1327 1328 /*------------------------------------------------------------------------* 1329 * ustorage_fs_synchronize_cache 1330 * 1331 * Return values: 1332 * 0: Success 1333 * Else: Failure 1334 *------------------------------------------------------------------------*/ 1335 static uint8_t 1336 ustorage_fs_synchronize_cache(struct ustorage_fs_softc *sc) 1337 { 1338 #if 0 1339 struct ustorage_fs_lun *currlun = sc->sc_transfer.currlun; 1340 uint8_t rc; 1341 1342 /* 1343 * We ignore the requested LBA and write out all dirty data buffers. 1344 */ 1345 rc = 0; 1346 if (rc) { 1347 currlun->sense_data = SS_WRITE_ERROR; 1348 } 1349 #endif 1350 return (0); 1351 } 1352 1353 /*------------------------------------------------------------------------* 1354 * ustorage_fs_read - read data from disk 1355 * 1356 * Return values: 1357 * 0: Success 1358 * Else: Failure 1359 *------------------------------------------------------------------------*/ 1360 static uint8_t 1361 ustorage_fs_read(struct ustorage_fs_softc *sc) 1362 { 1363 struct ustorage_fs_lun *currlun = sc->sc_transfer.currlun; 1364 uint64_t file_offset; 1365 uint32_t lba; 1366 uint32_t len; 1367 1368 /* 1369 * Get the starting Logical Block Address and check that it's not 1370 * too big 1371 */ 1372 if (sc->sc_cmd_data[0] == SC_READ_6) { 1373 lba = (((uint32_t)sc->sc_cmd_data[1]) << 16) | 1374 get_be16(&sc->sc_cmd_data[2]); 1375 } else { 1376 lba = get_be32(&sc->sc_cmd_data[2]); 1377 1378 /* 1379 * We allow DPO (Disable Page Out = don't save data in the 1380 * cache) and FUA (Force Unit Access = don't read from the 1381 * cache), but we don't implement them. 1382 */ 1383 if ((sc->sc_cmd_data[1] & ~0x18) != 0) { 1384 currlun->sense_data = SS_INVALID_FIELD_IN_CDB; 1385 return (1); 1386 } 1387 } 1388 len = sc->sc_transfer.data_rem >> 9; 1389 len += lba; 1390 1391 if ((len < lba) || 1392 (len > currlun->num_sectors) || 1393 (lba >= currlun->num_sectors)) { 1394 currlun->sense_data = SS_LOGICAL_BLOCK_ADDRESS_OUT_OF_RANGE; 1395 return (1); 1396 } 1397 file_offset = lba; 1398 file_offset <<= 9; 1399 1400 sc->sc_transfer.data_ptr = currlun->memory_image + file_offset; 1401 1402 return (0); 1403 } 1404 1405 /*------------------------------------------------------------------------* 1406 * ustorage_fs_write - write data to disk 1407 * 1408 * Return values: 1409 * 0: Success 1410 * Else: Failure 1411 *------------------------------------------------------------------------*/ 1412 static uint8_t 1413 ustorage_fs_write(struct ustorage_fs_softc *sc) 1414 { 1415 struct ustorage_fs_lun *currlun = sc->sc_transfer.currlun; 1416 uint64_t file_offset; 1417 uint32_t lba; 1418 uint32_t len; 1419 1420 if (currlun->read_only) { 1421 currlun->sense_data = SS_WRITE_PROTECTED; 1422 return (1); 1423 } 1424 /* XXX clear SYNC */ 1425 1426 /* 1427 * Get the starting Logical Block Address and check that it's not 1428 * too big. 1429 */ 1430 if (sc->sc_cmd_data[0] == SC_WRITE_6) 1431 lba = (((uint32_t)sc->sc_cmd_data[1]) << 16) | 1432 get_be16(&sc->sc_cmd_data[2]); 1433 else { 1434 lba = get_be32(&sc->sc_cmd_data[2]); 1435 1436 /* 1437 * We allow DPO (Disable Page Out = don't save data in the 1438 * cache) and FUA (Force Unit Access = write directly to the 1439 * medium). We don't implement DPO; we implement FUA by 1440 * performing synchronous output. 1441 */ 1442 if ((sc->sc_cmd_data[1] & ~0x18) != 0) { 1443 currlun->sense_data = SS_INVALID_FIELD_IN_CDB; 1444 return (1); 1445 } 1446 if (sc->sc_cmd_data[1] & 0x08) { 1447 /* FUA */ 1448 /* XXX set SYNC flag here */ 1449 } 1450 } 1451 1452 len = sc->sc_transfer.data_rem >> 9; 1453 len += lba; 1454 1455 if ((len < lba) || 1456 (len > currlun->num_sectors) || 1457 (lba >= currlun->num_sectors)) { 1458 currlun->sense_data = SS_LOGICAL_BLOCK_ADDRESS_OUT_OF_RANGE; 1459 return (1); 1460 } 1461 file_offset = lba; 1462 file_offset <<= 9; 1463 1464 sc->sc_transfer.data_ptr = currlun->memory_image + file_offset; 1465 1466 return (0); 1467 } 1468 1469 /*------------------------------------------------------------------------* 1470 * ustorage_fs_min_len 1471 * 1472 * Return values: 1473 * 0: Success 1474 * Else: Failure 1475 *------------------------------------------------------------------------*/ 1476 static uint8_t 1477 ustorage_fs_min_len(struct ustorage_fs_softc *sc, uint32_t len, uint32_t mask) 1478 { 1479 if (len != sc->sc_transfer.data_rem) { 1480 1481 if (sc->sc_transfer.cbw_dir == DIR_READ) { 1482 /* 1483 * there must be something wrong about this SCSI 1484 * command 1485 */ 1486 sc->sc_csw.bCSWStatus = CSWSTATUS_PHASE; 1487 return (1); 1488 } 1489 /* compute the minimum length */ 1490 1491 if (sc->sc_transfer.data_rem > len) { 1492 /* data ends prematurely */ 1493 sc->sc_transfer.data_rem = len; 1494 sc->sc_transfer.data_short = 1; 1495 } 1496 /* check length alignment */ 1497 1498 if (sc->sc_transfer.data_rem & ~mask) { 1499 /* data ends prematurely */ 1500 sc->sc_transfer.data_rem &= mask; 1501 sc->sc_transfer.data_short = 1; 1502 } 1503 } 1504 return (0); 1505 } 1506 1507 /*------------------------------------------------------------------------* 1508 * ustorage_fs_check_cmd - check command routine 1509 * 1510 * Check whether the command is properly formed and whether its data 1511 * size and direction agree with the values we already have. 1512 * 1513 * Return values: 1514 * 0: Success 1515 * Else: Failure 1516 *------------------------------------------------------------------------*/ 1517 static uint8_t 1518 ustorage_fs_check_cmd(struct ustorage_fs_softc *sc, uint8_t min_cmd_size, 1519 uint16_t mask, uint8_t needs_medium) 1520 { 1521 struct ustorage_fs_lun *currlun; 1522 uint8_t lun = (sc->sc_cmd_data[1] >> 5); 1523 uint8_t i; 1524 1525 /* Verify the length of the command itself */ 1526 if (min_cmd_size > sc->sc_transfer.cmd_len) { 1527 DPRINTF("%u > %u\n", 1528 min_cmd_size, sc->sc_transfer.cmd_len); 1529 sc->sc_csw.bCSWStatus = CSWSTATUS_PHASE; 1530 return (1); 1531 } 1532 /* Mask away the LUN */ 1533 sc->sc_cmd_data[1] &= 0x1f; 1534 1535 /* Check if LUN is correct */ 1536 if (lun != sc->sc_transfer.lun) { 1537 1538 } 1539 /* Check the LUN */ 1540 if (sc->sc_transfer.lun <= sc->sc_last_lun) { 1541 sc->sc_transfer.currlun = currlun = 1542 sc->sc_lun + sc->sc_transfer.lun; 1543 if (sc->sc_cmd_data[0] != SC_REQUEST_SENSE) { 1544 currlun->sense_data = SS_NO_SENSE; 1545 currlun->sense_data_info = 0; 1546 currlun->info_valid = 0; 1547 } 1548 /* 1549 * If a unit attention condition exists, only INQUIRY 1550 * and REQUEST SENSE commands are allowed. Anything 1551 * else must fail! 1552 */ 1553 if ((currlun->unit_attention_data != SS_NO_SENSE) && 1554 (sc->sc_cmd_data[0] != SC_INQUIRY) && 1555 (sc->sc_cmd_data[0] != SC_REQUEST_SENSE)) { 1556 currlun->sense_data = currlun->unit_attention_data; 1557 currlun->unit_attention_data = SS_NO_SENSE; 1558 return (1); 1559 } 1560 } else { 1561 sc->sc_transfer.currlun = currlun = NULL; 1562 1563 /* 1564 * INQUIRY and REQUEST SENSE commands are explicitly allowed 1565 * to use unsupported LUNs; all others may not. 1566 */ 1567 if ((sc->sc_cmd_data[0] != SC_INQUIRY) && 1568 (sc->sc_cmd_data[0] != SC_REQUEST_SENSE)) { 1569 return (1); 1570 } 1571 } 1572 1573 /* 1574 * Check that only command bytes listed in the mask are 1575 * non-zero. 1576 */ 1577 for (i = 0; i != min_cmd_size; i++) { 1578 if (sc->sc_cmd_data[i] && !(mask & (1UL << i))) { 1579 if (currlun) { 1580 currlun->sense_data = SS_INVALID_FIELD_IN_CDB; 1581 } 1582 return (1); 1583 } 1584 } 1585 1586 /* 1587 * If the medium isn't mounted and the command needs to access 1588 * it, return an error. 1589 */ 1590 if (currlun && (!currlun->memory_image) && needs_medium) { 1591 currlun->sense_data = SS_MEDIUM_NOT_PRESENT; 1592 return (1); 1593 } 1594 return (0); 1595 } 1596 1597 /*------------------------------------------------------------------------* 1598 * ustorage_fs_do_cmd - do command 1599 * 1600 * Return values: 1601 * 0: Success 1602 * Else: Failure 1603 *------------------------------------------------------------------------*/ 1604 static uint8_t 1605 ustorage_fs_do_cmd(struct ustorage_fs_softc *sc) 1606 { 1607 uint8_t error = 1; 1608 uint8_t i; 1609 uint32_t temp; 1610 const uint32_t mask9 = (0xFFFFFFFFUL >> 9) << 9; 1611 1612 /* set default data transfer pointer */ 1613 sc->sc_transfer.data_ptr = sc->sc_qdata; 1614 1615 DPRINTF("cmd_data[0]=0x%02x, data_rem=0x%08x\n", 1616 sc->sc_cmd_data[0], sc->sc_transfer.data_rem); 1617 1618 switch (sc->sc_cmd_data[0]) { 1619 case SC_INQUIRY: 1620 sc->sc_transfer.cmd_dir = DIR_WRITE; 1621 error = ustorage_fs_min_len(sc, sc->sc_cmd_data[4], 0 - 1); 1622 if (error) { 1623 break; 1624 } 1625 error = ustorage_fs_check_cmd(sc, 6, 1626 (1UL << 4) | 1, 0); 1627 if (error) { 1628 break; 1629 } 1630 error = ustorage_fs_inquiry(sc); 1631 1632 break; 1633 1634 case SC_MODE_SELECT_6: 1635 sc->sc_transfer.cmd_dir = DIR_READ; 1636 error = ustorage_fs_min_len(sc, sc->sc_cmd_data[4], 0 - 1); 1637 if (error) { 1638 break; 1639 } 1640 error = ustorage_fs_check_cmd(sc, 6, 1641 (1UL << 1) | (1UL << 4) | 1, 0); 1642 if (error) { 1643 break; 1644 } 1645 error = ustorage_fs_mode_select(sc); 1646 1647 break; 1648 1649 case SC_MODE_SELECT_10: 1650 sc->sc_transfer.cmd_dir = DIR_READ; 1651 error = ustorage_fs_min_len(sc, 1652 get_be16(&sc->sc_cmd_data[7]), 0 - 1); 1653 if (error) { 1654 break; 1655 } 1656 error = ustorage_fs_check_cmd(sc, 10, 1657 (1UL << 1) | (3UL << 7) | 1, 0); 1658 if (error) { 1659 break; 1660 } 1661 error = ustorage_fs_mode_select(sc); 1662 1663 break; 1664 1665 case SC_MODE_SENSE_6: 1666 sc->sc_transfer.cmd_dir = DIR_WRITE; 1667 error = ustorage_fs_min_len(sc, sc->sc_cmd_data[4], 0 - 1); 1668 if (error) { 1669 break; 1670 } 1671 error = ustorage_fs_check_cmd(sc, 6, 1672 (1UL << 1) | (1UL << 2) | (1UL << 4) | 1, 0); 1673 if (error) { 1674 break; 1675 } 1676 error = ustorage_fs_mode_sense(sc); 1677 1678 break; 1679 1680 case SC_MODE_SENSE_10: 1681 sc->sc_transfer.cmd_dir = DIR_WRITE; 1682 error = ustorage_fs_min_len(sc, 1683 get_be16(&sc->sc_cmd_data[7]), 0 - 1); 1684 if (error) { 1685 break; 1686 } 1687 error = ustorage_fs_check_cmd(sc, 10, 1688 (1UL << 1) | (1UL << 2) | (3UL << 7) | 1, 0); 1689 if (error) { 1690 break; 1691 } 1692 error = ustorage_fs_mode_sense(sc); 1693 1694 break; 1695 1696 case SC_PREVENT_ALLOW_MEDIUM_REMOVAL: 1697 error = ustorage_fs_min_len(sc, 0, 0 - 1); 1698 if (error) { 1699 break; 1700 } 1701 error = ustorage_fs_check_cmd(sc, 6, 1702 (1UL << 4) | 1, 0); 1703 if (error) { 1704 break; 1705 } 1706 error = ustorage_fs_prevent_allow(sc); 1707 1708 break; 1709 1710 case SC_READ_6: 1711 i = sc->sc_cmd_data[4]; 1712 sc->sc_transfer.cmd_dir = DIR_WRITE; 1713 temp = ((i == 0) ? 256UL : i); 1714 error = ustorage_fs_min_len(sc, temp << 9, mask9); 1715 if (error) { 1716 break; 1717 } 1718 error = ustorage_fs_check_cmd(sc, 6, 1719 (7UL << 1) | (1UL << 4) | 1, 1); 1720 if (error) { 1721 break; 1722 } 1723 error = ustorage_fs_read(sc); 1724 1725 break; 1726 1727 case SC_READ_10: 1728 sc->sc_transfer.cmd_dir = DIR_WRITE; 1729 temp = get_be16(&sc->sc_cmd_data[7]); 1730 error = ustorage_fs_min_len(sc, temp << 9, mask9); 1731 if (error) { 1732 break; 1733 } 1734 error = ustorage_fs_check_cmd(sc, 10, 1735 (1UL << 1) | (0xfUL << 2) | (3UL << 7) | 1, 1); 1736 if (error) { 1737 break; 1738 } 1739 error = ustorage_fs_read(sc); 1740 1741 break; 1742 1743 case SC_READ_12: 1744 sc->sc_transfer.cmd_dir = DIR_WRITE; 1745 temp = get_be32(&sc->sc_cmd_data[6]); 1746 if (temp >= (1UL << (32 - 9))) { 1747 /* numerical overflow */ 1748 sc->sc_csw.bCSWStatus = CSWSTATUS_FAILED; 1749 error = 1; 1750 break; 1751 } 1752 error = ustorage_fs_min_len(sc, temp << 9, mask9); 1753 if (error) { 1754 break; 1755 } 1756 error = ustorage_fs_check_cmd(sc, 12, 1757 (1UL << 1) | (0xfUL << 2) | (0xfUL << 6) | 1, 1); 1758 if (error) { 1759 break; 1760 } 1761 error = ustorage_fs_read(sc); 1762 1763 break; 1764 1765 case SC_READ_CAPACITY: 1766 sc->sc_transfer.cmd_dir = DIR_WRITE; 1767 error = ustorage_fs_check_cmd(sc, 10, 1768 (0xfUL << 2) | (1UL << 8) | 1, 1); 1769 if (error) { 1770 break; 1771 } 1772 error = ustorage_fs_read_capacity(sc); 1773 1774 break; 1775 1776 case SC_READ_FORMAT_CAPACITIES: 1777 sc->sc_transfer.cmd_dir = DIR_WRITE; 1778 error = ustorage_fs_min_len(sc, 1779 get_be16(&sc->sc_cmd_data[7]), 0 - 1); 1780 if (error) { 1781 break; 1782 } 1783 error = ustorage_fs_check_cmd(sc, 10, 1784 (3UL << 7) | 1, 1); 1785 if (error) { 1786 break; 1787 } 1788 error = ustorage_fs_read_format_capacities(sc); 1789 1790 break; 1791 1792 case SC_REQUEST_SENSE: 1793 sc->sc_transfer.cmd_dir = DIR_WRITE; 1794 error = ustorage_fs_min_len(sc, sc->sc_cmd_data[4], 0 - 1); 1795 if (error) { 1796 break; 1797 } 1798 error = ustorage_fs_check_cmd(sc, 6, 1799 (1UL << 4) | 1, 0); 1800 if (error) { 1801 break; 1802 } 1803 error = ustorage_fs_request_sense(sc); 1804 1805 break; 1806 1807 case SC_START_STOP_UNIT: 1808 error = ustorage_fs_min_len(sc, 0, 0 - 1); 1809 if (error) { 1810 break; 1811 } 1812 error = ustorage_fs_check_cmd(sc, 6, 1813 (1UL << 1) | (1UL << 4) | 1, 0); 1814 if (error) { 1815 break; 1816 } 1817 error = ustorage_fs_start_stop(sc); 1818 1819 break; 1820 1821 case SC_SYNCHRONIZE_CACHE: 1822 error = ustorage_fs_min_len(sc, 0, 0 - 1); 1823 if (error) { 1824 break; 1825 } 1826 error = ustorage_fs_check_cmd(sc, 10, 1827 (0xfUL << 2) | (3UL << 7) | 1, 1); 1828 if (error) { 1829 break; 1830 } 1831 error = ustorage_fs_synchronize_cache(sc); 1832 1833 break; 1834 1835 case SC_TEST_UNIT_READY: 1836 error = ustorage_fs_min_len(sc, 0, 0 - 1); 1837 if (error) { 1838 break; 1839 } 1840 error = ustorage_fs_check_cmd(sc, 6, 1841 0 | 1, 1); 1842 break; 1843 1844 /* 1845 * Although optional, this command is used by MS-Windows. 1846 * We support a minimal version: BytChk must be 0. 1847 */ 1848 case SC_VERIFY: 1849 error = ustorage_fs_min_len(sc, 0, 0 - 1); 1850 if (error) { 1851 break; 1852 } 1853 error = ustorage_fs_check_cmd(sc, 10, 1854 (1UL << 1) | (0xfUL << 2) | (3UL << 7) | 1, 1); 1855 if (error) { 1856 break; 1857 } 1858 error = ustorage_fs_verify(sc); 1859 1860 break; 1861 1862 case SC_WRITE_6: 1863 i = sc->sc_cmd_data[4]; 1864 sc->sc_transfer.cmd_dir = DIR_READ; 1865 temp = ((i == 0) ? 256UL : i); 1866 error = ustorage_fs_min_len(sc, temp << 9, mask9); 1867 if (error) { 1868 break; 1869 } 1870 error = ustorage_fs_check_cmd(sc, 6, 1871 (7UL << 1) | (1UL << 4) | 1, 1); 1872 if (error) { 1873 break; 1874 } 1875 error = ustorage_fs_write(sc); 1876 1877 break; 1878 1879 case SC_WRITE_10: 1880 sc->sc_transfer.cmd_dir = DIR_READ; 1881 temp = get_be16(&sc->sc_cmd_data[7]); 1882 error = ustorage_fs_min_len(sc, temp << 9, mask9); 1883 if (error) { 1884 break; 1885 } 1886 error = ustorage_fs_check_cmd(sc, 10, 1887 (1UL << 1) | (0xfUL << 2) | (3UL << 7) | 1, 1); 1888 if (error) { 1889 break; 1890 } 1891 error = ustorage_fs_write(sc); 1892 1893 break; 1894 1895 case SC_WRITE_12: 1896 sc->sc_transfer.cmd_dir = DIR_READ; 1897 temp = get_be32(&sc->sc_cmd_data[6]); 1898 if (temp > (mask9 >> 9)) { 1899 /* numerical overflow */ 1900 sc->sc_csw.bCSWStatus = CSWSTATUS_FAILED; 1901 error = 1; 1902 break; 1903 } 1904 error = ustorage_fs_min_len(sc, temp << 9, mask9); 1905 if (error) { 1906 break; 1907 } 1908 error = ustorage_fs_check_cmd(sc, 12, 1909 (1UL << 1) | (0xfUL << 2) | (0xfUL << 6) | 1, 1); 1910 if (error) { 1911 break; 1912 } 1913 error = ustorage_fs_write(sc); 1914 1915 break; 1916 1917 /* 1918 * Some mandatory commands that we recognize but don't 1919 * implement. They don't mean much in this setting. 1920 * It's left as an exercise for anyone interested to 1921 * implement RESERVE and RELEASE in terms of Posix 1922 * locks. 1923 */ 1924 case SC_FORMAT_UNIT: 1925 case SC_RELEASE: 1926 case SC_RESERVE: 1927 case SC_SEND_DIAGNOSTIC: 1928 /* Fallthrough */ 1929 1930 default: 1931 error = ustorage_fs_min_len(sc, 0, 0 - 1); 1932 if (error) { 1933 break; 1934 } 1935 error = ustorage_fs_check_cmd(sc, sc->sc_transfer.cmd_len, 1936 0xff, 0); 1937 if (error) { 1938 break; 1939 } 1940 sc->sc_transfer.currlun->sense_data = 1941 SS_INVALID_COMMAND; 1942 error = 1; 1943 1944 break; 1945 } 1946 return (error); 1947 } 1948