Parcourir la source

msc works well with samd51

hathach il y a 7 ans
Parent
commit
bdded75ad9

+ 9 - 11
examples/device/cdc_msc_hid/src/msc_flash_ram.c → examples/device/cdc_msc_hid/src/msc_disk_ram.c

@@ -1,6 +1,6 @@
 /**************************************************************************/
 /*!
- @file    msc_flash_ram.c
+ @file    msc_disk_ram.c
  @author  hathach (tinyusb.org)
 
  @section LICENSE
@@ -38,16 +38,14 @@
 
 #include "msc_app.h"
 
-#if CFG_TUD_MSC && defined (BOARD_MSC_FLASH_RAM)
+#if CFG_TUD_MSC
 
-//--------------------------------------------------------------------+
-// MACRO CONSTANT TYPEDEF
-//--------------------------------------------------------------------+
+enum
+{
+  DISK_BLOCK_NUM  = 16, // 8KB is the smallest size that windows allow to mount
+  DISK_BLOCK_SIZE = 512
+};
 
-//--------------------------------------------------------------------+
-// INTERNAL OBJECT & FUNCTION DECLARATION
-//--------------------------------------------------------------------+
-CFG_TUSB_ATTR_USBRAM CFG_TUSB_MEM_ALIGN
 uint8_t msc_device_ramdisk[DISK_BLOCK_NUM][DISK_BLOCK_SIZE] =
 {
   //------------- Boot Sector -------------//
@@ -81,7 +79,7 @@ uint8_t msc_device_ramdisk[DISK_BLOCK_NUM][DISK_BLOCK_SIZE] =
       // second entry is readme file
       'R' , 'E' , 'A' , 'D' , 'M' , 'E' , ' ' , ' ' , 'T' , 'X' , 'T' , 0x20, 0x00, 0xC6, 0x52, 0x6D,
       0x65, 0x43, 0x65, 0x43, 0x00, 0x00, 0x88, 0x6D, 0x65, 0x43, 0x02, 0x00,
-      sizeof(README_CONTENTS)-1, 0x00, 0x00, 0x00 // readme's filesize (4 Bytes)
+      sizeof(README_CONTENTS)-1, 0x00, 0x00, 0x00 // readme's files ize (4 Bytes)
   },
 
   //------------- Readme Content -------------//
@@ -101,7 +99,7 @@ int32_t tud_msc_read10_cb(uint8_t lun, uint32_t lba, uint32_t offset, void* buff
 
 // Callback invoked when received WRITE10 command.
 // Process data in buffer to disk's storage and return number of written bytes
-int32_t tud_msc_write10_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)
 {
   uint8_t* addr = msc_device_ramdisk[lba] + offset;
   memcpy(addr, buffer, bufsize);

+ 0 - 124
examples/device/cdc_msc_hid/src/msc_flash_qspi.c

@@ -1,124 +0,0 @@
-/**************************************************************************/
-/*!
- @file    msc_flash_qspi.c
- @author  hathach (tinyusb.org)
-
- @section LICENSE
-
- Software License Agreement (BSD License)
-
- Copyright (c) 2018, 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.
-*/
-/**************************************************************************/
-
-#include "msc_app.h"
-
-#if CFG_TUD_MSC && defined (BOARD_MSC_FLASH_QSPI)
-
-void flash_read (void *dst, uint32_t src, int len);
-void flash_write (uint32_t dst, const void *src, int len);
-void flash_flush (void);
-
-//--------------------------------------------------------------------+
-// MACRO TYPEDEF CONSTANT ENUM DECLARATION
-//--------------------------------------------------------------------+
-
-//------------- IMPLEMENTATION -------------//
-// Callback invoked when received READ10 command.
-// Copy disk's data to buffer (up to bufsize) and return number of copied bytes.
-int32_t tud_msc_read10_cb(uint8_t lun, uint32_t lba, uint32_t offset, void* buffer, uint32_t bufsize)
-{
-  uint32_t addr = lba * CFG_TUD_MSC_BLOCK_SZ + offset;
-
-  flash_read(buffer, addr, bufsize);
-  return bufsize;
-}
-
-// Callback invoked when received WRITE10 command.
-// Process data in buffer to disk's storage and return number of written bytes
-int32_t tud_msc_write10_cb(uint8_t lun, uint32_t lba, uint32_t offset, uint8_t* buffer, uint32_t bufsize)
-{
-  uint32_t addr = lba * CFG_TUD_MSC_BLOCK_SZ + offset;
-
-  flash_write(addr, buffer, bufsize);
-
-  return bufsize;
-}
-
-// Callback invoked when WRITE10 command is completed (status received and accepted by host).
-// used to flush any pending cache.
-void tud_msc_write10_complete_cb (uint8_t lun)
-{
-  (void) lun;
-
-  // flush pending cache when write10 is complete
-  flash_flush();
-}
-
-//--------------------------------------------------------------------+
-// Flash caching
-//--------------------------------------------------------------------+
-#define FLASH_PAGE_SIZE    4096
-
-#define NO_CACHE 0xffffffff
-
-static uint32_t _fl_addr = NO_CACHE;
-static uint8_t _fl_buf[FLASH_PAGE_SIZE] __attribute__((aligned(4)));
-
-void flash_flush (void)
-{
-  if ( _fl_addr == NO_CACHE ) return;
-
-  TU_ASSERT(NRFX_SUCCESS == nrfx_qspi_erase(NRF_QSPI_ERASE_LEN_4KB, _fl_addr),);
-  TU_ASSERT(NRFX_SUCCESS == nrfx_qspi_write(_fl_buf, FLASH_PAGE_SIZE, _fl_addr),);
-
-  _fl_addr = NO_CACHE;
-}
-
-void flash_write (uint32_t dst, const void *src, int len)
-{
-  uint32_t newAddr = dst & ~(FLASH_PAGE_SIZE - 1);
-
-  if ( newAddr != _fl_addr )
-  {
-    flash_flush();
-    _fl_addr = newAddr;
-
-    flash_read(_fl_buf, newAddr, FLASH_PAGE_SIZE);
-  }
-
-  memcpy(_fl_buf + (dst & (FLASH_PAGE_SIZE - 1)), src, len);
-}
-
-void flash_read (void *dst, uint32_t src, int len)
-{
-  TU_ASSERT(NRFX_SUCCESS == nrfx_qspi_read(dst, len, src),);
-}
-
-
-#endif

