Forum: Compiler & IDEs int0 vom atemag32 in der introutine stoppen.


von anfänger (Gast)


Lesenswert?

hallo, kann man den int0 in der routine so kurzfristig ausschalten?

ISR(INT0_vect)
{

  encoder_li = encoder_li+1;

  if(encoder_li >= enc_wert)
    {
      GIMSK &= ~(1<<INT0);
      robby_aus();
      encoder_li=0;
      encoder_re=0;
    }

  GIFR=_BV(INTF1)|_BV(INTF0);
}

ich schalte ihn in einer anderen routine, die ich festlege wieder ein.

mfg

von Johannes M. (johnny-m)


Lesenswert?

Warum nicht? Wüsste nicht, was dagegen spricht...

von Matthias L. (Gast)


Lesenswert?

Ja das geht.

Tip: Das ist dasselbe:
1
ISR(INT0_vect)
2
{
3
  if(++encoder_li >= enc_wert)
4
    {
5
      GIMSK &= ~(1<<INT0);
6
      robby_aus();
7
      encoder_li=0;
8
      encoder_re=0;
9
    }
10
11
  GIFR=_BV(INTF1)|_BV(INTF0);
12
}

von Peter D. (peda)


Lesenswert?

Das Löschen des Interruptflags macht man sinniger Weise aber erst direkt 
vor der nächsten Freigabe.
Es sein denn, man will wirklich auf uralte Ereignisse triggern.

Flags, die mit dem Interupt nichts zu tun haben (INTF1) muß man auch 
nicht löschen.


Peter

von anfänger (Gast)


Lesenswert?

...Das Löschen des Interruptflags macht man sinniger Weise aber erst 
direkt
vor der nächsten Freigabe.....

das verstehe ich nicht.
ich möchte einmal das robboter beim vorwärtsfahren eine bestimmte 
strecke fährt, dann soll es wieder manuel weitergehen ohne encoder.
darum versteh ich deine antwort nicht. kurz vor der freigabe heisst für 
mich, der int0 ist noch aktiv , obwohl ich ihn nicht brauche und kurz 
bevor ich ihn wieder aktiviere wird er vorher deaktiviert.

mfg

von Peter D. (peda)


Lesenswert?

anfänger wrote:
> ...Das Löschen des Interruptflags macht man sinniger Weise aber erst
> direkt
> vor der nächsten Freigabe.....
>
> das verstehe ich nicht.

Ein Interruptflag wird gesetzt, wenn das entsprechende Ereignis 
eintritt. Ob dabei der Interrupt enabled ist, ist wurscht.
Man kann also auch das Flag pollen, wird z.B. bei der UART oft gemacht. 
Oder wenn man mit nem Timer ein Delay macht.

Wird nun der Interrupt wieder enabled, will man in der Regel nicht auf 
uralte Ereignisse triggern, daher das Flag direkt davor löschen.

Wird der Interrupt disabled, braucht man dagegen das Flag nicht zu 
löschen, da ja kein Interrupt erfolgen kann.


Peter

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.