xref: /freebsd/sys/arm64/coresight/coresight_tmc.h (revision 95ee2897e98f5d444f26ed2334cc7c439f9c16c6)
1b1670691SRuslan Bukin /*-
2*c9ea007cSRuslan Bukin  * Copyright (c) 2018-2020 Ruslan Bukin <br@bsdpad.com>
3b1670691SRuslan Bukin  * All rights reserved.
4b1670691SRuslan Bukin  *
5b1670691SRuslan Bukin  * This software was developed by SRI International and the University of
6b1670691SRuslan Bukin  * Cambridge Computer Laboratory under DARPA/AFRL contract FA8750-10-C-0237
7b1670691SRuslan Bukin  * ("CTSRD"), as part of the DARPA CRASH research programme.
8b1670691SRuslan Bukin  *
9b1670691SRuslan Bukin  * Redistribution and use in source and binary forms, with or without
10b1670691SRuslan Bukin  * modification, are permitted provided that the following conditions
11b1670691SRuslan Bukin  * are met:
12b1670691SRuslan Bukin  * 1. Redistributions of source code must retain the above copyright
13b1670691SRuslan Bukin  *    notice, this list of conditions and the following disclaimer.
14b1670691SRuslan Bukin  * 2. Redistributions in binary form must reproduce the above copyright
15b1670691SRuslan Bukin  *    notice, this list of conditions and the following disclaimer in the
16b1670691SRuslan Bukin  *    documentation and/or other materials provided with the distribution.
17b1670691SRuslan Bukin  *
18b1670691SRuslan Bukin  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
19b1670691SRuslan Bukin  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
20b1670691SRuslan Bukin  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
21b1670691SRuslan Bukin  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
22b1670691SRuslan Bukin  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
23b1670691SRuslan Bukin  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
24b1670691SRuslan Bukin  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
25b1670691SRuslan Bukin  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
26b1670691SRuslan Bukin  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
27b1670691SRuslan Bukin  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
28b1670691SRuslan Bukin  * SUCH DAMAGE.
29b1670691SRuslan Bukin  */
30b1670691SRuslan Bukin 
31b1670691SRuslan Bukin #ifndef	_ARM64_CORESIGHT_CORESIGHT_TMC_H_
32b1670691SRuslan Bukin #define	_ARM64_CORESIGHT_CORESIGHT_TMC_H_
33b1670691SRuslan Bukin 
34b1670691SRuslan Bukin #define	TMC_RSZ		0x004 /* RAM Size Register */
35b1670691SRuslan Bukin #define	TMC_STS		0x00C /* Status Register */
36b1670691SRuslan Bukin #define	 STS_MEMERR	(1 << 5)
37b1670691SRuslan Bukin #define	 STS_EMPTY	(1 << 4)
38b1670691SRuslan Bukin #define	 STS_FTEMPTY	(1 << 3)
39b1670691SRuslan Bukin #define	 STS_TMCREADY	(1 << 2)
40b1670691SRuslan Bukin #define	 STS_TRIGGERED	(1 << 1)
41b1670691SRuslan Bukin #define	 STS_FULL	(1 << 0)
42b1670691SRuslan Bukin #define	TMC_RRD		0x010 /* RAM Read Data Register */
43b1670691SRuslan Bukin #define	TMC_RRP		0x014 /* RAM Read Pointer Register */
44b1670691SRuslan Bukin #define	TMC_RWP		0x018 /* RAM Write Pointer Register */
45b1670691SRuslan Bukin #define	TMC_TRG		0x01C /* Trigger Counter Register */
46b1670691SRuslan Bukin #define	TMC_CTL		0x020 /* Control Register */
47b1670691SRuslan Bukin #define	 CTL_TRACECAPTEN	(1 << 0)	/* Controls trace capture. */
48b1670691SRuslan Bukin #define	TMC_RWD		0x024 /* RAM Write Data Register */
49b1670691SRuslan Bukin #define	TMC_MODE	0x028 /* Mode Register */
50b1670691SRuslan Bukin #define	 MODE_HW_FIFO		2
51b1670691SRuslan Bukin #define	 MODE_SW_FIFO		1
52b1670691SRuslan Bukin #define	 MODE_CIRCULAR_BUFFER	0
53b1670691SRuslan Bukin #define	TMC_LBUFLEVEL	0x02C /* Latched Buffer Fill Level */
54b1670691SRuslan Bukin #define	TMC_CBUFLEVEL	0x030 /* Current Buffer Fill Level */
55b1670691SRuslan Bukin #define	TMC_BUFWM	0x034 /* Buffer Level Water Mark */
56b1670691SRuslan Bukin #define	TMC_RRPHI	0x038 /* RAM Read Pointer High Register */
57b1670691SRuslan Bukin #define	TMC_RWPHI	0x03C /* RAM Write Pointer High Register */
58b1670691SRuslan Bukin #define	TMC_AXICTL	0x110 /* AXI Control Register */
59b1670691SRuslan Bukin #define	 AXICTL_WRBURSTLEN_S	8
60b1670691SRuslan Bukin #define	 AXICTL_WRBURSTLEN_M	(0xf << AXICTL_WRBURSTLEN_S)
61b1670691SRuslan Bukin #define	 AXICTL_WRBURSTLEN_16	(0xf << AXICTL_WRBURSTLEN_S)
62b1670691SRuslan Bukin #define	 AXICTL_SG_MODE		(1 << 7)	/* Scatter Gather Mode */
63b1670691SRuslan Bukin #define	 AXICTL_CACHE_CTRL_BIT3	(1 << 5)
64b1670691SRuslan Bukin #define	 AXICTL_CACHE_CTRL_BIT2	(1 << 4)
65b1670691SRuslan Bukin #define	 AXICTL_CACHE_CTRL_BIT1	(1 << 3)
66b1670691SRuslan Bukin #define	 AXICTL_CACHE_CTRL_BIT0	(1 << 2)
67b1670691SRuslan Bukin #define	 AXICTL_AXCACHE_OS	(0xf << 2)
68b1670691SRuslan Bukin #define	 AXICTL_PROT_CTRL_BIT1	(1 << 1)
69b1670691SRuslan Bukin #define	 AXICTL_PROT_CTRL_BIT0	(1 << 0)
70b1670691SRuslan Bukin #define	TMC_DBALO	0x118 /* Data Buffer Address Low Register */
71b1670691SRuslan Bukin #define	TMC_DBAHI	0x11C /* Data Buffer Address High Register */
72b1670691SRuslan Bukin #define	TMC_FFSR	0x300 /* Formatter and Flush Status Register */
73b1670691SRuslan Bukin #define	TMC_FFCR	0x304 /* Formatter and Flush Control Register */
74b1670691SRuslan Bukin #define	 FFCR_EN_FMT		(1 << 0)
75b1670691SRuslan Bukin #define	 FFCR_EN_TI		(1 << 1)
76b1670691SRuslan Bukin #define	 FFCR_FON_FLIN		(1 << 4)
77b1670691SRuslan Bukin #define	 FFCR_FON_TRIG_EVT	(1 << 5)
78b1670691SRuslan Bukin #define	 FFCR_FLUSH_MAN		(1 << 6)
79b1670691SRuslan Bukin #define	 FFCR_TRIGON_TRIGIN	(1 << 8)
80b1670691SRuslan Bukin #define	TMC_PSCR	0x308 /* Periodic Synchronization Counter Register */
81b1670691SRuslan Bukin #define	TMC_ITATBMDATA0	0xED0 /* Integration Test ATB Master Data Register 0 */
82b1670691SRuslan Bukin #define	TMC_ITATBMCTR2	0xED4 /* Integration Test ATB Master Interface Control 2 Register */
83b1670691SRuslan Bukin #define	TMC_ITATBMCTR1	0xED8 /* Integration Test ATB Master Control Register 1 */
84b1670691SRuslan Bukin #define	TMC_ITATBMCTR0	0xEDC /* Integration Test ATB Master Interface Control 0 Register */
85b1670691SRuslan Bukin #define	TMC_ITMISCOP0	0xEE0 /* Integration Test Miscellaneous Output Register 0 */
86b1670691SRuslan Bukin #define	TMC_ITTRFLIN	0xEE8 /* Integration Test Trigger In and Flush In Register */
87b1670691SRuslan Bukin #define	TMC_ITATBDATA0	0xEEC /* Integration Test ATB Data Register 0 */
88b1670691SRuslan Bukin #define	TMC_ITATBCTR2	0xEF0 /* Integration Test ATB Control 2 Register */
89b1670691SRuslan Bukin #define	TMC_ITATBCTR1	0xEF4 /* Integration Test ATB Control 1 Register */
90b1670691SRuslan Bukin #define	TMC_ITATBCTR0	0xEF8 /* Integration Test ATB Control 0 Register */
91b1670691SRuslan Bukin #define	TMC_ITCTRL	0xF00 /* Integration Mode Control Register */
92b1670691SRuslan Bukin #define	TMC_CLAIMSET	0xFA0 /* Claim Tag Set Register */
93b1670691SRuslan Bukin #define	TMC_CLAIMCLR	0xFA4 /* Claim Tag Clear Register */
94b1670691SRuslan Bukin #define	TMC_LAR		0xFB0 /* Lock Access Register */
95b1670691SRuslan Bukin #define	TMC_LSR		0xFB4 /* Lock Status Register */
96b1670691SRuslan Bukin #define	TMC_AUTHSTATUS	0xFB8 /* Authentication Status Register */
97b1670691SRuslan Bukin #define	TMC_DEVID	0xFC8 /* Device Configuration Register */
98b1670691SRuslan Bukin #define	 DEVID_CONFIGTYPE_S	6
99b1670691SRuslan Bukin #define	 DEVID_CONFIGTYPE_M	(0x3 << DEVID_CONFIGTYPE_S)
100b1670691SRuslan Bukin #define	 DEVID_CONFIGTYPE_ETB	(0 << DEVID_CONFIGTYPE_S)
101b1670691SRuslan Bukin #define	 DEVID_CONFIGTYPE_ETR	(1 << DEVID_CONFIGTYPE_S)
102b1670691SRuslan Bukin #define	 DEVID_CONFIGTYPE_ETF	(2 << DEVID_CONFIGTYPE_S)
103b1670691SRuslan Bukin #define	TMC_DEVTYPE	0xFCC /* Device Type Identifier Register */
104b1670691SRuslan Bukin #define	TMC_PERIPHID4	0xFD0 /* Peripheral ID4 Register */
105b1670691SRuslan Bukin #define	TMC_PERIPHID5	0xFD4 /* Peripheral ID5 Register */
106b1670691SRuslan Bukin #define	TMC_PERIPHID6	0xFD8 /* Peripheral ID6 Register */
107b1670691SRuslan Bukin #define	TMC_PERIPHID7	0xFDC /* Peripheral ID7 Register */
108b1670691SRuslan Bukin #define	TMC_PERIPHID0	0xFE0 /* Peripheral ID0 Register */
109b1670691SRuslan Bukin #define	TMC_PERIPHID1	0xFE4 /* Peripheral ID1 Register */
110b1670691SRuslan Bukin #define	TMC_PERIPHID2	0xFE8 /* Peripheral ID2 Register */
111b1670691SRuslan Bukin #define	TMC_PERIPHID3	0xFEC /* Peripheral ID3 Register */
112b1670691SRuslan Bukin #define	TMC_COMPID0	0xFF0 /* Component ID0 Register */
113b1670691SRuslan Bukin #define	TMC_COMPID1	0xFF4 /* Component ID1 Register */
114b1670691SRuslan Bukin #define	TMC_COMPID2	0xFF8 /* Component ID2 Register */
115b1670691SRuslan Bukin #define	TMC_COMPID3	0xFFC /* Component ID3 Register */
116b1670691SRuslan Bukin 
117a132ec9fSRuslan Bukin DECLARE_CLASS(tmc_driver);
118a132ec9fSRuslan Bukin 
119a132ec9fSRuslan Bukin struct tmc_softc {
120a132ec9fSRuslan Bukin 	struct resource			*res;
121a132ec9fSRuslan Bukin 	device_t			dev;
122a132ec9fSRuslan Bukin 	uint64_t			cycle;
123a132ec9fSRuslan Bukin 	struct coresight_platform_data	*pdata;
124a132ec9fSRuslan Bukin 	uint32_t			dev_type;
125a132ec9fSRuslan Bukin #define	CORESIGHT_UNKNOWN		0
126a132ec9fSRuslan Bukin #define	CORESIGHT_ETR			1
127a132ec9fSRuslan Bukin #define	CORESIGHT_ETF			2
128a132ec9fSRuslan Bukin 	uint32_t			nev;
129a132ec9fSRuslan Bukin 	struct coresight_event		*event;
130a132ec9fSRuslan Bukin 	boolean_t			etf_configured;
131a132ec9fSRuslan Bukin };
132a132ec9fSRuslan Bukin 
133*c9ea007cSRuslan Bukin int tmc_attach(device_t dev);
134*c9ea007cSRuslan Bukin 
135b1670691SRuslan Bukin #endif /* !_ARM64_CORESIGHT_CORESIGHT_TMC_H_ */
136