From 6d983539bcff2a540dd136a7e84e1db2b334528f Mon Sep 17 00:00:00 2001 From: Damien George Date: Wed, 16 Apr 2014 23:08:36 +0100 Subject: stmhal: Improve flash storage cache management. Internal flash used for the filesystem is now written (from the cache) only after a 5s delay, or when a file is closed, or when the drive is unmounted from the host. This delay means that multiple writes can accumulate in the cache, and leads to less writes to the flash, making it last longer. It's implemented by a high-priority interrupt that takes care of flash erase and write, and flushing the cache. This is still only an interim solution for the flash filesystem. It eventually needs to be replaced with something that uses less RAM for the cache, something that can use more of the flash, and something that does proper wear levelling. --- stmhal/usbdev/class/cdc_msc_hid/src/usbd_msc_scsi.c | 1 + 1 file changed, 1 insertion(+) (limited to 'stmhal/usbdev/class/cdc_msc_hid/src') diff --git a/stmhal/usbdev/class/cdc_msc_hid/src/usbd_msc_scsi.c b/stmhal/usbdev/class/cdc_msc_hid/src/usbd_msc_scsi.c index b00d1ae2c..60258d64d 100644 --- a/stmhal/usbdev/class/cdc_msc_hid/src/usbd_msc_scsi.c +++ b/stmhal/usbdev/class/cdc_msc_hid/src/usbd_msc_scsi.c @@ -472,6 +472,7 @@ static int8_t SCSI_AllowMediumRemoval(USBD_HandleTypeDef *pdev, uint8_t lun, ui { USBD_MSC_BOT_HandleTypeDef *hmsc = pdev->pClassData; hmsc->bot_data_length = 0; + ((USBD_StorageTypeDef *)pdev->pUserData)->PreventAllowMediumRemoval(lun, params[0]); return 0; } -- cgit v1.2.3