2014-10-31 5:53 AM
Hi all.
I'm working on a project on an STM32L151CBT6 uC, and getting occasional, unexplained error bits WRPERR and SIZERRset in the flash controller. I set up the flash error interrupt to use the highest priority group so as to preempt other interrupts, and found that it is happening on the same line of code every time:dma_config->p_stream->CMAR = (uint32_t)dma_config->mem_addr;2014-10-31 9:13 AM
I'd start by looking at the flash prefetch and wait states with respect to clock/voltage, check the errata, and look at if the interrupt was trashing registers/stack
If you have a demonstrable failure, suggest you contact your local FAE2014-10-31 11:29 AM
Thanks for the response Clive.
I've figured some things out, and have gotten the error bits to stop being set. The problem seems to be linked to the DMA transfer itself. The error was happening (only occasionally) during a sequence (executed every 50 ms) that looked like this:In an ISR for an IDLE frame on the USART after a DMA transfer: - calculate the bytes transferred from the CNDTR register - Disable the DMA Channel - Write a new value for CMAR - Write the CNDTR register for the next transfer - Enable the DMA ChannelI expect to get 18 bytes for each transfer, and I do, *except* for the ones where the flash errors occur. On these, CNDTR indicates that I got 19 bytes. And the time at which the errors occur looks to be shortly after I disable the DMA channel.I fixed the error by disabling the USART before the above sequence, and then reenabling afterwards.Even though the problem is fixed (it seems), I'd still like to know what was happening. Does it make sense that I was getting those errors in this situation?