
- •Features
- •1. Pin Configurations
- •2. Overview
- •2.1 Block Diagram
- •2.2 Automotive Quality Grade
- •2.3 Pin Descriptions
- •2.3.3 Port B (PB5..PB0)
- •2.3.4 RESET
- •3. About Code Examples
- •4. AVR CPU Core
- •4.1 Introduction
- •4.2 Architectural Overview
- •4.4 Status Register
- •4.5 General Purpose Register File
- •4.6 Stack Pointer
- •4.7 Instruction Execution Timing
- •4.8 Reset and Interrupt Handling
- •4.8.1 Interrupt Response Time
- •5. AVR ATtiny25/45/85 Memories
- •5.2 SRAM Data Memory
- •5.2.1 Data Memory Access Times
- •5.3 EEPROM Data Memory
- •5.3.1 EEPROM Read/Write Access
- •5.3.6 Atomic Byte Programming
- •5.3.7 Split Byte Programming
- •5.3.8 Erase
- •5.3.9 Write
- •5.3.10 Preventing EEPROM Corruption
- •5.4 I/O Memory
- •6. System Clock and Clock Options
- •6.1 Clock Systems and their Distribution
- •6.2 Clock Sources
- •6.3 Default Clock Source
- •6.4 Crystal Oscillator
- •6.6 Calibrated Internal RC Oscillator
- •6.7 External Clock
- •6.8 128 kHz Internal Oscillator
- •6.9 Clock Output Buffer
- •6.10 System Clock Prescaler
- •6.10.2 Switching Time
- •7. Power Management and Sleep Modes
- •7.1 Idle Mode
- •7.2 ADC Noise Reduction Mode
- •7.4 Power Reduction Register
- •7.5 Minimizing Power Consumption
- •7.5.1 Analog to Digital Converter
- •7.5.2 Analog Comparator
- •7.5.4 Internal Voltage Reference
- •7.5.5 Watchdog Timer
- •7.5.6 Port Pins
- •8. System Control and Reset
- •8.0.1 Resetting the AVR
- •8.0.2 Reset Sources
- •8.0.3 Power-on Reset
- •8.0.4 External Reset
- •8.0.6 Watchdog Reset
- •8.1 Internal Voltage Reference
- •8.2 Watchdog Timer
- •8.3 Timed Sequences for Changing the Configuration of the Watchdog Timer
- •8.3.1 Safety Level 1
- •8.3.2 Safety Level 2
- •9. Interrupts
- •9.1 Interrupt Vectors in ATtiny25/45/85
- •10. I/O Ports
- •10.1 Introduction
- •10.2 Ports as General Digital I/O
- •10.2.1 Configuring the Pin
- •10.2.2 Toggling the Pin
- •10.2.3 Switching Between Input and Output
- •10.2.4 Reading the Pin Value
- •10.2.5 Digital Input Enable and Sleep Modes
- •10.2.6 Unconnected Pins
- •10.3 Alternate Port Functions
- •10.3.2 Alternate Functions of Port B
- •11. External Interrupts
- •12. 8-bit Timer/Counter0 with PWM
- •12.1 Overview
- •12.1.1 Registers
- •12.1.2 Definitions
- •12.2 Timer/Counter Clock Sources
- •12.3 Counter Unit
- •12.4 Output Compare Unit
- •12.4.1 Force Output Compare
- •12.4.2 Compare Match Blocking by TCNT0 Write
- •12.4.3 Using the Output Compare Unit
- •12.5 Compare Match Output Unit
- •12.5.1 Compare Output Mode and Waveform Generation
- •12.6 Modes of Operation
- •12.6.1 Normal Mode
- •12.6.2 Clear Timer on Compare Match (CTC) Mode
- •12.6.3 Fast PWM Mode
- •12.6.4 Phase Correct PWM Mode
- •12.7 Timer/Counter Timing Diagrams
- •13. Timer/Counter Prescaler
- •13.0.1 Prescaler Reset
- •13.0.2 External Clock Source
- •14. 8-bit Timer/Counter1
- •14.1 Timer/Counter1
- •14.1.1 Timer/Counter1 Control Register - TCCR1
- •14.1.2 General Timer/Counter1 Control Register - GTCCR
- •14.1.3 Timer/Counter1 - TCNT1
- •14.1.4 Timer/Counter1 Output Compare RegisterA - OCR1A
- •14.1.5 Timer/Counter1 Output Compare RegisterB - OCR1B
- •14.1.6 Timer/Counter1 Output Compare RegisterC - OCR1C
- •14.1.7 Timer/Counter Interrupt Mask Register - TIMSK
- •14.1.8 Timer/Counter Interrupt Flag Register - TIFR
- •14.1.9 PLL Control and Status Register - PLLCSR
- •14.1.10 Timer/Counter1 Initialization for Asynchronous Mode
- •14.1.11 Timer/Counter1 in PWM Mode
- •15. 8-bit Timer/Counter1 in ATtiny15 Mode
- •15.1 Timer/Counter1 Prescaler
- •15.2 Timer/Counter1
- •15.2.2 Timer/Counter1 Control Register - TCCR1
- •15.2.3 General Timer/Counter1 Control Register - GTCCR
- •15.2.4 Timer/Counter1 - TCNT1
- •15.2.5 Timer/Counter1 Output Compare RegisterA - OCR1A
- •15.2.6 Timer/Counter1 Output Compare Register C - OCR1C
- •15.2.7 Timer/Counter Interrupt Flag Register - TIFR
- •15.2.8 PLL Control and Status Register - PLLCSR
- •15.2.9 Timer/Counter1 in PWM Mode
- •16. Dead Time Generator
- •16.0.1 Timer/Counter1 Dead Time Prescaler register 1 - DTPS1
- •16.0.2 Timer/Counter1 Dead Time A - DT1A
- •16.0.3 Timer/Counter1 Dead Time B - DT1B
- •17.1 Overview
- •17.2 Functional Descriptions
- •17.2.2 SPI Master Operation Example
- •17.2.3 SPI Slave Operation Example
- •17.2.5 Start Condition Detector
- •17.3 Alternative USI Usage
- •17.3.4 Edge Triggered External Interrupt
- •17.3.5 Software Interrupt
- •17.4 USI Register Descriptions
- •18. Analog Comparator
- •18.1 Analog Comparator Multiplexed Input
- •19. Analog to Digital Converter
- •19.1 Features
- •19.2 Operation
- •19.3 Starting a Conversion
- •19.4 Prescaling and Conversion Timing
- •19.5 Changing Channel or Reference Selection
- •19.5.1 ADC Input Channels
- •19.5.2 ADC Voltage Reference
- •19.6 ADC Noise Canceler
- •19.6.1 Analog Input Circuitry
- •19.6.2 Analog Noise Canceling Techniques
- •19.6.3 ADC Accuracy Definitions
- •19.7 ADC Conversion Result
- •19.7.1 Single Ended Conversion
- •19.7.2 Unipolar Differential Conversion
- •19.7.3 Bipolar Differential Conversion
- •19.7.4 Temperature Measurement (Preliminary description)
- •19.7.7.1 ADLAR = 0
- •19.7.7.2 ADLAR = 1
- •20. debugWIRE On-chip Debug System
- •20.1 Features
- •20.2 Overview
- •20.3 Physical Interface
- •20.4 Software Break Points
- •20.5 Limitations of debugWIRE
- •20.6 debugWIRE Related Register in I/O Memory
- •21. Self-Programming the Flash
- •21.0.1 Performing Page Erase by SPM
- •21.0.2 Filling the Temporary Buffer (Page Loading)
- •21.0.3 Performing a Page Write
- •21.1.2 EEPROM Write Prevents Writing to SPMCSR
- •21.1.3 Reading the Fuse and Lock Bits from Software
- •21.1.4 Preventing Flash Corruption
- •21.1.5 Programming Time for Flash when Using SPM
- •22. Memory Programming
- •22.1 Program And Data Memory Lock Bits
- •22.2 Fuse Bytes
- •22.2.1 Latching of Fuses
- •22.3 Signature Bytes
- •22.3.1 ATtiny25 Signature Bytes
- •22.3.2 ATtiny45 Signature Bytes
- •22.3.3 ATtiny85 Signature Bytes
- •22.4 Calibration Byte
- •22.5 Page Size
- •22.6 Serial Downloading
- •22.6.1 Serial Programming Algorithm
- •22.6.2 Serial Programming Characteristics
- •22.7 High-voltage Serial Programming
- •22.8.2 Considerations for Efficient Programming
- •22.8.3 Chip Erase
- •22.8.4 Programming the Flash
- •22.8.5 Programming the EEPROM
- •22.8.6 Reading the Flash
- •22.8.7 Reading the EEPROM
- •22.8.8 Programming and Reading the Fuse and Lock Bits
- •22.8.9 Reading the Signature Bytes and Calibration Byte
- •23. Electrical Characteristics
- •23.1 Absolute Maximum Ratings*
- •23.2 External Clock Drive Waveforms
- •23.3 External Clock Drive
- •23.5 Calibrated RC Oscillator Accuracy
- •24. Typical Characteristics
- •24.1 Active Supply Current
- •24.2 Idle Supply Current
- •24.2.1 Using the Power Reduction Register
- •24.2.1.1 Example 1
- •24.5 Pin Driver Strength
- •24.6 Pin Thresholds and Hysteresis
- •24.7 BOD Thresholds and Analog Comparator Offset
- •24.8 Internal Oscillator Speed
- •24.9 Current Consumption of Peripheral Units
- •24.10 Current Consumption in Reset and Reset Pulse width
- •24.11 Analog to Digital Converter
- •25. Register Summary
- •26. Instruction Set Summary
- •27. Ordering Information
- •28. Packaging Information
- •29. Document Revision History
- •30. Errata
- •30.1 ATtiny25/45/85 Rev. A

