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