AVR Libc Home Page | AVR Libc Development Pages | |||
Main Page | User Manual | Reference | FAQ | Example Projects |
Functions |
|
void | clock_prescale_set (clock_div_t __x) |
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.
Power Macro |
Description
|
power_aca_disable() |
Disable the Analog Comparator on PortA.
|
power_aca_enable() |
Enable the Analog Comparator on PortA.
|
power_adc_enable() |
Enable the Analog to Digital Converter module.
|
power_adc_disable() |
Disable the Analog to Digital Converter module.
|
power_adca_disable() |
Disable the Analog to Digital Converter module on PortA
|
power_adca_enable() |
Enable the Analog to Digital Converter module on PortA
|
power_evsys_disable() |
Disable the EVSYS module
|
power_evsys_enable() |
Enable the EVSYS module
|
power_hiresc_disable() |
Disable the HIRES module on PortC
|
power_hiresc_enable() |
Enable the HIRES module on PortC
|
power_lcd_enable() |
Enable the LCD module.
|
power_lcd_disable(). |
Disable the LCD module.
|
power_pga_enable() |
Enable the Programmable Gain Amplifier module.
|
power_pga_disable() |
Disable the Programmable Gain Amplifier module.
|
power_pscr_enable() |
Enable the Reduced Power Stage Controller module.
|
power_pscr_disable() |
Disable the Reduced Power Stage Controller module.
|
power_psc0_enable() |
Enable the Power Stage Controller 0 module.
|
power_psc0_disable() |
Disable the Power Stage Controller 0 module.
|
power_psc1_enable() |
Enable the Power Stage Controller 1 module.
|
power_psc1_disable() |
Disable the Power Stage Controller 1 module.
|
power_psc2_enable() |
Enable the Power Stage Controller 2 module.
|
power_psc2_disable() |
Disable the Power Stage Controller 2 module.
|
power_ram0_enable() |
Enable the SRAM block 0 .
|
power_ram0_disable() |
Disable the SRAM block 0.
|
power_ram1_enable() |
Enable the SRAM block 1 .
|
power_ram1_disable() |
Disable the SRAM block 1.
|
power_ram2_enable() |
Enable the SRAM block 2 .
|
power_ram2_disable() |
Disable the SRAM block 2.
|
power_ram3_enable() |
Enable the SRAM block 3 .
|
power_ram3_disable() |
Disable the SRAM block 3.
|
power_rtc_disable() |
Disable the RTC module
|
power_rtc_enable() |
Enable the RTC module
|
power_spi_enable() |
Enable the Serial Peripheral Interface module.
|
power_spi_disable() |
Disable the Serial Peripheral Interface module.
|
power_spic_disable() |
Disable the SPI module on PortC
|
power_spic_enable() |
Enable the SPI module on PortC
|
power_spid_disable() |
Disable the SPI module on PortD
|
power_spid_enable() |
Enable the SPI module on PortD
|
power_tc0c_disable() |
Disable the TC0 module on PortC
|
power_tc0c_enable() |
Enable the TC0 module on PortC
|
power_tc0d_disable() |
Disable the TC0 module on PortD
|
power_tc0d_enable() |
Enable the TC0 module on PortD
|
power_tc0e_disable() |
Disable the TC0 module on PortE
|
power_tc0e_enable() |
Enable the TC0 module on PortE
|
power_tc0f_disable() |
Disable the TC0 module on PortF
|
power_tc0f_enable() |
Enable the TC0 module on PortF
|
power_tc1c_disable() |
Disable the TC1 module on PortC
|
power_tc1c_enable() |
Enable the TC1 module on PortC
|
power_twic_disable() |
Disable the Two Wire Interface module on PortC
|
power_twic_enable() |
Enable the Two Wire Interface module on PortC
|
power_twie_disable() |
Disable the Two Wire Interface module on PortE
|
power_twie_enable() |
Enable the Two Wire Interface module on PortE
|
power_timer0_enable() |
Enable the Timer 0 module.
|
power_timer0_disable() |
Disable the Timer 0 module.
|
power_timer1_enable() |
Enable the Timer 1 module.
|
power_timer1_disable() |
Disable the Timer 1 module.
|
power_timer2_enable() |
Enable the Timer 2 module.
|
power_timer2_disable() |
Disable the Timer 2 module.
|
power_timer3_enable() |
Enable the Timer 3 module.
|
power_timer3_disable() |
Disable the Timer 3 module.
|
power_timer4_enable() |
Enable the Timer 4 module.
|
power_timer4_disable() |
Disable the Timer 4 module.
|
power_timer5_enable() |
Enable the Timer 5 module.
|
power_timer5_disable() |
Disable the Timer 5 module.
|
power_twi_enable() |
Enable the Two Wire Interface module.
|
power_twi_disable() |
Disable the Two Wire Interface module.
|
power_usart_enable() |
Enable the USART module.
|
power_usart_disable() |
Disable the USART module.
|
power_usart0_enable() |
Enable the USART 0 module.
|
power_usart0_disable() |
Disable the USART 0 module.
|
power_usart1_enable() |
Enable the USART 1 module.
|
power_usart1_disable() |
Disable the USART 1 module.
|
power_usart2_enable() |
Enable the USART 2 module.
|
power_usart2_disable() |
Disable the USART 2 module.
|
power_usart3_enable() |
Enable the USART 3 module.
|
power_usart3_disable() |
Disable the USART 3 module.
|
power_usartc0_disable() |
Disable the USART0 module on PortC
|
power_usartc0_enable() |
Enable the USART0 module on PortC
|
power_usartd0_disable() |
Disable the USART0 module on PortD
|
power_usartd0_enable() |
Enable the USART0 module on PortD
|
power_usarte0_disable() |
Disable the USART0 module on PortE
|
power_usarte0_enable() |
Enable the USART0 module on PortE
|
power_usartf0_disable() |
Disable the USART0 module on PortF
|
power_usartf0_enable() |
Enable the USART0 module on PortF
|
power_usb_enable() |
Enable the USB module.
|
power_usb_disable() |
Disable the USB module.
|
power_usi_enable() |
Enable the Universal Serial Interface module.
|
power_usi_disable() |
Disable the Universal Serial Interface module.
|
power_vadc_enable() |
Enable the Voltage ADC module.
|
power_vadc_disable() |
Disable the Voltage ADC module.
|
power_all_enable() |
Enable all modules.
|
power_all_disable() | Disable all modules. |
Some of the newer AVRs contain a System Clock Prescale Register (CLKPR) that allows you to decrease the system clock frequency and the power consumption when the need for processing power is low. On some earlier AVRs (ATmega103, ATmega64, ATmega128), similar functionality can be achieved through the XTAL Divide Control Register. Below are two macros and an enumerated type that can be used to interface to the Clock Prescale Register or XTAL Divide Control Register.
Clock prescaler setting enumerations for device using System Clock Prescale Register.
typedef enum { clock_div_1 = 1, clock_div_2 = 2, clock_div_4 = 4, clock_div_8 = 8, clock_div_16 = 16, clock_div_32 = 32, clock_div_64 = 64, clock_div_128 = 128 } clock_div_t;Clock prescaler setting enumerations for device using XTAL Divide Control Register.
clock_prescale_set | ( | clock_div_t | x | ) |
Set the clock prescaler register select bits, selecting a system clock division setting. This function is inlined, even if compiler optimizations are disabled.
The type of x
is clock_div_t
.
x
can actually range from 1 to 129. Thus, one does not need to use clock_div_t
type as argument.