Table 15-5. Timer/Counter1 Clock Prescale Select in the Asynchronous Mode
PWM Frequency |
Clock Selection |
CS13..CS10 |
OCR1C |
RESOLUTION |
|
|
|
|
|
120 kHz |
PCK/4 |
0011 |
132 |
7.1 |
|
|
|
|
|
130 kHz |
PCK/2 |
0010 |
245 |
7.9 |
|
|
|
|
|
140 kHz |
PCK/2 |
0010 |
228 |
7.8 |
|
|
|
|
|
150 kHz |
PCK/2 |
0010 |
212 |
7.7 |
|
|
|
|
|
160 kHz |
PCK/2 |
0010 |
199 |
7.6 |
|
|
|
|
|
170 kHz |
PCK/2 |
0010 |
187 |
7.6 |
|
|
|
|
|
180 kHz |
PCK/2 |
0010 |
177 |
7.5 |
|
|
|
|
|
190 kHz |
PCK/2 |
0010 |
167 |
7.4 |
|
|
|
|
|
200 kHz |
PCK/2 |
0010 |
159 |
7.3 |
|
|
|
|
|
250 kHz |
PCK |
0001 |
255 |
8.0 |
|
|
|
|
|
300 kHz |
PCK |
0001 |
212 |
7.7 |
|
|
|
|
|
350 kHz |
PCK |
0001 |
182 |
7.5 |
|
|
|
|
|
400 kHz |
PCK |
0001 |
159 |
7.3 |
|
|
|
|
|
450 kHz |
PCK |
0001 |
141 |
7.1 |
|
|
|
|
|
500 kHz |
PCK |
0001 |
127 |
7.0 |
|
|
|
|
|
16. Dead Time Generator
The Dead Time Generator is provided for the Timer/Counter1 PWM output pairs to allow driving external power control switches safely. The Dead Time Generator is a separate block that can be connected to Timer/Counter1 and it is used to insert dead times (non-overlapping times) for the Timer/Counter1 complementary output pairs (OC1A-OC1A and OC1B-OC1B). The sharing of tasks is as follows: the timer/counter generates the PWM output and the Dead Time Generator generates the non-overlapping PWM output pair from the timer/counter PWM signal. Two Dead Time Generators are provided, one for each PWM output. The non-overlap time is adjustable and the PWM output and it’s complementary output are adjusted separately, and independently for both PWM outputs.
Figure 16-1. Timer/Counter1 & Dead Time Generators
PCKE
|
|
|
|
|
|
|
|
|
|
|
|
TIMER/COUNTER1 |
|
|
|
|
|
|
|
|||
T15M |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|||
CK |
|
|
|
|
|
|
|
|
PWM GENERATOR |
|
|
|
|
|
|
|
||||||
|
|
|
|
|
|
|
|
|
|
|
|
|
||||||||||
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
||||
|
|
|
|
|
|
|
|
|
|
PWM1A |
|
|
PWM1B |
|||||||||
|
|
|
|
|
|
|
|
|
|
|
|
|||||||||||
PCK |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|||||
DT1AH |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
DT1BH |
||
|
|
|
|
|
DEAD TIME GENERATOR |
|
|
|
|
|
|
|
|
|||||||||
|
|
|
|
|
|
|
|
|
|
|||||||||||||
DT1AL |
|
|
|
|
DEAD TIME GENERATOR |
|||||||||||||||||
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
DT1BL |
|||||||
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|||||
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
OC1A |
|
|
|
|
OC1B |
|
|
|
|
|
|
|||
|
|
|
|
|
|
|
|
OC1A |
OC1B |
100 ATtiny25/45/85 Auto
7598C–AVR–09/06

