Files
2025-11-23 20:39:37 +04:00

612 lines
43 KiB
XML

<?xml version="1.0" encoding="UTF-8"?>
<device name="ATtiny25" family="AVR8" configuration-value="attiny25" architecture="AVRe" avr-family="TINY">
<property-groups>
<property-group key="signatures">
<property key="jtagid" value="0x9108"/>
<property key="signature0" value="0x1e"/>
<property key="signature1" value="0x91"/>
<property key="signature2" value="0x08"/>
</property-group>
<property-group key="ocd">
<property key="ocd_revision" value="1"/>
<property key="ocd_datareg" value="0x22"/>
<property key="progbase" value="0x0000"/>
</property-group>
<property-group key="jtag_interface">
<property key="allowfullpagestream" value="0x00"/>
</property-group>
<property-group key="isp_interface">
<property key="ispenterprogmode_timeout" value="200"/>
<property key="ispenterprogmode_stabdelay" value="100"/>
<property key="ispenterprogmode_cmdexedelay" value="25"/>
<property key="ispenterprogmode_synchloops" value="32"/>
<property key="ispenterprogmode_bytedelay" value="0"/>
<property key="ispenterprogmode_pollindex" value="3"/>
<property key="ispenterprogmode_pollvalue" value="0x53"/>
<property key="ispleaveprogmode_predelay" value="1"/>
<property key="ispleaveprogmode_postdelay" value="1"/>
<property key="ispchiperase_erasedelay" value="45"/>
<property key="ispchiperase_pollmethod" value="1"/>
<property key="ispprogramflash_mode" value="0x41"/>
<property key="ispprogramflash_blocksize" value="32"/>
<property key="ispprogramflash_delay" value="10"/>
<property key="ispprogramflash_cmd1" value="0x40"/>
<property key="ispprogramflash_cmd2" value="0x4C"/>
<property key="ispprogramflash_cmd3" value="0x00"/>
<property key="ispprogramflash_pollval1" value="0x00"/>
<property key="ispprogramflash_pollval2" value="0x00"/>
<property key="ispprogrameeprom_mode" value="0x41"/>
<property key="ispprogrameeprom_blocksize" value="4"/>
<property key="ispprogrameeprom_delay" value="5"/>
<property key="ispprogrameeprom_cmd1" value="0xC1"/>
<property key="ispprogrameeprom_cmd2" value="0xC2"/>
<property key="ispprogrameeprom_cmd3" value="0x00"/>
<property key="ispprogrameeprom_pollval1" value="0x00"/>
<property key="ispprogrameeprom_pollval2" value="0x00"/>
<property key="ispreadflash_blocksize" value="256"/>
<property key="ispreadeeprom_blocksize" value="256"/>
<property key="ispreadfuse_pollindex" value="4"/>
<property key="ispreadlock_pollindex" value="4"/>
<property key="ispreadsign_pollindex" value="4"/>
<property key="ispreadosccal_pollindex" value="4"/>
</property-group>
<property-group key="hvsp_interface">
<property key="hvspcontrolstack" value="0x4C 0x0C 0x1C 0x2C 0x3C 0x64 0x74 0x66 0x68 0x78 0x68 0x68 0x7A 0x6A 0x68 0x78 0x78 0x7D 0x6D 0x0C 0x80 0x40 0x20 0x10 0x11 0x08 0x04 0x02 0x03 0x08 0x04 0x00"/>
<property key="hvspenterprogmode_stabdelay" value="100"/>
<property key="hvspenterprogmode_cmdexedelay" value="0"/>
<property key="hvspenterprogmode_synchcycles" value="6"/>
<property key="hvspenterprogmode_latchcycles" value="1"/>
<property key="hvspenterprogmode_togglevtg" value="1"/>
<property key="hvspenterprogmode_powoffdelay" value="25"/>
<property key="hvspenterprogmode_resetdelay1" value="1"/>
<property key="hvspenterprogmode_resetdelay2" value="0"/>
<property key="hvspleaveprogmode_stabdelay" value="100"/>
<property key="hvspleaveprogmode_resetdelay" value="25"/>
<property key="hvspchiperase_polltimeout" value="40"/>
<property key="hvspchiperase_erasetime" value="0"/>
<property key="hvspprogramflash_mode" value="0x0B"/>
<property key="hvspprogramflash_blocksize" value="256"/>
<property key="hvspprogramflash_polltimeout" value="5"/>
<property key="hvspreadflash_blocksize" value="256"/>
<property key="hvspprogrameeprom_mode" value="0x05"/>
<property key="hvspprogrameeprom_blocksize" value="256"/>
<property key="hvspprogrameeprom_polltimeout" value="5"/>
<property key="hvspreadeeprom_blocksize" value="256"/>
<property key="hvspprogramfuse_polltimeout" value="25"/>
<property key="hvspprogramlock_polltimeout" value="25"/>
</property-group>
<property-group key="isp_interface_stk600">
<property key="ispenterprogmode_timeout" value="200"/>
<property key="ispenterprogmode_stabdelay" value="100"/>
<property key="ispenterprogmode_cmdexedelay" value="25"/>
<property key="ispenterprogmode_synchloops" value="32"/>
<property key="ispenterprogmode_bytedelay" value="0"/>
<property key="ispenterprogmode_pollindex" value="3"/>
<property key="ispenterprogmode_pollvalue" value="0x53"/>
<property key="ispleaveprogmode_predelay" value="1"/>
<property key="ispleaveprogmode_postdelay" value="1"/>
<property key="ispchiperase_erasedelay" value="45"/>
<property key="ispchiperase_pollmethod" value="1"/>
<property key="ispprogramflash_mode" value="0x41"/>
<property key="ispprogramflash_blocksize" value="32"/>
<property key="ispprogramflash_delay" value="6"/>
<property key="ispprogramflash_cmd1" value="0x40"/>
<property key="ispprogramflash_cmd2" value="0x4C"/>
<property key="ispprogramflash_cmd3" value="0x00"/>
<property key="ispprogramflash_pollval1" value="0x00"/>
<property key="ispprogramflash_pollval2" value="0x00"/>
<property key="ispprogrameeprom_mode" value="0x41"/>
<property key="ispprogrameeprom_blocksize" value="4"/>
<property key="ispprogrameeprom_delay" value="5"/>
<property key="ispprogrameeprom_cmd1" value="0xC1"/>
<property key="ispprogrameeprom_cmd2" value="0xC2"/>
<property key="ispprogrameeprom_cmd3" value="0x00"/>
<property key="ispprogrameeprom_pollval1" value="0x00"/>
<property key="ispprogrameeprom_pollval2" value="0x00"/>
<property key="ispreadflash_blocksize" value="256"/>
<property key="ispreadeeprom_blocksize" value="256"/>
<property key="ispreadfuse_pollindex" value="4"/>
<property key="ispreadlock_pollindex" value="4"/>
<property key="ispreadsign_pollindex" value="4"/>
<property key="ispreadosccal_pollindex" value="4"/>
</property-group>
<property-group key="hvsp_interface_stk600">
<property key="hvspcontrolstack" value="0x4C 0x0C 0x1C 0x2C 0x3C 0x64 0x74 0x66 0x68 0x78 0x68 0x68 0x7A 0x6A 0x68 0x78 0x78 0x7D 0x6D 0x0C 0x80 0x40 0x20 0x10 0x11 0x08 0x04 0x02 0x03 0x08 0x04 0x00"/>
<property key="hvspenterprogmode_stabdelay" value="100"/>
<property key="hvspenterprogmode_cmdexedelay" value="0"/>
<property key="hvspenterprogmode_synchcycles" value="6"/>
<property key="hvspenterprogmode_latchcycles" value="1"/>
<property key="hvspenterprogmode_togglevtg" value="1"/>
<property key="hvspenterprogmode_powoffdelay" value="20"/>
<property key="hvspenterprogmode_resetdelay1" value="0"/>
<property key="hvspenterprogmode_resetdelay2" value="50"/>
<property key="hvspleaveprogmode_stabdelay" value="100"/>
<property key="hvspleaveprogmode_resetdelay" value="25"/>
<property key="hvspchiperase_polltimeout" value="40"/>
<property key="hvspchiperase_erasetime" value="0"/>
<property key="hvspprogramflash_mode" value="0x0B"/>
<property key="hvspprogramflash_blocksize" value="256"/>
<property key="hvspprogramflash_polltimeout" value="5"/>
<property key="hvspreadflash_blocksize" value="256"/>
<property key="hvspprogrameeprom_mode" value="0x05"/>
<property key="hvspprogrameeprom_blocksize" value="256"/>
<property key="hvspprogrameeprom_polltimeout" value="5"/>
<property key="hvspreadeeprom_blocksize" value="256"/>
<property key="hvspprogramfuse_polltimeout" value="25"/>
<property key="hvspprogramlock_polltimeout" value="25"/>
</property-group>
</property-groups>
<address-spaces>
<address-space key="prog" start="0x00000000" size="2048" endianness="little">
<memory-segment key="internal_program_memory" name="Internal FLASH" type="flash" start="0x00000000" size="2048" page-size="32" access="RW" executable="1"/>
</address-space>
<address-space key="signatures" start="0x00000000" size="3" endianness="little">
<memory-segment key="signatures" name="Signatures" type="signatures" start="0x00000000" size="3" access="R" executable="0"/>
</address-space>
<address-space key="fuses" start="0x00000000" size="3" endianness="little">
<memory-segment key="fuses" name="Fuses" type="fuses" start="0x00000000" size="3" access="RW" executable="0"/>
</address-space>
<address-space key="lockbits" start="0x00000000" size="1" endianness="little">
<memory-segment key="lockbits" name="Lockbits" type="lockbits" start="0x00000000" size="1" access="RW" executable="0"/>
</address-space>
<address-space key="data" start="0x00000000" size="224" endianness="little">
<memory-segment key="gp_registers" name="General Purpose Registers" type="gp_registers" start="0x00000000" size="32" executable="0"/>
<memory-segment key="mapped_io" name="Mapped Input/Output" type="io" start="0x00000020" size="64" executable="0"/>
<memory-segment key="internal_ram" name="Internal RAM" type="ram" start="0x00000060" size="128" executable="0"/>
</address-space>
<address-space key="eeprom" start="0x00000000" size="128" endianness="little">
<memory-segment key="internal_eeprom" name="Internal EEPROM" type="eeprom" start="0x00000000" size="128" page-size="4" access="RW" executable="0"/>
</address-space>
<address-space key="osccal" start="0x00000000" size="2" endianness="little">
<memory-segment key="osccal" name="OSCCAL" type="osccal" start="0x00000000" size="2" access="R" executable="0"/>
</address-space>
</address-spaces>
<physical-interfaces>
<physical-interface value="debug_wire">
<signals>
<signal name="dW" pad-key="pb5"/>
</signals>
</physical-interface>
<physical-interface value="isp">
<signals>
<signal name="RESET" pad-key="pb5"/>
<signal name="MOSI" pad-key="pb0"/>
<signal name="MISO" pad-key="pb1"/>
<signal name="SCLK" pad-key="pb2"/>
</signals>
</physical-interface>
<physical-interface value="hvsp"/>
</physical-interfaces>
<peripherals>
<peripheral key="portb" name="PORTB" module-key="gpio_port">
<register-group-instance description="I/O Port" register-group-key="portb" address-space-key="data" offset="0x0"/>
<signals>
<signal name="PB0" pad-key="pb0" index="0" function="PORTB"/>
<signal name="PB1" pad-key="pb1" index="1" function="PORTB"/>
<signal name="PB2" pad-key="pb2" index="2" function="PORTB"/>
<signal name="PB3" pad-key="pb3" index="3" function="PORTB"/>
<signal name="PB4" pad-key="pb4" index="4" function="PORTB"/>
<signal name="PB5" pad-key="pb5" index="5" function="PORTB"/>
</signals>
</peripheral>
<peripheral key="ac" name="AC" module-key="ac">
<register-group-instance description="Analog Comparator" register-group-key="ac" address-space-key="data" offset="0x0"/>
<signals>
<signal name="AIN" pad-key="pb1" index="1" function="ACIN"/>
<signal name="AIN" pad-key="pb0" index="0" function="ACIN"/>
</signals>
</peripheral>
<peripheral key="adc" name="ADC" module-key="adc">
<register-group-instance description="Analog-to-Digital Converter" register-group-key="adc" address-space-key="data" offset="0x0"/>
<signals>
<signal name="ADC" pad-key="pb5" index="0" function="ADC"/>
<signal name="ADC" pad-key="pb2" index="1" function="ADC"/>
<signal name="ADC" pad-key="pb4" index="2" function="ADC"/>
<signal name="AREF" pad-key="pb0" function="AREF"/>
</signals>
</peripheral>
<peripheral key="usi" name="USI" module-key="usi">
<register-group-instance description="Universal Serial Interface" register-group-key="usi" address-space-key="data" offset="0x0"/>
<signals>
<signal name="SDA" pad-key="pb0" function="TWI"/>
<signal name="SCL" pad-key="pb2" function="TWI"/>
<signal name="DI" pad-key="pb0" function="SPI"/>
<signal name="DO" pad-key="pb1" function="SPI"/>
<signal name="USCK" pad-key="pb2" function="SPI"/>
</signals>
</peripheral>
<peripheral key="exint" name="EXINT" module-key="exint">
<register-group-instance description="External Interrupts" register-group-key="exint" address-space-key="data" offset="0x0"/>
<signals>
<signal name="PCINT" pad-key="pb0" index="0" function="EXTINT"/>
<signal name="PCINT" pad-key="pb1" index="1" function="EXTINT"/>
<signal name="PCINT" pad-key="pb2" index="2" function="EXTINT"/>
<signal name="PCINT" pad-key="pb3" index="3" function="EXTINT"/>
<signal name="PCINT" pad-key="pb4" index="4" function="EXTINT"/>
<signal name="PCINT" pad-key="pb5" index="5" function="EXTINT"/>
<signal name="INT" pad-key="pb2" index="0" function="EXTINT"/>
</signals>
</peripheral>
<peripheral key="eeprom" name="EEPROM" module-key="eeprom">
<register-group-instance description="EEPROM" register-group-key="eeprom" address-space-key="data" offset="0x0"/>
</peripheral>
<peripheral key="wdt" name="WDT" module-key="wdt">
<register-group-instance description="Watchdog Timer" register-group-key="wdt" address-space-key="data" offset="0x0"/>
</peripheral>
<peripheral key="tc0" name="TC0" module-key="tc8">
<register-group-instance description="Timer/Counter, 8-bit" register-group-key="tc0" address-space-key="data" offset="0x0"/>
<signals>
<signal name="T0" pad-key="pb2" function="T0"/>
<signal name="OC0B" pad-key="pb1" function="T0"/>
<signal name="OC0A" pad-key="pb0" function="T0"/>
</signals>
</peripheral>
<peripheral key="tc1" name="TC1" module-key="tc8">
<register-group-instance description="Timer/Counter, 8-bit" register-group-key="tc1" address-space-key="data" offset="0x0"/>
<signals>
<signal name="OC1B" pad-key="pb4" function="T1"/>
<signal name="OC1BINV" pad-key="pb3" function="T1"/>
<signal name="OC1A" pad-key="pb1" function="T1"/>
<signal name="OC1AINV" pad-key="pb0" function="T1"/>
</signals>
</peripheral>
<peripheral key="boot_load" name="BOOT_LOAD" module-key="boot_load">
<register-group-instance description="Bootloader" register-group-key="boot_load" address-space-key="data" offset="0x0"/>
</peripheral>
<peripheral key="cpu" name="CPU" module-key="cpu">
<register-group-instance description="CPU Registers" register-group-key="cpu" address-space-key="data" offset="0x0"/>
</peripheral>
<peripheral key="fuse" name="FUSE" module-key="fuse">
<register-group-instance description="Fuses" register-group-key="fuse" address-space-key="fuses" offset="0x0"/>
</peripheral>
<peripheral key="lockbit" name="LOCKBIT" module-key="lockbit">
<register-group-instance description="Lockbits" register-group-key="lockbit" address-space-key="lockbits" offset="0x0"/>
</peripheral>
</peripherals>
<modules>
<module key="fuse" name="FUSE" description="Fuses">
<register-group key="fuse" name="FUSE">
<register key="low" name="LOW" offset="0x00" size="1" initial-value="0x62">
<bit-field key="ckdiv8" name="CKDIV8" description="Divide clock by 8 internally" mask="0x80"/>
<bit-field key="ckout" name="CKOUT" description="Clock output on PORTB4" mask="0x40"/>
<bit-field key="sut_cksel" name="SUT_CKSEL" description="Select Clock source" mask="0x3F"/>
</register>
<register key="high" name="HIGH" offset="0x01" size="1" initial-value="0xDF">
<bit-field key="rstdisbl" name="RSTDISBL" description="Reset Disabled (Enable PB5 as i/o pin)" mask="0x80"/>
<bit-field key="dwen" name="DWEN" description="Debug Wire enable" mask="0x40"/>
<bit-field key="spien" name="SPIEN" description="Serial program downloading (SPI) enabled" mask="0x20"/>
<bit-field key="wdton" name="WDTON" description="Watch-dog Timer always on" mask="0x10"/>
<bit-field key="eesave" name="EESAVE" description="Preserve EEPROM through the Chip Erase cycle" mask="0x08"/>
<bit-field key="bodlevel" name="BODLEVEL" description="Brown-out Detector trigger level" mask="0x07"/>
</register>
<register key="extended" name="EXTENDED" offset="0x02" size="1" initial-value="0xFF">
<bit-field key="selfprgen" name="SELFPRGEN" description="Self Programming enable" mask="0x01"/>
</register>
</register-group>
</module>
<module key="lockbit" name="LOCKBIT" description="Lockbits">
<register-group key="lockbit" name="LOCKBIT">
<register key="lockbit" name="LOCKBIT" offset="0x00" size="1" initial-value="0xFF">
<bit-field key="lb" name="LB" description="Memory Lock" mask="0x03"/>
</register>
</register-group>
</module>
<module key="gpio_port" name="PORT" description="I/O Port">
<register-group key="portb" name="PORTB">
<register key="pinb" name="PINB" description="Input Pins, Port B" offset="0x36" size="1"/>
<register key="ddrb" name="DDRB" description="Data Direction Register, Port B" offset="0x37" size="1"/>
<register key="portb" name="PORTB" description="Data Register, Port B" offset="0x38" size="1"/>
</register-group>
</module>
<module key="ac" name="AC" description="Analog Comparator">
<register-group key="ac" name="AC">
<register key="adcsrb" name="ADCSRB" description="ADC Control and Status Register B" offset="0x23" size="1">
<bit-field key="acme" name="ACME" description="Analog Comparator Multiplexer Enable" mask="0x40"/>
</register>
<register key="acsr" name="ACSR" description="Analog Comparator Control And Status Register" offset="0x28" size="1">
<bit-field key="acd" name="ACD" description="Analog Comparator Disable" mask="0x80"/>
<bit-field key="acbg" name="ACBG" description="Analog Comparator Bandgap Select" mask="0x40"/>
<bit-field key="aco" name="ACO" description="Analog Compare Output" mask="0x20"/>
<bit-field key="aci" name="ACI" description="Analog Comparator Interrupt Flag" mask="0x10"/>
<bit-field key="acie" name="ACIE" description="Analog Comparator Interrupt Enable" mask="0x08"/>
<bit-field key="acis" name="ACIS" description="Analog Comparator Interrupt Mode Select bits" mask="0x03"/>
</register>
<register key="didr0" name="DIDR0" offset="0x34" size="1">
<bit-field key="ain1d" name="AIN1D" description="AIN1 Digital Input Disable" mask="0x02"/>
<bit-field key="ain0d" name="AIN0D" description="AIN0 Digital Input Disable" mask="0x01"/>
</register>
</register-group>
</module>
<module key="adc" name="ADC" description="Analog-to-Digital Converter">
<register-group key="adc" name="ADC">
<register key="adcsrb" name="ADCSRB" description="ADC Control and Status Register B" offset="0x23" size="1">
<bit-field key="bin" name="BIN" description="Bipolar Input Mode" mask="0x80"/>
<bit-field key="ipr" name="IPR" description="Input Polarity Mode" mask="0x20"/>
<bit-field key="adts" name="ADTS" description="ADC Auto Trigger Sources" mask="0x07"/>
</register>
<register key="adc" name="ADC" description="ADC Data Register Bytes" offset="0x24" size="2"/>
<register key="adcsra" name="ADCSRA" description="The ADC Control and Status register" offset="0x26" size="1">
<bit-field key="aden" name="ADEN" description="ADC Enable" mask="0x80"/>
<bit-field key="adsc" name="ADSC" description="ADC Start Conversion" mask="0x40"/>
<bit-field key="adate" name="ADATE" description="ADC Auto Trigger Enable" mask="0x20"/>
<bit-field key="adif" name="ADIF" description="ADC Interrupt Flag" mask="0x10"/>
<bit-field key="adie" name="ADIE" description="ADC Interrupt Enable" mask="0x08"/>
<bit-field key="adps" name="ADPS" description="ADC Prescaler Select Bits" mask="0x07"/>
</register>
<register key="admux" name="ADMUX" description="The ADC multiplexer Selection Register" offset="0x27" size="1">
<bit-field key="refs" name="REFS" description="Reference Selection Bits" mask="0xC0"/>
<bit-field key="adlar" name="ADLAR" description="Left Adjust Result" mask="0x20"/>
<bit-field key="refs2" name="REFS2" description="Reference Selection Bit 2" mask="0x10"/>
<bit-field key="mux" name="MUX" description="Analog Channel and Gain Selection Bits" mask="0x0F"/>
</register>
<register key="didr0" name="DIDR0" description="Digital Input Disable Register 0" offset="0x34" size="1">
<bit-field key="adc0d" name="ADC0D" description="ADC0 Digital input Disable" mask="0x20"/>
<bit-field key="adc2d" name="ADC2D" description="ADC2 Digital input Disable" mask="0x10"/>
<bit-field key="adc3d" name="ADC3D" description="ADC3 Digital input Disable" mask="0x08"/>
<bit-field key="adc1d" name="ADC1D" description="ADC1 Digital input Disable" mask="0x04"/>
</register>
</register-group>
</module>
<module key="usi" name="USI" description="Universal Serial Interface">
<register-group key="usi" name="USI">
<register key="usicr" name="USICR" description="USI Control Register" offset="0x2D" size="1">
<bit-field key="usisie" name="USISIE" description="Start Condition Interrupt Enable" mask="0x80"/>
<bit-field key="usioie" name="USIOIE" description="Counter Overflow Interrupt Enable" mask="0x40"/>
<bit-field key="usiwm" name="USIWM" description="USI Wire Mode Bits" mask="0x30"/>
<bit-field key="usics" name="USICS" description="USI Clock Source Select Bits" mask="0x0C"/>
<bit-field key="usiclk" name="USICLK" description="Clock Strobe" mask="0x02"/>
<bit-field key="usitc" name="USITC" description="Toggle Clock Port Pin" mask="0x01"/>
</register>
<register key="usisr" name="USISR" description="USI Status Register" offset="0x2E" size="1">
<bit-field key="usisif" name="USISIF" description="Start Condition Interrupt Flag" mask="0x80"/>
<bit-field key="usioif" name="USIOIF" description="Counter Overflow Interrupt Flag" mask="0x40"/>
<bit-field key="usipf" name="USIPF" description="Stop Condition Flag" mask="0x20"/>
<bit-field key="usidc" name="USIDC" description="Data Output Collision" mask="0x10"/>
<bit-field key="usicnt" name="USICNT" description="USI Counter Value Bits" mask="0x0F"/>
</register>
<register key="usidr" name="USIDR" description="USI Data Register" offset="0x2F" size="1"/>
<register key="usibr" name="USIBR" description="USI Buffer Register" offset="0x30" size="1"/>
</register-group>
</module>
<module key="exint" name="EXINT" description="External Interrupts">
<register-group key="exint" name="EXINT">
<register key="pcmsk" name="PCMSK" description="Pin Change Enable Mask" offset="0x35" size="1"/>
<register key="mcucr" name="MCUCR" description="MCU Control Register" offset="0x55" size="1">
<bit-field key="isc01" name="ISC01" description="Interrupt Sense Control 0 Bit 1" mask="0x02"/>
<bit-field key="isc00" name="ISC00" description="Interrupt Sense Control 0 Bit 0" mask="0x01"/>
</register>
<register key="gifr" name="GIFR" description="General Interrupt Flag register" offset="0x5A" size="1">
<bit-field key="intf0" name="INTF0" description="External Interrupt Flag 0" mask="0x40"/>
<bit-field key="pcif" name="PCIF" description="Pin Change Interrupt Flag" mask="0x20"/>
</register>
<register key="gimsk" name="GIMSK" description="General Interrupt Mask Register" offset="0x5B" size="1">
<bit-field key="int0" name="INT0" description="External Interrupt Request 0 Enable" mask="0x40"/>
<bit-field key="pcie" name="PCIE" description="Pin Change Interrupt Enable" mask="0x20"/>
</register>
</register-group>
</module>
<module key="eeprom" name="EEPROM" description="EEPROM">
<register-group key="eeprom" name="EEPROM">
<register key="eecr" name="EECR" description="EEPROM Control Register" offset="0x3C" size="1">
<bit-field key="eepm" name="EEPM" description="EEPROM Programming Mode Bits" mask="0x30"/>
<bit-field key="eerie" name="EERIE" description="EEPROM Ready Interrupt Enable" mask="0x08"/>
<bit-field key="eempe" name="EEMPE" description="EEPROM Master Write Enable" mask="0x04"/>
<bit-field key="eepe" name="EEPE" description="EEPROM Write Enable" mask="0x02"/>
<bit-field key="eere" name="EERE" description="EEPROM Read Enable" mask="0x01"/>
</register>
<register key="eedr" name="EEDR" description="EEPROM Data Register" offset="0x3D" size="1"/>
<register key="eear" name="EEAR" description="EEPROM Address Register Bytes" offset="0x3E" size="2"/>
</register-group>
</module>
<module key="wdt" name="WDT" description="Watchdog Timer">
<register-group key="wdt" name="WDT">
<register key="wdtcr" name="WDTCR" description="Watchdog Timer Control Register" offset="0x41" size="1">
<bit-field key="wdif" name="WDIF" description="Watchdog Timeout Interrupt Flag" mask="0x80"/>
<bit-field key="wdie" name="WDIE" description="Watchdog Timeout Interrupt Enable" mask="0x40"/>
<bit-field key="wdp" name="WDP" description="Watchdog Timer Prescaler Bits" mask="0x27"/>
<bit-field key="wdce" name="WDCE" description="Watchdog Change Enable" mask="0x10"/>
<bit-field key="wde" name="WDE" description="Watch Dog Enable" mask="0x08"/>
</register>
</register-group>
</module>
<module key="tc8" name="TC8" description="Timer/Counter, 8-bit">
<register-group key="tc0" name="TC0">
<register key="ocr0b" name="OCR0B" description="Timer/Counter0 Output Compare Register" offset="0x48" size="1"/>
<register key="ocr0a" name="OCR0A" description="Timer/Counter0 Output Compare Register" offset="0x49" size="1"/>
<register key="tccr0a" name="TCCR0A" description="Timer/Counter Control Register A" offset="0x4A" size="1">
<bit-field key="com0a" name="COM0A" description="Compare Output Mode, Phase Correct PWM Mode" mask="0xC0"/>
<bit-field key="com0b" name="COM0B" description="Compare Output Mode, Fast PWm" mask="0x30"/>
<bit-field key="wgm0" name="WGM0" description="Waveform Generation Mode" mask="0x03"/>
</register>
<register key="gtccr" name="GTCCR" description="General Timer/Counter Control Register" offset="0x4C" size="1">
<bit-field key="tsm" name="TSM" description="Timer/Counter Synchronization Mode" mask="0x80"/>
<bit-field key="psr0" name="PSR0" description="Prescaler Reset Timer/Counter1 and Timer/Counter0" mask="0x01"/>
</register>
<register key="tcnt0" name="TCNT0" description="Timer/Counter0" offset="0x52" size="1"/>
<register key="tccr0b" name="TCCR0B" description="Timer/Counter Control Register B" offset="0x53" size="1">
<bit-field key="foc0a" name="FOC0A" description="Force Output Compare A" mask="0x80"/>
<bit-field key="foc0b" name="FOC0B" description="Force Output Compare B" mask="0x40"/>
<bit-field key="wgm02" name="WGM02" mask="0x08"/>
<bit-field key="cs0" name="CS0" description="Clock Select" mask="0x07"/>
</register>
<register key="tifr" name="TIFR" description="Timer/Counter0 Interrupt Flag register" offset="0x58" size="1">
<bit-field key="ocf0a" name="OCF0A" description="Timer/Counter0 Output Compare Flag 0A" mask="0x10"/>
<bit-field key="ocf0b" name="OCF0B" description="Timer/Counter0 Output Compare Flag 0B" mask="0x08"/>
<bit-field key="tov0" name="TOV0" description="Timer/Counter0 Overflow Flag" mask="0x02"/>
</register>
<register key="timsk" name="TIMSK" description="Timer/Counter Interrupt Mask Register" offset="0x59" size="1">
<bit-field key="ocie0a" name="OCIE0A" description="Timer/Counter0 Output Compare Match A Interrupt Enable" mask="0x10"/>
<bit-field key="ocie0b" name="OCIE0B" description="Timer/Counter0 Output Compare Match B Interrupt Enable" mask="0x08"/>
<bit-field key="toie0" name="TOIE0" description="Timer/Counter0 Overflow Interrupt Enable" mask="0x02"/>
</register>
</register-group>
<register-group key="tc1" name="TC1">
<register key="dtps" name="DTPS" description="Dead time prescaler register" offset="0x43" size="1">
<bit-field key="dtps" name="DTPS" mask="0x03"/>
</register>
<register key="dt1b" name="DT1B" description="Dead time value B" offset="0x44" size="1">
<bit-field key="dtvh" name="DTVH" mask="0xF0"/>
<bit-field key="dtvl" name="DTVL" mask="0x0F"/>
</register>
<register key="dt1a" name="DT1A" description="Dead time value register" offset="0x45" size="1">
<bit-field key="dtvh" name="DTVH" mask="0xF0"/>
<bit-field key="dtvl" name="DTVL" mask="0x0F"/>
</register>
<register key="ocr1b" name="OCR1B" description="Output Compare Register" offset="0x4B" size="1"/>
<register key="gtccr" name="GTCCR" description="Timer counter control register" offset="0x4C" size="1">
<bit-field key="pwm1b" name="PWM1B" description="Pulse Width Modulator B Enable" mask="0x40"/>
<bit-field key="com1b" name="COM1B" description="Comparator B Output Mode" mask="0x30"/>
<bit-field key="foc1b" name="FOC1B" description="Force Output Compare Match 1B" mask="0x08"/>
<bit-field key="foc1a" name="FOC1A" description="Force Output Compare 1A" mask="0x04"/>
<bit-field key="psr1" name="PSR1" description="Prescaler Reset Timer/Counter1" mask="0x02"/>
</register>
<register key="ocr1c" name="OCR1C" description="Output compare register" offset="0x4D" size="1"/>
<register key="ocr1a" name="OCR1A" description="Output Compare Register" offset="0x4E" size="1"/>
<register key="tcnt1" name="TCNT1" description="Timer/Counter Register" offset="0x4F" size="1"/>
<register key="tccr1" name="TCCR1" description="Timer/Counter Control Register" offset="0x50" size="1">
<bit-field key="ctc1" name="CTC1" description="Clear Timer/Counter on Compare Match" mask="0x80"/>
<bit-field key="pwm1a" name="PWM1A" description="Pulse Width Modulator Enable" mask="0x40"/>
<bit-field key="com1a" name="COM1A" description="Compare Output Mode, Bits" mask="0x30"/>
<bit-field key="cs1" name="CS1" description="Clock Select Bits" mask="0x0F"/>
</register>
<register key="tifr" name="TIFR" description="Timer/Counter Interrupt Flag Register" offset="0x58" size="1">
<bit-field key="ocf1a" name="OCF1A" description="Timer/Counter1 Output Compare Flag 1A" mask="0x40"/>
<bit-field key="ocf1b" name="OCF1B" description="Timer/Counter1 Output Compare Flag 1B" mask="0x20"/>
<bit-field key="tov1" name="TOV1" description="Timer/Counter1 Overflow Flag" mask="0x04"/>
</register>
<register key="timsk" name="TIMSK" description="Timer/Counter Interrupt Mask Register" offset="0x59" size="1">
<bit-field key="ocie1a" name="OCIE1A" description="OCIE1A: Timer/Counter1 Output Compare Interrupt Enable" mask="0x40"/>
<bit-field key="ocie1b" name="OCIE1B" description="OCIE1A: Timer/Counter1 Output Compare B Interrupt Enable" mask="0x20"/>
<bit-field key="toie1" name="TOIE1" description="Timer/Counter1 Overflow Interrupt Enable" mask="0x04"/>
</register>
</register-group>
</module>
<module key="boot_load" name="BOOT_LOAD" description="Bootloader">
<register-group key="boot_load" name="BOOT_LOAD">
<register key="spmcsr" name="SPMCSR" description="Store Program Memory Control Register" offset="0x57" size="1">
<bit-field key="rsig" name="RSIG" description="Read Device Signature Imprint Table" mask="0x20"/>
<bit-field key="ctpb" name="CTPB" description="Clear temporary page buffer" mask="0x10"/>
<bit-field key="rflb" name="RFLB" description="Read fuse and lock bits" mask="0x08"/>
<bit-field key="pgwrt" name="PGWRT" description="Page Write" mask="0x04"/>
<bit-field key="pgers" name="PGERS" description="Page Erase" mask="0x02"/>
<bit-field key="spmen" name="SPMEN" description="Store Program Memory Enable" mask="0x01"/>
</register>
</register-group>
</module>
<module key="cpu" name="CPU" description="CPU Registers">
<register-group key="cpu" name="CPU">
<register key="gpior0" name="GPIOR0" description="General purpose register 0" offset="0x31" size="1"/>
<register key="gpior1" name="GPIOR1" description="General Purpose register 1" offset="0x32" size="1"/>
<register key="gpior2" name="GPIOR2" description="General Purpose IO register 2" offset="0x33" size="1"/>
<register key="prr" name="PRR" description="Power Reduction Register" offset="0x40" size="1">
<bit-field key="prtim1" name="PRTIM1" description="Power Reduction Timer/Counter1" mask="0x08"/>
<bit-field key="prtim0" name="PRTIM0" description="Power Reduction Timer/Counter0" mask="0x04"/>
<bit-field key="prusi" name="PRUSI" description="Power Reduction USI" mask="0x02"/>
<bit-field key="pradc" name="PRADC" description="Power Reduction ADC" mask="0x01"/>
</register>
<register key="dwdr" name="DWDR" description="debugWIRE data register" offset="0x42" size="1"/>
<register key="clkpr" name="CLKPR" description="Clock Prescale Register" offset="0x46" size="1">
<bit-field key="clkpce" name="CLKPCE" description="Clock Prescaler Change Enable" mask="0x80"/>
<bit-field key="clkps" name="CLKPS" description="Clock Prescaler Select Bits" mask="0x0F"/>
</register>
<register key="pllcsr" name="PLLCSR" description="PLL Control and status register" offset="0x47" size="1">
<bit-field key="lsm" name="LSM" description="Low speed mode" mask="0x80"/>
<bit-field key="pcke" name="PCKE" description="PCK Enable" mask="0x04"/>
<bit-field key="plle" name="PLLE" description="PLL Enable" mask="0x02"/>
<bit-field key="plock" name="PLOCK" description="PLL Lock detector" mask="0x01"/>
</register>
<register key="osccal" name="OSCCAL" description="Oscillator Calibration Register" offset="0x51" size="1">
<bit-field key="osccal" name="OSCCAL" description="Oscillator Calibration" mask="0xFF"/>
</register>
<register key="mcusr" name="MCUSR" description="MCU Status register" offset="0x54" size="1">
<bit-field key="wdrf" name="WDRF" description="Watchdog Reset Flag" mask="0x08"/>
<bit-field key="borf" name="BORF" description="Brown-out Reset Flag" mask="0x04"/>
<bit-field key="extrf" name="EXTRF" description="External Reset Flag" mask="0x02"/>
<bit-field key="porf" name="PORF" description="Power-On Reset Flag" mask="0x01"/>
</register>
<register key="mcucr" name="MCUCR" description="MCU Control Register" offset="0x55" size="1">
<bit-field key="pud" name="PUD" description="Pull-up Disable" mask="0x40"/>
<bit-field key="se" name="SE" description="Sleep Enable" mask="0x20"/>
<bit-field key="sm" name="SM" description="Sleep Mode Select Bits" mask="0x18"/>
<bit-field key="isc0" name="ISC0" description="Interrupt Sense Control 0 bits" mask="0x03"/>
</register>
<register key="spl" name="SPL" description="Stack Pointer Low Byte" offset="0x5D" size="1"/>
<register key="sreg" name="SREG" description="Status Register" offset="0x5F" size="1">
<bit-field key="i" name="I" description="Global Interrupt Enable" mask="0x80"/>
<bit-field key="t" name="T" description="Bit Copy Storage" mask="0x40"/>
<bit-field key="h" name="H" description="Half Carry Flag" mask="0x20"/>
<bit-field key="s" name="S" description="Sign Bit" mask="0x10"/>
<bit-field key="v" name="V" description="Two's Complement Overflow Flag" mask="0x08"/>
<bit-field key="n" name="N" description="Negative Flag" mask="0x04"/>
<bit-field key="z" name="Z" description="Zero Flag" mask="0x02"/>
<bit-field key="c" name="C" description="Carry Flag" mask="0x01"/>
</register>
</register-group>
</module>
</modules>
<pads>
<pad key="gnd" name="GND"/>
<pad key="pb0" name="PB0"/>
<pad key="pb1" name="PB1"/>
<pad key="pb2" name="PB2"/>
<pad key="pb3" name="PB3"/>
<pad key="pb4" name="PB4"/>
<pad key="pb5" name="PB5"/>
<pad key="vcc" name="VCC"/>
</pads>
<pinouts>
<pinout key="soic_8" name="SOIC_8" type="soic">
<pin position="1" pad-key="pb5"/>
<pin position="2" pad-key="pb3"/>
<pin position="3" pad-key="pb4"/>
<pin position="4" pad-key="gnd"/>
<pin position="5" pad-key="pb0"/>
<pin position="6" pad-key="pb1"/>
<pin position="7" pad-key="pb2"/>
<pin position="8" pad-key="vcc"/>
</pinout>
<pinout key="qfn_20" name="QFN_20" type="qfn">
<pin position="1" pad-key="pb5"/>
<pin position="2" pad-key="pb3"/>
<pin position="3"/>
<pin position="4"/>
<pin position="5" pad-key="pb4"/>
<pin position="6"/>
<pin position="7"/>
<pin position="8" pad-key="gnd"/>
<pin position="9"/>
<pin position="10"/>
<pin position="11" pad-key="pb0"/>
<pin position="12" pad-key="pb1"/>
<pin position="13"/>
<pin position="14" pad-key="pb2"/>
<pin position="15" pad-key="vcc"/>
<pin position="16"/>
<pin position="17"/>
<pin position="18"/>
<pin position="19"/>
<pin position="20"/>
</pinout>
</pinouts>
<variants>
<variant key="attiny25v_10pu" name="ATtiny25V-10PU" pinout-key="soic_8"/>
<variant key="attiny25v_10su" name="ATtiny25V-10SU" pinout-key="soic_8"/>
<variant key="attiny25v_10sh" name="ATtiny25V-10SH" pinout-key="soic_8"/>
<variant key="attiny25v_10ssu" name="ATtiny25V-10SSU" pinout-key="soic_8"/>
<variant key="attiny25v_10ssh" name="ATtiny25V-10SSH" pinout-key="soic_8"/>
<variant key="attiny25v_10mu" name="ATtiny25V-10MU" pinout-key="qfn_20"/>
<variant key="attiny25v_10sn" name="ATtiny25V-10SN" pinout-key="soic_8"/>
<variant key="attiny25v_10ssn" name="ATtiny25V-10SSN" pinout-key="soic_8"/>
<variant key="attiny25v_10mf" name="ATtiny25V-10MF" pinout-key="qfn_20"/>
<variant key="attiny25v_20pu" name="ATtiny25V-20PU" pinout-key="soic_8"/>
<variant key="attiny25v_20su" name="ATtiny25V-20SU" pinout-key="soic_8"/>
<variant key="attiny25v_20sh" name="ATtiny25V-20SH" pinout-key="soic_8"/>
<variant key="attiny25v_20ssu" name="ATtiny25V-20SSU" pinout-key="soic_8"/>
<variant key="attiny25v_20ssh" name="ATtiny25V-20SSH" pinout-key="soic_8"/>
<variant key="attiny25v_20mu" name="ATtiny25V-20MU" pinout-key="qfn_20"/>
<variant key="attiny25v_20sn" name="ATtiny25V-20SN" pinout-key="soic_8"/>
<variant key="attiny25v_20ssn" name="ATtiny25V-20SSN" pinout-key="soic_8"/>
<variant key="attiny25v_20mf" name="ATtiny25V-20MF" pinout-key="qfn_20"/>
</variants>
</device>