Loading...
Searching...
No Matches
periph_cpu.h
Go to the documentation of this file.
1/*
2 * Copyright (C) Josua Arndt, Steffen Robertz 2017 RWTH Aachen
3 *
4 * This file is subject to the terms and conditions of the GNU Lesser
5 * General Public License v2.1. See the file LICENSE in the top level
6 * directory for more details.
7 */
8
9#pragma once
10
21
22#include "periph_cpu_common.h"
23#include "atmega_regs_common.h"
24
25#ifdef __cplusplus
26extern "C" {
27#endif
32#define PM_NUM_MODES (5)
33#define AVR8_PM_SLEEP_MODE_0 SLEEP_MODE_PWR_DOWN
34#define AVR8_PM_SLEEP_MODE_1 SLEEP_MODE_PWR_SAVE
35#define AVR8_PM_SLEEP_MODE_2 SLEEP_MODE_STANDBY
36#define AVR8_PM_SLEEP_MODE_3 SLEEP_MODE_ADC
38
43enum {
44 PORT_B = 1,
45 PORT_D = 3,
46 PORT_E = 4,
47 PORT_F = 5,
48 PORT_G = 6,
49};
51
57#define CPU_ATMEGA_EXT_INTS { GPIO_PIN(PORT_D, 0), \
58 GPIO_PIN(PORT_D, 1), \
59 GPIO_PIN(PORT_D, 2), \
60 GPIO_PIN(PORT_D, 3), \
61 GPIO_PIN(PORT_E, 4), \
62 GPIO_PIN(PORT_E, 5), \
63 GPIO_PIN(PORT_E, 6), \
64 GPIO_PIN(PORT_E, 7) }
65
69static inline uint8_t atmega_pin2exti(uint8_t port_num, uint8_t pin_num)
70{
71 (void)port_num;
72 return pin_num;
73}
74
78static inline bool atmega_has_pin_exti(uint8_t port_num, uint8_t pin_num)
79{
80 if (pin_num < 4) {
81 return port_num == PORT_D;
82 }
83
84 return port_num == PORT_E;
85}
86
91#define I2C_PORT_REG PORTD
92#define I2C_PIN_MASK (1 << PORTD1) | (1 << PORTD0)
94
99#define EEPROM_SIZE (4096U) /* 4kB */
101
102#ifdef __cplusplus
103}
104#endif
105
106#include "periph_conf.h"
107#include "default_timer_config.h"
108
static bool atmega_has_pin_exti(uint8_t port_num, uint8_t pin_num)
Check if the given pin can be used as external interrupt.
Definition periph_cpu.h:81
static uint8_t atmega_pin2exti(uint8_t port_num, uint8_t pin_num)
Get the interrupt vector number of the given GPIO pin.
Definition periph_cpu.h:72
@ PORT_B
port B
Definition periph_cpu.h:47
@ PORT_G
port G
Definition periph_cpu.h:52
@ PORT_F
port F
Definition periph_cpu.h:51
@ PORT_E
port E
Definition periph_cpu.h:50
@ PORT_D
port D
Definition periph_cpu.h:49
Default timer configuration.
CMSIS style register definitions for the atmega family.