Align fatfs window buffer for tinyusb

Also, update tinyusb.
This commit is contained in:
Scott Shawcroft 2023-07-27 09:15:58 -07:00
parent 03261fe188
commit e45a61f57e
No known key found for this signature in database
GPG Key ID: 0DFD512649C052DA
7 changed files with 39 additions and 9 deletions

View File

@ -162,7 +162,7 @@ typedef struct {
DWORD bitbase; /* Allocation bitmap base sector */ DWORD bitbase; /* Allocation bitmap base sector */
#endif #endif
DWORD winsect; /* Current sector appearing in the win[] */ DWORD winsect; /* Current sector appearing in the win[] */
BYTE win[FF_MAX_SS]; /* Disk access window for Directory, FAT (and file data at tiny cfg) */ __attribute__((aligned(FF_WINDOW_ALIGNMENT),)) BYTE win[FF_MAX_SS]; /* Disk access window for Directory, FAT (and file data at tiny cfg). */
} FATFS; } FATFS;

View File

@ -267,6 +267,12 @@
/ for variable sector size mode and disk_ioctl() function needs to implement / for variable sector size mode and disk_ioctl() function needs to implement
/ GET_SECTOR_SIZE command. */ / GET_SECTOR_SIZE command. */
#ifdef MICROPY_FATFS_WINDOW_ALIGNMENT
#define FF_WINDOW_ALIGNMENT (MICROPY_FATFS_WINDOW_ALIGNMENT)
#else
#define FF_WINDOW_ALIGNMENT 1
#endif
#define FF_USE_TRIM 0 #define FF_USE_TRIM 0
/* This option switches support for ATA-TRIM. (0:Disable or 1:Enable) /* This option switches support for ATA-TRIM. (0:Disable or 1:Enable)

@ -1 +1 @@
Subproject commit 6c7c9f2ef5a80d5a6879e9c3558162188c6cf889 Subproject commit db59494b1b24f7dad26c5c66c85a195a2cf09466

View File

@ -1748,6 +1748,10 @@ msgstr ""
msgid "Pins must share PWM slice" msgid "Pins must share PWM slice"
msgstr "" msgstr ""
#: shared-module/usb/core/Device.c
msgid "Pipe error"
msgstr ""
#: py/builtinhelp.c #: py/builtinhelp.c
msgid "Plus any modules on the filesystem\n" msgid "Plus any modules on the filesystem\n"
msgstr "" msgstr ""
@ -1825,7 +1829,8 @@ msgstr ""
#: shared-bindings/_bleio/__init__.c #: shared-bindings/_bleio/__init__.c
#: shared-bindings/memorymonitor/AllocationSize.c #: shared-bindings/memorymonitor/AllocationSize.c
#: shared-bindings/pulseio/PulseIn.c shared-module/displayio/Bitmap.c #: shared-bindings/pulseio/PulseIn.c shared-module/bitmaptools/__init__.c
#: shared-module/displayio/Bitmap.c
msgid "Read-only" msgid "Read-only"
msgstr "" msgstr ""
@ -3985,7 +3990,7 @@ msgstr ""
msgid "sosfilt requires iterable arguments" msgid "sosfilt requires iterable arguments"
msgstr "" msgstr ""
#: shared-bindings/bitmaptools/__init__.c shared-bindings/displayio/Bitmap.c #: shared-bindings/bitmaptools/__init__.c
msgid "source palette too large" msgid "source palette too large"
msgstr "" msgstr ""

@ -1 +1 @@
Subproject commit 5a7aa8d4e78f9a50e4fb9defcf3488b3fc44aff1 Subproject commit d00a10a8c425d0d40f81b87169102944b01f3bb3

View File

@ -611,6 +611,12 @@ void background_callback_run_all(void);
#define CIRCUITPY_DIGITALIO_HAVE_INVALID_DRIVE_MODE (0) #define CIRCUITPY_DIGITALIO_HAVE_INVALID_DRIVE_MODE (0)
#endif #endif
// Align the internal sector buffer. Useful when it is passed into TinyUSB for
// loads.
#ifndef MICROPY_FATFS_WINDOW_ALIGNMENT
#define MICROPY_FATFS_WINDOW_ALIGNMENT CIRCUITPY_TUSB_MEM_ALIGN
#endif
#define FF_FS_CASE_INSENSITIVE_COMPARISON_ASCII_ONLY (1) #define FF_FS_CASE_INSENSITIVE_COMPARISON_ASCII_ONLY (1)
#define FF_FS_MAKE_VOLID (1) #define FF_FS_MAKE_VOLID (1)

View File

@ -49,6 +49,7 @@ void tuh_umount_cb(uint8_t dev_addr) {
} }
STATIC xfer_result_t _xfer_result; STATIC xfer_result_t _xfer_result;
STATIC size_t _actual_len;
bool common_hal_usb_core_device_construct(usb_core_device_obj_t *self, uint8_t device_number) { bool common_hal_usb_core_device_construct(usb_core_device_obj_t *self, uint8_t device_number) {
if (device_number == 0 || device_number > CFG_TUH_DEVICE_MAX + CFG_TUH_HUB) { if (device_number == 0 || device_number > CFG_TUH_DEVICE_MAX + CFG_TUH_HUB) {
return false; return false;
@ -78,6 +79,9 @@ uint16_t common_hal_usb_core_device_get_idProduct(usb_core_device_obj_t *self) {
STATIC void _transfer_done_cb(tuh_xfer_t *xfer) { STATIC void _transfer_done_cb(tuh_xfer_t *xfer) {
// Store the result so we stop waiting for the transfer. // Store the result so we stop waiting for the transfer.
_xfer_result = xfer->result; _xfer_result = xfer->result;
// The passed in xfer is not the original one we passed in, so we need to
// copy any info out that we want (like actual_len.)
_actual_len = xfer->actual_len;
} }
STATIC bool _wait_for_callback(void) { STATIC bool _wait_for_callback(void) {
@ -159,11 +163,14 @@ STATIC size_t _xfer(tuh_xfer_t *xfer, mp_int_t timeout) {
} }
xfer_result_t result = _xfer_result; xfer_result_t result = _xfer_result;
_xfer_result = 0xff; _xfer_result = 0xff;
if (result == XFER_RESULT_STALLED || result == 0xff) { if (result == XFER_RESULT_STALLED) {
mp_raise_usb_core_USBError(translate("Pipe error"));
}
if (result == 0xff) {
mp_raise_usb_core_USBTimeoutError(); mp_raise_usb_core_USBTimeoutError();
} }
if (result == XFER_RESULT_SUCCESS) { if (result == XFER_RESULT_SUCCESS) {
return xfer->actual_len; return _actual_len;
} }
return 0; return 0;
@ -192,7 +199,10 @@ STATIC bool _open_endpoint(usb_core_device_obj_t *self, mp_int_t endpoint) {
} }
tusb_desc_configuration_t *desc_cfg = (tusb_desc_configuration_t *)desc_buf; tusb_desc_configuration_t *desc_cfg = (tusb_desc_configuration_t *)desc_buf;
uint8_t const *desc_end = ((uint8_t const *)desc_cfg) + tu_le16toh(desc_cfg->wTotalLength); uint32_t total_length = tu_le16toh(desc_cfg->wTotalLength);
// Cap to the buffer size we requested.
total_length = MIN(total_length, sizeof(desc_buf));
uint8_t const *desc_end = ((uint8_t const *)desc_cfg) + total_length;
uint8_t const *p_desc = tu_desc_next(desc_cfg); uint8_t const *p_desc = tu_desc_next(desc_cfg);
// parse each interfaces // parse each interfaces
@ -281,7 +291,10 @@ mp_int_t common_hal_usb_core_device_ctrl_transfer(usb_core_device_obj_t *self,
} }
xfer_result_t result = _xfer_result; xfer_result_t result = _xfer_result;
_xfer_result = 0xff; _xfer_result = 0xff;
if (result == XFER_RESULT_STALLED || result == 0xff) { if (result == XFER_RESULT_STALLED) {
mp_raise_usb_core_USBError(translate("Pipe error"));
}
if (result == 0xff) {
mp_raise_usb_core_USBTimeoutError(); mp_raise_usb_core_USBTimeoutError();
} }
if (result == XFER_RESULT_SUCCESS) { if (result == XFER_RESULT_SUCCESS) {