mirror of
https://github.com/openwrt/openwrt.git
synced 2025-01-23 04:48:22 +00:00
029093a302
This target has full device tree support, thus reducing the number of patches needed for bcm63xx, in which there's a patch for every board. The intention is to start with a minimal amount of downstream patches and start upstreaming all of them. Current status: - Enabling EHCI/OHCI on BCM6358 causes a kernel panic. - BCM63268 lacks Timer Clocks/Reset support. - No PCI/PCIe drivers. - No ethernet drivers. Signed-off-by: Álvaro Fernández Rojas <noltari@gmail.com> Acked-by: Adrian Schmutzler <freifunk@adrianschmutzler.de>
38 lines
767 B
C
38 lines
767 B
C
// SPDX-License-Identifier: GPL-2.0-or-later
|
|
/*
|
|
* BCM63XX specific implementation parts
|
|
*
|
|
* Copyright (C) 2020 Álvaro Fernández Rojas <noltari@gmail.com>
|
|
* Copyright (C) 2014 Jonas Gorski <jogo@openwrt.org>
|
|
*/
|
|
|
|
#include <stddef.h>
|
|
#include "config.h"
|
|
|
|
#define READREG(r) *(volatile unsigned int *)(r)
|
|
#define WRITEREG(r,v) *(volatile unsigned int *)(r) = v
|
|
|
|
#define UART_IR_REG 0x10
|
|
#define UART_FIFO_REG 0x14
|
|
|
|
static void wait_xfered(void)
|
|
{
|
|
unsigned int val;
|
|
|
|
do {
|
|
val = READREG(UART_BASE + UART_IR_REG);
|
|
if (val & (1 << 5))
|
|
break;
|
|
} while (1);
|
|
}
|
|
|
|
void board_putc(int ch)
|
|
{
|
|
if (!UART_BASE)
|
|
return;
|
|
|
|
wait_xfered();
|
|
WRITEREG(UART_BASE + UART_FIFO_REG, ch);
|
|
wait_xfered();
|
|
}
|