/* Copyright (c) 2006, 2007, 2008 Eric B. Weddington Copyright (c) 2011 Frédéric Nadeau All rights reserved. Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met: * Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer. * Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution. * Neither the name of the copyright holders nor the names of contributors may be used to endorse or promote products derived from this software without specific prior written permission. THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ /* $Id: power.h 2422 2014-04-29 10:33:23Z pitchumani $ */ #ifndef _AVR_POWER_H_ #define _AVR_POWER_H_ 1 #include #include /** \file */ /** \defgroup avr_power : Power Reduction Management \code #include \endcode Many AVRs contain a Power Reduction Register (PRR) or Registers (PRRx) that allow you to reduce power consumption by disabling or enabling various on-board peripherals as needed. Some devices have the XTAL Divide Control Register (XDIV) which offer similar functionality as System Clock Prescale Register (CLKPR). There are many macros in this header file that provide an easy interface to enable or disable on-board peripherals to reduce power. See the table below. \note Not all AVR devices have a Power Reduction Register (for example the ATmega8). On those devices without a Power Reduction Register, the power reduction macros are not available.. \note Not all AVR devices contain the same peripherals (for example, the LCD interface), or they will be named differently (for example, USART and USART0). Please consult your device's datasheet, or the header file, to find out which macros are applicable to your device. \note For device using the XTAL Divide Control Register (XDIV), when prescaler is used, Timer/Counter0 can only be used in asynchronous mode. Keep in mind that Timer/Counter0 source shall be less than ¼th of peripheral clock. Therefore, when using a typical 32.768 kHz crystal, one shall not scale the clock below 131.072 kHz. */ /** \addtogroup avr_power \anchor avr_powermacros
Power Macro Description Applicable for device
power_aca_disable() Disable the Analog Comparator on PortA. ATxmega64D3, ATxmega128D3, ATxmega192D3, ATxmega256D3
power_aca_enable() Enable the Analog Comparator on PortA. ATxmega64D3, ATxmega128D3, ATxmega192D3, ATxmega256D3
power_adc_enable() Enable the Analog to Digital Converter module. ATmega640, ATmega1280, ATmega1281, ATmega1284, ATmega128RFA1, ATmega2560, ATmega2561, AT90USB646, AT90USB647, AT90USB1286, AT90USB1287, AT90PWM1, AT90PWM2, AT90PWM2B, AT90PWM3, AT90PWM3B, AT90PWM216, AT90PWM316, AT90PWM81, ATmega165, ATmega165P, ATmega325, ATmega325A, ATmega325PA, ATmega3250, ATmega3250A, ATmega3250PA, ATmega645, ATmega6450, ATmega169, ATmega169P, ATmega329, ATmega329A, ATmega3290, ATmega3290A, ATmega3290PA, ATmega649, ATmega6490, ATmega164P, ATmega324P, ATmega644, ATmega48, ATmega88, ATmega168, ATtiny24, ATtiny44, ATtiny84, ATtiny84A, ATtiny25, ATtiny45, ATtiny85, ATtiny261, ATtiny461, ATtiny861, ATmega256RFR2, ATmega2564RFR2, ATmega128RFR2, ATmega1284RFR2, ATmega64RFR2, ATmega644RFR2, ATxmega16A4U, ATxmega32A4U
power_adc_disable() Disable the Analog to Digital Converter module. ATmega640, ATmega1280, ATmega1281, ATmega1284, ATmega128RFA1, ATmega2560, ATmega2561, AT90USB646, AT90USB647, AT90USB1286, AT90USB1287, AT90PWM1, AT90PWM2, AT90PWM2B, AT90PWM3, AT90PWM3B, AT90PWM216, AT90PWM316, AT90PWM81, ATmega165, ATmega165P, ATmega325, ATmega325A, ATmega325PA, ATmega3250, ATmega3250A, ATmega645, ATmega6450, ATmega169, ATmega169P, ATmega329, ATmega329A, ATmega3290, ATmega3290A, ATmega3290PA, ATmega649, ATmega6490, ATmega164P, ATmega324P, ATmega644, ATmega48, ATmega88, ATmega168, ATtiny24, ATtiny44, ATtiny84, ATtiny84A, ATtiny25, ATtiny45, ATtiny85, ATtiny261, ATtiny461, ATtiny861, ATmega256RFR2, ATmega2564RFR2, ATmega128RFR2, ATmega1284RFR2, ATmega64RFR2, ATmega644RFR2, ATxmega16A4U, ATxmega32A4U
power_adca_disable() Disable the Analog to Digital Converter module on PortA ATxmega64D3, ATxmega128D3, ATxmega192D3, ATxmega256D3
power_adca_enable() Enable the Analog to Digital Converter module on PortA ATxmega64D3, ATxmega128D3, ATxmega192D3, ATxmega256D3
power_evsys_disable() Disable the EVSYS module ATxmega64D3, ATxmega128D3, ATxmega192D3, ATxmega256D3
power_evsys_enable() Enable the EVSYS module ATxmega64D3, ATxmega128D3, ATxmega192D3, ATxmega256D3
power_hiresc_disable() Disable the HIRES module on PortC ATxmega64D3, ATxmega128D3, ATxmega192D3, ATxmega256D3
power_hiresc_enable() Enable the HIRES module on PortC ATxmega64D3, ATxmega128D3, ATxmega192D3, ATxmega256D3
power_lcd_enable() Enable the LCD module. ATmega169, ATmega169P, ATmega329, ATmega329A, ATmega3290, ATmega3290A, ATmega649, ATmega6490, ATxmega64B1, ATxmega64B3, ATxmega128B3
power_lcd_disable(). Disable the LCD module. ATmega169, ATmega169P, ATmega329, ATmega329A, ATmega3290, ATmega3290A, ATmega649, ATmega6490, ATxmega64B1, ATxmega128B1, ATxmega64B3, ATxmega128B3
power_pga_enable() Enable the Programmable Gain Amplifier module. ATmega256RFR2, ATmega2564RFR2, ATmega128RFR2, ATmega1284RFR2, ATmega64RFR2, ATmega644RFR2
power_pga_disable() Disable the Programmable Gain Amplifier module. ATmega256RFR2, ATmega2564RFR2, ATmega128RFR2, ATmega1284RFR2, ATmega64RFR2, ATmega644RFR2
power_pscr_enable() Enable the Reduced Power Stage Controller module. AT90PWM81
power_pscr_disable() Disable the Reduced Power Stage Controller module. AT90PWM81
power_psc0_enable() Enable the Power Stage Controller 0 module. AT90PWM1, AT90PWM2, AT90PWM2B, AT90PWM3, AT90PWM3B
power_psc0_disable() Disable the Power Stage Controller 0 module. AT90PWM1, AT90PWM2, AT90PWM2B, AT90PWM3, AT90PWM3B
power_psc1_enable() Enable the Power Stage Controller 1 module. AT90PWM1, AT90PWM2, AT90PWM2B, AT90PWM3, AT90PWM3B
power_psc1_disable() Disable the Power Stage Controller 1 module. AT90PWM1, AT90PWM2, AT90PWM2B, AT90PWM3, AT90PWM3B
power_psc2_enable() Enable the Power Stage Controller 2 module. AT90PWM1, AT90PWM2, AT90PWM2B, AT90PWM3, AT90PWM3B, AT90PWM81
power_psc2_disable() Disable the Power Stage Controller 2 module. AT90PWM1, AT90PWM2, AT90PWM2B, AT90PWM3, AT90PWM3B, AT90PWM81
power_ram0_enable() Enable the SRAM block 0 . ATmega256RFR2, ATmega2564RFR2, ATmega128RFR2, ATmega1284RFR2, ATmega64RFR2, ATmega644RFR2
power_ram0_disable() Disable the SRAM block 0. ATmega256RFR2, ATmega2564RFR2, ATmega128RFR2, ATmega1284RFR2, ATmega64RFR2, ATmega644RFR2
power_ram1_enable() Enable the SRAM block 1 . ATmega256RFR2, ATmega2564RFR2, ATmega128RFR2, ATmega1284RFR2, ATmega64RFR2, ATmega644RFR2
power_ram1_disable() Disable the SRAM block 1. ATmega256RFR2, ATmega2564RFR2, ATmega128RFR2, ATmega1284RFR2, ATmega64RFR2, ATmega644RFR2
power_ram2_enable() Enable the SRAM block 2 . ATmega256RFR2, ATmega2564RFR2, ATmega128RFR2, ATmega1284RFR2, ATmega64RFR2, ATmega644RFR2
power_ram2_disable() Disable the SRAM block 2. ATmega256RFR2, ATmega2564RFR2, ATmega128RFR2, ATmega1284RFR2, ATmega64RFR2, ATmega644RFR2
power_ram3_enable() Enable the SRAM block 3 . ATmega256RFR2, ATmega2564RFR2, ATmega128RFR2, ATmega1284RFR2, ATmega64RFR2, ATmega644RFR2
power_ram3_disable() Disable the SRAM block 3. ATmega256RFR2, ATmega2564RFR2, ATmega128RFR2, ATmega1284RFR2, ATmega64RFR2, ATmega644RFR2
power_rtc_disable() Disable the RTC module ATxmega64D3, ATxmega128D3, ATxmega192D3, ATxmega256D3
power_rtc_enable() Enable the RTC module ATxmega64D3, ATxmega128D3, ATxmega192D3, ATxmega256D3
power_spi_enable() Enable the Serial Peripheral Interface module. ATmega640, ATmega1280, ATmega1281, ATmega1284, ATmega128RFA1, ATmega2560, ATmega2561, AT90USB646, AT90USB647, AT90USB1286, AT90USB1287, AT90PWM1, AT90PWM2, AT90PWM2B, AT90PWM3, AT90PWM3B, AT90PWM216, AT90PWM316, AT90PWM81, ATmega165, ATmega165P, ATmega325, ATmega325A, ATmega325PA, ATmega3250, ATmega3250A, ATmega3250PA, ATmega645, ATmega6450, ATmega169, ATmega169P, ATmega329, ATmega329A, ATmega3290, ATmega3290A, ATmega3290PA, ATmega649, ATmega6490, ATmega164P, ATmega324P, ATmega644, ATmega48, ATmega88, ATmega168, ATmega256RFR2, ATmega2564RFR2, ATmega128RFR2, ATmega1284RFR2, ATmega64RFR2, ATmega644RFR2, ATxmega16A4U, ATxmega32A4U
power_spi_disable() Disable the Serial Peripheral Interface module. ATmega640, ATmega1280, ATmega1281, ATmega1284, ATmega128RFA1, ATmega2560, ATmega2561, AT90USB646, AT90USB647, AT90USB1286, AT90USB1287, AT90PWM1, AT90PWM2, AT90PWM2B, AT90PWM3, AT90PWM3B, AT90PWM216, AT90PWM316, AT90PWM81, ATmega165, ATmega165P, ATmega325, ATmega325A, ATmega325PA, ATmega3250, ATmega3250A, ATmega3250PA, ATmega645, ATmega6450, ATmega169, ATmega169P, ATmega329, ATmega329A, ATmega3290, ATmega3290A, ATmega3290PA, ATmega649, ATmega6490, ATmega164P, ATmega324P, ATmega644, ATmega48, ATmega88, ATmega168, ATmega256RFR2, ATmega2564RFR2, ATmega128RFR2, ATmega1284RFR2, ATmega64RFR2, ATmega644RFR2, ATxmega16A4U, ATxmega32A4U
power_spic_disable() Disable the SPI module on PortC ATxmega64D3, ATxmega128D3, ATxmega192D3, ATxmega256D3
power_spic_enable() Enable the SPI module on PortC ATxmega64D3, ATxmega128D3, ATxmega192D3, ATxmega256D3
power_spid_disable() Disable the SPI module on PortD ATxmega64D3, ATxmega128D3, ATxmega192D3, ATxmega256D3
power_spid_enable() Enable the SPI module on PortD ATxmega64D3, ATxmega128D3, ATxmega192D3, ATxmega256D3
power_tc0c_disable() Disable the TC0 module on PortC ATxmega64D3, ATxmega128D3, ATxmega192D3, ATxmega256D3
power_tc0c_enable() Enable the TC0 module on PortC ATxmega64D3, ATxmega128D3, ATxmega192D3, ATxmega256D3
power_tc0d_disable() Disable the TC0 module on PortD ATxmega64D3, ATxmega128D3, ATxmega192D3, ATxmega256D3
power_tc0d_enable() Enable the TC0 module on PortD ATxmega64D3, ATxmega128D3, ATxmega192D3, ATxmega256D3
power_tc0e_disable() Disable the TC0 module on PortE ATxmega64D3, ATxmega128D3, ATxmega192D3, ATxmega256D3
power_tc0e_enable() Enable the TC0 module on PortE ATxmega64D3, ATxmega128D3, ATxmega192D3, ATxmega256D3
power_tc0f_disable() Disable the TC0 module on PortF ATxmega64D3, ATxmega128D3, ATxmega192D3, ATxmega256D3
power_tc0f_enable() Enable the TC0 module on PortF ATxmega64D3, ATxmega128D3, ATxmega192D3, ATxmega256D3
power_tc1c_disable() Disable the TC1 module on PortC ATxmega64D3, ATxmega128D3, ATxmega192D3, ATxmega256D3
power_tc1c_enable() Enable the TC1 module on PortC ATxmega64D3, ATxmega128D3, ATxmega192D3, ATxmega256D3
power_twic_disable() Disable the Two Wire Interface module on PortC ATxmega64D3, ATxmega128D3, ATxmega192D3, ATxmega256D3
power_twic_enable() Enable the Two Wire Interface module on PortC ATxmega64D3, ATxmega128D3, ATxmega192D3, ATxmega256D3
power_twie_disable() Disable the Two Wire Interface module on PortE ATxmega64D3, ATxmega128D3, ATxmega192D3, ATxmega256D3
power_twie_enable() Enable the Two Wire Interface module on PortE ATxmega64D3, ATxmega128D3, ATxmega192D3, ATxmega256D3
power_timer0_enable() Enable the Timer 0 module. ATmega640, ATmega1280, ATmega1281, ATmega1284, ATmega128RFA1, ATmega2560, ATmega2561, AT90USB646, AT90USB647, AT90USB1286, AT90USB1287, AT90PWM1, AT90PWM216, AT90PWM316, AT90PWM2, AT90PWM2B, AT90PWM3, AT90PWM3B, ATmega165, ATmega165P, ATmega325, ATmega325A, ATmega3250, ATmega3250A, ATmega645, ATmega6450, ATmega164P, ATmega324P, ATmega644, ATmega406, ATmega48, ATmega88, ATmega168, ATtiny24, ATtiny44, ATtiny84, ATtiny84A, ATtiny25, ATtiny45, ATtiny85, ATtiny261, ATtiny461, ATtiny861, ATmega256RFR2, ATmega2564RFR2, ATmega128RFR2, ATmega1284RFR2, ATmega64RFR2, ATmega644RFR2, ATxmega16A4U, ATxmega32A4U
power_timer0_disable() Disable the Timer 0 module. ATmega640, ATmega1280, ATmega1281, ATmega1284, ATmega128RFA1, ATmega2560, ATmega2561, AT90USB646, AT90USB647, AT90USB1286, AT90USB1287, AT90PWM1, AT90PWM2, AT90PWM2B, AT90PWM3, AT90PWM3B, AT90PWM216, AT90PWM316, ATmega165, ATmega165P, ATmega325, ATmega325A, ATmega3250, ATmega3250A, ATmega645, ATmega6450, ATmega164P, ATmega324P, ATmega644, ATmega406, ATmega48, ATmega88, ATmega168, ATtiny24, ATtiny44, ATtiny84, ATtiny84A, ATtiny25, ATtiny45, ATtiny85, ATtiny261, ATtiny461, ATtiny861, ATmega256RFR2, ATmega2564RFR2, ATmega128RFR2, ATmega1284RFR2, ATmega64RFR2, ATmega644RFR2, ATxmega16A4U, ATxmega32A4U
power_timer1_enable() Enable the Timer 1 module. ATmega640, ATmega1280, ATmega1281, ATmega1284, ATmega128RFA1, ATmega2560, ATmega2561, AT90USB646, AT90USB647, AT90USB1286, AT90USB1287, AT90PWM1, AT90PWM2, AT90PWM2B, AT90PWM3, AT90PWM3B, AT90PWM216, AT90PWM316, AT90PWM81, ATmega165, ATmega165P, ATmega325, ATmega325A, ATmega325PA, ATmega3250, ATmega3250A, ATmega3250PA, ATmega645, ATmega6450, ATmega169, ATmega169P, ATmega329, ATmega329A, ATmega3290, ATmega3290A, ATmega3290PA, ATmega649, ATmega6490, ATmega164P, ATmega324P, ATmega644, ATmega406, ATmega48, ATmega88, ATmega168, ATtiny24, ATtiny44, ATtiny84, ATtiny84A, ATtiny25, ATtiny45, ATtiny85, ATtiny261, ATtiny461, ATtiny861, ATmega256RFR2, ATmega2564RFR2, ATmega128RFR2, ATmega1284RFR2, ATmega64RFR2, ATmega644RFR2, ATxmega16A4U, ATxmega32A4U
power_timer1_disable() Disable the Timer 1 module. ATmega640, ATmega1280, ATmega1281, ATmega1284, ATmega128RFA1, ATmega2560, ATmega2561, AT90USB646, AT90USB647, AT90USB1286, AT90USB1287, AT90PWM1, AT90PWM2, AT90PWM2B, AT90PWM3, AT90PWM3B, AT90PWM216, AT90PWM316, AT90PWM81, ATmega165, ATmega165P, ATmega325, ATmega325A, ATmega325PA, ATmega3250, ATmega3250A, ATmega3250PA, ATmega645, ATmega6450, ATmega169, ATmega169P, ATmega329, ATmega329A, ATmega3290, ATmega3290A, ATmega3290PA, ATmega649, ATmega6490, ATmega164P, ATmega324P, ATmega644, ATmega406, ATmega48, ATmega88, ATmega168, ATtiny24, ATtiny44, ATtiny84, ATtiny84A, ATtiny25, ATtiny45, ATtiny85, ATtiny261, ATtiny461, ATtiny861, ATmega256RFR2, ATmega2564RFR2, ATmega128RFR2, ATmega1284RFR2, ATmega64RFR2, ATmega644RFR2, ATxmega16A4U, ATxmega32A4U
power_timer2_enable() Enable the Timer 2 module. ATmega640, ATmega1280, ATmega1281, ATmega1284, ATmega128RFA1, ATmega2560, ATmega2561, AT90USB646, AT90USB647, AT90USB1286, AT90USB1287, ATmega164P, ATmega324P, ATmega644, ATmega48, ATmega88, ATmega168, ATmega256RFR2, ATmega2564RFR2, ATmega128RFR2, ATmega1284RFR2, ATmega64RFR2, ATmega644RFR2
power_timer2_disable() Disable the Timer 2 module. ATmega640, ATmega1280, ATmega1281, ATmega1284, ATmega128RFA1, ATmega2560, ATmega2561, AT90USB646, AT90USB647, AT90USB1286, AT90USB1287, ATmega164P, ATmega324P, ATmega644, ATmega48, ATmega88, ATmega168, ATmega256RFR2, ATmega2564RFR2, ATmega128RFR2, ATmega1284RFR2, ATmega64RFR2, ATmega644RFR2
power_timer3_enable() Enable the Timer 3 module. ATmega640, ATmega1280, ATmega1281, ATmega1284, ATmega128RFA1, ATmega2560, ATmega2561, AT90USB646, AT90USB647, AT90USB1286, AT90USB1287, ATmega256RFR2, ATmega2564RFR2, ATmega128RFR2, ATmega1284RFR2, ATmega64RFR2, ATmega644RFR2
power_timer3_disable() Disable the Timer 3 module. ATmega640, ATmega1280, ATmega1281, ATmega1284, ATmega128RFA1, ATmega2560, ATmega2561, AT90USB646, AT90USB647, AT90USB1286, AT90USB1287, ATmega256RFR2, ATmega2564RFR2, ATmega128RFR2, ATmega1284RFR2, ATmega64RFR2, ATmega644RFR2
power_timer4_enable() Enable the Timer 4 module. ATmega640, ATmega1280, ATmega1281, ATmega128RFA1, ATmega2560, ATmega2561, ATmega256RFR2, ATmega2564RFR2, ATmega128RFR2, ATmega1284RFR2, ATmega64RFR2, ATmega644RFR2
power_timer4_disable() Disable the Timer 4 module. ATmega640, ATmega1280, ATmega1281, ATmega128RFA1, ATmega2560, ATmega2561, ATmega256RFR2, ATmega2564RFR2, ATmega128RFR2, ATmega1284RFR2, ATmega64RFR2, ATmega644RFR2
power_timer5_enable() Enable the Timer 5 module. ATmega640, ATmega1280, ATmega1281, ATmega128RFA1, ATmega2560, ATmega2561, ATmega256RFR2, ATmega2564RFR2, ATmega128RFR2, ATmega1284RFR2, ATmega64RFR2, ATmega644RFR2
power_timer5_disable() Disable the Timer 5 module. ATmega640, ATmega1280, ATmega1281, ATmega128RFA1, ATmega2560, ATmega2561, ATmega256RFR2, ATmega2564RFR2, ATmega128RFR2, ATmega1284RFR2, ATmega64RFR2, ATmega644RFR2
power_twi_enable() Enable the Two Wire Interface module. ATmega640, ATmega1280, ATmega1281, ATmega1284, ATmega128RFA1, ATmega2560, ATmega2561, AT90USB646, AT90USB647, AT90USB1286, AT90USB1287, ATmega164P, ATmega324P, ATmega644, ATmega406, ATmega48, ATmega88, ATmega168, ATmega256RFR2, ATmega2564RFR2, ATmega128RFR2, ATmega1284RFR2, ATmega64RFR2, ATmega644RFR2, ATxmega16A4U, ATxmega32A4U
power_twi_disable() Disable the Two Wire Interface module. ATmega640, ATmega1280, ATmega1281, ATmega1284, ATmega128RFA1, ATmega2560, ATmega2561, AT90USB646, AT90USB647, AT90USB1286, AT90USB1287, ATmega164P, ATmega324P, ATmega644, ATmega406, ATmega48, ATmega88, ATmega168, ATmega256RFR2, ATmega2564RFR2, ATmega128RFR2, ATmega1284RFR2, ATmega64RFR2, ATmega644RFR2, ATxmega16A4U, ATxmega32A4U
power_usart_enable() Enable the USART module. AT90PWM2, AT90PWM2B, AT90PWM3, AT90PWM3B
power_usart_disable() Disable the USART module. AT90PWM2, AT90PWM2B, AT90PWM3, AT90PWM3B
power_usart0_enable() Enable the USART 0 module. ATmega640, ATmega1280, ATmega1281, ATmega1284, ATmega128RFA1, ATmega2560, ATmega2561, ATmega165, ATmega165P, ATmega325, ATmega325A, ATmega325PA, ATmega3250, ATmega3250A, ATmega3250PA, ATmega645, ATmega6450, ATmega169, ATmega169P, ATmega329, ATmega329A, ATmega3290, ATmega3290A, ATmega3290PA, ATmega649, ATmega6490, ATmega164P, ATmega324P, ATmega644, ATmega48, ATmega88, ATmega168, ATmega256RFR2, ATmega2564RFR2, ATmega128RFR2, ATmega1284RFR2, ATmega64RFR2, ATmega644RFR2, ATxmega16A4U, ATxmega32A4U
power_usart0_disable() Disable the USART 0 module. ATmega640, ATmega1280, ATmega1281, ATmega1284, ATmega128RFA1, ATmega2560, ATmega2561, ATmega165, ATmega165P, ATmega325, ATmega325A, ATmega325PA, ATmega3250, ATmega3250A, ATmega3250PA, ATmega645, ATmega6450, ATmega169, ATmega169P, ATmega329, ATmega329A, ATmega3290, ATmega3290A, ATmega3290PA, ATmega649, ATmega6490, ATmega164P, ATmega324P, ATmega644, ATmega48, ATmega88, ATmega168, ATmega256RFR2, ATmega2564RFR2, ATmega128RFR2, ATmega1284RFR2, ATmega64RFR2, ATmega644RFR2, ATxmega16A4U, ATxmega32A4U
power_usart1_enable() Enable the USART 1 module. ATmega640, ATmega1280, ATmega1281, ATmega128RFA1, ATmega2560, ATmega2561, AT90USB646, AT90USB647, AT90USB1286, AT90USB1287, ATmega164P, ATmega324P, ATmega644, ATmega256RFR2, ATmega2564RFR2, ATmega128RFR2, ATmega1284RFR2, ATmega64RFR2, ATmega644RFR2, ATxmega16A4U, ATxmega32A4U
power_usart1_disable() Disable the USART 1 module. ATmega640, ATmega1280, ATmega1281, ATmega128RFA1, ATmega2560, ATmega2561, AT90USB646, AT90USB647, AT90USB1286, AT90USB1287, ATmega164P, ATmega324P, ATmega644, ATmega256RFR2, ATmega2564RFR2, ATmega128RFR2, ATmega1284RFR2, ATmega64RFR2, ATmega644RFR2, ATxmega16A4U, ATxmega32A4U
power_usart2_enable() Enable the USART 2 module. ATmega640, ATmega1280, ATmega1281, ATmega2560, ATmega2561
power_usart2_disable() Disable the USART 2 module. ATmega640, ATmega1280, ATmega1281, ATmega2560, ATmega2561
power_usart3_enable() Enable the USART 3 module. ATmega640, ATmega1280, ATmega1281, ATmega2560, ATmega2561
power_usart3_disable() Disable the USART 3 module. ATmega640, ATmega1280, ATmega1281, ATmega2560, ATmega2561
power_usartc0_disable() Disable the USART0 module on PortC ATmega640, ATmega1280, ATmega1281, ATmega2560, ATmega2561
power_usartc0_enable() Enable the USART0 module on PortC ATmega640, ATmega1280, ATmega1281, ATmega2560, ATmega2561
power_usartd0_disable() Disable the USART0 module on PortD ATmega640, ATmega1280, ATmega1281, ATmega2560, ATmega2561
power_usartd0_enable() Enable the USART0 module on PortD ATmega640, ATmega1280, ATmega1281, ATmega2560, ATmega2561
power_usarte0_disable() Disable the USART0 module on PortE ATmega640, ATmega1280, ATmega1281, ATmega2560, ATmega2561
power_usarte0_enable() Enable the USART0 module on PortE ATmega640, ATmega1280, ATmega1281, ATmega2560, ATmega2561
power_usartf0_disable() Disable the USART0 module on PortF ATmega640, ATmega1280, ATmega1281, ATmega2560, ATmega2561
power_usartf0_enable() Enable the USART0 module on PortF ATmega640, ATmega1280, ATmega1281, ATmega2560, ATmega2561
power_usb_enable() Enable the USB module. AT90USB646, AT90USB647, AT90USB1286, AT90USB1287, ATxmega64B1, ATxmega128B1, ATxmega64B3, ATxmega128B3, ATxmega16A4U, ATxmega32A4U, ATxmega128c3, ATxmega256c3, ATxmega16c4, ATxmega32c4
power_usb_disable() Disable the USB module. AT90USB646, AT90USB647, AT90USB1286, AT90USB1287, ATxmega64B1, ATxmega128B1, ATxmega64B3, ATxmega128B3, ATxmega16A4U, ATxmega32A4U,ATxmega128c3, ATxmega256c3, ATxmega16c4, ATxmega32c4
power_usi_enable() Enable the Universal Serial Interface module. ATtiny24, ATtiny44, ATtiny84, ATtiny84A, ATtiny25, ATtiny45, ATtiny85, ATtiny261, ATtiny461, ATtiny861
power_usi_disable() Disable the Universal Serial Interface module. ATtiny24, ATtiny44, ATtiny84, ATtiny84A, ATtiny25, ATtiny45, ATtiny85, ATtiny261, ATtiny461, ATtiny861
power_vadc_enable() Enable the Voltage ADC module. ATmega406
power_vadc_disable() Disable the Voltage ADC module. ATmega406
power_all_enable() Enable all modules. ATxmega6A4, ATxmega32A4, ATxmega64A1, ATxmega64A1U, ATxmega64A3, ATxmegaA1, ATxmegaA1U, ATxmega128A3, ATxmega192A3, ATxmega256A3, ATxmegaA3B, ATxmega16D4, ATxmega32D4, ATxmega64D3, ATxmega128D3, ATxmega192D3, ATxmega256D3, ATmega640, ATmega1280, ATmega1281, ATmega128RFA1, ATmega2560, ATmega2561, AT90USB646, AT90USB647, AT90USB1286, AT90USB1287, AT90PWM1, AT90PWM2, AT90PWM2B, AT90PWM3, AT90PWM3B, AT90PWM216, AT90PWM316, ATmega165, ATmega165P, ATmega325, ATmega325A, ATmega325PA, ATmega3250, ATmega3250A, ATmega3250PA, ATmega645, ATmega6450, ATmega169, ATmega169P, ATmega329, ATmega329A, ATmega3290, ATmega3290A, ATmega3290PA, ATmega649, ATmega6490, ATmega164P, ATmega324P, ATmega644, ATmega406, ATmega48, ATmega88, ATmega168, ATtiny24, ATtiny44, ATtiny84, ATtiny84A, ATtiny25, ATtiny45, ATtiny85, ATtiny261, ATtiny461, ATtiny861, ATmega256RFR2, ATmega2564RFR2, ATmega128RFR2, ATmega1284RFR2, ATmega64RFR2, ATmega644RFR2, ATxmega64B1, ATxmega128B1, ATxmega64B3, ATxmega128B3, ATxmega16A4U, ATxmega32A4U, ATxmega64A3U, ATxmega128A3U, ATxmega192A3U, ATxmega256A3U
power_all_disable() Disable all modules. ATxmega6A4, ATxmega32A4, ATxmega64A1, ATxmega64A1U, ATxmega64A3, ATxmegaA1, ATxmegaA1U, ATxmega128A3, ATxmega192A3, ATxmega256A3, ATxmegaA3B, ATxmega16D4, ATxmega32D4, ATxmega64D3, ATxmega128D3, ATxmega192D3, ATxmega256D3, ATmega640, ATmega1280, ATmega1281, ATmega128RFA1, ATmega2560, ATmega2561, AT90USB646, AT90USB647, AT90USB1286, AT90USB1287, AT90PWM1, AT90PWM2, AT90PWM2B, AT90PWM3, AT90PWM3B, AT90PWM216, AT90PWM316, ATmega165, ATmega165P, ATmega325, ATmega325A, ATmega325PA, ATmega3250, ATmega3250A, ATmega3250PA, ATmega645, ATmega6450, ATmega169, ATmega169P, ATmega329, ATmega329A, ATmega3290, ATmega3290A, ATmega3290PA, ATmega649, ATmega6490, ATmega164P, ATmega324P, ATmega644, ATmega406, ATmega48, ATmega88, ATmega168, ATtiny24, ATtiny44, ATtiny84, ATtiny84A, ATtiny25, ATtiny45, ATtiny85, ATtiny261, ATtiny461, ATtiny861, ATmega256RFR2, ATmega2564RFR2, ATmega128RFR2, ATmega1284RFR2, ATmega64RFR2, ATmega644RFR2, ATxmega64B1, ATxmega128B1, ATxmega64B3, ATxmega128B3, ATxmega16A4U, ATxmega32A4U, ATxmega64A3U, ATxmega128A3U, ATxmega192A3U, ATxmega256A3U
@} */ // Xmega A series has AES, EBI and DMA bits // Include any other device on need basis #if defined(__AVR_ATxmega16A4__) \ || defined(__AVR_ATxmega16A4U__) \ || defined(__AVR_ATxmega32A4U__) \ || defined(__AVR_ATxmega32A4__) \ || defined(__AVR_ATxmega64A1__) \ || defined(__AVR_ATxmega64A1U__) \ || defined(__AVR_ATxmega64A3__) \ || defined(__AVR_ATxmega64A3U__) \ || defined(__AVR_ATxmega64A4U__) \ || defined(__AVR_ATxmega128A1__) \ || defined(__AVR_ATxmega128A1U__) \ || defined(__AVR_ATxmega128A3__) \ || defined(__AVR_ATxmega128A3U__) \ || defined(__AVR_ATxmega128A4U__) \ || defined(__AVR_ATxmega192A3__) \ || defined(__AVR_ATxmega192A3U__) \ || defined(__AVR_ATxmega256A3__) \ || defined(__AVR_ATxmega256A3U__) \ || defined(__AVR_ATxmega256A3B__) \ || defined(__AVR_ATxmega256A3BU__) \ || defined(__AVR_ATxmega384C3__) #define power_aes_enable() (PR_PRGEN &= (uint8_t)~(PR_AES_bm)) #define power_aes_disable() (PR_PRGEN |= (uint8_t)PR_AES_bm) #define power_ebi_enable() (PR_PRGEN &= (uint8_t)~(PR_EBI_bm)) #define power_ebi_disable() (PR_PRGEN |= (uint8_t)PR_EBI_bm) #define power_dma_enable() (PR_PRGEN &= (uint8_t)~(PR_DMA_bm)) #define power_dma_disable() (PR_PRGEN |= (uint8_t)PR_DMA_bm) #define power_daca_enable() (PR_PRPA &= (uint8_t)~(PR_DAC_bm)) #define power_daca_disable() (PR_PRPA |= (uint8_t)PR_DAC_bm) #define power_dacb_enable() (PR_PRPB &= (uint8_t)~(PR_DAC_bm)) #define power_dacb_disable() (PR_PRPB |= (uint8_t)PR_DAC_bm) #define power_usartc1_enable() (PR_PRPC &= (uint8_t)~(PR_USART1_bm)) #define power_usartc1_disable() (PR_PRPC |= (uint8_t)PR_USART1_bm) #define power_usartd1_enable() (PR_PRPD &= (uint8_t)~(PR_USART1_bm)) #define power_usartd1_disable() (PR_PRPD |= (uint8_t)PR_USART1_bm) #define power_usarte1_enable() (PR_PRPE &= (uint8_t)~(PR_USART1_bm)) #define power_usarte1_disable() (PR_PRPE |= (uint8_t)PR_USART1_bm) #define power_usartf1_enable() (PR_PRPF &= (uint8_t)~(PR_USART1_bm)) #define power_usartf1_disable() (PR_PRPF |= (uint8_t)PR_USART1_bm) #if defined(__AVR_ATxmega384C3__) \ || defined(__AVR_ATxmega256A3BU__) \ || defined(__AVR_ATxmega16A4U__) \ || defined(__AVR_ATxmega32A4U__) \ || defined(__AVR_ATxmega64A3U__) \ || defined(__AVR_ATxmega64A4U__) \ || defined(__AVR_ATxmega128A3U__) \ || defined(__AVR_ATxmega128A4U__) \ || defined(__AVR_ATxmega192A3U__) \ || defined(__AVR_ATxmega256A3U__) #define power_usb_enable() (PR_PRGEN &= (uint8_t)~(PR_USB_bm)) #define power_usb_disable() (PR_PRGEN &= (uint8_t)(PR_USB_bm)) #define power_all_enable() \ do { \ PR_PRGEN &= (uint8_t)~(PR_AES_bm|PR_EBI_bm|PR_RTC_bm|PR_EVSYS_bm|PR_DMA_bm|PR_USB_bm); \ PR_PRPA &= (uint8_t)~(PR_DAC_bm|PR_ADC_bm|PR_AC_bm); \ PR_PRPB &= (uint8_t)~(PR_DAC_bm|PR_ADC_bm|PR_AC_bm); \ PR_PRPC &= (uint8_t)~(PR_TWI_bm|PR_USART1_bm|PR_USART0_bm|PR_SPI_bm|PR_HIRES_bm|PR_TC1_bm|PR_TC0_bm); \ PR_PRPD &= (uint8_t)~(PR_TWI_bm|PR_USART1_bm|PR_USART0_bm|PR_SPI_bm|PR_HIRES_bm|PR_TC1_bm|PR_TC0_bm); \ PR_PRPE &= (uint8_t)~(PR_TWI_bm|PR_USART1_bm|PR_USART0_bm|PR_SPI_bm|PR_HIRES_bm|PR_TC1_bm|PR_TC0_bm); \ PR_PRPF &= (uint8_t)~(PR_TWI_bm|PR_USART1_bm|PR_USART0_bm|PR_SPI_bm|PR_HIRES_bm|PR_TC1_bm|PR_TC0_bm); \ } while(0) #define power_all_disable() \ do { \ PR_PRGEN |= (uint8_t)(PR_AES_bm|PR_EBI_bm|PR_RTC_bm|PR_EVSYS_bm|PR_DMA_bm|PR_USB_bm); \ PR_PRPA |= (uint8_t)(PR_DAC_bm|PR_ADC_bm|PR_AC_bm); \ PR_PRPB |= (uint8_t)(PR_DAC_bm|PR_ADC_bm|PR_AC_bm); \ PR_PRPC |= (uint8_t)(PR_TWI_bm|PR_USART1_bm|PR_USART0_bm|PR_SPI_bm|PR_HIRES_bm|PR_TC1_bm|PR_TC0_bm); \ PR_PRPD |= (uint8_t)(PR_TWI_bm|PR_USART1_bm|PR_USART0_bm|PR_SPI_bm|PR_HIRES_bm|PR_TC1_bm|PR_TC0_bm); \ PR_PRPE |= (uint8_t)(PR_TWI_bm|PR_USART1_bm|PR_USART0_bm|PR_SPI_bm|PR_HIRES_bm|PR_TC1_bm|PR_TC0_bm); \ PR_PRPF |= (uint8_t)(PR_TWI_bm|PR_USART1_bm|PR_USART0_bm|PR_SPI_bm|PR_HIRES_bm|PR_TC1_bm|PR_TC0_bm); \ } while(0) #else #define power_all_enable() \ do { \ PR_PRGEN &= (uint8_t)~(PR_AES_bm|PR_EBI_bm|PR_RTC_bm|PR_EVSYS_bm|PR_DMA_bm); \ PR_PRPA &= (uint8_t)~(PR_DAC_bm|PR_ADC_bm|PR_AC_bm); \ PR_PRPB &= (uint8_t)~(PR_DAC_bm|PR_ADC_bm|PR_AC_bm); \ PR_PRPC &= (uint8_t)~(PR_TWI_bm|PR_USART1_bm|PR_USART0_bm|PR_SPI_bm|PR_HIRES_bm|PR_TC1_bm|PR_TC0_bm); \ PR_PRPD &= (uint8_t)~(PR_TWI_bm|PR_USART1_bm|PR_USART0_bm|PR_SPI_bm|PR_HIRES_bm|PR_TC1_bm|PR_TC0_bm); \ PR_PRPE &= (uint8_t)~(PR_TWI_bm|PR_USART1_bm|PR_USART0_bm|PR_SPI_bm|PR_HIRES_bm|PR_TC1_bm|PR_TC0_bm); \ PR_PRPF &= (uint8_t)~(PR_TWI_bm|PR_USART1_bm|PR_USART0_bm|PR_SPI_bm|PR_HIRES_bm|PR_TC1_bm|PR_TC0_bm); \ } while(0) #define power_all_disable() \ do { \ PR_PRGEN|= (uint8_t)(PR_AES_bm|PR_EBI_bm|PR_RTC_bm|PR_EVSYS_bm|PR_DMA_bm); \ PR_PRPA |= (uint8_t)(PR_DAC_bm|PR_ADC_bm|PR_AC_bm); \ PR_PRPB |= (uint8_t)(PR_DAC_bm|PR_ADC_bm|PR_AC_bm); \ PR_PRPC |= (uint8_t)(PR_TWI_bm|PR_USART1_bm|PR_USART0_bm|PR_SPI_bm|PR_HIRES_bm|PR_TC1_bm|PR_TC0_bm); \ PR_PRPD |= (uint8_t)(PR_TWI_bm|PR_USART1_bm|PR_USART0_bm|PR_SPI_bm|PR_HIRES_bm|PR_TC1_bm|PR_TC0_bm); \ PR_PRPE |= (uint8_t)(PR_TWI_bm|PR_USART1_bm|PR_USART0_bm|PR_SPI_bm|PR_HIRES_bm|PR_TC1_bm|PR_TC0_bm); \ PR_PRPF |= (uint8_t)(PR_TWI_bm|PR_USART1_bm|PR_USART0_bm|PR_SPI_bm|PR_HIRES_bm|PR_TC1_bm|PR_TC0_bm); \ } while(0) #endif #endif #if defined(__AVR_ATxmega64D3__) \ || defined(__AVR_ATxmega128D3__) \ || defined(__AVR_ATxmega192D3__) \ || defined(__AVR_ATxmega256D3__) #define power_rtc_enable() (PR_PRGEN &= (uint8_t)~(PR_RTC_bm)) #define power_rtc_disable() (PR_PRGEN |= (uint8_t)PR_RTC_bm) #define power_evsys_enable() (PR_PRGEN &= (uint8_t)~(PR_EVSYS_bm)) #define power_evsys_disable() (PR_PRGEN |= (uint8_t)PR_EVSYS_bm) #define power_adca_enable() (PR_PRPA &= (uint8_t)~(PR_ADC_bm)) #define power_adca_disable() (PR_PRPA |= (uint8_t)PR_ADC_bm) #define power_aca_enable() (PR_PRPA &= (uint8_t)~(PR_AC_bm)) #define power_aca_disable() (PR_PRPA |= (uint8_t)PR_AC_bm) #define power_twic_enable() (PR_PRPC &= (uint8_t)~(PR_TWI_bm)) #define power_twic_disable() (PR_PRPC |= (uint8_t)PR_TWI_bm) #define power_twie_enable() (PR_PRPE &= (uint8_t)~(PR_TWI_bm)) #define power_twie_disable() (PR_PRPE |= (uint8_t)PR_TWI_bm) #define power_usartc0_enable() (PR_PRPC &= (uint8_t)~(PR_USART0_bm)) #define power_usartc0_disable() (PR_PRPC |= (uint8_t)PR_USART0_bm) #define power_usartd0_enable() (PR_PRPD &= (uint8_t)~(PR_USART0_bm)) #define power_usartd0_disable() (PR_PRPD |= (uint8_t)PR_USART0_bm) #define power_usarte0_enable() (PR_PRPE &= (uint8_t)~(PR_USART0_bm)) #define power_usarte0_disable() (PR_PRPE |= (uint8_t)PR_USART0_bm) #define power_usartf0_enable() (PR_PRPF &= (uint8_t)~(PR_USART0_bm)) #define power_usartf0_disable() (PR_PRPF |= (uint8_t)PR_USART0_bm) #define power_spic_enable() (PR_PRPC &= (uint8_t)~(PR_SPI_bm)) #define power_spic_disable() (PR_PRPC |= (uint8_t)PR_SPI_bm) #define power_spid_enable() (PR_PRPD &= (uint8_t)~(PR_SPI_bm)) #define power_spid_disable() (PR_PRPD |= (uint8_t)PR_SPI_bm) #define power_hiresc_enable() (PR_PRPC &= (uint8_t)~(PR_HIRES_bm)) #define power_hiresc_disable() (PR_PRPC |= (uint8_t)PR_HIRES_bm) #define power_tc1c_enable() (PR_PRPC &= (uint8_t)~(PR_TC1_bm)) #define power_tc1c_disable() (PR_PRPC |= (uint8_t)PR_TC1_bm) #define power_tc0c_enable() (PR_PRPC &= (uint8_t)~(PR_TC0_bm)) #define power_tc0c_disable() (PR_PRPC |= (uint8_t)PR_TC0_bm) #define power_tc0d_enable() (PR_PRPD &= (uint8_t)~(PR_TC0_bm)) #define power_tc0d_disable() (PR_PRPD |= (uint8_t)PR_TC0_bm) #define power_tc0e_enable() (PR_PRPE &= (uint8_t)~(PR_TC0_bm)) #define power_tc0e_disable() (PR_PRPE |= (uint8_t)PR_TC0_bm) #define power_tc0f_enable() (PR_PRPF &= (uint8_t)~(PR_TC0_bm)) #define power_tc0f_disable() (PR_PRPF |= (uint8_t)PR_TC0_bm) #define power_all_enable() \ do { \ PR_PRGEN &= (uint8_t)~(PR_RTC_bm|PR_EVSYS_bm); \ PR_PRPA &= (uint8_t)~(PR_ADC_bm|PR_AC_bm); \ PR_PRPC &= (uint8_t)~(PR_TWI_bm|PR_USART0_bm|PR_SPI_bm|PR_HIRES_bm|PR_TC1_bm|PR_TC0_bm); \ PR_PRPD &= (uint8_t)~(PR_USART0_bm|PR_SPI_bm|PR_TC0_bm); \ PR_PRPE &= (uint8_t)~(PR_TWI_bm|PR_USART0_bm|PR_TC0_bm); \ PR_PRPF &= (uint8_t)~(PR_USART0_bm|PR_TC0_bm); \ } while(0) #define power_all_disable() \ do { \ PR_PRGEN|= (uint8_t)(PR_RTC_bm|PR_EVSYS_bm); \ PR_PRPA |= (uint8_t)(PR_ADC_bm|PR_AC_bm); \ PR_PRPC |= (uint8_t)(PR_TWI_bm|PR_USART0_bm|PR_SPI_bm|PR_HIRES_bm|PR_TC1_bm|PR_TC0_bm); \ PR_PRPD |= (uint8_t)(PR_USART0_bm|PR_SPI_bm|PR_TC0_bm); \ PR_PRPE |= (uint8_t)(PR_TWI_bm|PR_USART0_bm|PR_TC0_bm); \ PR_PRPF |= (uint8_t)(PR_USART0_bm|PR_TC0_bm); \ } while(0) #endif #if defined(__AVR_ATxmega16C4__) \ || defined(__AVR_ATxmega32C4__) \ || defined(__AVR_ATxmega64C3__) \ || defined(__AVR_ATxmega128C3__) \ || defined(__AVR_ATxmega192C3__) \ || defined(__AVR_ATxmega256C3__) #define power_usb_enable() (PR_PRGEN &= (uint8_t)~(PR_USB_bm)) #define power_usb_disable() (PR_PRGEN &= (uint8_t)(PR_USB_bm)) #define power_aes_enable() (PR_PRGEN &= (uint8_t)~(PR_AES_bm)) #define power_aes_disable() (PR_PRGEN |= (uint8_t)PR_AES_bm) #define power_rtc_enable() (PR_PRGEN &= (uint8_t)~(PR_RTC_bm)) #define power_rtc_disable() (PR_PRGEN |= (uint8_t)PR_RTC_bm) #define power_evsys_enable() (PR_PRGEN &= (uint8_t)~(PR_EVSYS_bm)) #define power_evsys_disable() (PR_PRGEN |= (uint8_t)PR_EVSYS_bm) #define power_dma_enable() (PR_PRGEN &= (uint8_t)~(PR_DMA_bm)) #define power_dma_disable() (PR_PRGEN |= (uint8_t)PR_DMA_bm) #define power_adca_enable() (PR_PRPA &= (uint8_t)~(PR_ADC_bm)) #define power_adca_disable() (PR_PRPA |= (uint8_t)PR_ADC_bm) #define power_aca_enable() (PR_PRPA &= (uint8_t)~(PR_AC_bm)) #define power_aca_disable() (PR_PRPA |= (uint8_t)PR_AC_bm) #define power_twic_enable() (PR_PRPC &= (uint8_t)~(PR_TWI_bm)) #define power_twic_disable() (PR_PRPC |= (uint8_t)PR_TWI_bm) #define power_twie_enable() (PR_PRPE &= (uint8_t)~(PR_TWI_bm)) #define power_twie_disable() (PR_PRPE |= (uint8_t)PR_TWI_bm) #define power_usartc1_enable() (PR_PRPC &= (uint8_t)~(PR_USART1_bm)) #define power_usartc1_disable() (PR_PRPC |= (uint8_t)PR_USART1_bm) #define power_usartc0_enable() (PR_PRPC &= (uint8_t)~(PR_USART0_bm)) #define power_usartc0_disable() (PR_PRPC |= (uint8_t)PR_USART0_bm) #define power_usartd0_enable() (PR_PRPD &= (uint8_t)~(PR_USART0_bm)) #define power_usartd0_disable() (PR_PRPD |= (uint8_t)PR_USART0_bm) #define power_usarte0_enable() (PR_PRPE &= (uint8_t)~(PR_USART0_bm)) #define power_usarte0_disable() (PR_PRPE |= (uint8_t)PR_USART0_bm) #define power_usartf0_enable() (PR_PRPF &= (uint8_t)~(PR_USART0_bm)) #define power_usartf0_disable() (PR_PRPF |= (uint8_t)PR_USART0_bm) #define power_spic_enable() (PR_PRPC &= (uint8_t)~(PR_SPI_bm)) #define power_spic_disable() (PR_PRPC |= (uint8_t)PR_SPI_bm) #define power_spid_enable() (PR_PRPD &= (uint8_t)~(PR_SPI_bm)) #define power_spid_disable() (PR_PRPD |= (uint8_t)PR_SPI_bm) #define power_hiresc_enable() (PR_PRPC &= (uint8_t)~(PR_HIRES_bm)) #define power_hiresc_disable() (PR_PRPC |= (uint8_t)PR_HIRES_bm) #define power_tc1c_enable() (PR_PRPC &= (uint8_t)~(PR_TC1_bm)) #define power_tc1c_disable() (PR_PRPC |= (uint8_t)PR_TC1_bm) #define power_tc0c_enable() (PR_PRPC &= (uint8_t)~(PR_TC0_bm)) #define power_tc0c_disable() (PR_PRPC |= (uint8_t)PR_TC0_bm) #define power_tc0d_enable() (PR_PRPD &= (uint8_t)~(PR_TC0_bm)) #define power_tc0d_disable() (PR_PRPD |= (uint8_t)PR_TC0_bm) #define power_tc0e_enable() (PR_PRPE &= (uint8_t)~(PR_TC0_bm)) #define power_tc0e_disable() (PR_PRPE |= (uint8_t)PR_TC0_bm) #define power_tc0f_enable() (PR_PRPF &= (uint8_t)~(PR_TC0_bm)) #define power_tc0f_disable() (PR_PRPF |= (uint8_t)PR_TC0_bm) #define power_all_enable() \ do { \ PR_PRGEN &= (uint8_t)~(PR_USB_bm|PR_AES_bm|PR_DMA_bm|PR_RTC_bm|PR_EVSYS_bm); \ PR_PRPA &= (uint8_t)~(PR_ADC_bm|PR_AC_bm); \ PR_PRPC &= (uint8_t)~(PR_TWI_bm|PR_USART0_bm|PR_USART1_bm|PR_SPI_bm|PR_HIRES_bm|PR_TC1_bm|PR_TC0_bm); \ PR_PRPD &= (uint8_t)~(PR_USART0_bm|PR_SPI_bm|PR_TC0_bm); \ PR_PRPE &= (uint8_t)~(PR_TWI_bm|PR_USART0_bm|PR_TC0_bm); \ PR_PRPF &= (uint8_t)~(PR_USART0_bm|PR_TC0_bm); \ } while(0) #define power_all_disable() \ do { \ PR_PRGEN |= (uint8_t)(PR_USB_bm|PR_AES_bm|PR_DMA_bm|PR_RTC_bm|PR_EVSYS_bm); \ PR_PRPA |= (uint8_t)(PR_ADC_bm|PR_AC_bm); \ PR_PRPC |= (uint8_t)(PR_TWI_bm|PR_USART0_bm|PR_USART1_bm|PR_SPI_bm|PR_HIRES_bm|PR_TC1_bm|PR_TC0_bm); \ PR_PRPD |= (uint8_t)(PR_USART0_bm|PR_SPI_bm|PR_TC0_bm); \ PR_PRPE |= (uint8_t)(PR_TWI_bm|PR_USART0_bm|PR_TC0_bm); \ PR_PRPF |= (uint8_t)(PR_USART0_bm|PR_TC0_bm); \ } while(0) #endif #if defined(__AVR_ATxmega16A4__) \ || defined(__AVR_ATxmega16A4U__) \ || defined(__AVR_ATxmega16D4__) \ || defined(__AVR_ATxmega32A4__) \ || defined(__AVR_ATxmega32A4U__) \ || defined(__AVR_ATxmega32D4__) \ || defined(__AVR_ATxmega64A1__) \ || defined(__AVR_ATxmega64A1U__) \ || defined(__AVR_ATxmega64A3__) \ || defined(__AVR_ATxmega64A3U__) \ || defined(__AVR_ATxmega64A4U__) \ || defined(__AVR_ATxmega128A1__) \ || defined(__AVR_ATxmega128A1U__) \ || defined(__AVR_ATxmega128A3__) \ || defined(__AVR_ATxmega128A3U__) \ || defined(__AVR_ATxmega128A4U__) \ || defined(__AVR_ATxmega192A3__) \ || defined(__AVR_ATxmega192A3U__) \ || defined(__AVR_ATxmega256A3__) \ || defined(__AVR_ATxmega256A3U__) \ || defined(__AVR_ATxmega256A3B__) \ || defined(__AVR_ATxmega256A3BU__) \ || defined(__AVR_ATxmega384C3__) #define power_rtc_enable() (PR_PRGEN &= (uint8_t)~(PR_RTC_bm)) #define power_rtc_disable() (PR_PRGEN |= (uint8_t)PR_RTC_bm) #define power_evsys_enable() (PR_PRGEN &= (uint8_t)~(PR_EVSYS_bm)) #define power_evsys_disable() (PR_PRGEN |= (uint8_t)PR_EVSYS_bm) #define power_adca_enable() (PR_PRPA &= (uint8_t)~(PR_ADC_bm)) #define power_adca_disable() (PR_PRPA |= (uint8_t)PR_ADC_bm) #define power_adcb_enable() (PR_PRPB &= (uint8_t)~(PR_ADC_bm)) #define power_adcb_disable() (PR_PRPB |= (uint8_t)PR_ADC_bm) #define power_aca_enable() (PR_PRPA &= (uint8_t)~(PR_AC_bm)) #define power_aca_disable() (PR_PRPA |= (uint8_t)PR_AC_bm) #define power_acb_enable() (PR_PRPB &= (uint8_t)~(PR_AC_bm)) #define power_acb_disable() (PR_PRPB |= (uint8_t)PR_AC_bm) #define power_twic_enable() (PR_PRPC &= (uint8_t)~(PR_TWI_bm)) #define power_twic_disable() (PR_PRPC |= (uint8_t)PR_TWI_bm) #define power_twid_enable() (PR_PRPD &= (uint8_t)~(PR_TWI_bm)) #define power_twid_disable() (PR_PRPD |= (uint8_t)PR_TWI_bm) #define power_twie_enable() (PR_PRPE &= (uint8_t)~(PR_TWI_bm)) #define power_twie_disable() (PR_PRPE |= (uint8_t)PR_TWI_bm) #define power_twif_enable() (PR_PRPF &= (uint8_t)~(PR_TWI_bm)) #define power_twif_disable() (PR_PRPF |= (uint8_t)PR_TWI_bm) #define power_usartc0_enable() (PR_PRPC &= (uint8_t)~(PR_USART0_bm)) #define power_usartc0_disable() (PR_PRPC |= (uint8_t)PR_USART0_bm) #define power_usartd0_enable() (PR_PRPD &= (uint8_t)~(PR_USART0_bm)) #define power_usartd0_disable() (PR_PRPD |= (uint8_t)PR_USART0_bm) #define power_usarte0_enable() (PR_PRPE &= (uint8_t)~(PR_USART0_bm)) #define power_usarte0_disable() (PR_PRPE |= (uint8_t)PR_USART0_bm) #define power_usartf0_enable() (PR_PRPF &= (uint8_t)~(PR_USART0_bm)) #define power_usartf0_disable() (PR_PRPF |= (uint8_t)PR_USART0_bm) #define power_spic_enable() (PR_PRPC &= (uint8_t)~(PR_SPI_bm)) #define power_spic_disable() (PR_PRPC |= (uint8_t)PR_SPI_bm) #define power_spid_enable() (PR_PRPD &= (uint8_t)~(PR_SPI_bm)) #define power_spid_disable() (PR_PRPD |= (uint8_t)PR_SPI_bm) #define power_spie_enable() (PR_PRPE &= (uint8_t)~(PR_SPI_bm)) #define power_spie_disable() (PR_PRPE |= (uint8_t)PR_SPI_bm) #define power_spif_enable() (PR_PRPF &= (uint8_t)~(PR_SPI_bm)) #define power_spif_disable() (PR_PRPF |= (uint8_t)PR_SPI_bm) #define power_hiresc_enable() (PR_PRPC &= (uint8_t)~(PR_HIRES_bm)) #define power_hiresc_disable() (PR_PRPC |= (uint8_t)PR_HIRES_bm) #define power_hiresd_enable() (PR_PRPD &= (uint8_t)~(PR_HIRES_bm)) #define power_hiresd_disable() (PR_PRPD |= (uint8_t)PR_HIRES_bm) #define power_hirese_enable() (PR_PRPE &= (uint8_t)~(PR_HIRES_bm)) #define power_hirese_disable() (PR_PRPE |= (uint8_t)PR_HIRES_bm) #define power_hiresf_enable() (PR_PRPF &= (uint8_t)~(PR_HIRES_bm)) #define power_hiresf_disable() (PR_PRPF |= (uint8_t)PR_HIRES_bm) #define power_tc1c_enable() (PR_PRPC &= (uint8_t)~(PR_TC1_bm)) #define power_tc1c_disable() (PR_PRPC |= (uint8_t)PR_TC1_bm) #define power_tc1d_enable() (PR_PRPD &= (uint8_t)~(PR_TC1_bm)) #define power_tc1d_disable() (PR_PRPD |= (uint8_t)PR_TC1_bm) #define power_tc1e_enable() (PR_PRPE &= (uint8_t)~(PR_TC1_bm)) #define power_tc1e_disable() (PR_PRPE |= (uint8_t)PR_TC1_bm) #define power_tc1f_enable() (PR_PRPF &= (uint8_t)~(PR_TC1_bm)) #define power_tc1f_disable() (PR_PRPF |= (uint8_t)PR_TC1_bm) #define power_tc0c_enable() (PR_PRPC &= (uint8_t)~(PR_TC0_bm)) #define power_tc0c_disable() (PR_PRPC |= (uint8_t)PR_TC0_bm) #define power_tc0d_enable() (PR_PRPD &= (uint8_t)~(PR_TC0_bm)) #define power_tc0d_disable() (PR_PRPD |= (uint8_t)PR_TC0_bm) #define power_tc0e_enable() (PR_PRPE &= (uint8_t)~(PR_TC0_bm)) #define power_tc0e_disable() (PR_PRPE |= (uint8_t)PR_TC0_bm) #define power_tc0f_enable() (PR_PRPF &= (uint8_t)~(PR_TC0_bm)) #define power_tc0f_disable() (PR_PRPF |= (uint8_t)PR_TC0_bm) #endif #if defined(__AVR_ATxmega64D4__) \ || defined(__AVR_ATxmega128D4__) #define power_rtc_enable() (PR_PRGEN &= (uint8_t)~(PR_RTC_bm)) #define power_rtc_disable() (PR_PRGEN |= (uint8_t)PR_RTC_bm) #define power_evsys_enable() (PR_PRGEN &= (uint8_t)~(PR_EVSYS_bm)) #define power_evsys_disable() (PR_PRGEN |= (uint8_t)PR_EVSYS_bm) #define power_adca_enable() (PR_PRPA &= (uint8_t)~(PR_ADC_bm)) #define power_adca_disable() (PR_PRPA |= (uint8_t)PR_ADC_bm) #define power_aca_enable() (PR_PRPA &= (uint8_t)~(PR_AC_bm)) #define power_aca_disable() (PR_PRPA |= (uint8_t)PR_AC_bm) #define power_twic_enable() (PR_PRPC &= (uint8_t)~(PR_TWI_bm)) #define power_twic_disable() (PR_PRPC |= (uint8_t)PR_TWI_bm) #define power_twie_enable() (PR_PRPE &= (uint8_t)~(PR_TWI_bm)) #define power_twie_disable() (PR_PRPE |= (uint8_t)PR_TWI_bm) #define power_usartc0_enable() (PR_PRPC &= (uint8_t)~(PR_USART0_bm)) #define power_usartc0_disable() (PR_PRPC |= (uint8_t)PR_USART0_bm) #define power_usartd0_enable() (PR_PRPD &= (uint8_t)~(PR_USART0_bm)) #define power_usartd0_disable() (PR_PRPD |= (uint8_t)PR_USART0_bm) #define power_usarte0_enable() (PR_PRPE &= (uint8_t)~(PR_USART0_bm)) #define power_usarte0_disable() (PR_PRPE |= (uint8_t)PR_USART0_bm) #define power_usartf0_enable() (PR_PRPF &= (uint8_t)~(PR_USART0_bm)) #define power_usartf0_disable() (PR_PRPF |= (uint8_t)PR_USART0_bm) #define power_spic_enable() (PR_PRPC &= (uint8_t)~(PR_SPI_bm)) #define power_spic_disable() (PR_PRPC |= (uint8_t)PR_SPI_bm) #define power_spid_enable() (PR_PRPD &= (uint8_t)~(PR_SPI_bm)) #define power_spid_disable() (PR_PRPD |= (uint8_t)PR_SPI_bm) #define power_hiresc_enable() (PR_PRPC &= (uint8_t)~(PR_HIRES_bm)) #define power_hiresc_disable() (PR_PRPC |= (uint8_t)PR_HIRES_bm) #define power_tc1c_enable() (PR_PRPC &= (uint8_t)~(PR_TC1_bm)) #define power_tc1c_disable() (PR_PRPC |= (uint8_t)PR_TC1_bm) #define power_tc0c_enable() (PR_PRPC &= (uint8_t)~(PR_TC0_bm)) #define power_tc0c_disable() (PR_PRPC |= (uint8_t)PR_TC0_bm) #define power_tc0d_enable() (PR_PRPD &= (uint8_t)~(PR_TC0_bm)) #define power_tc0d_disable() (PR_PRPD |= (uint8_t)PR_TC0_bm) #define power_tc0e_enable() (PR_PRPE &= (uint8_t)~(PR_TC0_bm)) #define power_tc0e_disable() (PR_PRPE |= (uint8_t)PR_TC0_bm) #define power_tc0f_enable() (PR_PRPF &= (uint8_t)~(PR_TC0_bm)) #define power_tc0f_disable() (PR_PRPF |= (uint8_t)PR_TC0_bm) #define power_all_enable() \ do { \ PR_PRGEN &= (uint8_t)~(PR_RTC_bm|PR_EVSYS_bm); \ PR_PRPA &= (uint8_t)~(PR_ADC_bm|PR_AC_bm); \ PR_PRPC &= (uint8_t)~(PR_TWI_bm|PR_USART0_bm|PR_SPI_bm|PR_HIRES_bm|PR_TC1_bm|PR_TC0_bm); \ PR_PRPD &= (uint8_t)~(PR_USART0_bm|PR_SPI_bm|PR_TC0_bm); \ PR_PRPE &= (uint8_t)~(PR_TWI_bm|PR_USART0_bm|PR_TC0_bm); \ PR_PRPF &= (uint8_t)~(PR_USART0_bm|PR_TC0_bm); \ } while(0) #define power_all_disable() \ do { \ PR_PRGEN |= (uint8_t)(PR_RTC_bm|PR_EVSYS_bm); \ PR_PRPA |= (uint8_t)(PR_ADC_bm|PR_AC_bm); \ PR_PRPC |= (uint8_t)(PR_TWI_bm|PR_USART0_bm|PR_SPI_bm|PR_HIRES_bm|PR_TC1_bm|PR_TC0_bm); \ PR_PRPD |= (uint8_t)(PR_USART0_bm|PR_SPI_bm|PR_TC0_bm); \ PR_PRPE |= (uint8_t)(PR_TWI_bm|PR_USART0_bm|PR_TC0_bm); \ PR_PRPF |= (uint8_t)(PR_USART0_bm|PR_TC0_bm); \ } while(0) #endif #if defined(__AVR_ATxmega16D4__) \ || defined(__AVR_ATxmega32D4__) #define power_all_enable() \ do { \ PR_PRGEN &= (uint8_t)~(PR_RTC_bm|PR_EVSYS_bm); \ PR_PRPA &= (uint8_t)~(PR_ADC_bm|PR_AC_bm); \ PR_PRPB &= (uint8_t)~(PR_ADC_bm|PR_AC_bm); \ PR_PRPC &= (uint8_t)~(PR_TWI_bm|PR_USART0_bm|PR_SPI_bm|PR_HIRES_bm|PR_TC1_bm|PR_TC0_bm); \ PR_PRPD &= (uint8_t)~(PR_TWI_bm|PR_USART0_bm|PR_SPI_bm|PR_HIRES_bm|PR_TC1_bm|PR_TC0_bm); \ PR_PRPE &= (uint8_t)~(PR_TWI_bm|PR_USART0_bm|PR_SPI_bm|PR_HIRES_bm|PR_TC1_bm|PR_TC0_bm); \ PR_PRPF &= (uint8_t)~(PR_TWI_bm|PR_USART0_bm|PR_SPI_bm|PR_HIRES_bm|PR_TC1_bm|PR_TC0_bm); \ } while(0) #define power_all_disable() \ do { \ PR_PRGEN|= (uint8_t)(PR_EBI_bm|PR_RTC_bm|PR_EVSYS_bm|PR_DMA_bm); \ PR_PRPA |= (uint8_t)(PR_ADC_bm|PR_AC_bm); \ PR_PRPB |= (uint8_t)(PR_ADC_bm|PR_AC_bm); \ PR_PRPC |= (uint8_t)(PR_TWI_bm|PR_USART0_bm|PR_SPI_bm|PR_HIRES_bm|PR_TC1_bm|PR_TC0_bm); \ PR_PRPD |= (uint8_t)(PR_TWI_bm|PR_USART0_bm|PR_SPI_bm|PR_HIRES_bm|PR_TC1_bm|PR_TC0_bm); \ PR_PRPE |= (uint8_t)(PR_TWI_bm|PR_USART0_bm|PR_SPI_bm|PR_HIRES_bm|PR_TC1_bm|PR_TC0_bm); \ PR_PRPF |= (uint8_t)(PR_TWI_bm|PR_USART0_bm|PR_SPI_bm|PR_HIRES_bm|PR_TC1_bm|PR_TC0_bm); \ } while(0) #elif defined (__AVR_ATxmega64B1__) \ || defined (__AVR_ATxmega64B3__) \ || defined (__AVR_ATxmega128B1__) \ || defined (__AVR_ATxmega128B3__) #define power_lcd_enable() (PR_PRGEN &= (uint8_t)~(PR_LCD_bm)) #define power_lcd_disable() (PR_PRGEN |= (uint8_t)PR_LCD_bm) #define power_usb_enable() (PR_PRGEN &= (uint8_t)~(PR_USB_bm)) #define power_usb_disable() (PR_PRGEN |= (uint8_t)PR_USB_bm) #define power_aes_enable() (PR_PRGEN &= (uint8_t)~(PR_AES_bm)) #define power_aes_disable() (PR_PRGEN |= (uint8_t)PR_AES_bm) #define power_rtc_enable() (PR_PRGEN &= (uint8_t)~(PR_RTC_bm)) #define power_rtc_disable() (PR_PRGEN |= (uint8_t)PR_RTC_bm) #define power_evsys_enable() (PR_PRGEN &= (uint8_t)~(PR_EVSYS_bm)) #define power_evsys_disable() (PR_PRGEN |= (uint8_t)PR_EVSYS_bm) #define power_dma_enable() (PR_PRGEN &= (uint8_t)~(PR_DMA_bm)) #define power_dma_disable() (PR_PRGEN |= (uint8_t)PR_DMA_bm) #define power_adca_enable() (PR_PRPA &= (uint8_t)~(PR_ADC_bm)) #define power_adca_disable() (PR_PRPA |= (uint8_t)PR_ADC_bm) #define power_adcb_enable() (PR_PRPB &= (uint8_t)~(PR_ADC_bm)) #define power_adcb_disable() (PR_PRPB |= (uint8_t)PR_ADC_bm) #define power_aca_enable() (PR_PRPA &= (uint8_t)~(PR_AC_bm)) #define power_aca_disable() (PR_PRPA |= (uint8_t)PR_AC_bm) #define power_acb_enable() (PR_PRPB &= (uint8_t)~(PR_AC_bm)) #define power_acb_disable() (PR_PRPB |= (uint8_t)PR_AC_bm) #define power_twic_enable() (PR_PRPC &= (uint8_t)~(PR_TWI_bm)) #define power_twic_disable() (PR_PRPC |= (uint8_t)PR_TWI_bm) #define power_usartc0_enable() (PR_PRPC &= (uint8_t)~(PR_USART0_bm)) #define power_usartc0_disable() (PR_PRPC |= (uint8_t)PR_USART0_bm) #define power_usarte0_enable() (PR_PRPE &= (uint8_t)~(PR_USART0_bm)) #define power_usarte0_disable() (PR_PRPE |= (uint8_t)PR_USART0_bm) #define power_spic_enable() (PR_PRPC &= (uint8_t)~(PR_SPI_bm)) #define power_spic_disable() (PR_PRPC |= (uint8_t)PR_SPI_bm) #define power_hiresc_enable() (PR_PRPC &= (uint8_t)~(PR_HIRES_bm)) #define power_hiresc_disable() (PR_PRPC |= (uint8_t)PR_HIRES_bm) #define power_tc1c_enable() (PR_PRPC &= (uint8_t)~(PR_TC1_bm)) #define power_tc1c_disable() (PR_PRPC |= (uint8_t)PR_TC1_bm) #define power_tc0c_enable() (PR_PRPC &= (uint8_t)~(PR_TC0_bm)) #define power_tc0c_disable() (PR_PRPC |= (uint8_t)PR_TC0_bm) #define power_tc0e_enable() (PR_PRPE &= (uint8_t)~(PR_TC0_bm)) #define power_tc0e_disable() (PR_PRPE |= (uint8_t)PR_TC0_bm) #define power_all_enable() \ do { \ PR_PRGEN &= (uint8_t)~(PR_LCD_bm|PR_USB_bm|PR_AES_bm|PR_RTC_bm|PR_EVSYS_bm|PR_DMA_bm); \ PR_PRPA &= (uint8_t)~(PR_ADC_bm|PR_AC_bm); \ PR_PRPB &= (uint8_t)~(PR_ADC_bm|PR_AC_bm); \ PR_PRPC &= (uint8_t)~(PR_TWI_bm|PR_USART0_bm|PR_SPI_bm|PR_HIRES_bm|PR_TC1_bm|PR_TC0_bm); \ PR_PRPE &= (uint8_t)~(PR_USART0_bm|PR_TC0_bm); \ } while(0) #define power_all_disable() \ do { \ PR_PRGEN |= (uint8_t)(PR_LCD_bm|PR_USB_bm|PR_AES_bm|PR_RTC_bm|PR_EVSYS_bm|PR_DMA_bm); \ PR_PRPA |= (uint8_t)(PR_ADC_bm|PR_AC_bm); \ PR_PRPB |= (uint8_t)(PR_ADC_bm|PR_AC_bm); \ PR_PRPC |= (uint8_t)(PR_TWI_bm|PR_USART0_bm|PR_SPI_bm|PR_HIRES_bm|PR_TC1_bm|PR_TC0_bm); \ PR_PRPE |= (uint8_t)(PR_USART0_bm|PR_TC0_bm); \ } while(0) #elif defined(__AVR_ATmega640__) \ || defined(__AVR_ATmega1280__) \ || defined(__AVR_ATmega1281__) \ || defined(__AVR_ATmega2560__) \ || defined(__AVR_ATmega2561__) #define power_adc_enable() (PRR0 &= (uint8_t)~(1 << PRADC)) #define power_adc_disable() (PRR0 |= (uint8_t)(1 << PRADC)) #define power_spi_enable() (PRR0 &= (uint8_t)~(1 << PRSPI)) #define power_spi_disable() (PRR0 |= (uint8_t)(1 << PRSPI)) #define power_twi_enable() (PRR0 &= (uint8_t)~(1 << PRTWI)) #define power_twi_disable() (PRR0 |= (uint8_t)(1 << PRTWI)) #define power_timer0_enable() (PRR0 &= (uint8_t)~(1 << PRTIM0)) #define power_timer0_disable() (PRR0 |= (uint8_t)(1 << PRTIM0)) #define power_timer1_enable() (PRR0 &= (uint8_t)~(1 << PRTIM1)) #define power_timer1_disable() (PRR0 |= (uint8_t)(1 << PRTIM1)) #define power_timer2_enable() (PRR0 &= (uint8_t)~(1 << PRTIM2)) #define power_timer2_disable() (PRR0 |= (uint8_t)(1 << PRTIM2)) #define power_timer3_enable() (PRR1 &= (uint8_t)~(1 << PRTIM3)) #define power_timer3_disable() (PRR1 |= (uint8_t)(1 << PRTIM3)) #define power_timer4_enable() (PRR1 &= (uint8_t)~(1 << PRTIM4)) #define power_timer4_disable() (PRR1 |= (uint8_t)(1 << PRTIM4)) #define power_timer5_enable() (PRR1 &= (uint8_t)~(1 << PRTIM5)) #define power_timer5_disable() (PRR1 |= (uint8_t)(1 << PRTIM5)) #define power_usart0_enable() (PRR0 &= (uint8_t)~(1 << PRUSART0)) #define power_usart0_disable() (PRR0 |= (uint8_t)(1 << PRUSART0)) #define power_usart1_enable() (PRR1 &= (uint8_t)~(1 << PRUSART1)) #define power_usart1_disable() (PRR1 |= (uint8_t)(1 << PRUSART1)) #define power_usart2_enable() (PRR1 &= (uint8_t)~(1 << PRUSART2)) #define power_usart2_disable() (PRR1 |= (uint8_t)(1 << PRUSART2)) #define power_usart3_enable() (PRR1 &= (uint8_t)~(1 << PRUSART3)) #define power_usart3_disable() (PRR1 |= (uint8_t)(1 << PRUSART3)) #define power_all_enable() \ do{ \ PRR0 &= (uint8_t)~((1< 129)) { return;//Invalid value. } else { uint8_t __tmp = 0; //Algo explained: //1 - Clear XDIV in order for it to accept a new value (actually only // XDIVEN need to be cleared, but clearing XDIV is faster than // read-modify-write since we will rewrite XDIV later anyway) //2 - wait 8 clock cycle for stability, see datasheet erreta //3 - Exist if requested prescaller is 1 //4 - Calculate XDIV6..0 value = 129 - __x //5 - Set XDIVEN bit in calculated value //6 - write XDIV with calculated value //7 - wait 8 clock cycle for stability, see datasheet erreta __asm__ __volatile__ ( "in __tmp_reg__,__SREG__" "\n\t" "cli" "\n\t" "out %1, __zero_reg__" "\n\t" "nop" "\n\t" "nop" "\n\t" "nop" "\n\t" "nop" "\n\t" "nop" "\n\t" "nop" "\n\t" "nop" "\n\t" "nop" "\n\t" "cpi %0, 0x01" "\n\t" "breq L_%=" "\n\t" "ldi %2, 0x81" "\n\t" //129 "sub %2, %0" "\n\t" "ori %2, 0x80" "\n\t" //128 "out %1, %2" "\n\t" "nop" "\n\t" "nop" "\n\t" "nop" "\n\t" "nop" "\n\t" "nop" "\n\t" "nop" "\n\t" "nop" "\n\t" "nop" "\n\t" "L_%=: " "out __SREG__, __tmp_reg__" : /* no outputs */ :"d" (__x), "I" (_SFR_IO_ADDR(XDIV)), "d" (__tmp) : "r0"); } } static __inline__ clock_div_t clock_prescale_get(void) __attribute__((__always_inline__)); clock_div_t clock_prescale_get(void) { if(bit_is_clear(XDIV, XDIVEN)) { return 1; } else { return (clock_div_t)(129 - (XDIV & 0x7F)); } } #elif defined(__AVR_ATtiny4__) \ || defined(__AVR_ATtiny5__) \ || defined(__AVR_ATtiny9__) \ || defined(__AVR_ATtiny10__) \ || defined(__AVR_ATtiny20__) \ || defined(__AVR_ATtiny40__) \ typedef enum { clock_div_1 = 0, clock_div_2 = 1, clock_div_4 = 2, clock_div_8 = 3, clock_div_16 = 4, clock_div_32 = 5, clock_div_64 = 6, clock_div_128 = 7, clock_div_256 = 8 } clock_div_t; static __inline__ void clock_prescale_set(clock_div_t) __attribute__((__always_inline__)); void clock_prescale_set(clock_div_t __x) { uint8_t __tmp = 0xD8; __asm__ __volatile__ ( "in __tmp_reg__,__SREG__" "\n\t" "cli" "\n\t" "out %1, %0" "\n\t" "out %2, %3" "\n\t" "out __SREG__, __tmp_reg__" : /* no outputs */ : "d" (__tmp), "I" (_SFR_IO_ADDR(CCP)), "I" (_SFR_IO_ADDR(CLKPSR)), "d" (__x) : "r16"); } #define clock_prescale_get() (clock_div_t)(CLKPSR & (uint8_t)((1<