ATtiny25/45/85 Auto
The dead time generation is based on the 4-bit down counters that count the dead time, as shown in Figure 46. There is a dedicated prescaler in front of the Dead Time Generator that can divide the Timer/Counter1 clock (PCK or CK) by 1, 2, 4 or 8. This provides for large range of dead times that can be generated. The prescaler is controlled by two control bits DTPS11..10 from the I/O register at address 0x23. The block has also a rising and falling edge detector that is used to start the dead time counting period. Depending on the edge, one of the transitions on the rising edges, OC1x or OC1x is delayed until the counter has counted to zero. The comparator is used to compare the counter with zero and stop the dead time insertion when zero has been reached. The counter is loaded with a 4-bit DT1xH or DT1xL value from DT1x I/O register, depending on the edge of the PWM generator output when the dead time insertion is started.
Figure 16-2. Dead Time Generator
T/C1 CLOCK DTPS11..10 |
|
|
COMPARATOR |
|
|
|
|
||
|
|
|
OC1x |
|
DEAD TIME |
CLOCK CONTROL |
4-BIT COUNTER |
||
PRESCALER |
||||
|
||||
|
|
DT1xH |
OC1x |
|
|
|
DT1xL |
||
|
|
|
DT1x |
|
|
|
|
I/O REGISTER |
PWM1x
The length of the counting period is user adjustable by selecting the dead time prescaler setting in 0x23 register, and selecting then the dead time value in I/O register DT1x. The DT1x register consists of two 4-bit fields, DT1xH and DT1xL that control the dead time periods of the PWM output and its’ complementary output separately. Thus the rising edge of OC1x and OC1x can have different dead time periods. The dead time is adjusted as the number of prescaled dead time generator clock cycles.
Figure 16-3. The Complementary Output Pair
PWM1x
OC1x
OC1x
x = A or B
t non-overlap / rising edge t non-overlap / falling edge
16.0.1Timer/Counter1 Dead Time Prescaler register 1 - DTPS1
Bit |
7 |
6 |
5 |
4 |
3 |
2 |
1 |
0 |
|
$23 ($43) |
|
|
|
|
|
|
DTPS11 |
DTPS10 |
DTPS1 |
Read/Write |
R |
R |
R |
R |
R |
R |
R/W |
R/W |
|
Initial value |
0 |
0 |
0 |
0 |
0 |
0 |
0 |
0 |
|
101
7598C–AVR–09/06

