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
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
Man könnte aber CS einfach stehen lassen und erst bei der nächsten Übertragung kurz einen High-Puls erzeugen.
Bitte melde dich an um einen Beitrag zu schreiben. Anmeldung ist kostenlos und dauert nur eine Minute.
Bestehender Account
Schon ein Account bei Google/GoogleMail? Keine Anmeldung erforderlich!
Mit Google-Account einloggen
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.