未验证 提交 575abd58 编写于 作者: 杭州_燕十三's avatar 杭州_燕十三 提交者: GitHub

[bsp]add bl808 uart2 driver && add bl60x/bl70x bsp to ci-action (#7097)

* update bl_mcu_sdk SConscript && add bl808 uart2 driver

* add bl60x/bl70x bsp to ci-action
上级 1dc8e506
......@@ -246,6 +246,8 @@ jobs:
- {RTT_BSP: "microchip/samc21", RTT_TOOL_CHAIN: "sourcery-arm"}
- {RTT_BSP: "microchip/same54", RTT_TOOL_CHAIN: "sourcery-arm"}
- {RTT_BSP: "microchip/same70", RTT_TOOL_CHAIN: "sourcery-arm"}
- {RTT_BSP: "bouffalo_lab/bl60x", RTT_TOOL_CHAIN: "sourcery-riscv64-unknown-elf"}
- {RTT_BSP: "bouffalo_lab/bl70x", RTT_TOOL_CHAIN: "sourcery-riscv64-unknown-elf"}
steps:
- uses: actions/checkout@v3
- name: Set up Python
......
......@@ -4,6 +4,6 @@ cwd = GetCurrentDir()
src = Glob('*.c') + Glob('*.cpp') + Glob('*.S')
CPPPATH = [cwd]
group = DefineGroup('Applications', src, depend = [''], CPPPATH = CPPPATH)
group = DefineGroup('Board', src, depend = [''], CPPPATH = CPPPATH)
Return('group')
......@@ -4,6 +4,6 @@ cwd = GetCurrentDir()
src = Glob('*.c') + Glob('*.cpp') + Glob('*.S')
CPPPATH = [cwd]
group = DefineGroup('Applications', src, depend = [''], CPPPATH = CPPPATH)
group = DefineGroup('Board', src, depend = [''], CPPPATH = CPPPATH)
Return('group')
......@@ -4,6 +4,6 @@ cwd = GetCurrentDir()
src = Glob('*.c') + Glob('*.cpp') + Glob('*.S')
CPPPATH = [cwd]
group = DefineGroup('Applications', src, depend = [''], CPPPATH = CPPPATH)
group = DefineGroup('Board', src, depend = [''], CPPPATH = CPPPATH)
Return('group')
......@@ -4,6 +4,6 @@ cwd = GetCurrentDir()
src = Glob('*.c') + Glob('*.cpp') + Glob('*.S')
CPPPATH = [cwd]
group = DefineGroup('Applications', src, depend = [''], CPPPATH = CPPPATH)
group = DefineGroup('Board', src, depend = [''], CPPPATH = CPPPATH)
Return('group')
......@@ -4,6 +4,6 @@ cwd = GetCurrentDir()
src = Glob('*.c') + Glob('*.cpp') + Glob('*.S')
CPPPATH = [cwd]
group = DefineGroup('Applications', src, depend = [''], CPPPATH = CPPPATH)
group = DefineGroup('Board', src, depend = [''], CPPPATH = CPPPATH)
Return('group')
......@@ -175,16 +175,6 @@ void rt_hw_board_init(void)
}
#endif
/* GPIO driver initialization is open by default */
#ifdef BSP_USING_PIN
rt_hw_pin_init();
#endif
/* I2C driver initialization is open by default */
#ifdef BSP_USING_I2C
rt_hw_i2c_init();
#endif
/* Set the shell console output device */
#if defined(RT_USING_CONSOLE) && defined(RT_USING_DEVICE)
rt_console_set_device(RT_CONSOLE_DEVICE_NAME);
......
......@@ -4,7 +4,8 @@ from building import *
cwd = GetCurrentDir()
CPPPATH = [cwd + r'/include',
CPPPATH = [cwd,
cwd + r'/include',
cwd + r'/include/arch',
cwd + r'/include/arch/risc-v/t-head',
cwd + r'/include/arch/risc-v/t-head/Core/Include',
......
#include "bflb_ef_ctrl.h"
#include "hardware/ef_ctrl_reg.h"
#include "include/hardware/ef_ctrl_reg.h"
#if defined(BL602) || defined(BL702) || defined(BL702L)
#define BFLB_EF_CTRL_BASE ((uint32_t)0x40007000)
......
......@@ -25,7 +25,7 @@
#include "bflb_xip_sflash.h"
#include "bflb_sf_cfg.h"
#include "bflb_flash.h"
#include "hardware/sf_ctrl_reg.h"
#include "include/hardware/sf_ctrl_reg.h"
#if defined(BL616)
static uint32_t flash1_size = 4 * 1024 * 1024;
......
......@@ -35,7 +35,7 @@
*/
#include "bflb_sf_ctrl.h"
#include "hardware/sf_ctrl_reg.h"
#include "include/hardware/sf_ctrl_reg.h"
#if defined(BL602) || defined(BL702) || defined(BL702L)
#include <risc-v/e24/clic.h>
#else
......
......@@ -83,6 +83,42 @@ menu "General Drivers Configuration"
endchoice
endif
if BSP_USING_BL808
menuconfig BSP_USING_UART2
bool "Enable UART2"
default n
if BSP_USING_UART2
choice
prompt "UART2 TX PIN"
default UART2_TX_USING_GPIO20
config UART2_TX_USING_GPIO4
bool "GPIO_4"
config UART2_TX_USING_GPIO16
bool "GPIO_16"
config UART2_TX_USING_GPIO18
bool "GPIO_18"
config UART2_TX_USING_GPIO20
bool "GPIO_20"
endchoice
choice
prompt "UART2 RX PIN"
default UART2_RX_USING_GPIO21
config UART2_RX_USING_GPIO3
bool "GPIO_3"
config UART2_RX_USING_GPIO5
bool "GPIO_5"
config UART2_RX_USING_GPIO17
bool "GPIO_17"
config UART2_RX_USING_GPIO19
bool "GPIO_19"
config UART2_RX_USING_GPIO21
bool "GPIO_21"
endchoice
endif
endif
endmenu
endmenu
......
......@@ -63,7 +63,28 @@
#define UART1_GPIO_RX GPIO_PIN_27
#endif
static struct bflb_device_s *gpio;
// uart2
#ifdef UART2_TX_USING_GPIO4
#define UART2_GPIO_TX GPIO_PIN_4
#elif defined(UART2_TX_USING_GPIO16)
#define UART2_GPIO_TX GPIO_PIN_16
#elif defined(UART2_TX_USING_GPIO18)
#define UART2_GPIO_TX GPIO_PIN_18
#elif defined(UART2_TX_USING_GPIO20)
#define UART2_GPIO_TX GPIO_PIN_20
#endif
#ifdef UART2_RX_USING_GPIO3
#define UART2_GPIO_RX GPIO_PIN_3
#elif defined(UART2_RX_USING_GPIO5)
#define UART2_GPIO_RX GPIO_PIN_5
#elif defined(UART2_RX_USING_GPIO17)
#define UART2_GPIO_RX GPIO_PIN_17
#elif defined(UART2_RX_USING_GPIO19)
#define UART2_GPIO_RX GPIO_PIN_19
#elif defined(UART2_RX_USING_GPIO21)
#define UART2_GPIO_RX GPIO_PIN_21
#endif
struct device_uart
{
......@@ -250,6 +271,7 @@ static const struct rt_uart_ops _uart_ops =
int rt_hw_uart_init(void)
{
rt_err_t result = 0;
struct bflb_device_s *gpio;
struct serial_configure config = RT_SERIAL_CONFIG_DEFAULT;
struct rt_serial_device *serial;
......@@ -301,5 +323,27 @@ int rt_hw_uart_init(void)
uart);
RT_ASSERT(result == RT_EOK);
#endif
#ifdef BSP_USING_UART2
static struct device_uart bl_uart2;
serial = &bl_uart2.serial;
uart = &bl_uart2;
serial->ops = &_uart_ops;
serial->config = config;
serial->config.baud_rate = UART_DEFAULT_BAUDRATE;
uart->bflb_device = bflb_device_get_by_name("uart2");
bflb_gpio_uart_init(gpio, UART2_GPIO_TX, GPIO_UART_FUNC_UART2_TX);
bflb_gpio_uart_init(gpio, UART2_GPIO_RX, GPIO_UART_FUNC_UART2_RX);
/* register USART device */
result = rt_hw_serial_register(serial,
"uart2",
RT_DEVICE_FLAG_RDWR | RT_DEVICE_FLAG_INT_RX,
uart);
RT_ASSERT(result == RT_EOK);
#endif
return 0;
}
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册