The dead time prescaler register, DTPS1 is a 2-bit read/write register.
The dedicated Dead Time prescaler in front of the Dead Time Generator can divide the Timer/Counter1 clock (PCK or CK) by 1, 2, 4 or 8 providing a large range of dead times that can be generated. The Dead Time prescaler is controlled by two bits DTPS11..10 from the Dead Time Prescaler register. These bits define the division factor of the Dead Time prescaler. The division factors are given in table 46..
Table 16-1. |
Division factors of the Dead Time prescaler |
||
DTPS11 |
|
DTPS10 |
Prescaler divides the T/C1 clock by |
|
|
|
|
0 |
|
0 |
1x (no division) |
|
|
|
|
0 |
|
1 |
2x |
|
|
|
|
1 |
|
0 |
4x |
|
|
|
|
1 |
|
1 |
8x |
|
|
|
|
16.0.2Timer/Counter1 Dead Time A - DT1A
Bit |
7 |
6 |
5 |
4 |
3 |
2 |
1 |
0 |
|
$25 ($45) |
DT1AH3 |
DT1AH2 |
DT1AH1 |
DT1AH0 |
DT1AL3 |
DT1AL2 |
DT1AL1 |
DT1AL0 |
DT1A |
|
|
|
|
|
|
|
|
|
|
Read/Write |
R/W |
R/W |
R/W |
R/W |
R/W |
R/W |
R/W |
R/W |
|
Initial value |
0 |
0 |
0 |
0 |
0 |
0 |
0 |
0 |
|
The dead time value register A is an 8-bit read/write register.
The dead time delay of is adjusted by the dead time value register, DT1A. The register consists of two fields, DT1AH3..0 and DT1AL3..0, one for each complementary output. Therefore a different dead time delay can be adjusted for the rising edge of OC1A and the rising edge of OC1A.
• Bits 7..4- DT1AH3..DT1AH0: Dead Time Value for OC1A Output
The dead time value for the OC1A 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- DT1AL3..DT1AL0: Dead Time Value for OC1A Output
The dead time value for the OC1A 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.
16.0.3Timer/Counter1 Dead Time B - DT1B
Bit |
7 |
6 |
5 |
4 |
3 |
2 |
1 |
0 |
|
$25 ($45) |
DT1BH3 |
DT1BH2 |
DT1BH1 |
DT1BH0 |
DT1BL3 |
DT1BL2 |
DT1BL1 |
DT1BL0 |
DT1B |
|
|
|
|
|
|
|
|
|
|
Read/Write |
R/W |
R/W |
R/W |
R/W |
R/W |
R/W |
R/W |
R/W |
|
Initial value |
0 |
0 |
0 |
0 |
0 |
0 |
0 |
0 |
|
The dead time value register Bis an 8-bit read/write register.
The dead time delay of is adjusted by the dead time value register, DT1B. The register consists of two fields, DT1BH3..0 and DT1BL3..0, one for each complementary output. Therefore a different dead time delay can be adjusted for the rising edge of OC1A and the rising edge of OC1A.
• Bits 7..4- DT1BH3..DT1BH0: Dead Time Value for OC1B Output
102 ATtiny25/45/85 Auto
7598C–AVR–09/06

