mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
133 lines
2.7 KiB
C
133 lines
2.7 KiB
C
/**
|
|
* Native CPU peripheral configuration
|
|
*
|
|
* Copyright (C) 2014 Ludwig Knüpfer <ludwig.knuepfer@fu-berlin.de>
|
|
*
|
|
* 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 cpu_native
|
|
* @{
|
|
* @file
|
|
* @author Ludwig Knüpfer <ludwig.knuepfer@fu-berlin.de>
|
|
*/
|
|
|
|
#ifndef PERIPH_CONF_H
|
|
#define PERIPH_CONF_H
|
|
|
|
#include "macros/units.h"
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/**
|
|
* @brief System core clock in Hz
|
|
*
|
|
* 1GHz is an arbitrary value used for compatibility with other platforms.
|
|
*/
|
|
#ifndef CLOCK_CORECLOCK
|
|
#define CLOCK_CORECLOCK GHZ(1)
|
|
#endif
|
|
|
|
/**
|
|
* @name hardware timer clock skew avoidance
|
|
* @{
|
|
*/
|
|
#define NATIVE_TIMER_MIN_RES 200
|
|
/** @} */
|
|
|
|
/**
|
|
* @name Random Number Generator configuration
|
|
* @{
|
|
*/
|
|
#define RANDOM_NUMOF (1U)
|
|
/** @} */
|
|
|
|
/**
|
|
* @name Timer peripheral configuration
|
|
* @{
|
|
*/
|
|
#define TIMER_NUMOF (1U)
|
|
|
|
/**
|
|
* @brief xtimer configuration
|
|
*/
|
|
/* 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
|
|
|
|
/** @} */
|
|
|
|
/**
|
|
* @brief UART configuration
|
|
* @{
|
|
*/
|
|
#ifndef UART_NUMOF
|
|
#define UART_NUMOF (1U)
|
|
#endif
|
|
/** @} */
|
|
|
|
/**
|
|
* @brief PWM configuration
|
|
*/
|
|
#ifndef PWM_NUMOF
|
|
#define PWM_NUMOF (8U)
|
|
#endif
|
|
|
|
/**
|
|
* @brief QDEC configuration
|
|
*/
|
|
#ifndef QDEC_NUMOF
|
|
#define QDEC_NUMOF (8U)
|
|
#endif
|
|
|
|
/**
|
|
* @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.
|
|
*
|
|
* Can be overridden during compile time with a `-DSPI_NUMOF=n` flag.
|
|
*/
|
|
#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) (UINT_MAX - SPI_MAXCS + x)
|
|
/** @} */
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* PERIPH_CONF_H */
|
|
/** @} */
|