



Welcome to E-XFL.COM

#### What is "Embedded - Microcontrollers"?

"Embedded - Microcontrollers" refer to small, integrated circuits designed to perform specific tasks within larger systems. These microcontrollers are essentially compact computers on a single chip, containing a processor core, memory, and programmable input/output peripherals. They are called "embedded" because they are embedded within electronic devices to control various functions, rather than serving as standalone computers. Microcontrollers are crucial in modern electronics, providing the intelligence and control needed for a wide range of applications.

Applications of "<u>Embedded -</u> <u>Microcontrollers</u>"

#### Details

| Product Status             | Active                                                                   |
|----------------------------|--------------------------------------------------------------------------|
| Core Processor             | AVR                                                                      |
| Core Size                  | 8-Bit                                                                    |
| Speed                      | 20MHz                                                                    |
| Connectivity               | USI                                                                      |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, WDT                                    |
| Number of I/O              | 16                                                                       |
| Program Memory Size        | 4KB (2K x 16)                                                            |
| Program Memory Type        | FLASH                                                                    |
| EEPROM Size                | 256 x 8                                                                  |
| RAM Size                   | 256 x 8                                                                  |
| Voltage - Supply (Vcc/Vdd) | 2.7V ~ 5.5V                                                              |
| Data Converters            | A/D 11x10b                                                               |
| Oscillator Type            | Internal                                                                 |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                        |
| Mounting Type              | Through Hole                                                             |
| Package / Case             | 20-DIP (0.300", 7.62mm)                                                  |
| Supplier Device Package    | 20-PDIP                                                                  |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/attiny461-20pu |

Email: info@E-XFL.COM

Address: Room A, 16/F, Full Win Commercial Centre, 573 Nathan Road, Mongkok, Hong Kong

old value and program the new value) or to split the Erase and Write operations in two different operations. The Programming times for the different modes are shown in Table 5-1.

Table 5-1. EEPROM Mode Bits

| EEPM1 | EEPM0 | Programming<br>Time | Operation                                           |
|-------|-------|---------------------|-----------------------------------------------------|
| 0     | 0     | 3.4 ms              | Erase and Write in one operation (Atomic Operation) |
| 0     | 1     | 1.8 ms              | Erase Only                                          |
| 1     | 0     | 1.8 ms              | Write Only                                          |
| 1     | 1     | _                   | Reserved for future use                             |

When EEPE is set, any write to EEPMn will be ignored. During reset, the EEPMn bits will be reset to 0b00 unless the EEPROM is busy programming.

#### • Bit 3 – EERIE: EEPROM Ready Interrupt Enable

Writing EERIE to one enables the EEPROM Ready Interrupt if the I-bit in SREG is set. Writing EERIE to zero disables the interrupt. The EEPROM Ready Interrupt generates a constant interrupt when Non-volatile memory is ready for programming.

#### • Bit 2 – EEMPE: EEPROM Master Program Enable

The EEMPE bit determines whether writing EEPE to one will have effect or not.

When EEMPE is set, setting EEPE within four clock cycles will program the EEPROM at the selected address. If EEMPE is zero, setting EEPE will have no effect. When EEMPE has been written to one by software, hardware clears the bit to zero after four clock cycles.

#### • Bit 1 – EEPE: EEPROM Program Enable

The EEPROM Program Enable Signal EEPE is the programming enable signal to the EEPROM. When EEPE is written, the EEPROM will be programmed according to the EEPMn bits setting. The EEMPE bit must be written to one before a logical one is written to EEPE, otherwise no EEPROM write takes place. When the write access time has elapsed, the EEPE bit is cleared by hardware. When EEPE has been set, the CPU is halted for two cycles before the next instruction is executed.

#### Bit 0 – EERE: EEPROM Read Enable

The EEPROM Read Enable Signal – EERE – is the read strobe to the EEPROM. When the correct address is set up in the EEAR Register, the EERE bit must be written to one to trigger the EEPROM read. The EEPROM read access takes one instruction, and the requested data is available immediately. When the EEPROM is read, the CPU is halted for four cycles before the next instruction is executed. The user should poll the EEPE bit before starting the read operation. If a write operation is in progress, it is neither possible to read the EEPROM, nor to change the EEAR Register.

#### 5.5.5 GPIOR2 – General Purpose I/O Register 2



# ATtiny261/461/861

| CLKPS3 CLKPS2 |   | LKPS3 CLKPS2 CLKPS1 CLKPS0 |   | <b>Clock Division Factor</b> |  |
|---------------|---|----------------------------|---|------------------------------|--|
| 1             | 1 | 0                          | 1 | Reserved                     |  |
| 1             | 1 | 1                          | 0 | Reserved                     |  |
| 1             | 1 | 1                          | 1 | Reserved                     |  |

Table 6-13. Clock Prescaler Select (Continued)

#### 8.1.2 External Reset

