periph_cpu.h
Go to the documentation of this file.
1 /*
2  * Copyright (C) 2015 HAW Hamburg
3  * 2016 Freie Universität Berlin
4  * 2023 Hugues Larrive
5  *
6  * This file is subject to the terms and conditions of the GNU Lesser
7  * General Public License v2.1. See the file LICENSE in the top level
8  * directory for more details.
9  */
10 
11 #pragma once
12 
25 #include "periph_cpu_common.h"
26 
27 #ifdef __cplusplus
28 extern "C" {
29 #endif
30 
35 #define PM_NUM_MODES (5)
36 #define AVR8_PM_SLEEP_MODE_0 SLEEP_MODE_PWR_DOWN
37 #define AVR8_PM_SLEEP_MODE_1 SLEEP_MODE_PWR_SAVE
38 #define AVR8_PM_SLEEP_MODE_2 SLEEP_MODE_STANDBY
39 #define AVR8_PM_SLEEP_MODE_3 SLEEP_MODE_ADC
45 #define GPIO_PIN(x, y) ((x << 4) | y)
46 
50 enum {
51  PORT_B = 1,
52  PORT_C = 2,
53  PORT_D = 3
54 };
55 
61 #define CPU_ATMEGA_EXT_INTS { GPIO_PIN(PORT_D, 2), \
62  GPIO_PIN(PORT_D, 3) }
63 
67 static inline uint8_t atmega_pin2exti(uint8_t port_num, uint8_t pin_num)
68 {
69  (void)port_num;
70  return pin_num - 2;
71 }
72 
76 static inline bool atmega_has_pin_exti(uint8_t port_num, uint8_t pin_num)
77 {
78  if (port_num == PORT_D) {
79  return ((pin_num == 2) || (pin_num == 3));
80  }
81 
82  return false;
83 }
84 
89 #define I2C_PORT_REG PORTC
90 #define I2C_PIN_MASK (1 << PORTC4) | (1 << PORTC5)
97 #define EEPROM_SIZE (512U) /* 512B */
100 #ifdef __cplusplus
101 }
102 #endif
103 
104 #include "periph_conf.h"
105 #include "default_timer_config.h"
106 
@ PORT_B
port B
Definition: periph_cpu.h:47
@ PORT_C
port C
Definition: periph_cpu.h:48
@ PORT_D
port D
Definition: periph_cpu.h:49
Default timer configuration.
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:76
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:67