Skip to content

Commit 3c6bb1a

Browse files
committed
drivers: serial: Add gd32 uart driver
Introduce minimal serial driver support for gigadevice soc. Signed-off-by: Gerson Fernando Budke <[email protected]>
1 parent 975e92e commit 3c6bb1a

File tree

6 files changed

+159
-0
lines changed

6 files changed

+159
-0
lines changed

drivers/serial/CMakeLists.txt

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -44,6 +44,7 @@ zephyr_library_sources_ifdef(CONFIG_USB_CDC_ACM ${ZEPHYR_BASE}/misc/empty_file.c
4444
zephyr_library_sources_ifdef(CONFIG_UART_RCAR uart_rcar.c)
4545
zephyr_library_sources_ifdef(CONFIG_UART_XEC uart_mchp_xec.c)
4646
zephyr_library_sources_ifdef(CONFIG_UART_NEORV32 uart_neorv32.c)
47+
zephyr_library_sources_ifdef(CONFIG_USART_GD32 usart_gd32.c)
4748

4849
zephyr_library_sources_ifdef(CONFIG_USERSPACE uart_handlers.c)
4950

drivers/serial/Kconfig

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -165,6 +165,8 @@ source "drivers/serial/Kconfig.rcar"
165165

166166
source "drivers/serial/Kconfig.xec"
167167

168+
source "drivers/serial/Kconfig.gd32"
169+
168170
source "drivers/serial/Kconfig.test"
169171

170172
source "drivers/serial/Kconfig.neorv32"

drivers/serial/Kconfig.gd32

Lines changed: 14 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,14 @@
1+
# Copyright (c) 2021 ATL Electronics
2+
# SPDX-License-Identifier: Apache-2.0
3+
4+
# Workaround for not being able to have commas in macro arguments
5+
DT_COMPAT_GIGADEVICE_GD32_USART := gd,gd32-usart
6+
7+
config USART_GD32
8+
bool "GD32 serial driver"
9+
default $(dt_compat_enabled,$(DT_COMPAT_GIGADEVICE_GD32_USART))
10+
depends on SOC_FAMILY_GD32
11+
select SERIAL_HAS_DRIVER
12+
select USE_GD32_USART
13+
help
14+
This option enables the USART driver for GD32 SoC family.

drivers/serial/usart_gd32.c

Lines changed: 117 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,117 @@
1+
/*
2+
* Copyright (c) 2021, ATL Electronics
3+
* SPDX-License-Identifier: Apache-2.0
4+
*/
5+
6+
#define DT_DRV_COMPAT gd_gd32_usart
7+
8+
#include <drivers/uart.h>
9+
10+
struct gd32_usart_config {
11+
uint32_t reg;
12+
uint32_t rcu_periph_clock;
13+
};
14+
15+
struct gd32_usart_data {
16+
uint32_t baud_rate;
17+
};
18+
19+
static int usart_gd32_init(const struct device *dev)
20+
{
21+
const struct gd32_usart_config *const cfg = dev->config;
22+
struct gd32_usart_data *const data = dev->data;
23+
24+
/* NOTE: pins are configured at board_init till pinctrl be available */
25+
26+
rcu_periph_clock_enable(cfg->rcu_periph_clock);
27+
usart_deinit(cfg->reg);
28+
usart_baudrate_set(cfg->reg, data->baud_rate);
29+
usart_word_length_set(cfg->reg, USART_WL_8BIT);
30+
usart_parity_config(cfg->reg, USART_PM_NONE);
31+
usart_stop_bit_set(cfg->reg, USART_STB_1BIT);
32+
usart_parity_config(cfg->reg, USART_PM_NONE);
33+
usart_receive_config(cfg->reg, USART_RECEIVE_ENABLE);
34+
usart_transmit_config(cfg->reg, USART_TRANSMIT_ENABLE);
35+
usart_enable(cfg->reg);
36+
37+
return 0;
38+
}
39+
40+
static int usart_gd32_poll_in(const struct device *dev, unsigned char *c)
41+
{
42+
const struct gd32_usart_config *const cfg = dev->config;
43+
uint32_t status;
44+
45+
status = usart_flag_get(cfg->reg, USART_FLAG_RBNE);
46+
47+
if (!status) {
48+
return -EPERM;
49+
}
50+
51+
*c = usart_data_receive(cfg->reg);
52+
53+
return 0;
54+
}
55+
56+
static void usart_gd32_poll_out(const struct device *dev, unsigned char c)
57+
{
58+
const struct gd32_usart_config *const cfg = dev->config;
59+
60+
usart_data_transmit(cfg->reg, c);
61+
62+
while (usart_flag_get(cfg->reg, USART_FLAG_TBE) == RESET) {
63+
;
64+
}
65+
}
66+
67+
static int usart_gd32_err_check(const struct device *dev)
68+
{
69+
const struct gd32_usart_config *const cfg = dev->config;
70+
uint32_t status = USART_STAT0(cfg->reg);
71+
int errors = 0;
72+
73+
if (status & USART_FLAG_ORERR) {
74+
usart_flag_clear(cfg->reg, USART_FLAG_ORERR);
75+
76+
errors |= UART_ERROR_OVERRUN;
77+
}
78+
79+
if (status & USART_FLAG_PERR) {
80+
usart_flag_clear(cfg->reg, USART_FLAG_PERR);
81+
82+
errors |= UART_ERROR_PARITY;
83+
}
84+
85+
if (status & USART_FLAG_FERR) {
86+
usart_flag_clear(cfg->reg, USART_FLAG_FERR);
87+
88+
errors |= UART_ERROR_FRAMING;
89+
}
90+
91+
usart_flag_clear(cfg->reg, USART_FLAG_NERR);
92+
93+
return errors;
94+
}
95+
96+
static const struct uart_driver_api usart_gd32_driver_api = {
97+
.poll_in = usart_gd32_poll_in,
98+
.poll_out = usart_gd32_poll_out,
99+
.err_check = usart_gd32_err_check,
100+
};
101+
102+
#define GD32_USART_INIT(n) \
103+
static struct gd32_usart_data usart##n##_gd32_data = { \
104+
.baud_rate = DT_INST_PROP(n, current_speed), \
105+
}; \
106+
static const struct gd32_usart_config usart##n##_gd32_config = { \
107+
.reg = DT_INST_REG_ADDR(n), \
108+
.rcu_periph_clock = DT_INST_PROP(n, rcu_periph_clock), \
109+
}; \
110+
DEVICE_DT_INST_DEFINE(n, &usart_gd32_init, \
111+
NULL, \
112+
&usart##n##_gd32_data, \
113+
&usart##n##_gd32_config, PRE_KERNEL_1, \
114+
CONFIG_KERNEL_INIT_PRIORITY_DEVICE, \
115+
&usart_gd32_driver_api);
116+
117+
DT_INST_FOREACH_STATUS_OKAY(GD32_USART_INIT)

dts/arm/gigadevice/gd32f403.dtsi

Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -45,6 +45,14 @@
4545
label = "FLASH_0";
4646
};
4747
};
48+
49+
usart0: usart@40013800 {
50+
compatible = "gd,gd32-usart";
51+
reg = <0x40013800 0x400>;
52+
rcu-periph-clock = <0x60e>;
53+
status = "disabled";
54+
label = "usart_0";
55+
};
4856
};
4957
};
5058

Lines changed: 17 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,17 @@
1+
# Copyright (c) 2021, ATL Electronics
2+
# SPDX-License-Identifier: Apache-2.0
3+
4+
description: GigaDevice USART
5+
6+
compatible: "gd,gd32-usart"
7+
8+
include: uart-controller.yaml
9+
10+
properties:
11+
reg:
12+
required: true
13+
14+
rcu-periph-clock:
15+
type: int
16+
description: Reset Control Unit Peripheral Clock ID
17+
required: true

0 commit comments

Comments
 (0)