An External Reset is generated by a low level on the  $\overline{\text{RESET}}$  pin if enabled. Reset pulses longer than the minimum pulse width (see "System and Reset Characteristics" on page 190) will generate a reset, even if the clock is not running. Shorter pulses are not guaranteed to generate a reset. When the applied signal reaches the Reset Threshold Voltage –  $V_{RST}$  – on its positive edge, the delay counter starts the MCU after the Time-out period –  $t_{TOUT}$  – has expired.





#### 8.1.3 Brown-out Detection

ATtiny261/461/861 has an On-chip Brown-out Detection (BOD) circuit for monitoring the V<sub>CC</sub> level during operation by comparing it to a fixed trigger level. The trigger level for the BOD can be selected by the BODLEVEL Fuses. The trigger level has a hysteresis to ensure spike free Brown-out Detection. The hysteresis on the detection level should be interpreted as V<sub>BOT+</sub> = V<sub>BOT</sub> + V<sub>HYST</sub>/2 and V<sub>BOT-</sub> = V<sub>BOT</sub> - V<sub>HYST</sub>/2.

When the BOD is enabled, and  $V_{CC}$  decreases to a value below the trigger level ( $V_{BOT}$  in Figure 8-5), the Brown-out Reset is immediately activated. When  $V_{CC}$  increases above the trigger level ( $V_{BOT}$  in Figure 8-5), the delay counter starts the MCU after the Time-out period  $t_{TOUT}$  has expired.

The BOD circuit will only detect a drop in  $V_{CC}$  if the voltage stays below the trigger level for longer than  $t_{BOD}$  given in "System and Reset Characteristics" on page 190.



Atmel



- 1. In the same operation, write a logical one to WDCE and WDE. Even though the WDE always is set, the WDE must be written to one to start the timed sequence.
- 2. Within the next four clock cycles, in the same operation, write the WDP bits as desired, but with the WDCE bit cleared. The value written to the WDE bit is irrelevant.

#### 8.3.2 Code Examples

The following code example shows one assembly and one C function for turning off the WDT. The example assumes that interrupts are controlled (e.g., by disabling interrupts globally) so that no interrupts will occur during execution of these functions.

```
Assembly Code Example
   WDT off:
     wdr
     ; Clear WDRF in MCUSR
     ldi r16, (0<<WDRF)
     out MCUSR, r16
     ; Write logical one to WDCE and WDE
     ; Keep old prescaler setting to prevent unintentional Watchdog Reset
     in r16, WDTCSR
     ori r16, (1<<WDCE) | (1<<WDE)
     out WDTCSR, r16
     ; Turn off WDT
     ldi r16, (0<<WDE)
     out WDTCSR, r16
     ret
C Code Example
   void WDT_off(void)
   {
     WDR();
     /* Clear WDRF in MCUSR */
     MCUSR = 0x00
     /* Write logical one to WDCE and WDE */
     WDTCSR |= (1<<WDCE) | (1<<WDE);
     /* Turn off WDT */
     WDTCSR = 0 \times 00;
   }
```

Note: See "Code Examples" on page 6.

Table 10-2 summarizes the function of the overriding signals. The pin and port indexes from Figure 10-5 are not shown in the succeeding tables. The overriding signals are generated internally in the modules having the alternate function.

| Signal Name | Full Name                                  | Description                                                                                                                                                                                                                                                                          |
|-------------|--------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PUOE        | Pull-up Override<br>Enable                 | If this signal is set, the pull-up enable is controlled by the PUOV signal. If this signal is cleared, the pull-up is enabled when {DDxn, PORTxn, PUD} = 0b010.                                                                                                                      |
| PUOV        | Pull-up Override<br>Value                  | If PUOE is set, the pull-up is enabled/disabled when PUOV is set/cleared, regardless of the setting of the DDxn, PORTxn, and PUD Register bits.                                                                                                                                      |
| DDOE        | Data Direction<br>Override Enable          | If this signal is set, the Output Driver Enable is controlled by the DDOV signal. If this signal is cleared, the Output driver is enabled by the DDxn Register bit.                                                                                                                  |
| DDOV        | Data Direction<br>Override Value           | If DDOE is set, the Output Driver is enabled/disabled when DDOV is set/cleared, regardless of the setting of the DDxn Register bit.                                                                                                                                                  |
| PVOE        | Port Value<br>Override Enable              | If this signal is set and the Output Driver is enabled, the port<br>value is controlled by the PVOV signal. If PVOE is cleared, and<br>the Output Driver is enabled, the port Value is controlled by the<br>PORTxn Register bit.                                                     |
| PVOV        | Port Value<br>Override Value               | If PVOE is set, the port value is set to PVOV, regardless of the setting of the PORTxn Register bit.                                                                                                                                                                                 |
| PTOE        | Port Toggle<br>Override Enable             | If PTOE is set, the PORTxn Register bit is inverted.                                                                                                                                                                                                                                 |
| DIEOE       | Digital Input<br>Enable Override<br>Enable | If this bit is set, the Digital Input Enable is controlled by the DIEOV signal. If this signal is cleared, the Digital Input Enable is determined by MCU state (Normal mode, sleep mode).                                                                                            |
| DIEOV       | Digital Input<br>Enable Override<br>Value  | If DIEOE is set, the Digital Input is enabled/disabled when<br>DIEOV is set/cleared, regardless of the MCU state (Normal<br>mode, sleep mode).                                                                                                                                       |
| DI          | Digital Input                              | This is the Digital Input to alternate functions. In the figure, the signal is connected to the output of the schmitt-trigger but before the synchronizer. Unless the Digital Input is used as a clock source, the module with the alternate function will use its own synchronizer. |
| AIO         | Analog<br>Input/Output                     | This is the Analog Input/Output to/from alternate functions. The signal is connected directly to the pad, and can be used bi-directionally.                                                                                                                                          |

 Table 10-2.
 Generic Description of Overriding Signals for Alternate Functions

