add tud_msc_inquiry2_cb() for full inquiry response
This commit is contained in:
		| @@ -116,18 +116,20 @@ uint8_t msc_disk[DISK_BLOCK_NUM][DISK_BLOCK_SIZE] = { | |||||||
|   README_CONTENTS |   README_CONTENTS | ||||||
| }; | }; | ||||||
|  |  | ||||||
| // Invoked when received SCSI_CMD_INQUIRY | // Invoked when received SCSI_CMD_INQUIRY, v2 with full inquiry response | ||||||
| // Application fill vendor id, product id and revision with string up to 8, 16, 4 characters respectively | // Some inquiry_resp's fields are already filled with default values, application can update them | ||||||
| void tud_msc_inquiry_cb(uint8_t lun, uint8_t vendor_id[8], uint8_t product_id[16], uint8_t product_rev[4]) { | // Return length of inquiry response, typically sizeof(scsi_inquiry_resp_t) (36 bytes), can be longer if included vendor data. | ||||||
|  | uint32_t tud_msc_inquiry2_cb(uint8_t lun, scsi_inquiry_resp_t* inquiry_resp) { | ||||||
|   (void) lun; |   (void) lun; | ||||||
|  |  | ||||||
|   const char vid[] = "TinyUSB"; |   const char vid[] = "TinyUSB"; | ||||||
|   const char pid[] = "Mass Storage"; |   const char pid[] = "Mass Storage"; | ||||||
|   const char rev[] = "1.0"; |   const char rev[] = "1.0"; | ||||||
|  |  | ||||||
|   memcpy(vendor_id, vid, strlen(vid)); |   memcpy(inquiry_resp->vendor_id, vid, strlen(vid)); | ||||||
|   memcpy(product_id, pid, strlen(pid)); |   memcpy(inquiry_resp->product_id, pid, strlen(pid)); | ||||||
|   memcpy(product_rev, rev, strlen(rev)); |   memcpy(inquiry_resp->product_rev, rev, strlen(rev)); | ||||||
|  |  | ||||||
|  |   return sizeof(scsi_inquiry_resp_t); // 36 bytes | ||||||
| } | } | ||||||
|  |  | ||||||
| // Invoked when received Test Unit Ready command. | // Invoked when received Test Unit Ready command. | ||||||
|   | |||||||
| @@ -188,16 +188,20 @@ static void io_task(void *params) { | |||||||
| void msc_disk_init() {} | void msc_disk_init() {} | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| // Invoked when received SCSI_CMD_INQUIRY | // Invoked when received SCSI_CMD_INQUIRY, v2 with full inquiry response | ||||||
| // Application fill vendor id, product id and revision with string up to 8, 16, 4 characters respectively | // Some inquiry_resp's fields are already filled with default values, application can update them | ||||||
| void tud_msc_inquiry_cb(uint8_t lun, uint8_t vendor_id[8], uint8_t product_id[16], uint8_t product_rev[4]) { | // Return length of inquiry response, typically sizeof(scsi_inquiry_resp_t) (36 bytes), can be longer if included vendor data. | ||||||
|  | uint32_t tud_msc_inquiry2_cb(uint8_t lun, scsi_inquiry_resp_t* inquiry_resp) { | ||||||
|   (void) lun; |   (void) lun; | ||||||
|   const char vid[] = "TinyUSB"; |   const char vid[] = "TinyUSB"; | ||||||
|   const char pid[] = "Mass Storage"; |   const char pid[] = "Mass Storage"; | ||||||
|   const char rev[] = "1.0"; |   const char rev[] = "1.0"; | ||||||
|   memcpy(vendor_id  , vid, strlen(vid)); |  | ||||||
|   memcpy(product_id , pid, strlen(pid)); |   memcpy(inquiry_resp->vendor_id, vid, strlen(vid)); | ||||||
|   memcpy(product_rev, rev, strlen(rev)); |   memcpy(inquiry_resp->product_id, pid, strlen(pid)); | ||||||
|  |   memcpy(inquiry_resp->product_rev, rev, strlen(rev)); | ||||||
|  |  | ||||||
|  |   return sizeof(scsi_inquiry_resp_t); // 36 bytes | ||||||
| } | } | ||||||
|  |  | ||||||
| // Invoked when received Test Unit Ready command. | // Invoked when received Test Unit Ready command. | ||||||
|   | |||||||
| @@ -116,19 +116,20 @@ uint8_t msc_disk[DISK_BLOCK_NUM][DISK_BLOCK_SIZE] = | |||||||
|   README_CONTENTS |   README_CONTENTS | ||||||
| }; | }; | ||||||
|  |  | ||||||
| // Invoked when received SCSI_CMD_INQUIRY | // Invoked when received SCSI_CMD_INQUIRY, v2 with full inquiry response | ||||||
| // Application fill vendor id, product id and revision with string up to 8, 16, 4 characters respectively | // Some inquiry_resp's fields are already filled with default values, application can update them | ||||||
| void tud_msc_inquiry_cb(uint8_t lun, uint8_t vendor_id[8], uint8_t product_id[16], uint8_t product_rev[4]) | // Return length of inquiry response, typically sizeof(scsi_inquiry_resp_t) (36 bytes), can be longer if included vendor data. | ||||||
| { | uint32_t tud_msc_inquiry2_cb(uint8_t lun, scsi_inquiry_resp_t* inquiry_resp) { | ||||||
|   (void) lun; |   (void) lun; | ||||||
|  |  | ||||||
|   const char vid[] = "TinyUSB"; |   const char vid[] = "TinyUSB"; | ||||||
|   const char pid[] = "Mass Storage"; |   const char pid[] = "Mass Storage"; | ||||||
|   const char rev[] = "1.0"; |   const char rev[] = "1.0"; | ||||||
|  |  | ||||||
|   memcpy(vendor_id  , vid, strlen(vid)); |   memcpy(inquiry_resp->vendor_id, vid, strlen(vid)); | ||||||
|   memcpy(product_id , pid, strlen(pid)); |   memcpy(inquiry_resp->product_id, pid, strlen(pid)); | ||||||
|   memcpy(product_rev, rev, strlen(rev)); |   memcpy(inquiry_resp->product_rev, rev, strlen(rev)); | ||||||
|  |  | ||||||
|  |   return sizeof(scsi_inquiry_resp_t); // 36 bytes | ||||||
| } | } | ||||||
|  |  | ||||||
| // Invoked when received Test Unit Ready command. | // Invoked when received Test Unit Ready command. | ||||||
|   | |||||||
| @@ -207,18 +207,20 @@ uint8_t tud_msc_get_maxlun_cb(void) { | |||||||
|   return 2; // dual LUN |   return 2; // dual LUN | ||||||
| } | } | ||||||
|  |  | ||||||
| // Invoked when received SCSI_CMD_INQUIRY | // Invoked when received SCSI_CMD_INQUIRY, v2 with full inquiry response | ||||||
| // Application fill vendor id, product id and revision with string up to 8, 16, 4 characters respectively | // Some inquiry_resp's fields are already filled with default values, application can update them | ||||||
| void tud_msc_inquiry_cb(uint8_t lun, uint8_t vendor_id[8], uint8_t product_id[16], uint8_t product_rev[4]) { | // Return length of inquiry response, typically sizeof(scsi_inquiry_resp_t) (36 bytes), can be longer if included vendor data. | ||||||
|   (void) lun; // use same ID for both LUNs | uint32_t tud_msc_inquiry2_cb(uint8_t lun, scsi_inquiry_resp_t* inquiry_resp) { | ||||||
|  |   (void) lun; | ||||||
|   const char vid[] = "TinyUSB"; |   const char vid[] = "TinyUSB"; | ||||||
|   const char pid[] = "Mass Storage"; |   const char pid[] = "Mass Storage"; | ||||||
|   const char rev[] = "1.0"; |   const char rev[] = "1.0"; | ||||||
|  |  | ||||||
|   memcpy(vendor_id  , vid, strlen(vid)); |   memcpy(inquiry_resp->vendor_id, vid, strlen(vid)); | ||||||
|   memcpy(product_id , pid, strlen(pid)); |   memcpy(inquiry_resp->product_id, pid, strlen(pid)); | ||||||
|   memcpy(product_rev, rev, strlen(rev)); |   memcpy(inquiry_resp->product_rev, rev, strlen(rev)); | ||||||
|  |  | ||||||
|  |   return sizeof(scsi_inquiry_resp_t); // 36 bytes | ||||||
| } | } | ||||||
|  |  | ||||||
| // Invoked when received Test Unit Ready command. | // Invoked when received Test Unit Ready command. | ||||||
|   | |||||||
| @@ -108,8 +108,7 @@ TU_VERIFY_STATIC(sizeof(msc_csw_t) == 13, "size is not correct"); | |||||||
| //--------------------------------------------------------------------+ | //--------------------------------------------------------------------+ | ||||||
|  |  | ||||||
| /// SCSI Command Operation Code | /// SCSI Command Operation Code | ||||||
| typedef enum | typedef enum { | ||||||
| { |  | ||||||
|   SCSI_CMD_TEST_UNIT_READY              = 0x00, ///< The SCSI Test Unit Ready command is used to determine if a device is ready to transfer data (read/write), i.e. if a disk has spun up, if a tape is loaded and ready etc. The device does not perform a self-test operation. |   SCSI_CMD_TEST_UNIT_READY              = 0x00, ///< The SCSI Test Unit Ready command is used to determine if a device is ready to transfer data (read/write), i.e. if a disk has spun up, if a tape is loaded and ready etc. The device does not perform a self-test operation. | ||||||
|   SCSI_CMD_INQUIRY                      = 0x12, ///< The SCSI Inquiry command is used to obtain basic information from a target device. |   SCSI_CMD_INQUIRY                      = 0x12, ///< The SCSI Inquiry command is used to obtain basic information from a target device. | ||||||
|   SCSI_CMD_MODE_SELECT_6                = 0x15, ///<  provides a means for the application client to specify medium, logical unit, or peripheral device parameters to the device server. Device servers that implement the MODE SELECT(6) command shall also implement the MODE SENSE(6) command. Application clients should issue MODE SENSE(6) prior to each MODE SELECT(6) to determine supported mode pages, page lengths, and other parameters. |   SCSI_CMD_MODE_SELECT_6                = 0x15, ///<  provides a means for the application client to specify medium, logical unit, or peripheral device parameters to the device server. Device servers that implement the MODE SELECT(6) command shall also implement the MODE SENSE(6) command. Application clients should issue MODE SENSE(6) prior to each MODE SELECT(6) to determine supported mode pages, page lengths, and other parameters. | ||||||
| @@ -124,8 +123,7 @@ typedef enum | |||||||
| }scsi_cmd_type_t; | }scsi_cmd_type_t; | ||||||
|  |  | ||||||
| /// SCSI Sense Key | /// SCSI Sense Key | ||||||
| typedef enum | typedef enum { | ||||||
| { |  | ||||||
|   SCSI_SENSE_NONE            = 0x00, ///< no specific Sense Key. This would be the case for a successful command |   SCSI_SENSE_NONE            = 0x00, ///< no specific Sense Key. This would be the case for a successful command | ||||||
|   SCSI_SENSE_RECOVERED_ERROR = 0x01, ///< Indicates the last command completed successfully with some recovery action performed by the disc drive. |   SCSI_SENSE_RECOVERED_ERROR = 0x01, ///< Indicates the last command completed successfully with some recovery action performed by the disc drive. | ||||||
|   SCSI_SENSE_NOT_READY       = 0x02, ///< Indicates the logical unit addressed cannot be accessed. |   SCSI_SENSE_NOT_READY       = 0x02, ///< Indicates the logical unit addressed cannot be accessed. | ||||||
| @@ -141,6 +139,27 @@ typedef enum | |||||||
|   SCSI_SENSE_MISCOMPARE      = 0x0e  ///< Indicates that the source data did not match the data read from the medium. |   SCSI_SENSE_MISCOMPARE      = 0x0e  ///< Indicates that the source data did not match the data read from the medium. | ||||||
| }scsi_sense_key_type_t; | }scsi_sense_key_type_t; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | typedef enum { | ||||||
|  |   SCSI_PDT_DIRECT_ACCESS = 0x0, | ||||||
|  |   SCSI_PDT_SEQUENTIAL_ACCESS = 0x1, | ||||||
|  |   SCSI_PDT_PRINTER = 0x2, | ||||||
|  |   SCSI_PDT_PROCESSOR = 0x3, | ||||||
|  |   SCSI_PDT_WRITE_ONCE = 0x4, | ||||||
|  |   SCSI_PDT_CD_DVD = 0x5, | ||||||
|  |   SCSI_PDT_SCANNER = 0x6, | ||||||
|  |   SCSI_PDT_OPTICAL_DEVICE = 0x7, | ||||||
|  |   SCSI_PDT_MEDIUM_CHANGER = 0x8, | ||||||
|  |   SCSI_PDT_COMMUNICATIONS = 0x9, // obsolete | ||||||
|  |   SCSI_PDT_RAID = 0x0c, | ||||||
|  |   SCSI_PDT_ENCLOSURE_SERVICES = 0x0d, | ||||||
|  |   SCSI_PDT_SIMPLIFIED_DIRECT_ACCESS = 0x0e, | ||||||
|  |   SCSI_PDT_OPTICAL_CARD_READER = 0x0f, | ||||||
|  |   SCSI_PDT_BRIDGE = 0x10, ///< Bridge device, e.g. USB to SCSI bridge | ||||||
|  |   SCSI_PDT_OBJECT_BASED_STORAGE = 0x11, ///< Object-based storage device | ||||||
|  |   SCSI_PDT_AUTOMATION_DRIVE_INTERFACE = 0x12, ///< Automation/Drive Interface (ADI) device | ||||||
|  | } scsi_peripheral_device_type_t; | ||||||
|  |  | ||||||
| //--------------------------------------------------------------------+ | //--------------------------------------------------------------------+ | ||||||
| // SCSI Primary Command (SPC-4) | // SCSI Primary Command (SPC-4) | ||||||
| //--------------------------------------------------------------------+ | //--------------------------------------------------------------------+ | ||||||
|   | |||||||
| @@ -41,6 +41,17 @@ | |||||||
|  |  | ||||||
| #define TU_LOG_DRV(...)   TU_LOG(CFG_TUD_MSC_LOG_LEVEL, __VA_ARGS__) | #define TU_LOG_DRV(...)   TU_LOG(CFG_TUD_MSC_LOG_LEVEL, __VA_ARGS__) | ||||||
|  |  | ||||||
|  | //--------------------------------------------------------------------+ | ||||||
|  | // Weak stubs: invoked if no strong implementation is available | ||||||
|  | //--------------------------------------------------------------------+ | ||||||
|  | TU_ATTR_WEAK void tud_msc_inquiry_cb(uint8_t lun, uint8_t vendor_id[8], uint8_t product_id[16], uint8_t product_rev[4]) { | ||||||
|  |   (void) lun; (void) vendor_id; (void) product_id; (void) product_rev; | ||||||
|  | } | ||||||
|  | TU_ATTR_WEAK uint32_t tud_msc_inquiry2_cb(uint8_t lun, scsi_inquiry_resp_t* inquiry_resp) { | ||||||
|  |   (void) lun; (void) inquiry_resp; | ||||||
|  |   return 0; | ||||||
|  | } | ||||||
|  |  | ||||||
| //--------------------------------------------------------------------+ | //--------------------------------------------------------------------+ | ||||||
| // MACRO CONSTANT TYPEDEF | // MACRO CONSTANT TYPEDEF | ||||||
| //--------------------------------------------------------------------+ | //--------------------------------------------------------------------+ | ||||||
| @@ -731,22 +742,19 @@ static int32_t proc_builtin_scsi(uint8_t lun, uint8_t const scsi_cmd[16], uint8_ | |||||||
|     break; |     break; | ||||||
|  |  | ||||||
|     case SCSI_CMD_INQUIRY: { |     case SCSI_CMD_INQUIRY: { | ||||||
|       scsi_inquiry_resp_t inquiry_rsp = { |       scsi_inquiry_resp_t *inquiry_rsp = (scsi_inquiry_resp_t *) buffer; | ||||||
|         .is_removable = 1, |       tu_memclr(inquiry_rsp, sizeof(scsi_inquiry_resp_t)); | ||||||
|         .version = 2, |       inquiry_rsp->is_removable = 1; | ||||||
|         .response_data_format = 2, |       inquiry_rsp->version = 2; | ||||||
|         .additional_length = sizeof(scsi_inquiry_resp_t) - 5, |       inquiry_rsp->response_data_format = 2; | ||||||
|       }; |       inquiry_rsp->additional_length = sizeof(scsi_inquiry_resp_t) - 5; | ||||||
|  |  | ||||||
|       // vendor_id, product_id, product_rev is space padded string |       resplen = (int32_t) tud_msc_inquiry2_cb(lun, inquiry_rsp); | ||||||
|       memset(inquiry_rsp.vendor_id  , ' ', sizeof(inquiry_rsp.vendor_id)); |       if (resplen == 0) { | ||||||
|       memset(inquiry_rsp.product_id , ' ', sizeof(inquiry_rsp.product_id)); |         // stub callback with no response, use v1 callback | ||||||
|       memset(inquiry_rsp.product_rev, ' ', sizeof(inquiry_rsp.product_rev)); |         tud_msc_inquiry_cb(lun, inquiry_rsp->vendor_id, inquiry_rsp->product_id, inquiry_rsp->product_rev); | ||||||
|  |         resplen = sizeof(scsi_inquiry_resp_t); | ||||||
|       tud_msc_inquiry_cb(lun, inquiry_rsp.vendor_id, inquiry_rsp.product_id, inquiry_rsp.product_rev); |       } | ||||||
|  |  | ||||||
|       resplen = sizeof(inquiry_rsp); |  | ||||||
|       TU_VERIFY(0 == tu_memcpy_s(buffer, bufsize, &inquiry_rsp, (size_t) resplen)); |  | ||||||
|     } |     } | ||||||
|     break; |     break; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -90,10 +90,15 @@ bool tud_msc_async_io_done(int32_t bytes_io, bool in_isr); | |||||||
| int32_t tud_msc_read10_cb (uint8_t lun, uint32_t lba, uint32_t offset, void* buffer, uint32_t bufsize); | int32_t tud_msc_read10_cb (uint8_t lun, uint32_t lba, uint32_t offset, void* buffer, uint32_t bufsize); | ||||||
| int32_t tud_msc_write10_cb (uint8_t lun, uint32_t lba, uint32_t offset, uint8_t* buffer, uint32_t bufsize); | int32_t tud_msc_write10_cb (uint8_t lun, uint32_t lba, uint32_t offset, uint8_t* buffer, uint32_t bufsize); | ||||||
|  |  | ||||||
| // Invoked when received SCSI_CMD_INQUIRY | // Invoked when received SCSI_CMD_INQUIRY, v1, application should use v2 if possible | ||||||
| // Application fill vendor id, product id and revision with string up to 8, 16, 4 characters respectively | // Application fill vendor id, product id and revision with string up to 8, 16, 4 characters respectively | ||||||
| void tud_msc_inquiry_cb(uint8_t lun, uint8_t vendor_id[8], uint8_t product_id[16], uint8_t product_rev[4]); | void tud_msc_inquiry_cb(uint8_t lun, uint8_t vendor_id[8], uint8_t product_id[16], uint8_t product_rev[4]); | ||||||
|  |  | ||||||
|  | // Invoked when received SCSI_CMD_INQUIRY, v2 with full inquiry response | ||||||
|  | // Some inquiry_resp's fields are already filled with default values, application can update them | ||||||
|  | // Return length of inquiry response, typically sizeof(scsi_inquiry_resp_t) (36 bytes), can be longer if included vendor data. | ||||||
|  | uint32_t tud_msc_inquiry2_cb(uint8_t lun, scsi_inquiry_resp_t* inquiry_resp); | ||||||
|  |  | ||||||
| // Invoked when received Test Unit Ready command. | // Invoked when received Test Unit Ready command. | ||||||
| // return true allowing host to read/write this LUN e.g SD card inserted | // return true allowing host to read/write this LUN e.g SD card inserted | ||||||
| bool tud_msc_test_unit_ready_cb(uint8_t lun); | bool tud_msc_test_unit_ready_cb(uint8_t lun); | ||||||
|   | |||||||
| @@ -94,19 +94,20 @@ enum | |||||||
|  |  | ||||||
| uint8_t msc_disk[DISK_BLOCK_NUM][DISK_BLOCK_SIZE]; | uint8_t msc_disk[DISK_BLOCK_NUM][DISK_BLOCK_SIZE]; | ||||||
|  |  | ||||||
| // Invoked when received SCSI_CMD_INQUIRY | // Invoked when received SCSI_CMD_INQUIRY, v2 with full inquiry response | ||||||
| // Application fill vendor id, product id and revision with string up to 8, 16, 4 characters respectively | // Some inquiry_resp's fields are already filled with default values, application can update them | ||||||
| void tud_msc_inquiry_cb(uint8_t lun, uint8_t vendor_id[8], uint8_t product_id[16], uint8_t product_rev[4]) | // Return length of inquiry response, typically sizeof(scsi_inquiry_resp_t) (36 bytes), can be longer if included vendor data. | ||||||
| { | uint32_t tud_msc_inquiry2_cb(uint8_t lun, scsi_inquiry_resp_t* inquiry_resp) { | ||||||
|   (void) lun; |   (void) lun; | ||||||
|  |  | ||||||
|   const char vid[] = "TinyUSB"; |   const char vid[] = "TinyUSB"; | ||||||
|   const char pid[] = "Mass Storage"; |   const char pid[] = "Mass Storage"; | ||||||
|   const char rev[] = "1.0"; |   const char rev[] = "1.0"; | ||||||
|  |  | ||||||
|   memcpy(vendor_id  , vid, strlen(vid)); |   memcpy(inquiry_resp->vendor_id, vid, strlen(vid)); | ||||||
|   memcpy(product_id , pid, strlen(pid)); |   memcpy(inquiry_resp->product_id, pid, strlen(pid)); | ||||||
|   memcpy(product_rev, rev, strlen(rev)); |   memcpy(inquiry_resp->product_rev, rev, strlen(rev)); | ||||||
|  |  | ||||||
|  |   return sizeof(scsi_inquiry_resp_t); // 36 bytes | ||||||
| } | } | ||||||
|  |  | ||||||
| // Invoked when received Test Unit Ready command. | // Invoked when received Test Unit Ready command. | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 hathach
					hathach