-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
yaml --- r: 360068 b: refs/heads/master c: 5fff610 h: refs/heads/master v: v3
- Loading branch information
John Crispin
committed
Feb 17, 2013
1 parent
768dcf8
commit 805420b
Showing
2 changed files
with
45 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,2 +1,2 @@ | ||
--- | ||
refs/heads/master: 3a5bfe7bdbfd37c9206d7c6dfd7eb9664ccc5038 | ||
refs/heads/master: 5fff610b7c60195de98e68bec00c357f393ce634 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,44 @@ | ||
/* | ||
* This program is free software; you can redistribute it and/or modify it | ||
* under the terms of the GNU General Public License version 2 as published | ||
* by the Free Software Foundation. | ||
* | ||
* Copyright (C) 2011-2012 Gabor Juhos <juhosg@openwrt.org> | ||
*/ | ||
|
||
#include <linux/io.h> | ||
#include <linux/serial_reg.h> | ||
|
||
#include <asm/addrspace.h> | ||
|
||
#define EARLY_UART_BASE 0x10000c00 | ||
|
||
#define UART_REG_RX 0x00 | ||
#define UART_REG_TX 0x04 | ||
#define UART_REG_IER 0x08 | ||
#define UART_REG_IIR 0x0c | ||
#define UART_REG_FCR 0x10 | ||
#define UART_REG_LCR 0x14 | ||
#define UART_REG_MCR 0x18 | ||
#define UART_REG_LSR 0x1c | ||
|
||
static __iomem void *uart_membase = (__iomem void *) KSEG1ADDR(EARLY_UART_BASE); | ||
|
||
static inline void uart_w32(u32 val, unsigned reg) | ||
{ | ||
__raw_writel(val, uart_membase + reg); | ||
} | ||
|
||
static inline u32 uart_r32(unsigned reg) | ||
{ | ||
return __raw_readl(uart_membase + reg); | ||
} | ||
|
||
void prom_putchar(unsigned char ch) | ||
{ | ||
while ((uart_r32(UART_REG_LSR) & UART_LSR_THRE) == 0) | ||
; | ||
uart_w32(ch, UART_REG_TX); | ||
while ((uart_r32(UART_REG_LSR) & UART_LSR_THRE) == 0) | ||
; | ||
} |