The following subsections shortly describe the alternate functions for each port, and relate the overriding signals to the alternate function. Refer to the alternate function description for further details.

### • Port B, Bit 1 - MISO/ DO/ OC1A/ PCINT9

- DO: Three-wire mode Universal Serial Interface Data output. Three-wire mode Data output overrides PORTB1 value and it is driven to the port when data direction bit DDB1 is set (one). PORTB1 still enables the pull-up, if the direction is input and PORTB1 is set (one).
- OC1A: Output Compare Match output: The PB1 pin can serve as an external output for the Timer/Counter1 Compare Match B when configured as an output (DDB1 set). The OC1A pin is also the output pin for the PWM mode timer function.
- PCINT9: Pin Change Interrupt source 9.

### • Port B, Bit 0 – MOSI/ DI/ SDA/ OC1A/ PCINT8

- DI: Data Input in USI Three-wire mode. USI Three-wire mode does not override normal port functions, so pin must be configure as an input for DI function.
- SDA: Two-wire mode Serial Interface Data.
- OC1A: Inverted Output Compare Match output: The PB0 pin can serve as an external output for the Timer/Counter1 Compare Match B when configured as an output (DDB0 set). The OC1A pin is also the inverted output pin for the PWM mode timer function.
- PCINT8: Pin Change Interrupt source 8.

Table 10-7 and Table 10-8 relate the alternate functions of Port B to the overriding signals shown in Figure 10-5 on page 61.

| Signal<br>Name | PB7/RESET/<br>dW/ADC10/<br>PCINT15               | PB6/ADC9/T0/<br>INT0/PCINT14          | PB5/XTAL2/CLKO/<br>OC1D/ADC8/<br>PCINT13 <sup>(1)</sup> | PB4/XTAL1/<br>OC1D/ADC7/<br>PCINT12 <sup>(1)</sup> |
|----------------|--------------------------------------------------|---------------------------------------|---------------------------------------------------------|----------------------------------------------------|
| PUOE           | RSTDISBL <sup>(1)</sup> •<br>DWEN <sup>(1)</sup> | 0                                     | INTRC • EXTCLK                                          | INTRC                                              |
| PUOV           | 1                                                | 0                                     | 0                                                       | 0                                                  |
| DDOE           | RSTDISBL <sup>(1)</sup> •<br>DWEN <sup>(1)</sup> | 0                                     | INTRC • EXTCLK                                          | INTRC                                              |
| DDOV           | debugWire Transmit                               | 0                                     | 0                                                       | 0                                                  |
| PVOE           | 0                                                | 0                                     | OC1D Enable                                             | OC1D Enable                                        |
| PVOV           | 0                                                | 0                                     | OC1D                                                    | OC1D                                               |
| PTOE           | 0                                                | 0                                     | 0                                                       | 0                                                  |
| DIEOE          | 0                                                | RSTDISBL + (PCINT5<br>• PCIE + ADC9D) | INTRC • EXTCLK +<br>PCINT4 • PCIE +<br>ADC8D            | INTRC + PCINT12 •<br>PCIE + ADC7D                  |
| DIEOV          | ADC10D                                           | ADC9D                                 | (INTRC • EXTCLK) +<br>ADC8D                             | INTRC • ADC7D                                      |
| DI             | PCINT15                                          | T0/INT0/PCINT14                       | PCINT13                                                 | PCINT12                                            |
| AIO            | RESET / ADC10                                    | ADC9                                  | XTAL2, ADC8                                             | XTAL1, ADC7                                        |

 Table 10-7.
 Overriding Signals for Alternate Functions in PB7:PB4

Note: 1. "1" when the Fuse is "0" (Programmed).

The following code examples show how to do an atomic read of the TCNT0 register contents. Reading any of the OCR0 register can be done by using the same principle.

