Hab da ein Problem mit der SPI eines UC3A1512.
Wie man im Quelltext sieht, habe ich in der Interruptroutine (spi_irq)
alle möglichen Interruptquellen aufgeführt und in jedes einen Breakpoint
gelegt. Bis auf TXEMPTY und TDRE (diese lösen merkwürdigerweise immer
aus) habe ich alle aktiviert. Wenn nun das SPI Signal (Osci-Bild)
ankommt, wird keiner der Breakpoints angesprungen (noch nichtmal die
Interruptroutine aufgerufen). Im Osci-Bild ist der Kanal 1 der
Chipselect und wird deutlich vorher und nachher bewegt, deshalb sieht
man dessen Flanken hier nicht.
Zur Verdrahtung:
Chipselect (Kanal 1, gelb auf Osci-Bild): Pin 39 SPI1-CS0
MISO (Kanal 4, grün, nicht zu sehen): Pin 42 MISO1
MOSI (Kanal 3, pink): Pin 41 MOSI1
SCK (Kanal 2, blau): Pin40 SCK1
Wenn man alle SPI Interrupts aktiviert, werden TXEMPTY und TXRE dauernd
ausgelöst, warum? Wenn man die beiden weglässt, wird die
Interruptroutine nicht aufgerufen, warum? Könnte das an der
Initialisierung oder Verdrahtung liegen? Hab schon alles mehrmals
überprüft und seh die Ursache immer noch nicht. Kann mir da wer mit
einem Tip, Idee helfen? Hat jemand überhaupt schon mal den Slave-Mode
ausprobiert? Nachfragen erwünscht!
Schon mal Dank für die Mühe!
EDIT:
Manchmal sieht man den Wald vor lauter Bäumen nicht mehr.
Ok in der Initialisierung muss man natürlich noch die I/O der SPI
zuweisen, dann klappt es auch mit den Interrupts :-)))
1 | static const gpio_map_t SPI1_GPIO_MAP =
|
2 | {
|
3 | {SPI1_SCK_PIN, SPI1_SCK_FUNCTION }, // SPI Clock.
|
4 | {SPI1_MISO_PIN, SPI1_MISO_FUNCTION}, // MISO.
|
5 | {SPI1_MOSI_PIN, SPI1_MOSI_FUNCTION}, // MOSI.
|
6 | {SPI1_NPCS_PIN, SPI1_NPCS_FUNCTION}, // Chip Select NPCS.
|
7 | };
|
8 |
|
9 | gpio_enable_module(SD_MMC_SPI_GPIO_MAP, sizeof(SD_MMC_SPI_GPIO_MAP) / sizeof(SD_MMC_SPI_GPIO_MAP[0]));
|