mirror of
https://github.com/hathach/tinyusb.git
synced 2025-04-25 12:02:30 +00:00
update qspi
This commit is contained in:
parent
154daf584c
commit
3b79ba8451
@ -68,28 +68,24 @@ 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 )
|
||||||
// switch ( _fl_state )
|
{
|
||||||
// {
|
case FLASH_STATE_IDLE:
|
||||||
// case FLASH_STATE_IDLE:
|
_fl_state = FLASH_STATE_BUSY;
|
||||||
// _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;
|
|
||||||
// }
|
|
||||||
|
|
||||||
flash_read(buffer, addr, bufsize);
|
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;
|
return bufsize;
|
||||||
|
|
||||||
|
default:
|
||||||
|
_fl_state = FLASH_STATE_IDLE;
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Callback invoked when received WRITE10 command.
|
// Callback invoked when received WRITE10 command.
|
||||||
@ -128,16 +124,16 @@ 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 )
|
while ( _fl_state != FLASH_STATE_COMPLETE )
|
||||||
// {
|
{
|
||||||
// }
|
}
|
||||||
// _fl_state = FLASH_STATE_IDLE;
|
_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 )
|
while ( _fl_state != FLASH_STATE_COMPLETE )
|
||||||
// {
|
{
|
||||||
// }
|
}
|
||||||
// _fl_state = FLASH_STATE_IDLE;
|
_fl_state = FLASH_STATE_IDLE;
|
||||||
|
|
||||||
_fl_addr = NO_CACHE;
|
_fl_addr = NO_CACHE;
|
||||||
}
|
}
|
||||||
@ -153,6 +149,7 @@ void flash_write (uint32_t dst, const void *src, int len)
|
|||||||
|
|
||||||
flash_read(_fl_buf, newAddr, FLASH_PAGE_SIZE);
|
flash_read(_fl_buf, newAddr, FLASH_PAGE_SIZE);
|
||||||
}
|
}
|
||||||
|
|
||||||
memcpy(_fl_buf + (dst & (FLASH_PAGE_SIZE - 1)), src, len);
|
memcpy(_fl_buf + (dst & (FLASH_PAGE_SIZE - 1)), src, len);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -127,12 +127,12 @@ void board_init(void)
|
|||||||
},
|
},
|
||||||
.prot_if = {
|
.prot_if = {
|
||||||
.readoc = NRF_QSPI_READOC_READ4IO,
|
.readoc = NRF_QSPI_READOC_READ4IO,
|
||||||
.writeoc = NRF_QSPI_WRITEOC_PP,
|
.writeoc = NRF_QSPI_WRITEOC_PP4IO,
|
||||||
.addrmode = NRF_QSPI_ADDRMODE_24BIT,
|
.addrmode = NRF_QSPI_ADDRMODE_24BIT,
|
||||||
.dpmconfig = false, // deep power down
|
.dpmconfig = false, // deep power down
|
||||||
},
|
},
|
||||||
.phy_if = {
|
.phy_if = {
|
||||||
.sck_freq = NRF_QSPI_FREQ_32MDIV4,
|
.sck_freq = NRF_QSPI_FREQ_32MDIV1,
|
||||||
.sck_delay = 1,
|
.sck_delay = 1,
|
||||||
.spi_mode = NRF_QSPI_MODE_0,
|
.spi_mode = NRF_QSPI_MODE_0,
|
||||||
.dpmen = false
|
.dpmen = false
|
||||||
@ -140,8 +140,7 @@ void board_init(void)
|
|||||||
.irq_priority = 7,
|
.irq_priority = 7,
|
||||||
};
|
};
|
||||||
|
|
||||||
nrfx_qspi_init(&qspi_cfg, NULL, NULL);
|
nrfx_qspi_init(&qspi_cfg, qflash_hdl, NULL);
|
||||||
// nrfx_qspi_init(&qspi_cfg, qflash_hdl, NULL);
|
|
||||||
|
|
||||||
nrf_qspi_cinstr_conf_t cinstr_cfg = {
|
nrf_qspi_cinstr_conf_t cinstr_cfg = {
|
||||||
.opcode = 0,
|
.opcode = 0,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user