forked from 96boards-poplar/l-loader
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdebug.S
123 lines (106 loc) · 2.19 KB
/
debug.S
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
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
/*
* (C) Copyright 2017 Linaro Limited
*
* Jorge Ramirez-Ortiz <[email protected]>
*
* Configuration for Poplar 96boards EE. Parts were derived from other ARM
* configurations.
*
* SPDX-License-Identifier: GPL-2.0+
*/
#define DEBUG_UART_PHYS 0xF8B00000
#define DEBUG_UART_VIRT 0xF0000000
#define UART01x_FR_TXFF 0x020
#define UART01x_FR_BUSY 0x008
#define UART01x_DR 0x00
#define UART01x_FR 0x18
#define UART01x_IBRD 0x24
#define UART01x_FBRD 0x28
#define UART01x_LCR_H 0x2c
#define UART01x_CR 0x30
#define UART01x_CR_DISABLE 0x00
#define UART01x_CR_ENABLE 0x301
@-------------------------------------------
@
@-------------------------------------------
.text
.align 2
.global uart_init
.type uart_init, %function
uart_init:
ldr a4, uart_base_addr_L0
mov a3, #UART01x_CR_DISABLE
/* disable */
str a3, [a4, #UART01x_CR]
add a3, a3, #UART01x_FBRD
str a3, [a4, #UART01x_IBRD]
mov a3, #UART01x_LCR_H
str a3, [a4, #UART01x_FBRD]
/* 8 bits, 1 stop bit, no parity, fifo enabled. */
mov a3, #112
str a3, [a4, #UART01x_LCR_H]
/* enable */
ldr a3, =UART01x_CR_ENABLE
str a3, [a4, #UART01x_CR]
bx lr
uart_base_addr_L0:
.word DEBUG_UART_PHYS
@-------------------------------------------
@ Macros
@-------------------------------------------
.macro addruart, rp
ldr \rp, =DEBUG_UART_PHYS
.endm
.macro senduart, rd, rx
strb \rd, [\rx, #UART01x_DR]
.endm
.macro waituart, rd, rx
1001: ldr \rd, [\rx, #UART01x_FR]
tst \rd, #UART01x_FR_TXFF
bne 1001b
.endm
.macro busyuart, rd, rx
1001: ldr \rd, [\rx, #UART01x_FR]
tst \rd, #UART01x_FR_BUSY
bne 1001b
.endm
.global printascii
.global printch
.global printhex
/* print a 32-bit hexadecimal value passed via r0 */
printhex:
adr r2, hexbuf
add r3, r2, #8
mov r1, #0
strb r1, [r3]
1: and r1, r0, #15
mov r0, r0, lsr #4
cmp r1, #10
addlt r1, r1, #'0'
addge r1, r1, #'a' - 10
strb r1, [r3, #-1]!
teq r3, r2
bne 1b
mov r0, r2
b printascii
hexbuf: .space 16
.ltorg
printascii:
addruart r3
b 2f
1: waituart r2, r3
senduart r1, r3
busyuart r2, r3
teq r1, #'\n'
moveq r1, #'\r'
beq 1b
2: teq r0, #0
ldrneb r1, [r0], #1
teqne r1, #0
bne 1b
mov pc, lr
printch:
addruart r3
mov r1, r0
mov r0, #0
b 1b