CPU specific definitions for internal peripheral handling. More...
CPU specific definitions for internal peripheral handling.
Definition in file periph_cpu_common.h.
#include "cpu.h" Include dependency graph for periph_cpu_common.h:
 Include dependency graph for periph_cpu_common.h:Go to the source code of this file.
| Data Structures | |
| struct | atmega_gpio_port_t | 
| Structure describing the memory layout of the registers of a GPIO port on ATmega MCUs.  More... | |
| struct | pwm_conf_t | 
| PWM device configuration.  More... | |
| Macros | |
| #define | GPIO_UNDEF (0xff) | 
| Definition of a fitting UNDEF value. | |
| #define | GPIO_PIN(x, y) ((x << 4) | y) | 
| Define a CPU specific GPIO pin generator macro. | |
| #define | ATMEGA_GPIO_BASE_A 0x20 | 
| Base of the GPIO registers as memory address.  More... | |
| #define | ATMEGA_GPIO_BASE_G (ATMEGA_GPIO_BASE_A + ATMEGA_GPIO_SIZE * ('G' - 'A')) | 
| Base of the GPIO port G register as memory address.  More... | |
| #define | ATMEGA_GPIO_BASE_H (0x100) | 
| Base of the GPIO registers of the second memory region (port >= H)  More... | |
| #define | ATMEGA_GPIO_SIZE (0x03) | 
| sizeof(atmega_gpio_port_t), but preprocessor friendly | |
| #define | GPIO_EXT_INT_NUMOF <CPU_SPECIFIC> | 
| Number of external interrupt vectors. | |
| #define | PERIPH_TIMER_PROVIDES_SET | 
| A low-level timer_set() implementation is provided. | |
| #define | EEPROM_CLEAR_BYTE (0xff) | 
| EEPROM clear byte. | |
| #define | WDT_HAS_STOP (1) | 
| WDT can be stopped on AVR. | |
| Functions | |
| static atmega_gpio_port_t * | atmega_gpio_port (uint8_t port_num) | 
| Get the GPIO PORT registers of the given GPIO PORT.  More... | |
| Length of the CPU_ID in octets | |
| #define | CPUID_LEN (4U) | 
| #define | PERIPH_SPI_NEEDS_INIT_CS | 
| Use some common SPI functions. | |
| #define | PERIPH_SPI_NEEDS_TRANSFER_BYTE | 
| #define | PERIPH_SPI_NEEDS_TRANSFER_REG | 
| #define | PERIPH_SPI_NEEDS_TRANSFER_REGS | 
| WDT upper and lower bound times in ms | |
| #define | NWDT_TIME_LOWER_LIMIT (1) | 
| #define | NWDT_TIME_UPPER_LIMIT (8192U) | 
| RTT configuration | |
| #define | RTT_MAX_VALUE (0x00FFFFFF) /* 24-bit timer */ | 
| #define | RTT_FREQUENCY (1024U) /* in Hz. */ | 
| Bitmasks indicating which are the possible dividers for a timer | |
| enum | timer_div_t { TIMER_DIV1_8_64_128_1024 = 0x549 , TIMER_DIV1_8_32_64_128_256_1024 = 0x5E9 } | 
| #define ATMEGA_GPIO_BASE_A 0x20 | 
Base of the GPIO registers as memory address.
Must be identical to the address of PINA provided by avr/io.h 
Definition at line 81 of file periph_cpu_common.h.
| #define ATMEGA_GPIO_BASE_G (ATMEGA_GPIO_BASE_A + ATMEGA_GPIO_SIZE * ('G' - 'A')) | 
Base of the GPIO port G register as memory address.
Must be identical to the address of PING provided by avr/io.h 
Definition at line 88 of file periph_cpu_common.h.
| #define ATMEGA_GPIO_BASE_H (0x100) | 
Base of the GPIO registers of the second memory region (port >= H)
Must be identical to the address of PINH provided by avr/io.h 
Definition at line 94 of file periph_cpu_common.h.
| enum timer_div_t | 
| Enumerator | |
|---|---|
| TIMER_DIV1_8_64_128_1024 | 1/{1,8,64,128,1024} | 
| TIMER_DIV1_8_32_64_128_256_1024 | 1/{1,8,32,64,128,256,1024} | 
Definition at line 309 of file periph_cpu_common.h.
| 
 | inlinestatic | 
Get the GPIO PORT registers of the given GPIO PORT.
| [in] | port_num | Number of the port to get the registers of | 
Definition at line 155 of file periph_cpu_common.h.