www.mikrocontroller.net

Forum: Mikrocontroller und Digitale Elektronik STM32F4 Interrupt zu früh


Important 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: Gnubbel (Gast)
Datum:
Angehängte Dateien:

Diesen Beitrag bewerten:
lesenswert
nicht lesenswert
Hallo,

ich habe auf dem Discovery den SPI1 am laufen und bin auf das Problem 
gestoßen dass der TXE interrupt zu früh kommt. Das ganze hängt mit der 
Taktfrequenz des SPI zusammen, wenn der Vorteiler 16 ist funktionierts, 
wenn der Vorteiler 32 oder 64 ist funktioniert es nicht.

Gibt es eine minimalfrequenz oder so etwas?

Auf dem Bild ist die Stelle markiert wenn der Interrupt angesprungen 
wird und das /CS wieder hochgezogen wird. Dieses sollte erst erfolgen 
wenn alle acht Bit weg sind, und nicht nach drei Bit.

Folgendes wird initialisiert:

 *        Supported STM32F4xx device revision    | Rev A
  *----------------------------------------------------------------------- 
------
  *        System Clock source                    | PLL (HSE)
  *----------------------------------------------------------------------- 
------
  *        SYSCLK(Hz)                             | 168000000
  *----------------------------------------------------------------------- 
------
  *        HCLK(Hz)                               | 168000000
  *----------------------------------------------------------------------- 
------
  *        AHB Prescaler                          | 1
  *----------------------------------------------------------------------- 
------
  *        APB1 Prescaler                         | 4
  *----------------------------------------------------------------------- 
------
  *        APB2 Prescaler                         | 2
  *----------------------------------------------------------------------- 
------
  *        HSE Frequency(Hz)                      | 8000000

Autor: LTC1043 (Gast)
Datum:

Diesen Beitrag bewerten:
lesenswert
nicht lesenswert
TXE sagt dir nur dass du ein weiteres Byte in den BTX-Buffer schreiben 
kannst.

TXE Signalisiert dir aber nicht wenn das letzte Byte komplett gesendet 
wurde. Desshalb darfst du dein /CS nicht im TXE IRQ Handler setzen.

Du kannst aber das BSY Flag auswerten (leider ohne IRQ) oder den RXE IRQ 
verwenden.

Cheers

Autor: Gnubbel (Gast)
Datum:

Diesen Beitrag bewerten:
lesenswert
nicht lesenswert
Supi, danke.

Autor: en Spra (Gast)
Datum:

Diesen Beitrag bewerten:
lesenswert
nicht lesenswert
Man könnte aber CS einfach stehen lassen
und erst bei der nächsten Übertragung kurz einen
High-Puls erzeugen.

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




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 erkennst du die Nutzungsbedingungen an.

webmaster@mikrocontroller.netImpressumNutzungsbedingungenWerbung auf Mikrocontroller.net