211 lines
11 KiB
C
211 lines
11 KiB
C
/**
|
|
*******************************************************************************
|
|
* @file template/source/hc32f4xx_conf.h
|
|
* @brief This file contains HC32 Series Device Driver Library usage management.
|
|
@verbatim
|
|
Change Logs:
|
|
Date Author Notes
|
|
2022-04-28 CDT First version
|
|
@endverbatim
|
|
*******************************************************************************
|
|
* Copyright (C) 2022, Xiaohua Semiconductor Co., Ltd. All rights reserved.
|
|
*
|
|
* This software component is licensed by XHSC under BSD 3-Clause license
|
|
* (the "License"); You may not use this file except in compliance with the
|
|
* License. You may obtain a copy of the License at:
|
|
* opensource.org/licenses/BSD-3-Clause
|
|
*
|
|
*******************************************************************************
|
|
*/
|
|
#ifndef __HC32F4XX_CONF_H__
|
|
#define __HC32F4XX_CONF_H__
|
|
|
|
/*******************************************************************************
|
|
* Include files
|
|
******************************************************************************/
|
|
|
|
/* C binding of definitions if building with C++ compiler */
|
|
#ifdef __cplusplus
|
|
extern "C"
|
|
{
|
|
#endif
|
|
|
|
/*******************************************************************************
|
|
* Global type definitions ('typedef')
|
|
******************************************************************************/
|
|
|
|
/*******************************************************************************
|
|
* Global pre-processor symbols/macros ('#define')
|
|
******************************************************************************/
|
|
|
|
/**
|
|
* @brief This is the list of modules to be used in the Device Driver Library.
|
|
* Select the modules you need to use to DDL_ON.
|
|
* @note LL_ICG_ENABLE must be turned on(DDL_ON) to ensure that the chip works
|
|
* properly.
|
|
* @note LL_UTILITY_ENABLE must be turned on(DDL_ON) if using Device Driver
|
|
* Library.
|
|
* @note LL_PRINT_ENABLE must be turned on(DDL_ON) if using printf function.
|
|
*/
|
|
#define LL_ICG_ENABLE (DDL_ON)
|
|
#define LL_UTILITY_ENABLE (DDL_ON)
|
|
#define LL_PRINT_ENABLE (DDL_OFF)
|
|
|
|
#define LL_ADC_ENABLE (DDL_ON)
|
|
#define LL_AES_ENABLE (DDL_ON)
|
|
#define LL_AOS_ENABLE (DDL_ON)
|
|
#define LL_CAN_ENABLE (DDL_ON)
|
|
#define LL_CLK_ENABLE (DDL_ON)
|
|
#define LL_CMP_ENABLE (DDL_ON)
|
|
#define LL_CRC_ENABLE (DDL_ON)
|
|
#define LL_CTC_ENABLE (DDL_ON)
|
|
#define LL_DAC_ENABLE (DDL_ON)
|
|
#define LL_DCU_ENABLE (DDL_ON)
|
|
#define LL_DMA_ENABLE (DDL_ON)
|
|
#define LL_DMC_ENABLE (DDL_ON)
|
|
#define LL_DVP_ENABLE (DDL_ON)
|
|
#define LL_EFM_ENABLE (DDL_ON)
|
|
#define LL_EMB_ENABLE (DDL_ON)
|
|
#define LL_ETH_ENABLE (DDL_ON)
|
|
#define LL_EVENT_PORT_ENABLE (DDL_OFF)
|
|
#define LL_FCG_ENABLE (DDL_ON)
|
|
#define LL_FCM_ENABLE (DDL_ON)
|
|
#define LL_FMAC_ENABLE (DDL_ON)
|
|
#define LL_GPIO_ENABLE (DDL_ON)
|
|
#define LL_HASH_ENABLE (DDL_ON)
|
|
#define LL_HRPWM_ENABLE (DDL_ON)
|
|
#define LL_I2C_ENABLE (DDL_ON)
|
|
#define LL_I2S_ENABLE (DDL_ON)
|
|
#define LL_INTERRUPTS_ENABLE (DDL_ON)
|
|
#define LL_INTERRUPTS_SHARE_ENABLE (DDL_ON)
|
|
#define LL_KEYSCAN_ENABLE (DDL_ON)
|
|
#define LL_MAU_ENABLE (DDL_ON)
|
|
#define LL_MDIO_ENABLE (DDL_OFF)
|
|
#define LL_MPU_ENABLE (DDL_ON)
|
|
#define LL_NFC_ENABLE (DDL_ON)
|
|
#define LL_OTS_ENABLE (DDL_ON)
|
|
#define LL_PLA_ENABLE (DDL_OFF)
|
|
#define LL_PWC_ENABLE (DDL_ON)
|
|
#define LL_QSPI_ENABLE (DDL_ON)
|
|
#define LL_RMU_ENABLE (DDL_ON)
|
|
#define LL_RTC_ENABLE (DDL_ON)
|
|
#define LL_SDIOC_ENABLE (DDL_ON)
|
|
#define LL_SMC_ENABLE (DDL_ON)
|
|
#define LL_SPI_ENABLE (DDL_ON)
|
|
#define LL_SRAM_ENABLE (DDL_ON)
|
|
#define LL_SWDT_ENABLE (DDL_ON)
|
|
#define LL_TMR0_ENABLE (DDL_ON)
|
|
#define LL_TMR2_ENABLE (DDL_ON)
|
|
#define LL_TMR4_ENABLE (DDL_ON)
|
|
#define LL_TMR6_ENABLE (DDL_ON)
|
|
#define LL_TMRA_ENABLE (DDL_ON)
|
|
#define LL_TRNG_ENABLE (DDL_ON)
|
|
#define LL_USART_ENABLE (DDL_ON)
|
|
#define LL_USB_ENABLE (DDL_OFF)
|
|
#define LL_VREF_ENABLE (DDL_OFF)
|
|
#define LL_WDT_ENABLE (DDL_ON)
|
|
|
|
/**
|
|
* @brief The following is a list of currently supported BSP boards.
|
|
*/
|
|
#define BSP_EV_HC32F4A0_LQFP176 (1U)
|
|
#define BSP_EV_HC32F4A0_LQFP176_MEM (2U)
|
|
#define BSP_EV_HC32F460_LQFP100_V1 (3U)
|
|
#define BSP_EV_HC32F460_LQFP100_V2 (4U)
|
|
#define BSP_EV_HC32F451_LQFP100 (5U)
|
|
#define BSP_EV_HC32F452_LQFP100 (6U)
|
|
#define BSP_EV_HC32F472_LQFP100 (7U)
|
|
#define BSP_SK_HC32F4A0_LQFP100 (8U)
|
|
|
|
/**
|
|
* @brief The macro BSP_EV_HC32F4XX is used to specify the BSP board currently
|
|
* in use.
|
|
* The value should be set to one of the list of currently supported BSP boards.
|
|
* @note If there is no supported BSP board or the BSP function is not used,
|
|
* the value needs to be set to 0U.
|
|
*/
|
|
#define BSP_EV_HC32F4XX (BSP_EV_HC32F4A0_LQFP176)
|
|
|
|
/**
|
|
* @brief This is the list of BSP components to be used.
|
|
* Select the components you need to use to DDL_ON.
|
|
*/
|
|
#define BSP_24CXX_ENABLE (DDL_OFF)
|
|
#define BSP_CY62167EV30LL_ENABLE (DDL_OFF)
|
|
#define BSP_IS42S16400J7TLI_ENABLE (DDL_OFF)
|
|
#define BSP_IS62WV51216_ENABLE (DDL_OFF)
|
|
#define BSP_MT29F2G08AB_ENABLE (DDL_OFF)
|
|
#define BSP_NT35510_ENABLE (DDL_OFF)
|
|
#define BSP_OV5640_ENABLE (DDL_OFF)
|
|
#define BSP_S29GL064N90TFI03_ENABLE (DDL_OFF)
|
|
#define BSP_TCA9539_ENABLE (DDL_OFF)
|
|
#define BSP_W25QXX_ENABLE (DDL_OFF)
|
|
#define BSP_WM8731_ENABLE (DDL_OFF)
|
|
|
|
/**
|
|
* @brief Ethernet and PHY Configuration.
|
|
*/
|
|
/* MAC ADDRESS */
|
|
#define ETH_MAC_ADDR0 (0x02U)
|
|
#define ETH_MAC_ADDR1 (0x00U)
|
|
#define ETH_MAC_ADDR2 (0x00U)
|
|
#define ETH_MAC_ADDR3 (0x00U)
|
|
#define ETH_MAC_ADDR4 (0x00U)
|
|
#define ETH_MAC_ADDR5 (0x00U)
|
|
|
|
/* PHY(RTL8201F) Address*/
|
|
#define ETH_PHY_ADDR (0x00U)
|
|
|
|
/* PHY Configuration delay(ms) */
|
|
#define ETH_PHY_RST_DELAY (0x0080UL)
|
|
#define ETH_PHY_CONFIG_DELAY (0x0040UL)
|
|
#define ETH_PHY_RD_TIMEOUT (0x0005UL)
|
|
#define ETH_PHY_WR_TIMEOUT (0x0005UL)
|
|
|
|
/* Common PHY Registers */
|
|
#define PHY_BCR (0x00U) /*!< Basic Control Register */
|
|
#define PHY_BSR (0x01U) /*!< Basic Status Register */
|
|
|
|
#define PHY_SOFT_RESET (0x8000U) /*!< PHY Soft Reset */
|
|
#define PHY_LOOPBACK (0x4000U) /*!< Select loop-back mode */
|
|
#define PHY_FULLDUPLEX_100M (0x2100U) /*!< SET the full-duplex mode at 100 Mb/s */
|
|
#define PHY_HALFDUPLEX_100M (0x2000U) /*!< SET the half-duplex mode at 100 Mb/s */
|
|
#define PHY_FULLDUPLEX_10M (0x0100U) /*!< SET the full-duplex mode at 10 Mb/s */
|
|
#define PHY_HALFDUPLEX_10M (0x0000U) /*!< SET the half-duplex mode at 10 Mb/s */
|
|
#define PHY_AUTONEGOTIATION (0x1000U) /*!< Enable auto-negotiation function */
|
|
#define PHY_POWERDOWN (0x0800U) /*!< Select the power down mode */
|
|
#define PHY_ISOLATE (0x0400U) /*!< Isolate PHY from MII */
|
|
#define PHY_RESTART_AUTONEGOTIATION (0x0200U) /*!< Restart auto-negotiation function */
|
|
|
|
#define PHY_100BASE_TX_FD (0x4000U) /*!< 100Base-TX full duplex support */
|
|
#define PHY_100BASE_TX_HD (0x2000U) /*!< 100Base-TX half duplex support */
|
|
#define PHY_10BASE_T_FD (0x1000U) /*!< 10Base-T full duplex support */
|
|
#define PHY_10BASE_T_HD (0x0800U) /*!< 10Base-T half duplex support */
|
|
#define PHY_AUTONEGO_COMPLETE (0x0020U) /*!< Auto-Negotiation process completed */
|
|
#define PHY_LINK_STATUS (0x0004U) /*!< Valid link established */
|
|
#define PHY_JABBER_DETECTION (0x0002U) /*!< Jabber condition detected */
|
|
|
|
/**
|
|
* @brief The macro is used to re-define main function in system_device.c(eg. device=hc32f4a0).
|
|
* @note Set value to non-zero if re-define main function.
|
|
*/
|
|
#define RE_DEFINE_MAIN (0)
|
|
|
|
/*******************************************************************************
|
|
* Global variable definitions ('extern')
|
|
******************************************************************************/
|
|
|
|
/*******************************************************************************
|
|
* Global function prototypes (definition in C source)
|
|
******************************************************************************/
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* __HC32F4XX_CONF_H__ */
|
|
|
|
/*******************************************************************************
|
|
* EOF (not truncated)
|
|
******************************************************************************/
|