# Interrupts - Fundamental concept in computation - Interrupt execution of a program to "handle" an event - Don't have to rely on program relinquishing control - Can code program without worrying about others - Issues - What can interrupt and when? - Where is the code that knows what to do? - How long does it take to handle interruption? - Can an interruption be, in turn, interrupted? - How does the interrupt handling code communicate its results? - How is data shared between interrupt handlers and programs? CSE 466 Interrupts # What is an Interrupt? - Reaction to something in I/O (human, comm link) - Usually asynchronous to processor activities - "interrupt handler" or "interrupt service routine" (ISR) invoked to take care of condition causing interrupt - Change value of internal variable (count) - Read a data value (sensor, receive) - Write a data value (actuator, send) CSE 466 Interrupts # Interrupts Code sample that does not interrupt ``` char SPI_SlaveReceive(void) { /* Wait for reception complete */ while(!(SPSR & (1<<SPIF))) ; /* Return data register */ return SPDR; }</pre> ``` Instead of busy waiting until a byte is received the processor can generate an interrupt when it sets SPIF ``` SIGNAL(SIG_SPI) { RX_Byte = SPDR } ``` CSE 466 Interrupts # Saving and Restoring Context - Processor and compiler dependent - Where to find ISR code? - Different interrupts have separate ISRs - Who does dispatching? - Direct - Different address for each interrupt type - Supported directly by processor architecture - Indirect - One top-level ISR - Switch statement on interrupt type - A mix of these two extremes? CSE 466 # Saving and Restoring Context - How much context to save? - Registers, flags, program counter, etc. - Save all or part? - Agreement needed between ISR and program - Where should it be saved? - Stack, special memory locations, shadow registers, etc. - How much room will be needed on the stack? - Nested interrupts may make stack reach its limit what then? - Restore context when ISR completes CSE 466 Interrupts 5 # Ignoring Interrupts - Can interrupts be ignored? - It depends on the cause of the interrupt - No, for nuclear power plant temperature warning - Yes, for keypad on cell phone (human timescale is long) - When servicing another interrupt - Ignore others until done - Can't take too long keep ISRs as short as possible - Just do a quick count, or read, or write not a long computation - Interrupt disabling - Will ignored interrupt "stick"? - Rising edge sets a flip-flop - Or will it be gone when you get to it? - Level changes again and its as if it never happened - Don't forget to re-enable CSE 466 Interrupts # Prioritizing Interrupts - When multiple interrupts happen simultaneously - Which is serviced first? - Fixed or flexible priority? - Priority interrupts - Higher priority can interrupt - Lower priority can't - Maskable interrupts - "don't bother me with that right now" - Not all interrupts are maskable, some are non-maskable CSE 466 Interrupts # Interrupts in the ATmega16 - External interrupts - □ From I/O pins of microcontroller - Internal interrupts - Timers - Output compare - Input capture - Overflow - Communication units - Receiving something - Done sending - ADC - Completed conversion CSE 466 ## Shared Data Problem - When you use interrupts you create the opportunity for multiple sections of code to update a variable. - This might cause a problems in your logic if an interrupt updates a variable between two lines of code that are directly dependent on each other (e.g. if statement) - One solution is to create critical sections where you disable the interrupts for a short period of time while you complete your logic on the shared variable ``` cli(); .....critical section code goes here..... sei(); ``` CSE 466 Interrupts 11 ## External Interrupts General Interrupt Control Register – GICR Special pins: INT0, INT1, INT2 Can interrupt on edge or level Can interrupt even if set to be output pins Implements "software interrupts" by setting output The MCU Control Register contains control bits for interrupt sense control and general MCU Control Register – MCUCR Initial Value ISC11 ISC10 Description 0 0 The low level of INT1 generates an interrupt request. 0 1 Any logical change on INT1 generates an interrupt request. CSE 466 Interrupts 12 The falling edge of INT1 generates an interrupt request The rising edge of INT1 generates an interrupt request. ## Closer Look at a Timer/Counter Timer0/Counter0 Clear timer on compare match (auto reload) Prescaler (divide clock by up to 1024) Overflow and compare match interrupts Registers Configuration Count value Tn воттом TOP Output compare value = 0 = 0xFF OCn CSE 466 Interrupts ## Timer/Counter Registers Timer/Counter Bit 7 – FOC0: Force Output Compare The FOCO bit is only active when the WGM00 bit specifies a non-PWM mode. However, for ensuring compatibility with future devices, this bit must be set to zero when TCCR0 is written when operating in PWM mode. When writing a logical one to the FOCO bit, an immediate compare match is forced on the Waveform Generation unit. The OCO output is changed according to its CoM01:0 bits setting. Note that the FOCO bit is implemented as a strobe. Therefore it is the value present in the COM01:0 bits that determines the effect of the forced compare. **Control Register** TCCR0 A FOC0 strobe will not generate any interrupt, nor will it clear the timer in CTC mode using OCR0 as TOP. The FOC0 bit is always read as zero • Bit 6, 3 – WGM01:0: Waveform Generation Mode These bits control the counting sequence of the counter, the source for the maximum (TOP) counter value, and what type of Waveform Generation to be used. Modes of operation supported by the Timer/Counter unit are: Normal mode, Clear Timer on Compare Match (CTC) mode, and two types of Pulse Width Modulation (PWM) modes. See Table 38 and "Modes of Operation" on page 74. Table 38. Waveform Generation Mode Bit Description<sup>(1)</sup> Mode (CTC0) (PWM0) Timer/Counter Mode of Operation ТОР 0 0 Normal 0xFF Immediate MAX PWM, Phase Correct 0xFF TOP BOTTOM OCR0 Immediate MAX 1 Fast PWM 0xFF TOP MAX The CTC0 and PWM0 bit definition names are now obsolete. Use the WGM01:0 def-initions. However, the functionality and location of these bits are compatible with previous versions of the timer. Interrupts CSE 466 # Timer/Counter Registers (cont'd) ## Timer/Counter Control Register TCCR0 ## • Bit 5:4 - COM01:0: Compare Match Output Mode These bits control the Output Compare pin (OC0) behavior. If one or both of the COM01:0 bits are set, the OC0 output overrides the normal port functionality of the I/O pin it is connected to. However, note that the Data Direction Register (DDR) bit corresponding to the OC0 pin must be set in order to enable the output driver. When OC0 is connected to the pin, the function of the COM01:0 bits depends on the WGM01:0 bit setting. Table 39 shows the COM01:0 bit functionality when the WGM01:0 bits are set to a normal or CTC mode (non-PWM). Table 39. Compare Output Mode, non-PWM Mode | COM01 | COM00 | Description | | | | |-------|-------|------------------------------------------|--|--|--| | 0 | 0 | Normal port operation, OC0 disconnected. | | | | | 0 | 1 | Toggle OC0 on compare match | | | | | 1 | 0 | Clear OC0 on compare match | | | | | 1 | 1 | Set OC0 on compare match | | | | CSE 466 Interrupts 15 # Timer/Counter Registers (cont'd) # Timer/Counter Control Register TCCR0 Bit 2: ## • Bit 2:0 - CS02:0: Clock Select The three Clock Select bits select the clock source to be used by the Timer/Counter. Table 42. Clock Select Bit Description | CS02 | CS01 | CS00 | Description | |------|------|------|---------------------------------------------------------| | 0 | 0 | 0 | No clock source (Timer/Counter stopped). | | 0 | 0 | 1 | clk <sub>I/O</sub> /(No prescaling) | | 0 | 1 | 0 | clk <sub>I/O</sub> /8 (From prescaler) | | 0 | 1 | 1 | clk <sub>I/O</sub> /64 (From prescaler) | | 1 | 0 | 0 | clk <sub>I/O</sub> /256 (From prescaler) | | 1 | 0 | 1 | clk <sub>I/O</sub> /1024 (From prescaler) | | 1 | 1 | 0 | External clock source on T0 pin. Clock on falling edge. | | 1 | 1 | 1 | External clock source on T0 pin. Clock on rising edge. | If external pin modes are used for the Timer/Counter0, transitions on the T0 pin will clock the counter even if the pin is configured as an output. This feature allows software control of the counting. # Setting Register Values - Defined names for each register and bit - Set timer to clear on match - Set prescaler to 1024 $$TCCR0 = (1 << WGM01) | (1 << CS02) | (1 << CS00);$$ Set count value to compare against $$OCR0 = 150;$$ Set timer to interrupt when it reaches count $$TIMSK = (1 << OCIE0);$$ # Writing an Interrupt Handler in C - Set and clear interrupt enable - sei(); - cli(); - Interrupt handler - Setting I/O registers - □ TCCR0 = (1<<WGM01) | (1<<CS02) | (1<<CS00); - Enabling specific interrupts - □ TIMSK = (1<<OCIE0); CSE 466 Interrupts Switch Debouncing # Analog to Digital Conversion # Basic ADC circuits (1) Simple ramp and comparator ADC Unknown analog input Digitizing begins with a 'start' pulse DAC is ramped up from zero counter stopped by comparator when Vin = DAC out ADC output is counter value Tracking ADC # Basic ADC circuits (2) This ADC circuit is limited and rarely used ## WHY - - slow - variable time to give result - input signal can vary during digitising - Successive Approximation ADC solves these problems using - complex logic to test and retain each DAC bit - a sample and hold circuit ahead of the comparator # A-to-D Conversion on the ATmega16 - 10-bit resolution (adjusted to 8 bits as needed) - 65-260 usec conversion time - 8 multiplexed input channels - Capability to do differential conversion - Difference of two pins - Optional gain on differential signal (amplifies difference) - Interrupt on completion of A-to-D conversion - 0-V<sub>CC</sub> input range - 2\*LSB accuracy (2 \* 1/1024 = ~0.2%) - Susceptible to noise special analog supply pin (AVCC) and capacitor connection for reference voltage (AREF) # A-to-D Conversion (cont'd) ADC Multiplexer Selection Register – ADMUX ## • Bit 7:6 - REF\$1:0: Reference Selection Bits These bits select the voltage reference for the ADC, as shown in Table 83. If these bits are changed during a conversion, the change will not go in effect until this conversion is complete (ADF in ADCSRA is set). The internal voltage reference options may not be used if an external reference voltage is being applied to the AREF pin. Table 83. Voltage Reference Selections for ADC | REFS1 | REF\$0 | Voltage Reference Selection | |-------|--------|----------------------------------------------------------------------| | 0 | 0 | AREF, Internal Vref turned off | | 0 | 1 | AVCC with external capacitor at AREF pin | | 1 | 0 | Reserved | | 1 | 1 | Internal 2.56V Voltage Reference with external capacitor at AREF pin | ### · Bit 5 - ADLAR: ADC Left Adjust Result The ADLAR bit affects the presentation of the ADC conversion result in the ADC Data Register. Write one to ADLAR to left adjust the result. Otherwise, the result is right adjusted. Chanqing the ADLAR bit will affect the ADC Data Register immediately. regardless of any ongoing conversions. For a complete description of this bit, see "The ADC Data Register – ADCL and ADCH" on page 218. CSE 466 Interrupts 31 # A-to-D Conversion (cont'd) ## Single-ended or differential - □ 1 of 8 single-ended - □ ADCx ADC1 at 1x gain - □ ADC{0,1} ADC0 at 10x - □ ADC{0,1} ADC0 at 200x - □ ADC{2,3} ADC2 at 10x - □ ADC{2,3} ADC3 at 200x - □ ADC{0,1,2,3,4,5} ADC2 at 1x The value of these bits selects which combination of analog inputs are connected to the ADC. These bits also select the gain for the differential channels. See Table 84 for details, if these bits are changed during a conversion, the change will not go in effect until this conversion is complete (ADIF in ADCSRA is set). Table 84. Input Channel and Gain Selections | MUX40 | Single Ended<br>Input | Positive Differential<br>Input | Negative Differential<br>Input | Gain | | |----------|-----------------------|--------------------------------|--------------------------------|------|--| | 00000 | ADC0 | | | | | | 00001 | ADC1 | | | | | | 00010 | ADC2 | | | | | | 00011 | ADC3 | N/A | | | | | 00100 | ADC4 | | | | | | 00101 | ADC5 | | | | | | 00110 | ADC6 | | | | | | 00111 | ADC7 | | | | | | 01000 | | ADC0 | ADC0 | 10x | | | 01001 | | ADC1 | ADC0 | 10x | | | 01010(1) | | ADC0 | ADC0 | 200x | | | 01011(1) | | ADC1 | ADC0 | 200x | | | 01100 | | ADC2 | ADC2 | 10x | | | 01101 | | ADC3 | ADC2 | 10x | | | 01110(1) | | ADC2 | ADC2 | 200x | | | 01111(1) | | ADC3 | ADC2 | 200x | | | 10000 | | ADC0 | ADC1 | 1x | | | 10001 | | ADC1 | ADC1 | 1x | | | 10010 | N/A | ADC2 | ADC1 | 1x | | | 10011 | | ADC3 | ADC1 | 1x | | | 10100 | | ADC4 | ADC1 | 1x | | | 10101 | | ADC5 | ADC1 | 1x | | | 10110 | | ADC6 | ADC1 | 1x | | | 10111 | | ADC7 | ADC1 | 1x | | | 11000 | | ADC0 | ADC2 | 1x | | | 11001 | | ADC1 | ADC2 | 1x | | | 11010 | | ADC2 | ADC2 | 1x | | | 11011 | | ADC3 | ADC2 | 1x | | | 11100 | | ADC4 | ADC2 | 1x | | CSE 466 Interrupts # A-to-D Conversion (cont'd) Special FunctionIO Register – SFIOR Bit 7:5 – ADTS2:0: ADC Auto Trigger Source • Bit (15 - ADI 52:0: ADC. Auto Trigger Source) If ADATE in ADCSRA is written to one, the value of these bits selects which source will trigger an ADC conversion. If ADATE is cleared, the ADTS2:0 settings will have no effect. A conversion will be triggered by the rising edge of the selected Interrupt Flag. Note that switching from a trigger source that is eta. Will generate a positive edge on the trigger source that is set, will generate a positive edge on the trigger signal. If ADEN in ADCSRA is set, this will start a conversion. Switching to Free Running mode (ADTS[2:0]=0) will not cause a trigger event, even if the ADC Interrupt Flag is set. Table 86. ADC Auto Trigger Source Selections | ADTS2 | ADTS1 | ADTS0 | Trigger Source | |-------|-------|-------|-------------------------------| | 0 | 0 | 0 | Free Running mode | | 0 | 0 | 1 | Analog Comparator | | 0 | 1 | 0 | External Interrupt Request 0 | | 0 | 1 | 1 | Timer/Counter0 Compare Match | | 1 | 0 | 0 | Timer/Counter0 Overflow | | 1 | 0 | 1 | Timer/Counter Compare Match B | | 1 | 1 | 0 | Timer/Counter1 Overflow | | 1 | 1 | 1 | Timer/Counter1 Capture Event | • Bit 4 - Res: Reserved Bit This bit is reserved for future use. To ensure compatibility with future devices, this bit must be written to zero when SFIOR is written. CSE 466 Interrupts 35 # Writing an Interrupt Handler in C (again) - Ensure main program sets up all registers - Enable interrupts as needed - Enable global interrupts (SEI) - Write handler routine for each enabled interrupt - What if an interrupt occurs and a handler isn't defined? - Make sure routine does not disrupt others - Data sharing problem - Save any state that might be changed (done by compiler) - Re-enable interrupts upon return - done by compiler with RETI CSE 466 Sleep modes # Power modes - Processor can go to "sleep" and save power - Different modes put different sets of modules to sleep - Which one to use depends on which modules are needed to wake up processor - □ Timers, external interrupts, ADC, serial communication lines, etc. - set\_sleep\_mode (mode); - sleep\_mode (); # Power modes (cont'd) MCU Control Register – MCUCR The MCU Control Register contains control bits for power management. • Bits 7, 5, 4 - SM2..0: Sleep Mode Select Bits 2, 1, and 0 These bits select between the six available sleep modes as shown in Table 13. Table 13. Sleep Mode Select | SM2 | SM1 | SM0 | Sleep Mode | |-----|-----|-----|---------------------------------| | 0 | 0 | 0 | Idle | | 0 | 0 | 1 | ADC Noise Reduction | | 0 | 1 | 0 | Power-down | | 0 | 1 | 1 | Power-save | | 1 | 0 | 0 | Reserved | | 1 | 0 | 1 | Reserved | | 1 | 1 | 0 | Standby <sup>(1)</sup> | | 1 | 1 | 1 | Extended Standby <sup>(1)</sup> | Note: 1. Standby mode and Extended Standby mode are only available with external crystals or resonators. Bit 6 – SE: Sleep Enable The SE bit must be written to logic one to make the MCU enter the sleep mode when the SLEEP instruction is executed. To avoid the MCU entering the sleep mode unless it is the programmers purpose, it is recommended to write the Sleep Enable (SE) bit to one just before the execution of the SLEEP instruction and to clear it immediately after waking up. CSE 466 Interrupts # Power modes (cont'd) Wake up sources and active clocks | | Active Clock domains | | | | 6 | Oscillators | | Wake-up Sources | | | | | | |-----------------------------------------|----------------------|----------------------|-------------------|--------------------|--------------------|------------------------------|-----------------------|----------------------|-------------------------|------------------|--------------------------|-----|--------------| | Sleep<br>Mode | clk <sub>cpu</sub> | clk <sub>FLASH</sub> | clk <sub>to</sub> | clk <sub>ADC</sub> | clk <sub>ASY</sub> | Main Clock<br>Source Enabled | Timer Osc.<br>Enabled | INT2<br>INT1<br>INT0 | TWI<br>Address<br>Match | Timer<br>2 | SPM /<br>EEPROM<br>Ready | ADC | Other<br>I/O | | Idle | | | Х | Х | Х | Х | X <sup>(2)</sup> | Х | Х | Х | Х | Х | Х | | ADC<br>Noise<br>Redu-<br>ction | | | | х | х | х | X <sup>(2)</sup> | X(3) | х | х | х | x | | | Power<br>Down | | | | | | | | X <sup>(3)</sup> | х | | | | | | Power<br>Save | | | | | X <sup>(2)</sup> | | X <sup>(2)</sup> | X <sup>(3)</sup> | Х | X <sup>(2)</sup> | | | | | Standby <sup>(1)</sup> | | | | | | х | | X <sup>(3)</sup> | Х | | | | | | Exten-<br>ded<br>Standby <sup>(1)</sup> | | | | | X <sup>(2)</sup> | х | X <sup>(2)</sup> | X <sup>(3)</sup> | х | X <sup>(2)</sup> | | | | Notes: 1. External Crystal or resonator selected as clock source. 2. If AS2 bit in ASSR is set. 3. Only INT2 or level interrupt INT1 and INT0. CSE 466