summaryrefslogtreecommitdiffstats
path: root/bsps/riscv/griscv
diff options
context:
space:
mode:
authorSebastian Huber <sebastian.huber@embedded-brains.de>2023-06-15 13:24:28 +0200
committerSebastian Huber <sebastian.huber@embedded-brains.de>2023-07-14 12:21:33 +0200
commit8fdecf6c5589493d3559a79cdd9b752c9065f140 (patch)
tree3d9735c3f9a7e0498ddbdf99d70f7c491c69b269 /bsps/riscv/griscv
parentbsps/grlib: Use GRLIB definition of GRSPWROUTER (diff)
downloadrtems-8fdecf6c5589493d3559a79cdd9b752c9065f140.tar.bz2
bsps: Use new APBUART register block API
Diffstat (limited to 'bsps/riscv/griscv')
-rw-r--r--bsps/riscv/griscv/console/console.c2
-rw-r--r--bsps/riscv/griscv/console/printk_support.c23
2 files changed, 17 insertions, 8 deletions
diff --git a/bsps/riscv/griscv/console/console.c b/bsps/riscv/griscv/console/console.c
index af4c19d4cb..0627be5ee3 100644
--- a/bsps/riscv/griscv/console/console.c
+++ b/bsps/riscv/griscv/console/console.c
@@ -82,7 +82,7 @@ static int find_matching_apbuart(struct ambapp_dev *dev, int index, void *arg)
struct ambapp_apb_info *apb = (struct ambapp_apb_info *)dev->devinfo;
/* Extract needed information of one APBUART */
- apbuarts[uarts].regs = (struct apbuart_regs *)apb->start;
+ apbuarts[uarts].regs = (apbuart *)apb->start;
apbuarts[uarts].irq = apb->common.irq;
/* Get APBUART core frequency, it is assumed that it is the same
* as Bus frequency where the UART is situated
diff --git a/bsps/riscv/griscv/console/printk_support.c b/bsps/riscv/griscv/console/printk_support.c
index 3a3450551f..f3af16be4d 100644
--- a/bsps/riscv/griscv/console/printk_support.c
+++ b/bsps/riscv/griscv/console/printk_support.c
@@ -43,9 +43,10 @@
#include <stdio.h>
#include <grlib/apbuart.h>
#include <grlib/ambapp.h>
+#include <grlib/io.h>
int grlib_debug_uart_index __attribute__((weak)) = 0;
-struct apbuart_regs *grlib_debug_uart = NULL;
+apbuart *grlib_debug_uart = NULL;
/* Before UART driver has registered (or when no UART is available), calls to
* printk that gets to bsp_out_char() will be filling data into the
@@ -87,13 +88,17 @@ static void bsp_debug_uart_init(void)
VENDOR_GAISLER, GAISLER_APBUART,
ambapp_find_by_idx, (void *)&i);
if (adev) {
+ uint32_t ctrl;
+
/* Found a matching debug console, initialize debug uart if present
* for printk
*/
apb = (struct ambapp_apb_info *)adev->devinfo;
- grlib_debug_uart = (struct apbuart_regs *)apb->start;
- grlib_debug_uart->ctrl |= APBUART_CTRL_RE | APBUART_CTRL_TE;
- grlib_debug_uart->status = 0;
+ grlib_debug_uart = (apbuart *)apb->start;
+ ctrl = grlib_load_32(&grlib_debug_uart->ctrl);
+ ctrl |= APBUART_CTRL_RE | APBUART_CTRL_TE;
+ grlib_store_32(&grlib_debug_uart->ctrl, ctrl);
+ grlib_store_32(&grlib_debug_uart->status, 0);
}
}
@@ -107,10 +112,14 @@ RTEMS_SYSINIT_ITEM(
static void bsp_out_char(char c)
{
if (grlib_debug_uart == NULL) {
+ uint32_t ctrl;
+
/* Try to assign standard UART address to debug driver to pass some tests */
- grlib_debug_uart = (struct apbuart_regs *) 0x80000100;
- grlib_debug_uart->ctrl |= APBUART_CTRL_RE | APBUART_CTRL_TE;
- grlib_debug_uart->status = 0;
+ grlib_debug_uart = (apbuart *) 0x80000100;
+ ctrl = grlib_load_32(&grlib_debug_uart->ctrl);
+ ctrl |= APBUART_CTRL_RE | APBUART_CTRL_TE;
+ grlib_store_32(&grlib_debug_uart->ctrl, ctrl);
+ grlib_store_32(&grlib_debug_uart->status, 0);
/* Local debug buffer when UART driver has not registered */
/*
pre_printk_dbgbuf[pre_printk_pos++] = c;