Difference between revisions of "Custom Interrupts - AVR"
(9 intermediate revisions by 3 users not shown) | |||
Line 7: | Line 7: | ||
[[File:Gen_Customer_Interrupts_AVR_USART.png|right]] | [[File:Gen_Customer_Interrupts_AVR_USART.png|right]] | ||
− | |||
The Flowcode RS232 component can be used to set the Baud rate and configure the mode of operation, and the ReceiveRS232Char function can be used in the handler macro to read the data (clearing the interrupt). | The Flowcode RS232 component can be used to set the Baud rate and configure the mode of operation, and the ReceiveRS232Char function can be used in the handler macro to read the data (clearing the interrupt). | ||
Line 28: | Line 27: | ||
{ | { | ||
− | FCM_%n(); // | + | FCM_%n(); // Call Flowcode Macro |
− | |||
− | |||
− | |||
− | |||
+ | }</font> | ||
Line 51: | Line 47: | ||
− | '''Disable code:'' | + | '''Disable code:''' |
<span style="color:#000080"> ACSR &= ~(1 << ACIE); // disable comparator interrupts </span> | <span style="color:#000080"> ACSR &= ~(1 << ACIE); // disable comparator interrupts </span> | ||
Line 62: | Line 58: | ||
{ | { | ||
− | FCM_%n(); // | + | FCM_%n(); // Call Flowcode Macro |
− | } </font> | + | }</font> |
Line 98: | Line 94: | ||
{ | { | ||
− | FCM_%n(); // | + | FCM_%n(); // Call Flowcode Macro |
}</font> | }</font> | ||
Line 108: | Line 104: | ||
<span style="color:#000080"> FCV_CAPTVAL = ICR1; </span> | <span style="color:#000080"> FCV_CAPTVAL = ICR1; </span> | ||
− | + | {| width="auto" | |
− | + | |<pre>** captval must be declared as an integer variable **</pre> | |
+ | |} |
Latest revision as of 12:11, 3 July 2019
Target AVR Processor ( ATMEGA8, 16, 32 )
(Note: For other AVR devices you may have to refer to the device datasheet to obtain the correct code)
USART Receive
The Flowcode RS232 component can be used to set the Baud rate and configure the mode of operation, and the ReceiveRS232Char function can be used in the handler macro to read the data (clearing the interrupt).
Enable code:
UCSRB |= ((1 << RXCIE) | (1 << RXEN)); // enable USART receiver and receive interrupts
Disable code:
UCSRB &= ~(1 << RXCIE); // disable USART receive interrupts
Handler code:
ISR(USART_RXC_vect) // USART receive vector
{
FCM_%n(); // Call Flowcode Macro
}
Analogue Comparator
Enable code:
SFIOR &= ~(1 << ACME); // disable multiplexer input
ACSR |= (1 << ACIE); // enable comparator interrupts - interrupt when comparator output toggles
Disable code:
ACSR &= ~(1 << ACIE); // disable comparator interrupts
Handler code:
ISR(ANA_COMP_vect) // analogue comparator interrupt vector
{
FCM_%n(); // Call Flowcode Macro
}
The state of the comparator input can be read into a Flowcode variable 'compstate' with the following C code line:
FCV_COMPSTATE = ACSR & (1 << ACO);
Timer1 Rollover
Enable code:
TCCR1B = 0x45; // positive edge trigger with no noise canceler, prescaler = /1024
TIMSK |= (1 << TICIE1); // enable input capture interrupts
Disable code:
TIMSK &= ~(1 << TICIE1); // disable input capture interrupts
Handler code:
ISR(TIMER1_CAPT_vect) // input capture vector
{
FCM_%n(); // Call Flowcode Macro
}
The captured 16-bit count value can be read into a Flowcode variable 'captval' with the following C code line:
FCV_CAPTVAL = ICR1;
** captval must be declared as an integer variable ** |