freertos example clean up
This commit is contained in:
@@ -61,9 +61,6 @@
|
|||||||
//--------------------------------------------------------------------+
|
//--------------------------------------------------------------------+
|
||||||
void print_greeting(void);
|
void print_greeting(void);
|
||||||
void led_blinky_cb(TimerHandle_t xTimer);
|
void led_blinky_cb(TimerHandle_t xTimer);
|
||||||
void cdc_task(void* params);
|
|
||||||
void usb_hid_task(void* params);
|
|
||||||
|
|
||||||
|
|
||||||
/*------------- MAIN -------------*/
|
/*------------- MAIN -------------*/
|
||||||
int main(void)
|
int main(void)
|
||||||
@@ -78,10 +75,16 @@ int main(void)
|
|||||||
tusb_init();
|
tusb_init();
|
||||||
|
|
||||||
// Create task
|
// Create task
|
||||||
|
#if CFG_TUD_CDC
|
||||||
|
extern void cdc_task(void* params);
|
||||||
xTaskCreate( cdc_task, "cdc", 256, NULL, 2, NULL);
|
xTaskCreate( cdc_task, "cdc", 256, NULL, 2, NULL);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if CFG_TUD_HID
|
||||||
|
extern void usb_hid_task(void* params);
|
||||||
|
#endif
|
||||||
|
|
||||||
vTaskStartScheduler();
|
vTaskStartScheduler();
|
||||||
|
|
||||||
NVIC_SystemReset();
|
NVIC_SystemReset();
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
@@ -90,6 +93,7 @@ int main(void)
|
|||||||
//--------------------------------------------------------------------+
|
//--------------------------------------------------------------------+
|
||||||
// USB CDC
|
// USB CDC
|
||||||
//--------------------------------------------------------------------+
|
//--------------------------------------------------------------------+
|
||||||
|
#if CFG_TUD_CDC
|
||||||
void cdc_task(void* params)
|
void cdc_task(void* params)
|
||||||
{
|
{
|
||||||
(void) params;
|
(void) params;
|
||||||
@@ -111,10 +115,12 @@ void cdc_task(void* params)
|
|||||||
taskYIELD();
|
taskYIELD();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
//--------------------------------------------------------------------+
|
//--------------------------------------------------------------------+
|
||||||
// USB HID
|
// USB HID
|
||||||
//--------------------------------------------------------------------+
|
//--------------------------------------------------------------------+
|
||||||
|
#if CFG_TUD_HID
|
||||||
void usb_hid_task(void* params)
|
void usb_hid_task(void* params)
|
||||||
{
|
{
|
||||||
(void) params;
|
(void) params;
|
||||||
@@ -170,6 +176,7 @@ void tud_hid_generic_set_report_cb(uint8_t report_id, hid_report_type_t report_t
|
|||||||
{
|
{
|
||||||
// TODO not Implemented
|
// TODO not Implemented
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
//--------------------------------------------------------------------+
|
//--------------------------------------------------------------------+
|
||||||
// tinyusb callbacks
|
// tinyusb callbacks
|
||||||
|
|||||||
@@ -47,19 +47,6 @@ void flash_flush (void);
|
|||||||
//--------------------------------------------------------------------+
|
//--------------------------------------------------------------------+
|
||||||
// MACRO TYPEDEF CONSTANT ENUM DECLARATION
|
// MACRO TYPEDEF CONSTANT ENUM DECLARATION
|
||||||
//--------------------------------------------------------------------+
|
//--------------------------------------------------------------------+
|
||||||
enum
|
|
||||||
{
|
|
||||||
FLASH_STATE_IDLE,
|
|
||||||
FLASH_STATE_BUSY,
|
|
||||||
FLASH_STATE_COMPLETE
|
|
||||||
};
|
|
||||||
|
|
||||||
volatile uint8_t _fl_state = FLASH_STATE_IDLE;
|
|
||||||
|
|
||||||
void qspi_flash_complete (void)
|
|
||||||
{
|
|
||||||
_fl_state = FLASH_STATE_COMPLETE;
|
|
||||||
}
|
|
||||||
|
|
||||||
//------------- IMPLEMENTATION -------------//
|
//------------- IMPLEMENTATION -------------//
|
||||||
// Callback invoked when received READ10 command.
|
// Callback invoked when received READ10 command.
|
||||||
@@ -68,24 +55,8 @@ int32_t tud_msc_read10_cb(uint8_t lun, uint32_t lba, uint32_t offset, void* buff
|
|||||||
{
|
{
|
||||||
uint32_t addr = lba * CFG_TUD_MSC_BLOCK_SZ + offset;
|
uint32_t addr = lba * CFG_TUD_MSC_BLOCK_SZ + offset;
|
||||||
|
|
||||||
switch ( _fl_state )
|
flash_read(buffer, addr, bufsize);
|
||||||
{
|
return bufsize;
|
||||||
case FLASH_STATE_IDLE:
|
|
||||||
_fl_state = FLASH_STATE_BUSY;
|
|
||||||
flash_read(buffer, addr, bufsize);
|
|
||||||
return 0; // data not ready
|
|
||||||
|
|
||||||
case FLASH_STATE_BUSY:
|
|
||||||
return 0; // data not ready
|
|
||||||
|
|
||||||
case FLASH_STATE_COMPLETE:
|
|
||||||
_fl_state = FLASH_STATE_IDLE;
|
|
||||||
return bufsize;
|
|
||||||
|
|
||||||
default:
|
|
||||||
_fl_state = FLASH_STATE_IDLE;
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Callback invoked when received WRITE10 command.
|
// Callback invoked when received WRITE10 command.
|
||||||
@@ -124,16 +95,7 @@ void flash_flush (void)
|
|||||||
if ( _fl_addr == NO_CACHE ) return;
|
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_erase(NRF_QSPI_ERASE_LEN_4KB, _fl_addr),);
|
||||||
while ( _fl_state != FLASH_STATE_COMPLETE )
|
|
||||||
{
|
|
||||||
}
|
|
||||||
_fl_state = FLASH_STATE_IDLE;
|
|
||||||
|
|
||||||
TU_ASSERT(NRFX_SUCCESS == nrfx_qspi_write(_fl_buf, FLASH_PAGE_SIZE, _fl_addr),);
|
TU_ASSERT(NRFX_SUCCESS == nrfx_qspi_write(_fl_buf, FLASH_PAGE_SIZE, _fl_addr),);
|
||||||
while ( _fl_state != FLASH_STATE_COMPLETE )
|
|
||||||
{
|
|
||||||
}
|
|
||||||
_fl_state = FLASH_STATE_IDLE;
|
|
||||||
|
|
||||||
_fl_addr = NO_CACHE;
|
_fl_addr = NO_CACHE;
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user