Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revisionPrevious revision
Next revision
Previous revision
et:avr:external_interrupts [2010/02/12 15:34] mikk.leiniet:avr:external_interrupts [2020/07/20 09:00] (current) – external edit 127.0.0.1
Line 14: Line 14:
 Lähtudes tööpõhimõttelt, on väliseid katkestusi kahte liiki: kontrolleri taktiga sünkroniseeritud ja asünkroonsed. Sünkroniseeritud katkestused toimivad sisendite väärtuse meelespidamise teel, mis tähendab, et loogilised muutused leitakse kahel erineval taktil saadud väärtuste võrdlemise teel. Kui välise signaali loogilised muutused toimuvad kiiremini, kui käib töötakt, siis katkestused, kas ei teki õigesti või jäävad üldse vahele. Asünkroonsed katkestused ei sõltu kontrolleri taktist ja võimaldavad tuvastada ka kiiremini muutuvat välist signaali - loogilist nivood peab signaal hoidma vähemalt 50 ns. ATmega128-l on 4 sünkroniseeritud ja 4 asünkroonset välist katkestust. Lähtudes tööpõhimõttelt, on väliseid katkestusi kahte liiki: kontrolleri taktiga sünkroniseeritud ja asünkroonsed. Sünkroniseeritud katkestused toimivad sisendite väärtuse meelespidamise teel, mis tähendab, et loogilised muutused leitakse kahel erineval taktil saadud väärtuste võrdlemise teel. Kui välise signaali loogilised muutused toimuvad kiiremini, kui käib töötakt, siis katkestused, kas ei teki õigesti või jäävad üldse vahele. Asünkroonsed katkestused ei sõltu kontrolleri taktist ja võimaldavad tuvastada ka kiiremini muutuvat välist signaali - loogilist nivood peab signaal hoidma vähemalt 50 ns. ATmega128-l on 4 sünkroniseeritud ja 4 asünkroonset välist katkestust.
  
-~~PB~~+Atmeli xmega seeria kontrolleritel on välised katkestused realiseeritud natuke erinevalt võrreldes tavaliste 8-bitiste kontrolleritega. Atmeli xmega seerial on igale siinile omistatud kaks välist katkestust INT0 ja INT1, mis on võimalik kasutades biti maski ühendada suvalise siini viiguga (või mitmega korraga). 
  
 <box 100% round #EEEEEE|Näide> <box 100% round #EEEEEE|Näide>
  
 Vaja on panna ATmega128 viik number 9 ehk siini E viik 7 tekitama katkestust, kui selle väärtus muutub. Sellele viigule vastab väline katkestus INT7, mis on sünkroonne. Vaja on panna ATmega128 viik number 9 ehk siini E viik 7 tekitama katkestust, kui selle väärtus muutub. Sellele viigule vastab väline katkestus INT7, mis on sünkroonne.
- 
 <code c> <code c>
 #include <avr/interrupt.h> #include <avr/interrupt.h>
Line 29: Line 29:
 } }
  
-int main()+// Põhiprogramm 
 +int main(void)
 { {
  // Siini E viigu 7 muutmine sisendiks biti 7 nullimise teel  // Siini E viigu 7 muutmine sisendiks biti 7 nullimise teel
Line 49: Line 50:
  // Lõputu programmitsükkel  // Lõputu programmitsükkel
  while (1) continue;  while (1) continue;
 +}
 +</code>
 +
 +Xmega puhul otsime sisendi muutust viigul PORTE0:
 +
 +<code c>
 +#include <avr/interrupt.h>
 +
 +// Välise katkestuse programm
 +ISR(PORTE_INT0_vect)
 +{
 + // Tee midagi
 +}
 +
 +// Põhiprogramm
 +int main(void)
 +{
 + // Siini E viigu 0 muutmine sisendiks biti 0 nullimise teel
 + PORTE.DIR &= ~(PIN0_bm);
 +
 + // Siini E viigule 0 pull-up takisti määramine sisendi ujumise vastu
 + PORTE.PIN0CTRL = (PORT_OPC_PULLUP_gc);
 +
 + // Siini E viigu 0 katkestuse töörežiimi määramine
 + PORTE.PIN0CTRL |= (PORT_ISC_BOTHEDGES_gc);
 +
 + // Siini E INT0 katkestuse prioriteedi määramine
 + PORTE.INTCTRL |= (PORT_INT0LVL_MED_gc);
 +
 + // Viigu määramine siini E INT0 sisendiks
 + PORTC.INT0MASK = (PIN0_bm);
 +
 + // Keskmise prioriteediga katkestuste lubamine
 + PMIC.CTRL |= PMIC_MEDLVLEN_bm;
 +
 + // Globaalne katkestuste lubamine
 + sei();
 +
 + // Lõputu programmitsükkel
 + while (1){};
 } }
 </code> </code>
et/avr/external_interrupts.1265988851.txt.gz · Last modified: 2020/07/20 09:00 (external edit)
CC Attribution-Share Alike 4.0 International
www.chimeric.de Valid CSS Driven by DokuWiki do yourself a favour and use a real browser - get firefox!! Recent changes RSS feed Valid XHTML 1.0