/* * Copyright (C) 2020 Koen Zandberg * 2023 Gunar Schorcht * * 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_gd32v * @{ * * @file * @brief Common peripheral configuration for GD32VF103 boards * * @author Koen Zandberg * @author Gunar Schorcht */ #ifndef PERIPH_COMMON_CONF_H #define PERIPH_COMMON_CONF_H #include "macros/units.h" #include "periph_cpu.h" #ifdef __cplusplus extern "C" { #endif #if defined(MODULE_USBDEV_SYNOPSYS_DWC2) || defined(MODULE_TINYUSB_DEVICE) /* If the USB OTG peripheral is used, the USB clock of 48 MHz is derived by * dividing the PLL clock by 1, 1.5, 2, or 2.5. That is the maximum core clock * frequency can be 96 MHz. */ #define CLOCK_CORECLOCK MHZ(96) /**< CPU clock frequency in Hz */ #else #define CLOCK_CORECLOCK MHZ(108) /**< CPU clock frequency in Hz */ #endif #define CLOCK_AHB CLOCK_CORECLOCK /**< Equal to the CPU clock */ #define CLOCK_APB1 CLOCK_AHB/2 /**< Half AHB clock */ #define CLOCK_APB2 CLOCK_AHB /**< Equal to the AHB clock */ /** * @name RTT/RTC configuration * @{ */ #if CONFIG_BOARD_HAS_LXTAL #define RTT_CLOCK_FREQUENCY (32768U) /**< Low frequency XTAL is used as clock source */ #else #define RTT_CLOCK_FREQUENCY (40000U) /**< IRC40K is used as clock source */ #endif #define RTT_MAX_FREQUENCY (RTT_CLOCK_FREQUENCY) /* maximum RTT frequency in Hz */ #ifndef RTT_FREQUENCY #define RTT_FREQUENCY (RTT_MAX_FREQUENCY) /* RTT frequency in Hz */ #endif /** @} */ #ifdef __cplusplus } #endif #endif /* PERIPH_COMMON_CONF_H */ /** @} */