| Assembly Code Example                          |  |
|------------------------------------------------|--|
| TIM0_ReadTCNT0:                                |  |
| ; Save global interrupt flag                   |  |
| in r18,SREG                                    |  |
| ; Disable interrupts                           |  |
| cli                                            |  |
| ; Read TCNT <b>O</b> into r17:r16              |  |
| in r16,TCNTOL                                  |  |
| in r17,TCNTOH                                  |  |
| ; Restore global interrupt flag                |  |
| out SREG, r18                                  |  |
| ret                                            |  |
| C Code Example                                 |  |
| <pre>unsigned int TIM0_ReadTCNT0( void )</pre> |  |
| {                                              |  |
| unsigned char sreg;                            |  |
| unsigned int i;                                |  |
| /* Save global interrupt flag */               |  |
| <pre>sreg = SREG;</pre>                        |  |
| /* Disable interrupts */                       |  |
| _CLI();                                        |  |
| /* Read TCNT0 into i */                        |  |
| i = TCNTOL;                                    |  |
| i  = ((unsigned int)TCNTOH << 8);              |  |
| /* Restore global interrupt flag */            |  |
| SREG = sreg;                                   |  |
| return i;                                      |  |
|                                                |  |

Note: See "Code Examples" on page 6.

The assembly code example returns the TCNT0H/L value in the r17:r16 register pair.

in a constantly high or low output (depending on the polarity of the output set by the COM1x1:0 bits.)

A frequency (with 50% duty cycle) waveform output in fast PWM mode can be achieved by setting the Waveform Output (OCW1x) to toggle its logical level on each Compare Match (COM1x1:0 = 1). The waveform generated will have a maximum frequency of  $f_{OC1} = f_{clkT1}/4$  when OCR1C is set to three.

The general I/O port function is overridden by the Output Compare value (OC1x /  $\overline{OC1x}$ ) from the Dead Time Generator, if either of the COM1x1:0 bits are set and the Data Direction Register bits for the OC1X and  $\overline{OC1X}$  pins are set as an output. If the COM1x1:0 bits are cleared, the actual value from the port register will be visible on the port pin. The Output Compare Pin configurations are described in Table 12-3.

| COM1x1 | COM1x0 | OC1x Pin     | OC1x Pin     |
|--------|--------|--------------|--------------|
| 0      | 0      | Disconnected | Disconnected |
| 0      | 1      | OC1x         | OC1x         |
| 1      | 0      | Disconnected | OC1x         |
| 1      | 1      | Disconnected | OC1x         |

 Table 12-3.
 Output Compare Pin Configurations in Fast PWM Mode

#### 12.8.3 Phase and Frequency Correct PWM Mode

The Phase and Frequency Correct PWM Mode (PWM1A/PWM1B = 1 and WGM11:10 = 01) provides a high resolution Phase and Frequency Correct PWM waveform generation option. The Phase and Frequency Correct PWM mode is based on a dual-slope operation. The counter counts repeatedly from BOTTOM to TOP (defined as OCR1C) and then from TOP to BOTTOM. In non-inverting Compare Output Mode the Waveform Output (OCW1x) is cleared on the Compare Match between TCNT1 and OCR1x while upcounting, and set on the Compare Match while down-counting. In inverting Output Compare mode, the operation is inverted. In complementary Compare Output Mode, the Waveform Output is cleared on the Compare Match and set at BOT-TOM. The dual-slope operation has lower maximum operation frequency than single slope operation. However, due to the symmetric feature of the dual-slope PWM modes, these modes are preferred for motor control applications.

The timing diagram for the Phase and Frequency Correct PWM mode is shown on Figure 12-13 in which the TCNT1 value is shown as a histogram for illustrating the dual-slope operation. The counter is incremented until the counter value matches TOP. When the counter reaches TOP, it changes the count direction. The TCNT1 value will be equal to TOP for one timer clock cycle. The diagram includes the Waveform Output (OCW1x) in non-inverted and inverted Compare Output Mode. The small horizontal line marks on the TCNT1 slopes represent Compare Matches between OCR1x and TCNT1.

The following code examples show how to do an atomic read of the TCNT1 register contents. Reading any of the OCR1A/B/C/D registers can be done by using the same principle.

| Assembly Code Example                          |  |
|------------------------------------------------|--|
| TIM1_ReadTCNT1:                                |  |
| ; Save global interrupt flag                   |  |
| in r18,SREG                                    |  |
| ; Disable interrupts                           |  |
| cli                                            |  |
| ; Read TCNT1 into r17:r16                      |  |
| in r16,TCNT1                                   |  |
| <b>in</b> r17,TC <b>1</b> H                    |  |
| ; Restore global interrupt flag                |  |
| out SREG, r18                                  |  |
| ret                                            |  |
| C Code Example                                 |  |
| <pre>unsigned int TIM1_ReadTCNT1( void )</pre> |  |
| {                                              |  |
| unsigned char sreg;                            |  |
| unsigned int i;                                |  |
| /* Save global interrupt flag */               |  |
| <pre>sreg = SREG;</pre>                        |  |
| /* Disable interrupts */                       |  |
| _CLI();                                        |  |
| /* Read TCNT1 into i */                        |  |
| i = TCNT1;                                     |  |
| i  = ((unsigned int)TC1H << 8);                |  |
| /* Restore global interrupt flag               |  |
| SREG = sreg;                                   |  |
| return i;                                      |  |
|                                                |  |

Note: See "Code Examples" on page 6.

The assembly code example returns the TCNT1 value in the r17:r16 register pair.

Table 12-10 shows the COM1A1:0 bit functionality when the PWM1A, WGM10 and WGM11 bits are set to Phase and Frequency Correct PWM Mode.

| COM1A1:0 | OCW1A Behaviour                                                                        | OC1A Pin     | OC1A Pin     |
|----------|----------------------------------------------------------------------------------------|--------------|--------------|
| 00       | Normal port operation.                                                                 | Disconnected | Disconnected |
| 01       | Cleared on Compare Match when up-counting.<br>Set on Compare Match when down-counting. | Connected    | Connected    |
| 10       | Cleared on Compare Match when up-counting.<br>Set on Compare Match when down-counting. | Connected    | Disconnected |
| 11       | Set on Compare Match when up-counting.<br>Cleared on Compare Match when down-counting. | Connected    | Disconnected |

 Table 12-10.
 Compare Output Mode, Phase and Frequency Correct PWM Mode

Table 12-11 shows the COM1A1:0 bit functionality when the PWM1A, WGM10 and WGM11 bits are set to single-slope PWM6 Mode. In the PWM6 Mode the same Waveform Output (OCW1A) is used for generating all waveforms and the Output Compare values OC1A and  $\overline{OC1A}$  are connected on thw all OC1x and  $\overline{OC1x}$  pins as described below.

| COM1A1:0 | OCW1A Behaviour                                      | OC1x Pin     | OC1x Pin     |
|----------|------------------------------------------------------|--------------|--------------|
| 00       | Normal port operation.                               | Disconnected | Disconnected |
| 01       | Cleared on Compare Match.<br>Set when TCNT1 = 0x000. | OC1A         | OC1A         |
| 10       | Cleared on Compare Match.<br>Set when TCNT1 = 0x000. | OC1A         | OC1A         |
| 11       | Set on Compare Match.<br>Cleared when TCNT1 = 0x000. | OC1A         | OC1A         |

Table 12-11. Compare Output Mode, Single-Slope PWM6 Mode

Table 12-12 shows the COM1A1:0 bit functionality when the PWM1A, WGM10 and WGM11 bits are set to dual-slope PWM6 Mode.I

 Table 12-12.
 Compare Output Mode, Dual-Slope PWM6 Mode

| COM1A1:0 | OCW1A Behaviour                                                                        | OC1x Pin     | OC1x Pin     |
|----------|----------------------------------------------------------------------------------------|--------------|--------------|
| 00       | Normal port operation.                                                                 | Disconnected | Disconnected |
| 01       | Cleared on Compare Match when up-counting.<br>Set on Compare Match when down-counting. | OC1A         | OC1A         |
| 10       | Cleared on Compare Match when up-counting.<br>Set on Compare Match when down-counting. | OC1A         | OC1A         |
| 11       | Set on Compare Match when up-counting.<br>Cleared on Compare Match when down-counting. | OC1A         | OC1A         |

Bits COM1A1 and COM1A0 are shadowed in TCCR1C. Writing to bits COM1A1 and COM1A0 will also change bits COM1A1S and COM1A0S in TCCR1C. Similary, changes written to bits COM1A1S and COM1A0S in TCCR1C will show here. See "TCCR1C – Timer/Counter1 Control Register C" on page 117.

the corresponding interrupt handling vector. Alternatively, OCF1A is cleared, after synchronization clock cycle, by writing a logic one to the flag. When the I-bit in SREG, OCIE1A, and OCF1A are set (one), the Timer/Counter1 A compare match interrupt is executed.

#### Bit 5 – OCF1B: Output Compare Flag 1B

The OCF1B bit is set (one) when compare match occurs between Timer/Counter1 and the data value in OCR1B - Output Compare Register 1A. OCF1B is cleared by hardware when executing the corresponding interrupt handling vector. Alternatively, OCF1B is cleared, after synchronization clock cycle, by writing a logic one to the flag. When the I-bit in SREG, OCIE1B, and OCF1B are set (one), the Timer/Counter1 B compare match interrupt is executed.

#### • Bit 2 – TOV1: Timer/Counter1 Overflow Flag

In Normal Mode and Fast PWM Mode the TOV1 bit is set (one) each time the counter reaches TOP at the same clock cycle when the counter is reset to BOTTOM. In Phase and Frequency Correct PWM Mode the TOV1 bit is set (one) each time the counter reaches BOTTOM at the same clock cycle when zero is clocked to the counter.

The bit TOV1 is cleared by hardware when executing the corresponding interrupt handling vector. Alternatively, TOV1 is cleared, after synchronization clock cycle, by writing a logical one to the flag. When the SREG I-bit, and TOIE1 (Timer/Counter1 Overflow Interrupt Enable), and TOV1 are set (one), the Timer/Counter1 Overflow interrupt is executed.

#### 12.12.15 DT1 – Timer/Counter1 Dead Time Value

| Bit           | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |     |
|---------------|-------|-------|-------|-------|-------|-------|-------|-------|-----|
| 0x24 (0x44)   | DT1H3 | DT1H2 | DT1H1 | DT1H0 | DT1L3 | DT1L2 | DT1L1 | DT1L0 | DT1 |
| Read/Write    | R/W   |     |
| Initial value | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |     |

The dead time value register is an 8-bit read/write register.

The dead time delay of all Timer/Counter1 channels are adjusted by the dead time value register, DT1. The register consists of two fields, DT1H3:0 and DT1L3:0, one for each complementary output. Therefore a different dead time delay can be adjusted for the rising edge of OC1x and the rising edge of OC1x.

#### Bits 7:4 – DT1H3:DT1H0: Dead Time Value for OC1x Output

The dead time value for the OC1x output. The dead time delay is set as a number of the prescaled timer/counter clocks. The minimum dead time is zero and the maximum dead time is the prescaled time/counter clock period multiplied by 15.

#### • Bits 3:0 – DT1L3:DT1L0: Dead Time Value for OC1x Output

The dead time value for the OC1x output. The dead time delay is set as a number of the prescaled timer/counter clocks. The minimum dead time is zero and the maximum dead time is the prescaled time/counter clock period multiplied by 15. The 4-bit counter can be both read and written via the data bus, and it can generate an overflow interrupt. The data register and the counter are clocked simultaneously by the same clock source, allowing the counter to count the number of bits received or transmitted and generate an interrupt when the transfer is complete. Note that when an external clock source is selected the counter counts both clock edges. In this case the counter counts the number of edges, and not the number of bits. The clock can be selected from three different sources: The USCK pin, the Timer/Counter0 Compare Match or from software.

The Two-wire clock control unit can generate an interrupt when a start condition is detected on the Two-wire bus. It can also generate wait states by holding the clock pin low after a start condition is detected, or after the counter overflows.

### **13.3 Functional Descriptions**

#### 13.3.1 Three-wire Mode

The USI Three-wire mode is compliant to the Serial Peripheral Interface (SPI) mode 0 and 1, but does not have the slave select (SS) pin functionality. However, this feature can be implemented in software if necessary. Pin names used by this mode are: DI, DO, and USCK.



Figure 13-2. Three-wire Mode Operation, Simplified Diagram

Figure 13-2 shows two USI units operating in three-wire mode, one as Master and one as Slave. The two USI Data Register are interconnected in such way that after eight USCK clocks, the data in each register are interchanged. The same clock also increments the USI's 4-bit counter. The Counter Overflow (interrupt) Flag, or USIOIF, can therefore be used to determine when a transfer is completed. The clock is generated by the Master device software by toggling the USCK pin via the PORT Register or by writing a one to the USITC bit in USICR.

|      | ,    |        | ·····       |                |                |
|------|------|--------|-------------|----------------|----------------|
| ACME | ADEN | MUX5:0 | ACM2:0      | Positive Input | Negative Input |
| 0    | х    | хххххх | 100         | AIN2           | AIN0           |
| 0    | х    | хххххх | 101,110,111 | AIN2           | AIN1           |
| 1    | 1    | хххххх | 000         | AIN0           | AIN1           |
| 1    | 0    | 000000 | 000         | AIN0           | ADC0           |
| 1    | 0    | 000000 | 01x         | AIN1           | ADC0           |
| 1    | 0    | 000000 | 1xx         | AIN2           | ADC0           |
| 1    | 0    | 000001 | 000         | AIN0           | ADC1           |
| 1    | 0    | 000001 | 01x         | AIN1           | ADC1           |
| 1    | 0    | 000001 | 1xx         | AIN2           | ADC1           |
| 1    | 0    | 000010 | 000         | AIN0           | ADC2           |
| 1    | 0    | 000010 | 01x         | AIN1           | ADC2           |
| 1    | 0    | 000010 | 1xx         | AIN2           | ADC2           |
| 1    | 0    | 000011 | 000         | AIN0           | ADC3           |
| 1    | 0    | 000011 | 01x         | AIN1           | ADC3           |
| 1    | 0    | 000011 | 1xx         | AIN2           | ADC3           |
| 1    | 0    | 000100 | 000         | AIN0           | ADC4           |
| 1    | 0    | 000100 | 01x         | AIN1           | ADC4           |
| 1    | 0    | 000100 | 1xx         | AIN2           | ADC4           |
| 1    | 0    | 000101 | 000         | AIN0           | ADC5           |
| 1    | 0    | 000101 | 01x         | AIN1           | ADC5           |
| 1    | 0    | 000101 | 1xx         | AIN2           | ADC5           |
| 1    | 0    | 000110 | 000         | AIN0           | ADC6           |
| 1    | 0    | 000110 | 01x         | AIN1           | ADC6           |
| 1    | 0    | 000110 | 1xx         | AIN2           | ADC6           |
| 1    | 0    | 000111 | 000         | AIN0           | ADC7           |
| 1    | 0    | 000111 | 01x         | AIN1           | ADC7           |
| 1    | 0    | 000111 | 1xx         | AIN2           | ADC7           |
| 1    | 0    | 001000 | 000         | AIN0           | ADC8           |
| 1    | 0    | 001000 | 01x         | AIN1           | ADC8           |
| 1    | 0    | 001000 | 1xx         | AIN2           | ADC8           |
| 1    | 0    | 001001 | 000         | AIN0           | ADC9           |
| 1    | 0    | 001001 | 01x         | AIN1           | ADC9           |
| 1    | 0    | 001001 | 1xx         | AIN2           | ADC9           |
| 1    | 0    | 001010 | 000         | AIN0           | ADC10          |
| 1    | 0    | 001010 | 01x         | AIN1           | ADC10          |
| 1    | 0    | 001010 | 1xx         | AIN2           | ADC10          |

 Table 14-1.
 Analog Comparator Multiplexed Input (Continued)

reference may be decoupled by an external capacitor at the AREF pin to improve noise immunity.

The analog input channel and differential gain are selected by writing to the MUX5:0 bits in ADMUX. Any of the 11 ADC input pins ADC10:0 can be selected as single ended inputs to the ADC. The positive and negative inputs to the differential gain amplifier are described in Table 15-4.

If differential channels are selected, the differential gain stage amplifies the voltage difference between the selected input pair by the selected gain factor, 1x, 8x, 20x or 32x, according to the setting of the MUX5:0 bits in ADMUX and the GSEL bit in ADCSRB. This amplified value then becomes the analog input to the ADC. If single ended channels are used, the gain amplifier is bypassed altogether.

If the same ADC input pin is selected as both the positive and negative input to the differential gain amplifier, the remaining offset in the gain stage and conversion circuitry can be measured directly as the result of the conversion. This figure can be subtracted from subsequent conversions with the same gain setting to reduce offset error to below 1 LSW.

The on-chip temperature sensor is selected by writing the code "111111" to the MUX5:0 bits in ADMUX register when the ADC11 channel is used as an ADC input.

The ADC is enabled by setting the ADC Enable bit, ADEN in ADCSRA. Voltage reference and input channel selections will not go into effect until ADEN is set. The ADC does not consume power when ADEN is cleared, so it is recommended to switch off the ADC before entering power saving sleep modes.

The ADC generates a 10-bit result which is presented in the ADC Data Registers, ADCH and ADCL. By default, the result is presented right adjusted, but can optionally be presented left adjusted by setting the ADLAR bit in ADMUX.

If the result is left adjusted and no more than 8-bit precision is required, it is sufficient to read ADCH. Otherwise, ADCL must be read first, then ADCH, to ensure that the content of the data registers belongs to the same conversion. Once ADCL is read, ADC access to data registers is blocked. This means that if ADCL has been read, and a conversion completes before ADCH is read, neither register is updated and the result from the conversion is lost. When ADCH is read, ADC access to the ADCH and ADCL Registers is re-enabled.

The ADC has its own interrupt which can be triggered when a conversion completes. When ADC access to the data registers is prohibited between reading of ADCH and ADCL, the interrupt will trigger even if the result is lost.

#### 15.4 Starting a Conversion

A single conversion is started by writing a logical one to the ADC Start Conversion bit, ADSC. This bit stays high as long as the conversion is in progress and will be cleared by hardware when the conversion is completed. If a different data channel is selected while a conversion is in progress, the ADC will finish the current conversion before performing the channel change.

Alternatively, a conversion can be triggered automatically by various sources. Auto Triggering is enabled by setting the ADC Auto Trigger Enable bit, ADATE in ADCSRA. The trigger source is selected by setting the ADC Trigger Select bits, ADTS in ADCSRB (see description of the ADTS bits for a list of the trigger sources). When a positive edge occurs on the selected trigger signal, the ADC prescaler is reset and a conversion is started. This provides a method of starting conversions at fixed intervals. If the trigger signal still is set when the conversion completes, a new

|                     |                                                   | V <sub>CC</sub> = 1.8 - 5.5V |      | V <sub>CC</sub> = 2.7 - 5.5V |      | V <sub>CC</sub> = 4.5 - 5.5V |      |       |
|---------------------|---------------------------------------------------|------------------------------|------|------------------------------|------|------------------------------|------|-------|
| Symbol              | Parameter                                         | Min.                         | Max. | Min.                         | Max. | Min.                         | Max. | Units |
| 1/t <sub>CLCL</sub> | Clock Frequency                                   | 0                            | 4    | 0                            | 10   | 0                            | 20   | MHz   |
| t <sub>CLCL</sub>   | Clock Period                                      | 250                          |      | 100                          |      | 50                           |      | ns    |
| t <sub>CHCX</sub>   | High Time                                         | 100                          |      | 40                           |      | 20                           |      | ns    |
| t <sub>CLCX</sub>   | Low Time                                          | 100                          |      | 40                           |      | 20                           |      | ns    |
| t <sub>CLCH</sub>   | Rise Time                                         |                              | 2.0  |                              | 1.6  |                              | 0.5  | μS    |
| t <sub>CHCL</sub>   | Fall Time                                         |                              | 2.0  |                              | 1.6  |                              | 0.5  | μS    |
| $\Delta t_{CLCL}$   | Change in period from one clock cycle to the next |                              | 2    |                              | 2    |                              | 2    | %     |

#### Table 19-3. External Clock Drive Characteristics

## 19.5 System and Reset Characteristics

| Symbol            | Parameter                                                     | Condition                              | Min                 | Тур | Max                 | Units |
|-------------------|---------------------------------------------------------------|----------------------------------------|---------------------|-----|---------------------|-------|
| V <sub>RST</sub>  | RESET Pin Threshold Voltage <sup>(1)</sup>                    |                                        | 0.2 V <sub>CC</sub> |     | 0.9 V <sub>CC</sub> | V     |
| t <sub>RST</sub>  | Minimum pulse width on RESET Pin <sup>(1)</sup>               | $V_{CC} = 3V$                          |                     |     | 2.5                 | μs    |
| V <sub>HYST</sub> | Brown-out Detector Hysteresis (1)                             |                                        |                     | 50  |                     | mV    |
| t <sub>BOD</sub>  | Min Pulse Width on<br>Brown-out Reset <sup>(1)</sup>          |                                        |                     | 2   |                     | μs    |
| V <sub>BG</sub>   | Internal bandgap reference voltage                            | $V_{CC} = 2.7V$<br>$T_A = 25^{\circ}C$ | 1.0                 | 1.1 | 1.2                 | V     |
| t <sub>BG</sub>   | Internal bandgap reference start-up time <sup>(1)</sup>       | $V_{CC} = 5V$<br>$T_A = 25^{\circ}C$   |                     | 40  | 70                  | μs    |
| I <sub>BG</sub>   | Internal bandgap reference current consumption <sup>(1)</sup> | $V_{CC} = 5V$<br>$T_A = 25^{\circ}C$   |                     | 15  |                     | μA    |

Table 19-4. Reset, Brown-out, and Internal Voltage Characteristics

Note: 1. Values are guidelines, only.

#### 19.5.1 Power-On Reset

| Table 19-5. | Characteristics of Power-On Reset. $T_A =$ | -40 to +85°C |
|-------------|--------------------------------------------|--------------|
|-------------|--------------------------------------------|--------------|

| Symbol           | Parameter                                             | Min <sup>(1)</sup> | <b>Typ</b> <sup>(1)</sup> | Max <sup>(1)</sup> | Units |
|------------------|-------------------------------------------------------|--------------------|---------------------------|--------------------|-------|
| V <sub>POR</sub> | Release threshold of power-on reset <sup>(2)</sup>    | 0.7                | 1.0                       | 1.4                | V     |
| V <sub>POA</sub> | Activation threshold of power-on reset <sup>(3)</sup> | 0.05               | 0.9                       | 1.3                | V     |
| SR <sub>ON</sub> | Power-on slope rate                                   | 0.01               |                           | 4.5                | V/ms  |

Notes: 1. Values are guidelines, only.

2. Threshold where device is released from reset when voltage is rising

3. The power-on reset will not work unless the supply voltage has been below  ${\rm V}_{\rm POA}$ 

#### 19.5.2 Brown-Out Detection

| BODLEVEL[2:0] Fuses | Min V <sub>BOT</sub> | Тур V <sub>вот</sub> | Max V <sub>BOT</sub> | Units |  |  |
|---------------------|----------------------|----------------------|----------------------|-------|--|--|
| 111                 |                      | BOD Disabled         |                      |       |  |  |
| 110                 | 1.7                  | 1.8                  | 2.0                  |       |  |  |
| 101                 | 2.5                  | 2.7                  | 2.9                  | V     |  |  |
| 100                 | 4.1                  | 4.3                  | 4.5                  |       |  |  |
| 0XX                 | Reserved             |                      |                      |       |  |  |

 Table 19-6.
 BODLEVEL Fuse Coding<sup>(1)</sup>

Note: 1. V<sub>BOT</sub> may be below nominal minimum operating voltage for some devices. For devices where this is the case, the device is tested down to V<sub>CC</sub> = V<sub>BOT</sub> during the production test. This guarantees that a Brown-out Reset will occur before V<sub>CC</sub> drops to a voltage where correct operation of the microcontroller is no longer guaranteed.

## 19.8 Parallel Programming Characteristics

Figure 19-6. Parallel Programming Timing, Including some General Timing Requirements







Note: The timing requirements shown in Figure 19-6 (i.e., t<sub>DVXH</sub>, t<sub>XHXL</sub>, and t<sub>XLDX</sub>) also apply to loading operation.

ATtiny261/461/861



**Figure 20-2.** Active Supply Current vs. Frequency (1 - 20 MHz)



Atmel





Figure 20-20. I/O Pin Output Voltage vs. Sink Current ( $V_{CC} = 5V$ )





Figure 20-36. Bandgap Voltage vs. Supply Voltage (V<sub>CC</sub>).



## 20.9 Internal Oscillator Speed





# 216 ATtiny261/461/861