Forum: Mikrocontroller und Digitale Elektronik STM32: Interrupt manchmal zu langsam


von lars (Gast)


Lesenswert?

Auf einem STM32F7 mit 160 MHz habe ich einen externen Interrupt mit 
Handler geschrieben, der innerhalb von 700 ns ein bestimmtes Signal 
ausgeben soll. Dazu habe ich alle verwendeten Funktionen ins ITCM-RAM 
gelegt und verzichte auf den HAL.
1
void EXTI3_IRQHandler(void) __attribute__((section(".itcm_text")));
2
void signalFunktion(void) __attribute__((section(".itcm_text")));
3
4
void EXTI3_IRQHandler(void)
5
{
6
  __HAL_GPIO_EXTI_CLEAR_IT(GPIO_PIN_3);
7
  __disable_irq();
8
  signalFunktion();
9
  __enable_irq();
10
}

Innerhalb von 3 Sekunden wird der Interrupt ca. 100.000 Mal ausgelöst 
und funktioniert auch so wie gewünscht.

Aber in 20 Fällen wird die Interrupt-Auslösung um ca. 350 ns verzögert, 
sodass das Zeitlimit gerissen wird.

Ich nehme an, die Verzögerung liegt an den anderen Aufgaben, die der 
STM32 zu erledigen hat. Allerdings verwende ich bisher keine Peripherie 
außer GPIO und SDMMC1, wobei letztere inaktiv ist.

Wie kann ich diese Verzögerungen verhindern? Kann ich weitere Teile des 
STM32, insb. bestimmte Interrupts (SysTick?) abschalten?

von Uwe B. (Firma: TU Darmstadt) (uwebonnes)


Lesenswert?

Versuche doch erst einmal die Interrupts zu priorisieren.

von lars (Gast)


Lesenswert?

Uwe B. schrieb:
> Versuche doch erst einmal die Interrupts zu priorisieren.

Gar keine schlechte Idee. :-)

Ich habe jetzt
1
HAL_NVIC_SetPriority(SysTick_IRQn, 1, 0);
2
HAL_NVIC_SetPriority(FLASH_IRQn, 1, 0);
3
HAL_NVIC_SetPriority(SDMMC1_IRQn, 1, 0);
4
HAL_NVIC_SetPriority(RCC_IRQn, 1, 0);
5
HAL_NVIC_SetPriority(WWDG_IRQn, 1, 0);
6
HAL_NVIC_SetPriority(EXTI3_IRQn, 0, 0);

gesetzt, und damit funktioniert es. Ich kann noch ein wenig 
herumspielen, welcher Interrupt hier der Auslöser ist, aber fürs Erste 
funktioniert es!

Was mich allerdings wundert: CubeMX setzt SysTick auf Prio 0, dabei hat 
der Prio -1 und kann damit gar nicht verändert werden?!

von (prx) A. K. (prx)


Lesenswert?

lars schrieb:
> Was mich allerdings wundert: CubeMX setzt SysTick auf Prio 0, dabei hat
> der Prio -1 und kann damit gar nicht verändert werden?!

Woher kommt die Idee, das ginge nicht? Wäre ziemlich sinnfrei.
Siehe System Handler Priority Register 3, SHPR3.
http://infocenter.arm.com/help/index.jsp?topic=/com.arm.doc.dui0646a/CIAGECDD.html

von Carl D. (jcw2)


Lesenswert?

Das Cortext-M3 Manual sagt:
"Configurable priorities for all exceptions
except Reset, Hard fault, and NMI"

von Dr. Sommer (Gast)


Lesenswert?

Wenn dein Interrupt hohe Priorität hat, brauchst du auch das 
__disable_irq(); nicht.

von Jim M. (turboj)


Lesenswert?

lars schrieb:
> Was mich allerdings wundert: CubeMX setzt SysTick auf Prio 0, dabei hat
> der Prio -1 und kann damit gar nicht verändert werden?!

Doch, kann sie. Das NVIC_SetPriority() funktioniert auch für den Systick 
- schau Dir das Makro mal im CMSIS Header an.

von lars (Gast)


Lesenswert?

OK, danke, ich bin überzeugt. Dann habe ich das "Mastering STM32"-Buch 
falsch verstanden.

von Chris J. (Gast)


Angehängte Dateien:

Lesenswert?

lars schrieb:
> insb. bestimmte Interrupts (SysTick?) abschalten?

ja, den kann man abschalten. Mit dem letzten Bit ziehst du die 
Handbremse an und es wird keine ISR mehr ausgelöst. Zumindest hier bei 
M0.

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
Noch kein Account? Hier anmelden.