2018-10-28 19:42:48 +01:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2018 Inria
|
|
|
|
*
|
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
|
|
* directory for more details.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @ingroup boards_common_nrf52
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief Default timer configuration for nRF52 based boards
|
|
|
|
*
|
|
|
|
* @author Alexandre Abadie <alexandre.abadie@inria.fr>
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef CFG_TIMER_DEFAULT_H
|
|
|
|
#define CFG_TIMER_DEFAULT_H
|
|
|
|
|
2022-10-27 21:12:19 +02:00
|
|
|
#include "kernel_defines.h"
|
2018-10-28 19:42:48 +01:00
|
|
|
#include "periph_cpu.h"
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @name Timer configuration
|
|
|
|
* @{
|
|
|
|
*/
|
2022-10-27 21:12:19 +02:00
|
|
|
/**
|
|
|
|
* @brief Configuration of the exposed timers
|
|
|
|
*
|
|
|
|
* @warning The timer `NRF802154_TIMER`, which by default is `TIMER_DEV(1)`,
|
|
|
|
* is used for the IEEE 802.15.4 driver
|
|
|
|
*/
|
2018-10-28 19:42:48 +01:00
|
|
|
static const timer_conf_t timer_config[] = {
|
|
|
|
{
|
|
|
|
.dev = NRF_TIMER1,
|
2022-10-27 21:12:19 +02:00
|
|
|
.channels = 4,
|
2018-10-28 19:42:48 +01:00
|
|
|
.bitmode = TIMER_BITMODE_BITMODE_32Bit,
|
|
|
|
.irqn = TIMER1_IRQn
|
2019-03-04 13:20:46 +01:00
|
|
|
},
|
|
|
|
{
|
2022-10-27 21:12:19 +02:00
|
|
|
/* BEWARE: This timer is allocated to the nRF52 IEEE 802.15.4 driver.
|
|
|
|
* Do not use this timer (unless you do not use IEEE 802.15.4
|
|
|
|
* networking)!
|
|
|
|
*/
|
2019-03-04 13:20:46 +01:00
|
|
|
.dev = NRF_TIMER2,
|
2022-10-27 21:12:19 +02:00
|
|
|
.channels = 4,
|
|
|
|
.bitmode = TIMER_BITMODE_BITMODE_32Bit,
|
2019-03-04 13:20:46 +01:00
|
|
|
.irqn = TIMER2_IRQn
|
2021-03-30 00:53:37 +02:00
|
|
|
},
|
|
|
|
/* The later timers are only present on the larger NRF52 CPUs like NRF52840
|
2022-10-27 21:12:19 +02:00
|
|
|
* or NRF52833, but not small ones like NRF52810. They do have 2 channels
|
|
|
|
* more (CC registers [0..5] instead of CC registers [0..3]). */
|
2021-03-30 00:53:37 +02:00
|
|
|
#ifdef NRF_TIMER3
|
|
|
|
{
|
|
|
|
.dev = NRF_TIMER3,
|
2022-10-27 21:12:19 +02:00
|
|
|
.channels = 6,
|
|
|
|
.bitmode = TIMER_BITMODE_BITMODE_32Bit,
|
2021-03-30 00:53:37 +02:00
|
|
|
.irqn = TIMER3_IRQn
|
|
|
|
},
|
|
|
|
#endif
|
|
|
|
#ifdef NRF_TIMER4
|
|
|
|
{
|
|
|
|
.dev = NRF_TIMER4,
|
2022-10-27 21:12:19 +02:00
|
|
|
.channels = 6,
|
|
|
|
.bitmode = TIMER_BITMODE_BITMODE_32Bit,
|
2021-03-30 00:53:37 +02:00
|
|
|
.irqn = TIMER4_IRQn
|
2018-10-28 19:42:48 +01:00
|
|
|
}
|
2021-03-30 00:53:37 +02:00
|
|
|
#endif
|
2018-10-28 19:42:48 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
#define TIMER_0_ISR isr_timer1
|
2019-03-04 13:20:46 +01:00
|
|
|
#define TIMER_1_ISR isr_timer2
|
2021-03-30 00:53:37 +02:00
|
|
|
#define TIMER_2_ISR isr_timer3
|
|
|
|
#define TIMER_3_ISR isr_timer4
|
2018-10-28 19:42:48 +01:00
|
|
|
|
2019-07-18 15:14:29 +02:00
|
|
|
#define TIMER_NUMOF ARRAY_SIZE(timer_config)
|
2018-10-28 19:42:48 +01:00
|
|
|
/** @} */
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* CFG_TIMER_DEFAULT_H */
|
|
|
|
/** @} */
|