ATtiny25/45/85 Auto
The dead time value for the OC1B 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- DT1BL3..DT1BL0: Dead Time Value for OC1B Output
The dead time value for the OC1B 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.
17. Universal Serial Interface – USI
The Universal Serial Interface, or USI, provides the basic hardware resources needed for serial communication. Combined with a minimum of control software, the USI allows significantly higher transfer rates and uses less code space than solutions based on software only. Interrupts are included to minimize the processor load. The main features of the USI are:
•Two-wire Synchronous Data Transfer (Master or Slave, fSCLmax = fCK/16)
•Three-wire Synchronous Data Transfer (Master or Slave fSCKmax = fCK/4)
•Data Received Interrupt
•Wakeup from Idle Mode
•In Two-wire Mode: Wake-up from All Sleep Modes, Including Power-down Mode
•Two-wire Start Condition Detector with Interrupt Capability
17.1Overview
A simplified block diagram of the USI is shown on Figure 17-1. For the actual placement of I/O pins, refer to “Pinout ATtiny25/45/85” on page 2. CPU accessible I/O Registers, including I/O bits and I/O pins, are shown in bold. The device-specific I/O Register and bit locations are listed in the “USI Register Descriptions” on page 110.
Figure 17-1. Universal Serial Interface, Block Diagram |
|
|
|||||||||
|
|
|
|
|
|
|
|
|
D Q |
DO |
(Output only) |
|
|
|
|
|
|
|
|
|
|
||
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
LE |
|
|
|
Bit7 |
|
|
|
|
|
|
Bit0 |
|
DI/SDA |
(Input/Open Drain) |
|
|
|
|
|
|
|
|
|
|||
|
|
|
|
|
|
|
|
|
|
||
|
|
|
|
|
|
|
|
3 |
|
|
|
|
|
|
|
|
USIDR |
|
2 |
|
|
|
|
|
|
|
|
|
|
1 |
TIM0 COMP |
|
|
||
|
|
|
|
|
|
|
|
|
|
||
|
|
|
|
|
|
|
|
0 |
|
|
|
|
|
|
|
|
USIDB |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
3 |
0 |
|
(Input/Open Drain) |
|
|
|
|
|
|
|
|
2 |
1 |
USCK/SCL |
|
BUSDATA |
USISIF |
USIOIF |
USIPF |
USIDC |
|
4-bit Counter |
Control Unit |
|
|||
USISR |
|
1 |
|
|
|||||||
|
|
|
|
|
|
|
|
0 |
|
CLOCK |
|
|
|
|
|
|
|
|
|
|
|
HOLD |
|
|
|
|
|
|
|
|
|
|
[1] |
Two-wire Clock |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2 |
|
|
|
|
|
|
USISIE |
USIOIE |
USIWM1 |
USIWM0 |
USICS1 |
USICS0 |
USICLK |
USITC |
|
|
|
|
|
|
|
|
USICR |
|
|
|
|
|
103
7598C–AVR–09/06