mikrocontroller.net

Forum: Mikrocontroller und Digitale Elektronik STM32F4 RCC Enable-Problem


Announcement: there is an English version of this forum on EmbDev.net. Posts you create there will be displayed on Mikrocontroller.net and EmbDev.net.
Autor: Rangi J. (rangi)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
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:
STM32_RCC->AHB1ENR |= STM32_RCC_AHB1ENR_DMA1EN;  /*DMA 1 enable*/
/*DMA - Stream 5 - Channel 1 = I2C1_RX*/
STM32_DMA1_S5->CR = DMA_SxCR_CHSEL_0 | DMA_SxCR_MINC;
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

Autor: Hans (Gast)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
danke

Autor: Markus M. (mmvisual)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
Vielen Dank!
Ich habe im Artikel
http://www.mikrocontroller.net/articles/STM32#Errata_vom_STM32F4xx_die_nicht_im_Errata_von_ST_stehen

einen Punkt
"Errata vom STM32F4xx die nicht im Errata von ST stehen "
hinzugefügt.

Es gab mal wo anders einen Thread wo auch was aufgelistet war, finde das 
aber gerade nicht mehr.

Antwort schreiben

Die Angabe einer E-Mail-Adresse ist freiwillig. Wenn Sie automatisch per E-Mail über Antworten auf Ihren Beitrag informiert werden möchten, melden Sie sich bitte an.

Wichtige Regeln - erst lesen, dann posten!

  • Groß- und Kleinschreibung verwenden
  • Längeren Sourcecode nicht im Text einfügen, sondern als Dateianhang

Formatierung (mehr Informationen...)

  • [c]C-Code[/c]
  • [avrasm]AVR-Assembler-Code[/avrasm]
  • [code]Code in anderen Sprachen, ASCII-Zeichnungen[/code]
  • [math]Formel in LaTeX-Syntax[/math]
  • [[Titel]] - Link zu Artikel
  • Verweis auf anderen Beitrag einfügen: Rechtsklick auf Beitragstitel,
    "Adresse kopieren", und in den Text einfügen




Bild automatisch verkleinern, falls nötig
Bitte das JPG-Format nur für Fotos und Scans verwenden!
Zeichnungen und Screenshots im PNG- oder
GIF-Format hochladen. Siehe Bildformate.
Hinweis: der ursprüngliche Beitrag ist mehr als 6 Monate alt.
Bitte hier nur auf die ursprüngliche Frage antworten,
für neue Fragen einen neuen Beitrag erstellen.

Mit dem Abschicken bestätigst du, die Nutzungsbedingungen anzuerkennen.