2014-11-19 11:52:57 +01:00
|
|
|
/**
|
|
|
|
* Native CPU peripheral configuration
|
|
|
|
*
|
2015-09-27 18:58:30 +02:00
|
|
|
* Copyright (C) 2014 Ludwig Knüpfer <ludwig.knuepfer@fu-berlin.de>
|
2014-11-19 11:52:57 +01:00
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*
|
2018-06-01 12:17:51 +02:00
|
|
|
* @ingroup cpu_native
|
2014-11-19 11:52:57 +01:00
|
|
|
* @{
|
|
|
|
* @file
|
2015-09-27 18:58:30 +02:00
|
|
|
* @author Ludwig Knüpfer <ludwig.knuepfer@fu-berlin.de>
|
2014-11-19 11:52:57 +01:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef PERIPH_CONF_H
|
|
|
|
#define PERIPH_CONF_H
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
2019-04-06 06:24:22 +02:00
|
|
|
extern "C" {
|
2014-11-19 11:52:57 +01:00
|
|
|
#endif
|
|
|
|
|
2015-07-09 16:09:59 +02:00
|
|
|
/**
|
|
|
|
* @name hardware timer clock skew avoidance
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
#define NATIVE_TIMER_MIN_RES 200
|
|
|
|
/** @} */
|
|
|
|
|
2014-11-19 11:52:57 +01:00
|
|
|
/**
|
|
|
|
* @name Random Number Generator configuration
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
#define RANDOM_NUMOF (1U)
|
|
|
|
/** @} */
|
|
|
|
|
2015-04-25 22:36:39 +02:00
|
|
|
/**
|
|
|
|
* @name Timer peripheral configuration
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
#define TIMER_NUMOF (1U)
|
|
|
|
#define TIMER_0_EN 1
|
2015-07-09 02:12:16 +02:00
|
|
|
|
2015-08-14 14:02:58 +02:00
|
|
|
/**
|
|
|
|
* @brief xtimer configuration
|
|
|
|
*/
|
2016-01-06 13:57:48 +01:00
|
|
|
/* timer_set_absolute() has a high margin for possible underflow if set with
|
|
|
|
* value not far in the future. To prevent this, we set high backoff values
|
|
|
|
* here.
|
|
|
|
*/
|
|
|
|
#define XTIMER_BACKOFF 200
|
|
|
|
#define XTIMER_ISR_BACKOFF 200
|
|
|
|
|
2015-04-25 22:36:39 +02:00
|
|
|
/** @} */
|
|
|
|
|
2015-12-09 09:29:47 +01:00
|
|
|
/**
|
|
|
|
* @brief UART configuration
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
#ifndef UART_NUMOF
|
|
|
|
#define UART_NUMOF (1U)
|
|
|
|
#endif
|
|
|
|
/** @} */
|
|
|
|
|
2018-10-15 23:43:52 +02:00
|
|
|
/**
|
|
|
|
* @brief PWM configuration
|
|
|
|
*/
|
|
|
|
#ifndef PWM_NUMOF
|
|
|
|
#define PWM_NUMOF (8U)
|
|
|
|
#endif
|
|
|
|
|
2018-02-23 21:49:42 +01:00
|
|
|
/**
|
|
|
|
* @brief QDEC configuration
|
|
|
|
*/
|
|
|
|
#ifndef QDEC_NUMOF
|
|
|
|
#define QDEC_NUMOF (8U)
|
|
|
|
#endif
|
|
|
|
|
2019-04-06 06:24:22 +02:00
|
|
|
/**
|
|
|
|
* @name SPI configuration (Linux host only)
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
#if !defined(SPI_NUMOF) || defined(DOXYGEN)
|
|
|
|
/**
|
|
|
|
* @brief Amount of SPI devices
|
|
|
|
*
|
|
|
|
* Allows up to SPI_NUMOF SPI devices with each having up to SPI_MAXCS hardware
|
|
|
|
* cable select lines. Assignment to hardware devices can be configured at
|
|
|
|
* runtime using the `--spi` startup parameter.
|
|
|
|
*
|
2019-10-23 21:13:53 +02:00
|
|
|
* Can be overridden during compile time with a `-DSPI_NUMOF=n` flag.
|
2019-04-06 06:24:22 +02:00
|
|
|
*/
|
|
|
|
#define SPI_NUMOF (1U)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if !defined(SPI_MAXCS) || defined(DOXYGEN)
|
|
|
|
/**
|
|
|
|
* @brief Maximum amount of chip select lines per bus
|
|
|
|
*
|
|
|
|
* Allows up to SPI_MAXCS hardware cable select lines per SPI device. The n-th
|
|
|
|
* hardware select line can be used with the SPI_HWCS macro.
|
|
|
|
*/
|
|
|
|
#define SPI_MAXCS (4U)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Hardware chip select access macro.
|
|
|
|
*
|
|
|
|
* The amount of available hardware chip select lines depends on the SPI_MAXCS
|
|
|
|
* parameter. If the line is actually available at runtime depends of whether a
|
|
|
|
* `--spi` startup parameter with the corresponding SPI device and HWCS-line
|
|
|
|
* parameter has been given.
|
|
|
|
*/
|
|
|
|
#define SPI_HWCS(x) (x)
|
|
|
|
/** @} */
|
|
|
|
|
2014-11-19 11:52:57 +01:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* PERIPH_CONF_H */
|
|
|
|
/** @} */
|