Forum: Mikrocontroller und Digitale Elektronik script: worst-case Laufzeit von AVR ISRs ermitteln


von znuh (Gast)


Lesenswert?

Hi!

Kennen vllt. manche das Problem: ISR darf wegen Echtzeit-Anforderung 
nicht länger als N cycles laufen. Von Hand abzählen ist etwas unbequem. 
Ich hab also mal mit nem kleinen Perlscript angefangen, das längsten 
Pfad + Laufzeit von ner schleifenfreien ISR ermittelt.

Sieht dann z.B. so aus:

1: rjmp INT_0 (4 + 2)
INT_0:
54: in t0cnt, TCNT0 (6 + 1)
55: cpi ovf, 1 (7 + 1)
56: brlo NO_OVF (8 + 1/2)
  NO_OVF:
  67: mov temp, t0cnt (10 + 1)
  68: sub temp, t0last (11 + 1)
  69: cpi temp, 45 (12 + 1)
  70: brsh LONG_DELTA (13 + 1/2)
    LONG_DELTA:
...
    129: mov t0last, t0cnt (33 + 1)
    130: clr ovf (34 + 1)
    131: reti  (35 + 4)
    => 39 cycles
  128: sbi PORTB, PB2 (32 + 2)
  129: mov t0last, t0cnt (34 + 1)
  130: clr ovf (35 + 1)
  131: reti  (36 + 4)
  => 40 cycles
...
max: 62 cycles

Einschränkungen:
* kennt nicht alle Instructions
* skip-Befehle rechnen immer mit 1/2 cycles - auch wenn 2 worte 
überspringen werden
* kann keine Schleifen (das zu ändern ist nicht ganz trivial)
* Keine Garantie, dass darüber hinaus kein Bug drin ist - ehrliche 
Finder bitte melden

Wer's trotzdem brauchen kann oder erweitern will:
* Code liegt hier: http://github.com/znuh/unsorted/blob/master/trace.pl
* Instruction-Tabelle braucht man noch: 
http://github.com/znuh/unsorted/blob/master/ins.txt
* Beispiel AVRcode liegt hier: 
http://github.com/znuh/unsorted/blob/master/main.asm

von spess53 (Gast)


Lesenswert?

Hi

>ennen vllt. manche das Problem: ISR darf wegen Echtzeit-Anforderung
>nicht länger als N cycles laufen. Von Hand abzählen ist etwas unbequem.
>Ich hab also mal mit nem kleinen Perlscript angefangen, das längsten
>Pfad + Laufzeit von ner schleifenfreien ISR ermittelt.

Als Programmierübung nicht schlecht. Mir reicht da allerdings der 
Simulator. Ohne Einschränkungen.

MfG Spess

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.