261 lines
7.2 KiB
C
261 lines
7.2 KiB
C
/*
|
|
* Copyright (C) 2022, Xiaohua Semiconductor Co., Ltd.
|
|
*
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*
|
|
* Change Logs:
|
|
* Date Author Notes
|
|
* 2022-04-28 CDT first version
|
|
*/
|
|
|
|
#include <rtdevice.h>
|
|
#include "board_config.h"
|
|
#include "tca9539.h"
|
|
|
|
/**
|
|
* The below functions will initialize HC32 board.
|
|
*/
|
|
|
|
#if defined RT_USING_SERIAL
|
|
rt_err_t rt_hw_board_uart_init(CM_USART_TypeDef *USARTx)
|
|
{
|
|
rt_err_t result = RT_EOK;
|
|
|
|
switch ((rt_uint32_t)USARTx)
|
|
{
|
|
#if defined(BSP_USING_UART1)
|
|
case (rt_uint32_t)CM_USART1:
|
|
/* Configure USART RX/TX pin. */
|
|
GPIO_SetFunc(USART1_RX_PORT, USART1_RX_PIN, GPIO_FUNC_33);
|
|
GPIO_SetFunc(USART1_TX_PORT, USART1_TX_PIN, GPIO_FUNC_32);
|
|
break;
|
|
#endif
|
|
#if defined(BSP_USING_UART6)
|
|
case (rt_uint32_t)CM_USART6:
|
|
/* Configure USART RX/TX pin. */
|
|
GPIO_SetFunc(USART6_RX_PORT, USART6_RX_PIN, GPIO_FUNC_37);
|
|
GPIO_SetFunc(USART6_TX_PORT, USART6_TX_PIN, GPIO_FUNC_36);
|
|
break;
|
|
#endif
|
|
default:
|
|
result = -RT_ERROR;
|
|
break;
|
|
}
|
|
|
|
return result;
|
|
}
|
|
#endif
|
|
|
|
#if defined(RT_USING_PWM)
|
|
rt_err_t rt_hw_board_pwm_init(CM_TMRA_TypeDef *TMRAx)
|
|
{
|
|
rt_err_t result = RT_EOK;
|
|
|
|
switch ((rt_uint32_t)TMRAx)
|
|
{
|
|
#if defined(BSP_USING_PWM1)
|
|
case (rt_uint32_t)CM_TMRA_1:
|
|
#if defined(BSP_USING_PWM1_CH1)
|
|
GPIO_SetFunc(PWM1_CH1_PORT, PWM1_CH1_PIN, PWM1_CH1_FUNC);
|
|
#endif
|
|
#if defined(BSP_USING_PWM1_CH2)
|
|
GPIO_SetFunc(PWM1_CH2_PORT, PWM1_CH2_PIN, PWM1_CH2_FUNC);
|
|
#endif
|
|
break;
|
|
#endif
|
|
default:
|
|
result = -RT_ERROR;
|
|
break;
|
|
}
|
|
|
|
return result;
|
|
}
|
|
#endif
|
|
|
|
#if defined(RT_USING_PULSE_ENCODER)
|
|
rt_err_t rt_hw_board_pulse_encoder_init(CM_TMRA_TypeDef *TMRAx)
|
|
{
|
|
rt_err_t result = RT_EOK;
|
|
|
|
switch ((rt_uint32_t)TMRAx)
|
|
{
|
|
#if defined(BSP_USING_PULSE_ENCODER9)
|
|
case (rt_uint32_t)CM_TMRA_9:
|
|
GPIO_SetFunc(PULSE_ENCODER9_CLKA_PORT, PULSE_ENCODER9_CLKA_PIN, PULSE_ENCODER9_CLKA_FUNC);
|
|
GPIO_SetFunc(PULSE_ENCODER9_CLKB_PORT, PULSE_ENCODER9_CLKB_PIN, PULSE_ENCODER9_CLKB_FUNC);
|
|
break;
|
|
#endif
|
|
default:
|
|
result = -RT_ERROR;
|
|
break;
|
|
}
|
|
|
|
return result;
|
|
}
|
|
#endif
|
|
|
|
#if defined(RT_USING_ADC)
|
|
rt_err_t rt_hw_board_adc_init(CM_ADC_TypeDef *ADCx)
|
|
{
|
|
rt_err_t result = RT_EOK;
|
|
stc_gpio_init_t stcGpioInit;
|
|
|
|
(void)GPIO_StructInit(&stcGpioInit);
|
|
stcGpioInit.u16PinAttr = PIN_ATTR_ANALOG;
|
|
switch ((rt_uint32_t)ADCx)
|
|
{
|
|
#if defined(BSP_USING_ADC1)
|
|
case (rt_uint32_t)CM_ADC1:
|
|
(void)GPIO_Init(ADC1_CH_PORT, ADC1_CH_PIN, &stcGpioInit);
|
|
break;
|
|
#endif
|
|
#if defined(BSP_USING_ADC2)
|
|
case (rt_uint32_t)CM_ADC2:
|
|
(void)GPIO_Init(ADC2_CH_PORT, ADC2_CH_PIN, &stcGpioInit);
|
|
break;
|
|
#endif
|
|
#if defined(BSP_USING_ADC3)
|
|
case (rt_uint32_t)CM_ADC3:
|
|
(void)GPIO_Init(ADC3_CH_PORT, ADC3_CH_PIN, &stcGpioInit);
|
|
break;
|
|
#endif
|
|
default:
|
|
result = -RT_ERROR;
|
|
break;
|
|
}
|
|
|
|
return result;
|
|
}
|
|
#endif
|
|
|
|
#if defined(RT_USING_CAN)
|
|
void CanPhyEnable(void)
|
|
{
|
|
TCA9539_WritePin(CAN_STB_PORT, CAN_STB_PIN, TCA9539_PIN_RESET);
|
|
TCA9539_ConfigPin(CAN_STB_PORT, CAN_STB_PIN, TCA9539_DIR_OUT);
|
|
}
|
|
rt_err_t rt_hw_board_can_init(CM_CAN_TypeDef *CANx)
|
|
{
|
|
rt_err_t result = RT_EOK;
|
|
|
|
switch ((rt_uint32_t)CANx)
|
|
{
|
|
#if defined(BSP_USING_CAN1)
|
|
case (rt_uint32_t)CM_CAN1:
|
|
GPIO_SetFunc(CAN1_TX_PORT, CAN1_TX_PIN, CAN1_TX_PIN_FUNC);
|
|
GPIO_SetFunc(CAN1_RX_PORT, CAN1_RX_PIN, CAN1_RX_PIN_FUNC);
|
|
break;
|
|
#endif
|
|
#if defined(BSP_USING_CAN2)
|
|
case (rt_uint32_t)CM_CAN2:
|
|
GPIO_SetFunc(CAN2_TX_PORT, CAN2_TX_PIN, CAN2_TX_PIN_FUNC);
|
|
GPIO_SetFunc(CAN2_RX_PORT, CAN2_RX_PIN, CAN2_RX_PIN_FUNC);
|
|
break;
|
|
#endif
|
|
default:
|
|
result = -RT_ERROR;
|
|
break;
|
|
}
|
|
|
|
return result;
|
|
}
|
|
#endif
|
|
|
|
|
|
#if defined (RT_USING_SPI)
|
|
rt_err_t rt_hw_spi_board_init(CM_SPI_TypeDef *CM_SPIx)
|
|
{
|
|
rt_err_t result = RT_EOK;
|
|
|
|
switch ((rt_uint32_t)CM_SPIx)
|
|
{
|
|
#if defined(BSP_USING_SPI1)
|
|
case (rt_uint32_t)CM_SPI1:
|
|
GPIO_SetFunc(GPIO_PORT_C, GPIO_PIN_06, GPIO_FUNC_40); /* SCK */
|
|
GPIO_SetFunc(GPIO_PORT_B, GPIO_PIN_13, GPIO_FUNC_41); /* MOSI */
|
|
GPIO_SetFunc(GPIO_PORT_B, GPIO_PIN_12, GPIO_FUNC_42); /* MISO */
|
|
break;
|
|
#endif
|
|
default:
|
|
result = -RT_ERROR;
|
|
break;
|
|
}
|
|
|
|
return result;
|
|
}
|
|
#endif
|
|
|
|
#if defined(BSP_USING_ETH)
|
|
/* PHY hardware reset time */
|
|
#define PHY_HW_RST_DELAY (0x40U)
|
|
|
|
rt_err_t rt_hw_eth_phy_reset(CM_ETH_TypeDef *CM_ETHx)
|
|
{
|
|
TCA9539_ConfigPin(TCA9539_IO_PORT1, EIO_ETH_RST, TCA9539_DIR_OUT);
|
|
TCA9539_WritePin(TCA9539_IO_PORT1, EIO_ETH_RST, TCA9539_PIN_RESET);
|
|
rt_thread_mdelay(PHY_HW_RST_DELAY);
|
|
TCA9539_WritePin(TCA9539_IO_PORT1, EIO_ETH_RST, TCA9539_PIN_SET);
|
|
rt_thread_mdelay(PHY_HW_RST_DELAY);
|
|
return RT_EOK;
|
|
}
|
|
|
|
rt_err_t rt_hw_eth_board_init(CM_ETH_TypeDef *CM_ETHx)
|
|
{
|
|
#if defined(ETH_USING_INTERFACE_RMII)
|
|
/*
|
|
ETH_SMI_MDIO ----------------> PA2
|
|
ETH_SMI_MDC -----------------> PC1
|
|
ETH_RMII_TX_EN --------------> PG11
|
|
ETH_RMII_TXD0 ---------------> PG13
|
|
ETH_RMII_TXD1 ---------------> PG14
|
|
ETH_RMII_REF_CLK ------------> PA1
|
|
ETH_RMII_CRS_DV -------------> PA7
|
|
ETH_RMII_RXD0 ---------------> PC4
|
|
ETH_RMII_RXD1 ---------------> PC5
|
|
ETH_RMII_RX_ER --------------> PI10
|
|
*/
|
|
/* Configure PA1, PA2 and PA7 */
|
|
GPIO_SetFunc(GPIO_PORT_A, (GPIO_PIN_01 | GPIO_PIN_02 | GPIO_PIN_07), GPIO_FUNC_11);
|
|
/* Configure PC1, PC4 and PC5 */
|
|
GPIO_SetFunc(GPIO_PORT_C, (GPIO_PIN_01 | GPIO_PIN_04 | GPIO_PIN_05), GPIO_FUNC_11);
|
|
/* Configure PG11, PG13 and PG14 */
|
|
GPIO_SetFunc(GPIO_PORT_G, (GPIO_PIN_11 | GPIO_PIN_13 | GPIO_PIN_14), GPIO_FUNC_11);
|
|
/* Configure PI10 */
|
|
GPIO_SetFunc(GPIO_PORT_I, GPIO_PIN_10, GPIO_FUNC_11);
|
|
#else
|
|
/*
|
|
ETH_SMI_MDIO ----------------> PA2
|
|
ETH_SMI_MDC -----------------> PC1
|
|
ETH_MII_TX_CLK --------------> PB6
|
|
ETH_MII_TX_EN ---------------> PG11
|
|
ETH_MII_TXD0 ----------------> PG13
|
|
ETH_MII_TXD1 ----------------> PG14
|
|
ETH_MII_TXD2 ----------------> PB9
|
|
ETH_MII_TXD3 ----------------> PB8
|
|
ETH_MII_RX_CLK --------------> PA1
|
|
ETH_MII_RX_DV ---------------> PA7
|
|
ETH_MII_RXD0 ----------------> PC4
|
|
ETH_MII_RXD1 ----------------> PC5
|
|
ETH_MII_RXD2 ----------------> PB0
|
|
ETH_MII_RXD3 ----------------> PB1
|
|
ETH_MII_RX_ER ---------------> PI10
|
|
ETH_MII_CRS -----------------> PH2
|
|
ETH_MII_COL -----------------> PH3
|
|
*/
|
|
/* Configure PA1, PA2 and PA7 */
|
|
GPIO_SetFunc(GPIO_PORT_A, (GPIO_PIN_01 | GPIO_PIN_02 | GPIO_PIN_07), GPIO_FUNC_11);
|
|
/* Configure PB0, PB1, PB6, PB8 and PB9 */
|
|
GPIO_SetFunc(GPIO_PORT_B, (GPIO_PIN_00 | GPIO_PIN_01 | GPIO_PIN_06 | GPIO_PIN_08 | GPIO_PIN_09), GPIO_FUNC_11);
|
|
/* Configure PC1, PC4 and PC5 */
|
|
GPIO_SetFunc(GPIO_PORT_C, (GPIO_PIN_01 | GPIO_PIN_04 | GPIO_PIN_05), GPIO_FUNC_11);
|
|
/* Configure PG11, PG13 and PG14 */
|
|
GPIO_SetFunc(GPIO_PORT_G, (GPIO_PIN_11 | GPIO_PIN_13 | GPIO_PIN_14), GPIO_FUNC_11);
|
|
/* Configure PH2, PH3 */
|
|
GPIO_SetFunc(GPIO_PORT_H, (GPIO_PIN_02 | GPIO_PIN_03), GPIO_FUNC_11);
|
|
/* Configure PI10 */
|
|
GPIO_SetFunc(GPIO_PORT_I, GPIO_PIN_10, GPIO_FUNC_11);
|
|
#endif
|
|
return RT_EOK;
|
|
}
|
|
#endif
|