+ 2 - 2
examples/device/cdc_msc_hid/src/tusb_config.h

@@ -87,7 +87,7 @@
 
 //------------- CLASS -------------//
 #define CFG_TUD_CDC                 1
-#define CFG_TUD_MSC                 0
+#define CFG_TUD_MSC                 1
 
 #define CFG_TUD_HID                 0
 #define CFG_TUD_HID_KEYBOARD        0
@@ -119,7 +119,7 @@
 #define CFG_TUD_MSC_BUFSIZE         512
 
 // Number of Blocks
-#define CFG_TUD_MSC_BLOCK_NUM       BOARD_MSC_FLASH_SIZE/CFG_TUD_MSC_BLOCK_SZ
+#define CFG_TUD_MSC_BLOCK_NUM       16
 
 // Block size
 #define CFG_TUD_MSC_BLOCK_SZ        512

+ 0 - 124
examples/device/cdc_msc_hid_freertos/src/msc_flash_qspi.c

@@ -1,124 +0,0 @@
-/**************************************************************************/
-/*!
- @file    msc_flash_qspi.c
- @author  hathach (tinyusb.org)
-
- @section LICENSE
-
- Software License Agreement (BSD License)
-
- Copyright (c) 2018, 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.
-*/
-/**************************************************************************/
-
-#include "msc_app.h"
-
-#if CFG_TUD_MSC && defined (BOARD_MSC_FLASH_QSPI)
-
-void flash_read (void *dst, uint32_t src, int len);
-void flash_write (uint32_t dst, const void *src, int len);
-void flash_flush (void);
-
-//--------------------------------------------------------------------+
-// MACRO TYPEDEF CONSTANT ENUM DECLARATION
-//--------------------------------------------------------------------+
-
-//------------- IMPLEMENTATION -------------//
-// Callback invoked when received READ10 command.
-// Copy disk's data to buffer (up to bufsize) and return number of copied bytes.
-int32_t tud_msc_read10_cb(uint8_t lun, uint32_t lba, uint32_t offset, void* buffer, uint32_t bufsize)
-{
-  uint32_t addr = lba * CFG_TUD_MSC_BLOCK_SZ + offset;
-
-  flash_read(buffer, addr, bufsize);
-  return bufsize;
-}
-
-// Callback invoked when received WRITE10 command.
-// Process data in buffer to disk's storage and return number of written bytes
-int32_t tud_msc_write10_cb(uint8_t lun, uint32_t lba, uint32_t offset, uint8_t* buffer, uint32_t bufsize)
-{
-  uint32_t addr = lba * CFG_TUD_MSC_BLOCK_SZ + offset;
-
-  flash_write(addr, buffer, bufsize);
-
-  return bufsize;
-}
-
-// Callback invoked when WRITE10 command is completed (status received and accepted by host).
-// used to flush any pending cache.
-void tud_msc_write10_complete_cb (uint8_t lun)
-{
-  (void) lun;
-
-  // flush pending cache when write10 is complete
-  flash_flush();
-}
-
-//--------------------------------------------------------------------+
-// Flash caching
-//--------------------------------------------------------------------+
-#define FLASH_PAGE_SIZE    4096
-
-#define NO_CACHE 0xffffffff
-
-static uint32_t _fl_addr = NO_CACHE;
-static uint8_t _fl_buf[FLASH_PAGE_SIZE] __attribute__((aligned(4)));
-
-void flash_flush (void)
-{
-  if ( _fl_addr == NO_CACHE ) return;
-
-  TU_ASSERT(NRFX_SUCCESS == nrfx_qspi_erase(NRF_QSPI_ERASE_LEN_4KB, _fl_addr),);
-  TU_ASSERT(NRFX_SUCCESS == nrfx_qspi_write(_fl_buf, FLASH_PAGE_SIZE, _fl_addr),);
-
-  _fl_addr = NO_CACHE;
-}
-
-void flash_write (uint32_t dst, const void *src, int len)
-{
-  uint32_t newAddr = dst & ~(FLASH_PAGE_SIZE - 1);
-
-  if ( newAddr != _fl_addr )
-  {
-    flash_flush();
-    _fl_addr = newAddr;
-
-    flash_read(_fl_buf, newAddr, FLASH_PAGE_SIZE);
-  }
-
-  memcpy(_fl_buf + (dst & (FLASH_PAGE_SIZE - 1)), src, len);
-}
-
-void flash_read (void *dst, uint32_t src, int len)
-{
-  TU_ASSERT(NRFX_SUCCESS == nrfx_qspi_read(dst, len, src),);
-}
-
-
-#endif