blob: e32de804f7c3e5af54ab114f87fbfb3de2279b82 [file] [log] [blame]
Satyajit Desai66b6c452017-06-27 17:10:46 -07001/* Copyright (c) 2014, 2016-2017, The Linux Foundation. All rights reserved.
2 *
3 * This program is free software; you can redistribute it and/or modify
4 * it under the terms of the GNU General Public License version 2 and
5 * only version 2 as published by the Free Software Foundation.
6 *
7 * This program is distributed in the hope that it will be useful,
8 * but WITHOUT ANY WARRANTY; without even the implied warranty of
9 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
10 * GNU General Public License for more details.
11 */
12
13#ifndef __ASM_DEBUGV8_H
14#define __ASM_DEBUGV8_H
15
16#include <linux/types.h>
17
18/* 32 bit register reads for aarch 64 bit */
19#define dbg_readl(reg) RSYSL_##reg()
20/* 64 bit register reads for aarch 64 bit */
21#define dbg_readq(reg) RSYSQ_##reg()
22/* 32 and 64 bit register writes for aarch 64 bit */
23#define dbg_write(val, reg) WSYS_##reg(val)
24
25#define MRSL(reg) \
26({ \
27uint32_t val; \
28asm volatile("mrs %0, "#reg : "=r" (val)); \
29val; \
30})
31
32#define MRSQ(reg) \
33({ \
34uint64_t val; \
35asm volatile("mrs %0, "#reg : "=r" (val)); \
36val; \
37})
38
39#define MSR(val, reg) \
40({ \
41asm volatile("msr "#reg", %0" : : "r" (val)); \
42})
43
44/*
45 * Debug Feature Register
46 *
47 * Read only
48 */
49#define RSYSQ_ID_AA64DFR0_EL1() MRSQ(ID_AA64DFR0_EL1)
50
51/*
52 * Debug Registers
53 *
54 * Available only in DBGv8
55 *
56 * Read only
57 * MDCCSR_EL0, MDRAR_EL1, OSLSR_EL1, DBGDTRRX_EL0, DBGAUTHSTATUS_EL1
58 *
59 * Write only
60 * DBGDTRTX_EL0, OSLAR_EL1
61 */
62/* 32 bit registers */
63#define RSYSL_DBGDTRRX_EL0() MRSL(DBGDTRRX_EL0)
64#define RSYSL_MDCCSR_EL0() MRSL(MDCCSR_EL0)
65#define RSYSL_MDSCR_EL1() MRSL(MDSCR_EL1)
66#define RSYSL_OSDTRRX_EL1() MRSL(OSDTRRX_EL1)
67#define RSYSL_OSDTRTX_EL1() MRSL(OSDTRTX_EL1)
68#define RSYSL_OSDLR_EL1() MRSL(OSDLR_EL1)
69#define RSYSL_OSLSR_EL1() MRSL(OSLSR_EL1)
70#define RSYSL_MDCCINT_EL1() MRSL(MDCCINT_EL1)
71#define RSYSL_OSECCR_EL1() MRSL(OSECCR_EL1)
72#define RSYSL_DBGPRCR_EL1() MRSL(DBGPRCR_EL1)
73#define RSYSL_DBGBCR0_EL1() MRSL(DBGBCR0_EL1)
74#define RSYSL_DBGBCR1_EL1() MRSL(DBGBCR1_EL1)
75#define RSYSL_DBGBCR2_EL1() MRSL(DBGBCR2_EL1)
76#define RSYSL_DBGBCR3_EL1() MRSL(DBGBCR3_EL1)
77#define RSYSL_DBGBCR4_EL1() MRSL(DBGBCR4_EL1)
78#define RSYSL_DBGBCR5_EL1() MRSL(DBGBCR5_EL1)
79#define RSYSL_DBGBCR6_EL1() MRSL(DBGBCR6_EL1)
80#define RSYSL_DBGBCR7_EL1() MRSL(DBGBCR7_EL1)
81#define RSYSL_DBGBCR8_EL1() MRSL(DBGBCR8_EL1)
82#define RSYSL_DBGBCR9_EL1() MRSL(DBGBCR9_EL1)
83#define RSYSL_DBGBCR10_EL1() MRSL(DBGBCR10_EL1)
84#define RSYSL_DBGBCR11_EL1() MRSL(DBGBCR11_EL1)
85#define RSYSL_DBGBCR12_EL1() MRSL(DBGBCR12_EL1)
86#define RSYSL_DBGBCR13_EL1() MRSL(DBGBCR13_EL1)
87#define RSYSL_DBGBCR14_EL1() MRSL(DBGBCR14_EL1)
88#define RSYSL_DBGBCR15_EL1() MRSL(DBGBCR15_EL1)
89#define RSYSL_DBGWCR0_EL1() MRSL(DBGWCR0_EL1)
90#define RSYSL_DBGWCR1_EL1() MRSL(DBGWCR1_EL1)
91#define RSYSL_DBGWCR2_EL1() MRSL(DBGWCR2_EL1)
92#define RSYSL_DBGWCR3_EL1() MRSL(DBGWCR3_EL1)
93#define RSYSL_DBGWCR4_EL1() MRSL(DBGWCR4_EL1)
94#define RSYSL_DBGWCR5_EL1() MRSL(DBGWCR5_EL1)
95#define RSYSL_DBGWCR6_EL1() MRSL(DBGWCR6_EL1)
96#define RSYSL_DBGWCR7_EL1() MRSL(DBGWCR7_EL1)
97#define RSYSL_DBGWCR8_EL1() MRSL(DBGWCR8_EL1)
98#define RSYSL_DBGWCR9_EL1() MRSL(DBGWCR9_EL1)
99#define RSYSL_DBGWCR10_EL1() MRSL(DBGWCR10_EL1)
100#define RSYSL_DBGWCR11_EL1() MRSL(DBGWCR11_EL1)
101#define RSYSL_DBGWCR12_EL1() MRSL(DBGWCR12_EL1)
102#define RSYSL_DBGWCR13_EL1() MRSL(DBGWCR13_EL1)
103#define RSYSL_DBGWCR14_EL1() MRSL(DBGWCR14_EL1)
104#define RSYSL_DBGWCR15_EL1() MRSL(DBGWCR15_EL1)
105#define RSYSL_DBGCLAIMSET_EL1() MRSL(DBGCLAIMSET_EL1)
106#define RSYSL_DBGCLAIMCLR_EL1() MRSL(DBGCLAIMCLR_EL1)
107#define RSYSL_DBGAUTHSTATUS_EL1() MRSL(DBGAUTHSTATUS_EL1)
108#define RSYSL_DBGVCR32_EL2() MRSL(DBGVCR32_EL2)
109#define RSYSL_MDCR_EL2() MRSL(MDCR_EL2)
110#define RSYSL_MDCR_EL3() MRSL(MDCR_EL3)
111/* 64 bit registers */
112#define RSYSQ_DBGDTR_EL0() MRSQ(DBGDTR_EL0)
113#define RSYSQ_MDRAR_EL1() MRSQ(MDRAR_EL1)
114#define RSYSQ_DBGBVR0_EL1() MRSQ(DBGBVR0_EL1)
115#define RSYSQ_DBGBVR1_EL1() MRSQ(DBGBVR1_EL1)
116#define RSYSQ_DBGBVR2_EL1() MRSQ(DBGBVR2_EL1)
117#define RSYSQ_DBGBVR3_EL1() MRSQ(DBGBVR3_EL1)
118#define RSYSQ_DBGBVR4_EL1() MRSQ(DBGBVR4_EL1)
119#define RSYSQ_DBGBVR5_EL1() MRSQ(DBGBVR5_EL1)
120#define RSYSQ_DBGBVR6_EL1() MRSQ(DBGBVR6_EL1)
121#define RSYSQ_DBGBVR7_EL1() MRSQ(DBGBVR7_EL1)
122#define RSYSQ_DBGBVR8_EL1() MRSQ(DBGBVR8_EL1)
123#define RSYSQ_DBGBVR9_EL1() MRSQ(DBGBVR9_EL1)
124#define RSYSQ_DBGBVR10_EL1() MRSQ(DBGBVR10_EL1)
125#define RSYSQ_DBGBVR11_EL1() MRSQ(DBGBVR11_EL1)
126#define RSYSQ_DBGBVR12_EL1() MRSQ(DBGBVR12_EL1)
127#define RSYSQ_DBGBVR13_EL1() MRSQ(DBGBVR13_EL1)
128#define RSYSQ_DBGBVR14_EL1() MRSQ(DBGBVR14_EL1)
129#define RSYSQ_DBGBVR15_EL1() MRSQ(DBGBVR15_EL1)
130#define RSYSQ_DBGWVR0_EL1() MRSQ(DBGWVR0_EL1)
131#define RSYSQ_DBGWVR1_EL1() MRSQ(DBGWVR1_EL1)
132#define RSYSQ_DBGWVR2_EL1() MRSQ(DBGWVR2_EL1)
133#define RSYSQ_DBGWVR3_EL1() MRSQ(DBGWVR3_EL1)
134#define RSYSQ_DBGWVR4_EL1() MRSQ(DBGWVR4_EL1)
135#define RSYSQ_DBGWVR5_EL1() MRSQ(DBGWVR5_EL1)
136#define RSYSQ_DBGWVR6_EL1() MRSQ(DBGWVR6_EL1)
137#define RSYSQ_DBGWVR7_EL1() MRSQ(DBGWVR7_EL1)
138#define RSYSQ_DBGWVR8_EL1() MRSQ(DBGWVR8_EL1)
139#define RSYSQ_DBGWVR9_EL1() MRSQ(DBGWVR9_EL1)
140#define RSYSQ_DBGWVR10_EL1() MRSQ(DBGWVR10_EL1)
141#define RSYSQ_DBGWVR11_EL1() MRSQ(DBGWVR11_EL1)
142#define RSYSQ_DBGWVR12_EL1() MRSQ(DBGWVR12_EL1)
143#define RSYSQ_DBGWVR13_EL1() MRSQ(DBGWVR13_EL1)
144#define RSYSQ_DBGWVR14_EL1() MRSQ(DBGWVR14_EL1)
145#define RSYSQ_DBGWVR15_EL1() MRSQ(DBGWVR15_EL1)
146
147/* 32 bit registers */
148#define WSYS_DBGDTRTX_EL0(val) MSR(val, DBGDTRTX_EL0)
149#define WSYS_MDCCINT_EL1(val) MSR(val, MDCCINT_EL1)
150#define WSYS_MDSCR_EL1(val) MSR(val, MDSCR_EL1)
151#define WSYS_OSDTRRX_EL1(val) MSR(val, OSDTRRX_EL1)
152#define WSYS_OSDTRTX_EL1(val) MSR(val, OSDTRTX_EL1)
153#define WSYS_OSDLR_EL1(val) MSR(val, OSDLR_EL1)
154#define WSYS_OSECCR_EL1(val) MSR(val, OSECCR_EL1)
155#define WSYS_DBGPRCR_EL1(val) MSR(val, DBGPRCR_EL1)
156#define WSYS_DBGBCR0_EL1(val) MSR(val, DBGBCR0_EL1)
157#define WSYS_DBGBCR1_EL1(val) MSR(val, DBGBCR1_EL1)
158#define WSYS_DBGBCR2_EL1(val) MSR(val, DBGBCR2_EL1)
159#define WSYS_DBGBCR3_EL1(val) MSR(val, DBGBCR3_EL1)
160#define WSYS_DBGBCR4_EL1(val) MSR(val, DBGBCR4_EL1)
161#define WSYS_DBGBCR5_EL1(val) MSR(val, DBGBCR5_EL1)
162#define WSYS_DBGBCR6_EL1(val) MSR(val, DBGBCR6_EL1)
163#define WSYS_DBGBCR7_EL1(val) MSR(val, DBGBCR7_EL1)
164#define WSYS_DBGBCR8_EL1(val) MSR(val, DBGBCR8_EL1)
165#define WSYS_DBGBCR9_EL1(val) MSR(val, DBGBCR9_EL1)
166#define WSYS_DBGBCR10_EL1(val) MSR(val, DBGBCR10_EL1)
167#define WSYS_DBGBCR11_EL1(val) MSR(val, DBGBCR11_EL1)
168#define WSYS_DBGBCR12_EL1(val) MSR(val, DBGBCR12_EL1)
169#define WSYS_DBGBCR13_EL1(val) MSR(val, DBGBCR13_EL1)
170#define WSYS_DBGBCR14_EL1(val) MSR(val, DBGBCR14_EL1)
171#define WSYS_DBGBCR15_EL1(val) MSR(val, DBGBCR15_EL1)
172#define WSYS_DBGWCR0_EL1(val) MSR(val, DBGWCR0_EL1)
173#define WSYS_DBGWCR1_EL1(val) MSR(val, DBGWCR1_EL1)
174#define WSYS_DBGWCR2_EL1(val) MSR(val, DBGWCR2_EL1)
175#define WSYS_DBGWCR3_EL1(val) MSR(val, DBGWCR3_EL1)
176#define WSYS_DBGWCR4_EL1(val) MSR(val, DBGWCR4_EL1)
177#define WSYS_DBGWCR5_EL1(val) MSR(val, DBGWCR5_EL1)
178#define WSYS_DBGWCR6_EL1(val) MSR(val, DBGWCR6_EL1)
179#define WSYS_DBGWCR7_EL1(val) MSR(val, DBGWCR7_EL1)
180#define WSYS_DBGWCR8_EL1(val) MSR(val, DBGWCR8_EL1)
181#define WSYS_DBGWCR9_EL1(val) MSR(val, DBGWCR9_EL1)
182#define WSYS_DBGWCR10_EL1(val) MSR(val, DBGWCR10_EL1)
183#define WSYS_DBGWCR11_EL1(val) MSR(val, DBGWCR11_EL1)
184#define WSYS_DBGWCR12_EL1(val) MSR(val, DBGWCR12_EL1)
185#define WSYS_DBGWCR13_EL1(val) MSR(val, DBGWCR13_EL1)
186#define WSYS_DBGWCR14_EL1(val) MSR(val, DBGWCR14_EL1)
187#define WSYS_DBGWCR15_EL1(val) MSR(val, DBGWCR15_EL1)
188#define WSYS_DBGCLAIMSET_EL1(val) MSR(val, DBGCLAIMSET_EL1)
189#define WSYS_DBGCLAIMCLR_EL1(val) MSR(val, DBGCLAIMCLR_EL1)
190#define WSYS_OSLAR_EL1(val) MSR(val, OSLAR_EL1)
191#define WSYS_DBGVCR32_EL2(val) MSR(val, DBGVCR32_EL2)
192#define WSYS_MDCR_EL2(val) MSR(val, MDCR_EL2)
193#define WSYS_MDCR_EL3(val) MSR(val, MDCR_EL3)
194/* 64 bit registers */
195#define WSYS_DBGDTR_EL0(val) MSR(val, DBGDTR_EL0)
196#define WSYS_DBGBVR0_EL1(val) MSR(val, DBGBVR0_EL1)
197#define WSYS_DBGBVR1_EL1(val) MSR(val, DBGBVR1_EL1)
198#define WSYS_DBGBVR2_EL1(val) MSR(val, DBGBVR2_EL1)
199#define WSYS_DBGBVR3_EL1(val) MSR(val, DBGBVR3_EL1)
200#define WSYS_DBGBVR4_EL1(val) MSR(val, DBGBVR4_EL1)
201#define WSYS_DBGBVR5_EL1(val) MSR(val, DBGBVR5_EL1)
202#define WSYS_DBGBVR6_EL1(val) MSR(val, DBGBVR6_EL1)
203#define WSYS_DBGBVR7_EL1(val) MSR(val, DBGBVR7_EL1)
204#define WSYS_DBGBVR8_EL1(val) MSR(val, DBGBVR8_EL1)
205#define WSYS_DBGBVR9_EL1(val) MSR(val, DBGBVR9_EL1)
206#define WSYS_DBGBVR10_EL1(val) MSR(val, DBGBVR10_EL1)
207#define WSYS_DBGBVR11_EL1(val) MSR(val, DBGBVR11_EL1)
208#define WSYS_DBGBVR12_EL1(val) MSR(val, DBGBVR12_EL1)
209#define WSYS_DBGBVR13_EL1(val) MSR(val, DBGBVR13_EL1)
210#define WSYS_DBGBVR14_EL1(val) MSR(val, DBGBVR14_EL1)
211#define WSYS_DBGBVR15_EL1(val) MSR(val, DBGBVR15_EL1)
212#define WSYS_DBGWVR0_EL1(val) MSR(val, DBGWVR0_EL1)
213#define WSYS_DBGWVR1_EL1(val) MSR(val, DBGWVR1_EL1)
214#define WSYS_DBGWVR2_EL1(val) MSR(val, DBGWVR2_EL1)
215#define WSYS_DBGWVR3_EL1(val) MSR(val, DBGWVR3_EL1)
216#define WSYS_DBGWVR4_EL1(val) MSR(val, DBGWVR4_EL1)
217#define WSYS_DBGWVR5_EL1(val) MSR(val, DBGWVR5_EL1)
218#define WSYS_DBGWVR6_EL1(val) MSR(val, DBGWVR6_EL1)
219#define WSYS_DBGWVR7_EL1(val) MSR(val, DBGWVR7_EL1)
220#define WSYS_DBGWVR8_EL1(val) MSR(val, DBGWVR8_EL1)
221#define WSYS_DBGWVR9_EL1(val) MSR(val, DBGWVR9_EL1)
222#define WSYS_DBGWVR10_EL1(val) MSR(val, DBGWVR10_EL1)
223#define WSYS_DBGWVR11_EL1(val) MSR(val, DBGWVR11_EL1)
224#define WSYS_DBGWVR12_EL1(val) MSR(val, DBGWVR12_EL1)
225#define WSYS_DBGWVR13_EL1(val) MSR(val, DBGWVR13_EL1)
226#define WSYS_DBGWVR14_EL1(val) MSR(val, DBGWVR14_EL1)
227#define WSYS_DBGWVR15_EL1(val) MSR(val, DBGWVR15_EL1)
228
229#endif