| 
									
										
										
										
											2013-11-01 12:11:26 +07:00
										 |  |  | /**************************************************************************/ | 
					
						
							|  |  |  | /*!
 | 
					
						
							|  |  |  |     @file     msc_device.h | 
					
						
							|  |  |  |     @author   hathach (tinyusb.org) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     @section LICENSE | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     Software License Agreement (BSD License) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     Copyright (c) 2013, hathach (tinyusb.org) | 
					
						
							|  |  |  |     All rights reserved. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     Redistribution and use in source and binary forms, with or without | 
					
						
							|  |  |  |     modification, are permitted provided that the following conditions are met: | 
					
						
							|  |  |  |     1. Redistributions of source code must retain the above copyright | 
					
						
							|  |  |  |     notice, this list of conditions and the following disclaimer. | 
					
						
							|  |  |  |     2. Redistributions in binary form must reproduce the above copyright | 
					
						
							|  |  |  |     notice, this list of conditions and the following disclaimer in the | 
					
						
							|  |  |  |     documentation and/or other materials provided with the distribution. | 
					
						
							|  |  |  |     3. Neither the name of the copyright holders nor the | 
					
						
							|  |  |  |     names of its contributors may be used to endorse or promote products | 
					
						
							|  |  |  |     derived from this software without specific prior written permission. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS ''AS IS'' AND ANY | 
					
						
							|  |  |  |     EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | 
					
						
							|  |  |  |     WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | 
					
						
							|  |  |  |     DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER BE LIABLE FOR ANY | 
					
						
							|  |  |  |     DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | 
					
						
							|  |  |  |     (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | 
					
						
							|  |  |  |     LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | 
					
						
							|  |  |  |     ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | 
					
						
							|  |  |  |     (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | 
					
						
							|  |  |  |     SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     This file is part of the tinyusb stack. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | /**************************************************************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef _TUSB_MSC_DEVICE_H_
 | 
					
						
							|  |  |  | #define _TUSB_MSC_DEVICE_H_
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-18 17:12:58 +07:00
										 |  |  | #include "common/tusb_common.h"
 | 
					
						
							| 
									
										
										
										
											2013-11-01 12:11:26 +07:00
										 |  |  | #include "device/usbd.h"
 | 
					
						
							|  |  |  | #include "msc.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-17 16:04:55 +07:00
										 |  |  | 
 | 
					
						
							|  |  |  | //--------------------------------------------------------------------+
 | 
					
						
							|  |  |  | // Class Driver Configuration
 | 
					
						
							|  |  |  | //--------------------------------------------------------------------+
 | 
					
						
							| 
									
										
										
										
											2018-08-13 18:10:23 +07:00
										 |  |  | TU_VERIFY_STATIC(CFG_TUD_MSC_BUFSIZE < UINT16_MAX, "Size is not correct"); | 
					
						
							| 
									
										
										
										
											2018-07-17 16:04:55 +07:00
										 |  |  | 
 | 
					
						
							|  |  |  | #ifndef CFG_TUD_MSC_MAXLUN
 | 
					
						
							|  |  |  |   #define CFG_TUD_MSC_MAXLUN 1
 | 
					
						
							|  |  |  | #elif CFG_TUD_MSC_MAXLUN == 0 || CFG_TUD_MSC_MAXLUN > 16
 | 
					
						
							|  |  |  |   #error MSC Device: Incorrect setting of MAX LUN
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef CFG_TUD_MSC_BUFSIZE
 | 
					
						
							|  |  |  |   #error CFG_TUD_MSC_BUFSIZE must be defined, value of CFG_TUD_MSC_BLOCK_SZ should work well, the more the better
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef CFG_TUD_MSC_VENDOR
 | 
					
						
							|  |  |  |   #error CFG_TUD_MSC_VENDOR 8-byte name must be defined
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef CFG_TUD_MSC_PRODUCT
 | 
					
						
							|  |  |  |   #error CFG_TUD_MSC_PRODUCT 16-byte name must be defined
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef CFG_TUD_MSC_PRODUCT_REV
 | 
					
						
							|  |  |  |   #error CFG_TUD_MSC_PRODUCT_REV 4-byte string must be defined
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // TODO highspeed device is 512
 | 
					
						
							|  |  |  | #ifndef CFG_TUD_MSC_EPSIZE
 | 
					
						
							|  |  |  | #define CFG_TUD_MSC_EPSIZE 64
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-01 12:11:26 +07:00
										 |  |  | #ifdef __cplusplus
 | 
					
						
							|  |  |  |  extern "C" { | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-22 15:16:24 +07:00
										 |  |  | /** \addtogroup ClassDriver_MSC
 | 
					
						
							|  |  |  |  *  @{ | 
					
						
							|  |  |  |  * \defgroup MSC_Device Device | 
					
						
							| 
									
										
										
										
											2014-03-31 11:59:43 +07:00
										 |  |  |  *  @{ */ | 
					
						
							| 
									
										
										
										
											2013-11-22 15:16:24 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-25 12:24:16 +07:00
										 |  |  | 
 | 
					
						
							|  |  |  | // Check if MSC interface is ready to use
 | 
					
						
							|  |  |  | bool tud_msc_ready(void); | 
					
						
							| 
									
										
										
										
											2018-07-26 15:59:13 +07:00
										 |  |  | bool tud_msc_set_sense(uint8_t lun, uint8_t sense_key, uint8_t add_sense_code, uint8_t add_sense_qualifier); | 
					
						
							| 
									
										
										
										
											2018-07-25 12:24:16 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-21 12:47:55 +07:00
										 |  |  | //--------------------------------------------------------------------+
 | 
					
						
							| 
									
										
										
										
											2018-07-26 22:41:46 +07:00
										 |  |  | // APPLICATION CALLBACK (WEAK is optional)
 | 
					
						
							| 
									
										
										
										
											2013-11-21 12:47:55 +07:00
										 |  |  | //--------------------------------------------------------------------+
 | 
					
						
							| 
									
										
										
										
											2018-07-26 22:41:46 +07:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Callback invoked when received \ref SCSI_CMD_READ_10 command | 
					
						
							| 
									
										
										
										
											2018-07-27 17:14:49 +07:00
										 |  |  |  * \param[in]   lun         Logical unit number | 
					
						
							|  |  |  |  * \param[in]   lba         Logical Block Address to be read | 
					
						
							|  |  |  |  * \param[in]   offset      Byte offset from LBA | 
					
						
							|  |  |  |  * \param[out]  buffer      Buffer which application need to update with the response data. | 
					
						
							| 
									
										
										
										
											2018-07-26 22:41:46 +07:00
										 |  |  |  * \param[in]   bufsize     Requested bytes | 
					
						
							| 
									
										
										
										
											2018-04-18 16:55:44 +07:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2018-07-26 22:41:46 +07:00
										 |  |  |  * \return      Number of byte read, if it is less than requested bytes by \a \b bufsize. Tinyusb will transfer | 
					
						
							|  |  |  |  *              this amount first and invoked this again for remaining data. | 
					
						
							| 
									
										
										
										
											2018-04-20 20:23:22 +07:00
										 |  |  |  * | 
					
						
							|  |  |  |  * \retval      zero        Indicate application is not ready yet to response e.g disk I/O is not complete. | 
					
						
							| 
									
										
										
										
											2018-07-26 22:41:46 +07:00
										 |  |  |  *                          tinyusb will invoke this callback with the same parameters again some time later. | 
					
						
							| 
									
										
										
										
											2018-04-20 20:23:22 +07:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2018-07-26 22:41:46 +07:00
										 |  |  |  * \retval      negative    Indicate error e.g reading disk I/O. tinyusb will \b STALL the corresponding | 
					
						
							| 
									
										
										
										
											2013-12-01 12:18:26 +07:00
										 |  |  |  *                          endpoint and return failed status in command status wrapper phase. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2018-07-25 20:34:56 +07:00
										 |  |  | int32_t tud_msc_read10_cb (uint8_t lun, uint32_t lba, uint32_t offset, void* buffer, uint32_t bufsize); | 
					
						
							| 
									
										
										
										
											2013-12-01 12:18:26 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-26 22:41:46 +07:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Callback invoked when received \ref SCSI_CMD_WRITE_10 command | 
					
						
							| 
									
										
										
										
											2018-07-27 17:14:49 +07:00
										 |  |  |  * \param[in]   lun         Logical unit number | 
					
						
							|  |  |  |  * \param[in]   lba         Logical Block Address to be write | 
					
						
							|  |  |  |  * \param[in]   offset      Byte offset from LBA | 
					
						
							|  |  |  |  * \param[out]  buffer      Buffer which holds written data. | 
					
						
							| 
									
										
										
										
											2018-07-26 22:41:46 +07:00
										 |  |  |  * \param[in]   bufsize     Requested bytes | 
					
						
							| 
									
										
										
										
											2018-04-20 20:23:22 +07:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2018-07-26 22:41:46 +07:00
										 |  |  |  * \return      Number of byte written, if it is less than requested bytes by \a \b bufsize. Tinyusb will proceed with | 
					
						
							|  |  |  |  *              other work and invoked this again with adjusted parameters. | 
					
						
							| 
									
										
										
										
											2018-04-20 20:23:22 +07:00
										 |  |  |  * | 
					
						
							|  |  |  |  * \retval      zero        Indicate application is not ready yet e.g disk I/O is not complete. | 
					
						
							| 
									
										
										
										
											2018-07-26 22:41:46 +07:00
										 |  |  |  *                          Tinyusb will invoke this callback with the same parameters again some time later. | 
					
						
							| 
									
										
										
										
											2018-04-18 16:55:44 +07:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2018-04-20 20:23:22 +07:00
										 |  |  |  * \retval      negative    Indicate error writing disk I/O. Tinyusb will \b STALL the corresponding | 
					
						
							| 
									
										
										
										
											2013-12-01 12:18:26 +07:00
										 |  |  |  *                          endpoint and return failed status in command status wrapper phase. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2018-10-24 23:55:10 -07:00
										 |  |  | int32_t tud_msc_write10_cb (uint8_t lun, uint32_t lba, uint32_t offset, uint8_t* buffer, uint32_t bufsize); | 
					
						
							| 
									
										
										
										
											2018-04-18 16:55:44 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-22 12:11:06 +07:00
										 |  |  | // Invoked to determine the disk size
 | 
					
						
							|  |  |  | void tud_msc_capacity_cb(uint8_t lun, uint32_t* block_count, uint16_t* block_size); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-26 22:41:46 +07:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Callback invoked when received an SCSI command not in built-in list below. | 
					
						
							| 
									
										
										
										
											2018-07-27 17:14:49 +07:00
										 |  |  |  * \param[in]   lun         Logical unit number | 
					
						
							|  |  |  |  * \param[in]   scsi_cmd    SCSI command contents which application must examine to response accordingly | 
					
						
							| 
									
										
										
										
											2018-04-20 20:23:22 +07:00
										 |  |  |  * \param[out]  buffer      Buffer for SCSI Data Stage. | 
					
						
							|  |  |  |  *                            - For INPUT: application must fill this with response. | 
					
						
							|  |  |  |  *                            - For OUTPUT it holds the Data from host | 
					
						
							|  |  |  |  * \param[in]   bufsize     Buffer's length. | 
					
						
							| 
									
										
										
										
											2018-04-18 16:55:44 +07:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2018-07-26 22:41:46 +07:00
										 |  |  |  * \return      Actual bytes processed, can be zero for no-data command. | 
					
						
							|  |  |  |  * \retval      negative    Indicate error e.g unsupported command, tinyusb will \b STALL the corresponding | 
					
						
							| 
									
										
										
										
											2018-04-20 20:23:22 +07:00
										 |  |  |  *                          endpoint and return failed status in command status wrapper phase. | 
					
						
							| 
									
										
										
										
											2018-07-26 22:41:46 +07:00
										 |  |  |  * | 
					
						
							|  |  |  |  * \note        Following command is automatically handled by tinyusb stack, callback should not be worried: | 
					
						
							|  |  |  |  *              - READ_CAPACITY10, READ_FORMAT_CAPACITY, INQUIRY, MODE_SENSE6, REQUEST_SENSE | 
					
						
							|  |  |  |  *              - READ10 and WRITE10 has their own callbacks | 
					
						
							| 
									
										
										
										
											2013-12-01 12:18:26 +07:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2018-07-25 20:34:56 +07:00
										 |  |  | int32_t tud_msc_scsi_cb (uint8_t lun, uint8_t const scsi_cmd[16], void* buffer, uint16_t bufsize); | 
					
						
							| 
									
										
										
										
											2013-11-30 22:29:37 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-18 17:12:58 +07:00
										 |  |  | /*------------- Optional callbacks : Could be used by application to free up resources -------------*/ | 
					
						
							| 
									
										
										
										
											2018-11-22 12:11:06 +07:00
										 |  |  | 
 | 
					
						
							|  |  |  | // Invoked when Read10 command is complete
 | 
					
						
							| 
									
										
										
										
											2018-07-25 20:34:56 +07:00
										 |  |  | ATTR_WEAK void tud_msc_read10_complete_cb(uint8_t lun); | 
					
						
							| 
									
										
										
										
											2018-11-22 12:11:06 +07:00
										 |  |  | 
 | 
					
						
							|  |  |  | // Invoke when Write10 command is complete
 | 
					
						
							| 
									
										
										
										
											2018-07-25 20:34:56 +07:00
										 |  |  | ATTR_WEAK void tud_msc_write10_complete_cb(uint8_t lun); | 
					
						
							| 
									
										
										
										
											2018-11-22 12:11:06 +07:00
										 |  |  | 
 | 
					
						
							|  |  |  | // Invoked when command in tud_msc_scsi_cb is complete
 | 
					
						
							| 
									
										
										
										
											2018-07-25 20:34:56 +07:00
										 |  |  | ATTR_WEAK void tud_msc_scsi_complete_cb(uint8_t lun, uint8_t const scsi_cmd[16]); | 
					
						
							| 
									
										
										
										
											2018-04-18 17:12:58 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-22 12:11:06 +07:00
										 |  |  | // Hook to make a mass storage device read-only. TODO remove
 | 
					
						
							| 
									
										
										
										
											2018-10-24 23:55:10 -07:00
										 |  |  | ATTR_WEAK bool tud_msc_is_writable_cb(uint8_t lun); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-22 15:16:24 +07:00
										 |  |  | /** @} */ | 
					
						
							|  |  |  | /** @} */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-01 12:11:26 +07:00
										 |  |  | //--------------------------------------------------------------------+
 | 
					
						
							|  |  |  | // USBD-CLASS DRIVER API
 | 
					
						
							|  |  |  | //--------------------------------------------------------------------+
 | 
					
						
							|  |  |  | #ifdef _TINY_USB_SOURCE_FILE_
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-13 12:40:11 +07:00
										 |  |  | void mscd_init(void); | 
					
						
							| 
									
										
										
										
											2018-03-23 12:32:40 +07:00
										 |  |  | tusb_error_t mscd_open(uint8_t rhport, tusb_desc_interface_t const * p_interface_desc, uint16_t *p_length); | 
					
						
							| 
									
										
										
										
											2018-11-16 21:56:39 +07:00
										 |  |  | bool mscd_control_request(uint8_t rhport, tusb_control_request_t const * p_request); | 
					
						
							|  |  |  | bool mscd_control_request_complete (uint8_t rhport, tusb_control_request_t const * p_request); | 
					
						
							| 
									
										
										
										
											2018-03-23 12:17:47 +07:00
										 |  |  | tusb_error_t mscd_xfer_cb(uint8_t rhport, uint8_t edpt_addr, tusb_event_t event, uint32_t xferred_bytes); | 
					
						
							| 
									
										
										
										
											2018-07-13 16:09:26 +07:00
										 |  |  | void mscd_reset(uint8_t rhport); | 
					
						
							| 
									
										
										
										
											2013-11-01 12:11:26 +07:00
										 |  |  | 
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef __cplusplus
 | 
					
						
							|  |  |  |  } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif /* _TUSB_MSC_DEVICE_H_ */
 |