Hallo Forum,
ich habe hier ein Problem gefunden und wollte andere warnen, um nicht so
lange suchen zu müssen wie ich.
Ich verwende ein STM32F4xx. In diesem speziellen Beispiel will ich die
DMA verwenden. Dazu schalte ich den Takt der Periperie "DMA" an und
schreibe unmittelbar danach in ein Register:
1 | STM32_RCC->AHB1ENR |= STM32_RCC_AHB1ENR_DMA1EN; /*DMA 1 enable*/
|
2 | /*DMA - Stream 5 - Channel 1 = I2C1_RX*/
|
3 | STM32_DMA1_S5->CR = DMA_SxCR_CHSEL_0 | DMA_SxCR_MINC;
|
4 | STM32_DMA1_S5->PAR = & STM32_I2C1->DR;
|
Das führt reproduzierbar dazu, das im CR-register nicht geschrieben
werden kann, Danach ist das Register leer, wie zuvor. Im PAR-Register
nur einen Befehl später schon. Das heisst für mich, die Baugruppe
braucht eine gewisse Zeit um loszulaufen. Und tatsächlich genügt es
einige andere Befehle, z.B. nop, einzufügen und das schreiben klappt.
Vermutlich reicht auch ein Sprung eine Subroutine aus (vgl Beispiele von
ST).
Im Errata und im Datasheet habe ich nichts dazu finden können. Ich weiss
auch nicht ob das bei anderen Peripherieeinheiten problematisch ist.
Achtet mal darauf und berichtet, wenn es ähnliche Probleme gibt.
MfG
Rangi