Hallo,
ich möchte Laufzeiten von Programmcode mit den Timer messen.
Dazu habe ich den Timer5 genommen, lasse diesen frei laufen, setze dann 
einmal das CNT Register zurück, führe meinen Code aus und frage CNT 
anschliessend wieder ab.
Die Timer-Einstellung passt soweit. Kontrolliert habe ich das durch das 
Toggeln einer LED, welche jede Sekunde ihren Zustand wechselt.
(Timer zählt bis 100 Millionen).
Die Laufzeitmessung passt allerdings vorne und hinten nicht. Die 
Laufzeiten sind viel zu hoch. Ich messe beim Debugging zwischen zwei 
Codezeilen zufällige Werte zwischen 0,3 - 0,8 Sekunden. Debuggen lässt 
sich das auch nicht richtig. Zwischen StartTiming() und StopTiming() 
fliegt der Debugger in die ISR Routine. Wenn ich die Haltepunkte nur 
ganz am Ende setze bei zeit = ReturnTiming() habe ich dennoch viel zu 
hohe Werte.
Das CNT Register ist lt. Reference "rw".
Hier die main
•
| 1 | uint32_t Zeitspanne = 0;
 | 
| 2 | 
 | 
| 3 | //main
 | 
| 4 | uint32_t zeit = 0;
 | 
| 5 |   
 | 
| 6 |   Timer5Init();                         
 | 
| 7 |   StartTiming();
 | 
| 8 |   for(int i = 0 ; i< 1000;i++)
 | 
| 9 |   {}
 | 
| 10 |   StopTiming();
 | 
| 11 |   zeit = ReturnTiming();
 | 
| 12 | 
 | 
| 13 | //Funktionen
 | 
| 14 | 
 | 
| 15 | void Timer5Init()
 | 
| 16 | {
 | 
| 17 | TIM5_PSC     = 0;                                      
 | 
| 18 | TIM5_ARR     = 100000000 ;                        
 | 
| 19 | TIM5_DIER   |= 1;                                      
 | 
| 20 | TIM5_CR1    |= 1;                                      
 | 
| 21 | }
 | 
| 22 | 
 | 
| 23 | 
 | 
| 24 | void StartTiming()
 | 
| 25 | {  
 | 
| 26 | TIM5_CNT = 0x00000000;                                
 | 
| 27 | }
 | 
| 28 | 
 | 
| 29 | void StopTiming()
 | 
| 30 | {
 | 
| 31 | zeitspanne = TIM5_CNT;                               
 | 
| 32 | }
 | 
| 33 | 
 | 
| 34 | uint32_t ReturnTiming()
 | 
| 35 | {
 | 
| 36 | return (zeitspanne/100);     //Rückgabe der Zeit in µs
 | 
| 37 | }
 | 
| 38 | 
 | 
| 39 | //IR
 | 
| 40 | 
 | 
| 41 | void TIM5_IRQHandler(void)
 | 
| 42 | {
 | 
| 43 |   TIM5_SR = 0x0; 
 | 
| 44 |   GPIOE_BRRS = (GPIOE_ODR ^ 0x8000) | (0x8000 << 16); //LED toggeln
 | 
| 45 | }
 |