Use nuclei-sdk functions for init code
Instead of using the HAL functions we can just use the defines from the board support for the longan nano that comes with the nuclei-sdk. Also we move some includes and defines to the header file.
This commit is contained in:
		| @@ -37,38 +37,21 @@ void USBFS_IRQHandler(void) { tud_int_handler(0); } | |||||||
| // MACRO TYPEDEF CONSTANT ENUM | // MACRO TYPEDEF CONSTANT ENUM | ||||||
| //--------------------------------------------------------------------+ | //--------------------------------------------------------------------+ | ||||||
|  |  | ||||||
| #define HXTAL_VALUE \ |  | ||||||
|   ((uint32_t)8000000) /*!< value of the external oscillator in Hz */ |  | ||||||
| #define USB_NO_VBUS_PIN | #define USB_NO_VBUS_PIN | ||||||
|  |  | ||||||
| //--------------------------------------------------------------------+ | #define BUTTON_PORT         GPIOA | ||||||
| // LED | #define BUTTON_PIN          GPIO_PIN_0 | ||||||
| //--------------------------------------------------------------------+ |  | ||||||
|  |  | ||||||
| #define LED_PORT GPIOC |  | ||||||
| #define LED_PIN GPIO_PIN_13 |  | ||||||
| #define LED_STATE_ON 1 |  | ||||||
|  |  | ||||||
| #define BUTTON_PORT GPIOA |  | ||||||
| #define BUTTON_PIN GPIO_PIN_0 |  | ||||||
| #define BUTTON_STATE_ACTIVE 1 | #define BUTTON_STATE_ACTIVE 1 | ||||||
|  |  | ||||||
| //--------------------------------------------------------------------+ | #define UART_DEV            SOC_DEBUG_UART | ||||||
| // UART |  | ||||||
| //--------------------------------------------------------------------+ |  | ||||||
|  |  | ||||||
| #define UART_DEV USART0 | #define LED_PIN             LED_R | ||||||
| #define UART_GPIO_PORT GPIOA |  | ||||||
| #define UART_TX_PIN GPIO_PIN_9 |  | ||||||
| #define UART_RX_PIN GPIO_PIN_10 |  | ||||||
|  |  | ||||||
| void board_init(void) { | void board_init(void) { | ||||||
|   /* Disable interrupts during init */ |   /* Disable interrupts during init */ | ||||||
|   __disable_irq(); |   __disable_irq(); | ||||||
|  |  | ||||||
|   /* Reset eclic configuration registers */ |   ECLIC_Init(); | ||||||
|   ECLIC->CFG = 0; |  | ||||||
|   ECLIC->MTH = 0; |  | ||||||
|  |  | ||||||
|   /* Reset eclic interrupt registers */ |   /* Reset eclic interrupt registers */ | ||||||
|   for (int32_t i = 0; i < SOC_INT_MAX; i++) { |   for (int32_t i = 0; i < SOC_INT_MAX; i++) { | ||||||
| @@ -103,37 +86,11 @@ void board_init(void) { | |||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #ifdef LED_PIN | #ifdef LED_PIN | ||||||
|   gpio_init(LED_PORT, GPIO_MODE_OUT_PP, GPIO_OSPEED_50MHZ, LED_PIN); |   gd_led_init(LED_PIN); | ||||||
|   board_led_write(0); |  | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #if defined(UART_DEV) | #if defined(UART_DEV) | ||||||
|   /* enable GPIO TX and RX clock */ |   gd_com_init(UART_DEV); | ||||||
|   rcu_periph_clock_enable(GD32_COM_TX_GPIO_CLK); |  | ||||||
|   rcu_periph_clock_enable(GD32_COM_RX_GPIO_CLK); |  | ||||||
|  |  | ||||||
|   /* enable USART clock */ |  | ||||||
|   rcu_periph_clock_enable(GD32_COM_CLK); |  | ||||||
|  |  | ||||||
|   /* connect port to USARTx_Tx */ |  | ||||||
|   gpio_init(GD32_COM_TX_GPIO_PORT, GPIO_MODE_AF_PP, GPIO_OSPEED_50MHZ, |  | ||||||
|             GD32_COM_TX_PIN); |  | ||||||
|  |  | ||||||
|   /* connect port to USARTx_Rx */ |  | ||||||
|   gpio_init(GD32_COM_RX_GPIO_PORT, GPIO_MODE_IN_FLOATING, GPIO_OSPEED_50MHZ, |  | ||||||
|             GD32_COM_RX_PIN); |  | ||||||
|  |  | ||||||
|   /* USART configure */ |  | ||||||
|   usart_deinit(UART_DEV); |  | ||||||
|   usart_baudrate_set(UART_DEV, 115200U); |  | ||||||
|   usart_word_length_set(UART_DEV, USART_WL_8BIT); |  | ||||||
|   usart_stop_bit_set(UART_DEV, USART_STB_1BIT); |  | ||||||
|   usart_parity_config(UART_DEV, USART_PM_NONE); |  | ||||||
|   usart_hardware_flow_rts_config(UART_DEV, USART_RTS_DISABLE); |  | ||||||
|   usart_hardware_flow_cts_config(UART_DEV, USART_CTS_DISABLE); |  | ||||||
|   usart_receive_config(UART_DEV, USART_RECEIVE_ENABLE); |  | ||||||
|   usart_transmit_config(UART_DEV, USART_TRANSMIT_ENABLE); |  | ||||||
|   usart_enable(UART_DEV); |  | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|   /* USB D+ and D- pins don't need to be configured. */ |   /* USB D+ and D- pins don't need to be configured. */ | ||||||
| @@ -153,7 +110,7 @@ void board_init(void) { | |||||||
|   rcu_periph_reset_disable(RCU_USBFSRST); |   rcu_periph_reset_disable(RCU_USBFSRST); | ||||||
|  |  | ||||||
|   /* Set IRQ priority and trigger */ |   /* Set IRQ priority and trigger */ | ||||||
|   ECLIC_SetLevelIRQ(USBFS_IRQn, 15); |   ECLIC_SetLevelIRQ(USBFS_IRQn, 3); | ||||||
|   ECLIC_SetTrigIRQ(USBFS_IRQn, ECLIC_POSTIVE_EDGE_TRIGGER); |   ECLIC_SetTrigIRQ(USBFS_IRQn, ECLIC_POSTIVE_EDGE_TRIGGER); | ||||||
|  |  | ||||||
|   /* Retrieve otg core registers */ |   /* Retrieve otg core registers */ | ||||||
| @@ -172,14 +129,6 @@ void board_init(void) { | |||||||
|   __enable_irq(); |   __enable_irq(); | ||||||
| } | } | ||||||
|  |  | ||||||
| #include "gd32vf103_dbg.h" |  | ||||||
|  |  | ||||||
| #define DBG_KEY_UNLOCK 0x4B5A6978 |  | ||||||
| #define DBG_CMD_RESET 0x1 |  | ||||||
|  |  | ||||||
| #define DBG_KEY REG32(DBG + 0x0C) |  | ||||||
| #define DBG_CMD REG32(DBG + 0x08) |  | ||||||
|  |  | ||||||
| void gd32vf103_reset(void) { | void gd32vf103_reset(void) { | ||||||
|   /* The MTIMER unit of the GD32VF103 doesn't have the MSFRST |   /* The MTIMER unit of the GD32VF103 doesn't have the MSFRST | ||||||
|    * register to generate a software reset request. |    * register to generate a software reset request. | ||||||
| @@ -196,7 +145,11 @@ void gd32vf103_reset(void) { | |||||||
| //--------------------------------------------------------------------+ | //--------------------------------------------------------------------+ | ||||||
|  |  | ||||||
| void board_led_write(bool state) { | void board_led_write(bool state) { | ||||||
|   gpio_bit_write(LED_PORT, LED_PIN, state ? LED_STATE_ON : (1 - LED_STATE_ON)); |   if (state) { | ||||||
|  |     gd_led_on(LED_PIN); | ||||||
|  |   } else { | ||||||
|  |     gd_led_off(LED_PIN); | ||||||
|  |   } | ||||||
| } | } | ||||||
|  |  | ||||||
| uint32_t board_button_read(void) { | uint32_t board_button_read(void) { | ||||||
|   | |||||||
| @@ -1,29 +1,19 @@ | |||||||
| // See LICENSE for license details. |  | ||||||
| #ifndef _NUCLEI_SDK_HAL_H | #ifndef _NUCLEI_SDK_HAL_H | ||||||
| #define _NUCLEI_SDK_HAL_H | #define _NUCLEI_SDK_HAL_H | ||||||
|  |  | ||||||
| #include "nmsis_gcc.h" | #include "gd32vf103c_longan_nano.h" | ||||||
| #include "gd32vf103.h" |  | ||||||
| #include "gd32vf103_libopt.h" |  | ||||||
| #include "drv_usb_hw.h" | #include "drv_usb_hw.h" | ||||||
| #include "drv_usb_dev.h" | #include "drv_usb_dev.h" | ||||||
|  |  | ||||||
| #ifdef __cplusplus | // 4 bits for interrupt level, 0 for priority. | ||||||
| extern "C" { | // level 0 = lowest priority, level 15 = highest priority. | ||||||
| #endif | #define __ECLIC_INTCTLBITS 4 | ||||||
|  |  | ||||||
| /* sipeed longan nano board UART com port */ | #define SOC_DEBUG_UART GD32_COM0 | ||||||
| #define SOC_DEBUG_UART      USART0 |  | ||||||
| #define GD32_COM0 USART0 | #define DBG_KEY_UNLOCK 0x4B5A6978 | ||||||
| #define GD32_COM_CLK RCU_USART0 | #define DBG_CMD_RESET  0x1 | ||||||
| #define GD32_COM_TX_PIN GPIO_PIN_9 | #define DBG_KEY        REG32(DBG + 0x0C) | ||||||
| #define GD32_COM_RX_PIN GPIO_PIN_10 | #define DBG_CMD        REG32(DBG + 0x08) | ||||||
| #define GD32_COM_TX_GPIO_PORT GPIOA |  | ||||||
| #define GD32_COM_RX_GPIO_PORT GPIOA |  | ||||||
| #define GD32_COM_TX_GPIO_CLK RCU_GPIOA |  | ||||||
| #define GD32_COM_RX_GPIO_CLK RCU_GPIOA |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus |  | ||||||
| } |  | ||||||
| #endif |  | ||||||
| #endif | #endif | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Stefan Kerkmann
					Stefan Kerkmann