aboutsummaryrefslogtreecommitdiff
path: root/target/linux/ramips/image/lzma-loader/src/board.c
blob: de02f58b9f4813df143077ebe13674f7edbbbee3 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
/*
 * Arch specific code for ramips based boards
 *
 * Copyright (C) 2013 John Crispin <blogic@openwrt.org>
 * Copyright (C) 2018 Tobias Schramm <tobleminer@gmail.com>
 * Copyright (C) 2023 Antonio Vázquez <antoniovazquezblanco@gmail.com>
 *
 * 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.
 */

#include <stdint.h>
#include <stddef.h>

#define KSEG0			0x80000000
#define KSEG1			0xa0000000

#define _ATYPE_ 		__PTRDIFF_TYPE__
#define _ATYPE32_		int

#define _ACAST32_		(_ATYPE_)(_ATYPE32_)

#define CPHYSADDR(a)		((_ACAST32_(a)) & 0x1fffffff)

#define KSEG0ADDR(a)		(CPHYSADDR(a) | KSEG0)
#define KSEG1ADDR(a)		(CPHYSADDR(a) | KSEG1)

#define UART_LSR_THRE		0x20
#define UART_LSR_TEMT		0x40

#if defined(SOC_MT7620) || defined(SOC_RT3883)
#define UART_BASE			KSEG1ADDR(0x10000c00)
#define UART_THR			(UART_BASE + 0x04)
#define UART_LSR			(UART_BASE + 0x1c)
#define UART_LSR_MASK			UART_LSR_TEMT
#elif defined(SOC_MT7621)
#define UART_BASE			KSEG1ADDR(0x1e000c00)
#define UART_THR			(UART_BASE + 0x00)
#define UART_LSR			(UART_BASE + 0x14)
#define UART_LSR_MASK			UART_LSR_THRE
#elif defined(SOC_RT305X)
#define UART_BASE			KSEG1ADDR(0x10000c00)
#define UART_THR			(UART_BASE + 0x04)
#define UART_LSR			(UART_BASE + 0x1c)
#define UART_LSR_MASK			UART_LSR_THRE
#else
#error "Unsupported SOC..."
#endif

// Helper functions
#define READREG(r)		(*(volatile uint32_t *)(r))
#define WRITEREG(r,v)	(*(volatile uint32_t *)(r)) = v


void board_init(void)
{
}

void board_putc(int ch)
{
	while ((READREG(UART_LSR) & UART_LSR_MASK) == 0);
	WRITEREG(UART_THR, ch);
	while ((READREG(UART_LSR) & UART_LSR_MASK) == 0);
}