Current Path : /sys/contrib/octeon-sdk/ |
FreeBSD hs32.drive.ne.jp 9.1-RELEASE FreeBSD 9.1-RELEASE #1: Wed Jan 14 12:18:08 JST 2015 root@hs32.drive.ne.jp:/sys/amd64/compile/hs32 amd64 |
Current File : //sys/contrib/octeon-sdk/cvmx-tra-defs.h |
/***********************license start*************** * Copyright (c) 2003-2010 Cavium Networks (support@cavium.com). All rights * reserved. * * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are * met: * * * Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * * Redistributions in binary form must reproduce the above * copyright notice, this list of conditions and the following * disclaimer in the documentation and/or other materials provided * with the distribution. * * Neither the name of Cavium Networks nor the names of * its contributors may be used to endorse or promote products * derived from this software without specific prior written * permission. * This Software, including technical data, may be subject to U.S. export control * laws, including the U.S. Export Administration Act and its associated * regulations, and may be subject to export or import regulations in other * countries. * TO THE MAXIMUM EXTENT PERMITTED BY LAW, THE SOFTWARE IS PROVIDED "AS IS" * AND WITH ALL FAULTS AND CAVIUM NETWORKS MAKES NO PROMISES, REPRESENTATIONS OR * WARRANTIES, EITHER EXPRESS, IMPLIED, STATUTORY, OR OTHERWISE, WITH RESPECT TO * THE SOFTWARE, INCLUDING ITS CONDITION, ITS CONFORMITY TO ANY REPRESENTATION OR * DESCRIPTION, OR THE EXISTENCE OF ANY LATENT OR PATENT DEFECTS, AND CAVIUM * SPECIFICALLY DISCLAIMS ALL IMPLIED (IF ANY) WARRANTIES OF TITLE, * MERCHANTABILITY, NONINFRINGEMENT, FITNESS FOR A PARTICULAR PURPOSE, LACK OF * VIRUSES, ACCURACY OR COMPLETENESS, QUIET ENJOYMENT, QUIET POSSESSION OR * CORRESPONDENCE TO DESCRIPTION. THE ENTIRE RISK ARISING OUT OF USE OR * PERFORMANCE OF THE SOFTWARE LIES WITH YOU. ***********************license end**************************************/ /** * cvmx-tra-defs.h * * Configuration and status register (CSR) type definitions for * Octeon tra. * * This file is auto generated. Do not edit. * * <hr>$Revision$<hr> * */ #ifndef __CVMX_TRA_TYPEDEFS_H__ #define __CVMX_TRA_TYPEDEFS_H__ #if CVMX_ENABLE_CSR_ADDRESS_CHECKING #define CVMX_TRA_BIST_STATUS CVMX_TRA_BIST_STATUS_FUNC() static inline uint64_t CVMX_TRA_BIST_STATUS_FUNC(void) { if (!(OCTEON_IS_MODEL(OCTEON_CN31XX) || OCTEON_IS_MODEL(OCTEON_CN38XX) || OCTEON_IS_MODEL(OCTEON_CN52XX) || OCTEON_IS_MODEL(OCTEON_CN56XX) || OCTEON_IS_MODEL(OCTEON_CN58XX) || OCTEON_IS_MODEL(OCTEON_CN63XX))) cvmx_warn("CVMX_TRA_BIST_STATUS not supported on this chip\n"); return CVMX_ADD_IO_SEG(0x00011800A8000010ull); } #else #define CVMX_TRA_BIST_STATUS (CVMX_ADD_IO_SEG(0x00011800A8000010ull)) #endif #if CVMX_ENABLE_CSR_ADDRESS_CHECKING #define CVMX_TRA_CTL CVMX_TRA_CTL_FUNC() static inline uint64_t CVMX_TRA_CTL_FUNC(void) { if (!(OCTEON_IS_MODEL(OCTEON_CN31XX) || OCTEON_IS_MODEL(OCTEON_CN38XX) || OCTEON_IS_MODEL(OCTEON_CN52XX) || OCTEON_IS_MODEL(OCTEON_CN56XX) || OCTEON_IS_MODEL(OCTEON_CN58XX) || OCTEON_IS_MODEL(OCTEON_CN63XX))) cvmx_warn("CVMX_TRA_CTL not supported on this chip\n"); return CVMX_ADD_IO_SEG(0x00011800A8000000ull); } #else #define CVMX_TRA_CTL (CVMX_ADD_IO_SEG(0x00011800A8000000ull)) #endif #if CVMX_ENABLE_CSR_ADDRESS_CHECKING #define CVMX_TRA_CYCLES_SINCE CVMX_TRA_CYCLES_SINCE_FUNC() static inline uint64_t CVMX_TRA_CYCLES_SINCE_FUNC(void) { if (!(OCTEON_IS_MODEL(OCTEON_CN31XX) || OCTEON_IS_MODEL(OCTEON_CN38XX) || OCTEON_IS_MODEL(OCTEON_CN52XX) || OCTEON_IS_MODEL(OCTEON_CN56XX) || OCTEON_IS_MODEL(OCTEON_CN58XX) || OCTEON_IS_MODEL(OCTEON_CN63XX))) cvmx_warn("CVMX_TRA_CYCLES_SINCE not supported on this chip\n"); return CVMX_ADD_IO_SEG(0x00011800A8000018ull); } #else #define CVMX_TRA_CYCLES_SINCE (CVMX_ADD_IO_SEG(0x00011800A8000018ull)) #endif #if CVMX_ENABLE_CSR_ADDRESS_CHECKING #define CVMX_TRA_CYCLES_SINCE1 CVMX_TRA_CYCLES_SINCE1_FUNC() static inline uint64_t CVMX_TRA_CYCLES_SINCE1_FUNC(void) { if (!(OCTEON_IS_MODEL(OCTEON_CN52XX) || OCTEON_IS_MODEL(OCTEON_CN56XX) || OCTEON_IS_MODEL(OCTEON_CN58XX) || OCTEON_IS_MODEL(OCTEON_CN63XX))) cvmx_warn("CVMX_TRA_CYCLES_SINCE1 not supported on this chip\n"); return CVMX_ADD_IO_SEG(0x00011800A8000028ull); } #else #define CVMX_TRA_CYCLES_SINCE1 (CVMX_ADD_IO_SEG(0x00011800A8000028ull)) #endif #if CVMX_ENABLE_CSR_ADDRESS_CHECKING #define CVMX_TRA_FILT_ADR_ADR CVMX_TRA_FILT_ADR_ADR_FUNC() static inline uint64_t CVMX_TRA_FILT_ADR_ADR_FUNC(void) { if (!(OCTEON_IS_MODEL(OCTEON_CN31XX) || OCTEON_IS_MODEL(OCTEON_CN38XX) || OCTEON_IS_MODEL(OCTEON_CN52XX) || OCTEON_IS_MODEL(OCTEON_CN56XX) || OCTEON_IS_MODEL(OCTEON_CN58XX) || OCTEON_IS_MODEL(OCTEON_CN63XX))) cvmx_warn("CVMX_TRA_FILT_ADR_ADR not supported on this chip\n"); return CVMX_ADD_IO_SEG(0x00011800A8000058ull); } #else #define CVMX_TRA_FILT_ADR_ADR (CVMX_ADD_IO_SEG(0x00011800A8000058ull)) #endif #if CVMX_ENABLE_CSR_ADDRESS_CHECKING #define CVMX_TRA_FILT_ADR_MSK CVMX_TRA_FILT_ADR_MSK_FUNC() static inline uint64_t CVMX_TRA_FILT_ADR_MSK_FUNC(void) { if (!(OCTEON_IS_MODEL(OCTEON_CN31XX) || OCTEON_IS_MODEL(OCTEON_CN38XX) || OCTEON_IS_MODEL(OCTEON_CN52XX) || OCTEON_IS_MODEL(OCTEON_CN56XX) || OCTEON_IS_MODEL(OCTEON_CN58XX) || OCTEON_IS_MODEL(OCTEON_CN63XX))) cvmx_warn("CVMX_TRA_FILT_ADR_MSK not supported on this chip\n"); return CVMX_ADD_IO_SEG(0x00011800A8000060ull); } #else #define CVMX_TRA_FILT_ADR_MSK (CVMX_ADD_IO_SEG(0x00011800A8000060ull)) #endif #if CVMX_ENABLE_CSR_ADDRESS_CHECKING #define CVMX_TRA_FILT_CMD CVMX_TRA_FILT_CMD_FUNC() static inline uint64_t CVMX_TRA_FILT_CMD_FUNC(void) { if (!(OCTEON_IS_MODEL(OCTEON_CN31XX) || OCTEON_IS_MODEL(OCTEON_CN38XX) || OCTEON_IS_MODEL(OCTEON_CN52XX) || OCTEON_IS_MODEL(OCTEON_CN56XX) || OCTEON_IS_MODEL(OCTEON_CN58XX) || OCTEON_IS_MODEL(OCTEON_CN63XX))) cvmx_warn("CVMX_TRA_FILT_CMD not supported on this chip\n"); return CVMX_ADD_IO_SEG(0x00011800A8000040ull); } #else #define CVMX_TRA_FILT_CMD (CVMX_ADD_IO_SEG(0x00011800A8000040ull)) #endif #if CVMX_ENABLE_CSR_ADDRESS_CHECKING #define CVMX_TRA_FILT_DID CVMX_TRA_FILT_DID_FUNC() static inline uint64_t CVMX_TRA_FILT_DID_FUNC(void) { if (!(OCTEON_IS_MODEL(OCTEON_CN31XX) || OCTEON_IS_MODEL(OCTEON_CN38XX) || OCTEON_IS_MODEL(OCTEON_CN52XX) || OCTEON_IS_MODEL(OCTEON_CN56XX) || OCTEON_IS_MODEL(OCTEON_CN58XX) || OCTEON_IS_MODEL(OCTEON_CN63XX))) cvmx_warn("CVMX_TRA_FILT_DID not supported on this chip\n"); return CVMX_ADD_IO_SEG(0x00011800A8000050ull); } #else #define CVMX_TRA_FILT_DID (CVMX_ADD_IO_SEG(0x00011800A8000050ull)) #endif #if CVMX_ENABLE_CSR_ADDRESS_CHECKING #define CVMX_TRA_FILT_SID CVMX_TRA_FILT_SID_FUNC() static inline uint64_t CVMX_TRA_FILT_SID_FUNC(void) { if (!(OCTEON_IS_MODEL(OCTEON_CN31XX) || OCTEON_IS_MODEL(OCTEON_CN38XX) || OCTEON_IS_MODEL(OCTEON_CN52XX) || OCTEON_IS_MODEL(OCTEON_CN56XX) || OCTEON_IS_MODEL(OCTEON_CN58XX) || OCTEON_IS_MODEL(OCTEON_CN63XX))) cvmx_warn("CVMX_TRA_FILT_SID not supported on this chip\n"); return CVMX_ADD_IO_SEG(0x00011800A8000048ull); } #else #define CVMX_TRA_FILT_SID (CVMX_ADD_IO_SEG(0x00011800A8000048ull)) #endif #if CVMX_ENABLE_CSR_ADDRESS_CHECKING #define CVMX_TRA_INT_STATUS CVMX_TRA_INT_STATUS_FUNC() static inline uint64_t CVMX_TRA_INT_STATUS_FUNC(void) { if (!(OCTEON_IS_MODEL(OCTEON_CN31XX) || OCTEON_IS_MODEL(OCTEON_CN38XX) || OCTEON_IS_MODEL(OCTEON_CN52XX) || OCTEON_IS_MODEL(OCTEON_CN56XX) || OCTEON_IS_MODEL(OCTEON_CN58XX) || OCTEON_IS_MODEL(OCTEON_CN63XX))) cvmx_warn("CVMX_TRA_INT_STATUS not supported on this chip\n"); return CVMX_ADD_IO_SEG(0x00011800A8000008ull); } #else #define CVMX_TRA_INT_STATUS (CVMX_ADD_IO_SEG(0x00011800A8000008ull)) #endif #if CVMX_ENABLE_CSR_ADDRESS_CHECKING #define CVMX_TRA_READ_DAT CVMX_TRA_READ_DAT_FUNC() static inline uint64_t CVMX_TRA_READ_DAT_FUNC(void) { if (!(OCTEON_IS_MODEL(OCTEON_CN31XX) || OCTEON_IS_MODEL(OCTEON_CN38XX) || OCTEON_IS_MODEL(OCTEON_CN52XX) || OCTEON_IS_MODEL(OCTEON_CN56XX) || OCTEON_IS_MODEL(OCTEON_CN58XX) || OCTEON_IS_MODEL(OCTEON_CN63XX))) cvmx_warn("CVMX_TRA_READ_DAT not supported on this chip\n"); return CVMX_ADD_IO_SEG(0x00011800A8000020ull); } #else #define CVMX_TRA_READ_DAT (CVMX_ADD_IO_SEG(0x00011800A8000020ull)) #endif #if CVMX_ENABLE_CSR_ADDRESS_CHECKING #define CVMX_TRA_READ_DAT_HI CVMX_TRA_READ_DAT_HI_FUNC() static inline uint64_t CVMX_TRA_READ_DAT_HI_FUNC(void) { if (!(OCTEON_IS_MODEL(OCTEON_CN63XX))) cvmx_warn("CVMX_TRA_READ_DAT_HI not supported on this chip\n"); return CVMX_ADD_IO_SEG(0x00011800A8000030ull); } #else #define CVMX_TRA_READ_DAT_HI (CVMX_ADD_IO_SEG(0x00011800A8000030ull)) #endif #if CVMX_ENABLE_CSR_ADDRESS_CHECKING #define CVMX_TRA_TRIG0_ADR_ADR CVMX_TRA_TRIG0_ADR_ADR_FUNC() static inline uint64_t CVMX_TRA_TRIG0_ADR_ADR_FUNC(void) { if (!(OCTEON_IS_MODEL(OCTEON_CN31XX) || OCTEON_IS_MODEL(OCTEON_CN38XX) || OCTEON_IS_MODEL(OCTEON_CN52XX) || OCTEON_IS_MODEL(OCTEON_CN56XX) || OCTEON_IS_MODEL(OCTEON_CN58XX) || OCTEON_IS_MODEL(OCTEON_CN63XX))) cvmx_warn("CVMX_TRA_TRIG0_ADR_ADR not supported on this chip\n"); return CVMX_ADD_IO_SEG(0x00011800A8000098ull); } #else #define CVMX_TRA_TRIG0_ADR_ADR (CVMX_ADD_IO_SEG(0x00011800A8000098ull)) #endif #if CVMX_ENABLE_CSR_ADDRESS_CHECKING #define CVMX_TRA_TRIG0_ADR_MSK CVMX_TRA_TRIG0_ADR_MSK_FUNC() static inline uint64_t CVMX_TRA_TRIG0_ADR_MSK_FUNC(void) { if (!(OCTEON_IS_MODEL(OCTEON_CN31XX) || OCTEON_IS_MODEL(OCTEON_CN38XX) || OCTEON_IS_MODEL(OCTEON_CN52XX) || OCTEON_IS_MODEL(OCTEON_CN56XX) || OCTEON_IS_MODEL(OCTEON_CN58XX) || OCTEON_IS_MODEL(OCTEON_CN63XX))) cvmx_warn("CVMX_TRA_TRIG0_ADR_MSK not supported on this chip\n"); return CVMX_ADD_IO_SEG(0x00011800A80000A0ull); } #else #define CVMX_TRA_TRIG0_ADR_MSK (CVMX_ADD_IO_SEG(0x00011800A80000A0ull)) #endif #if CVMX_ENABLE_CSR_ADDRESS_CHECKING #define CVMX_TRA_TRIG0_CMD CVMX_TRA_TRIG0_CMD_FUNC() static inline uint64_t CVMX_TRA_TRIG0_CMD_FUNC(void) { if (!(OCTEON_IS_MODEL(OCTEON_CN31XX) || OCTEON_IS_MODEL(OCTEON_CN38XX) || OCTEON_IS_MODEL(OCTEON_CN52XX) || OCTEON_IS_MODEL(OCTEON_CN56XX) || OCTEON_IS_MODEL(OCTEON_CN58XX) || OCTEON_IS_MODEL(OCTEON_CN63XX))) cvmx_warn("CVMX_TRA_TRIG0_CMD not supported on this chip\n"); return CVMX_ADD_IO_SEG(0x00011800A8000080ull); } #else #define CVMX_TRA_TRIG0_CMD (CVMX_ADD_IO_SEG(0x00011800A8000080ull)) #endif #if CVMX_ENABLE_CSR_ADDRESS_CHECKING #define CVMX_TRA_TRIG0_DID CVMX_TRA_TRIG0_DID_FUNC() static inline uint64_t CVMX_TRA_TRIG0_DID_FUNC(void) { if (!(OCTEON_IS_MODEL(OCTEON_CN31XX) || OCTEON_IS_MODEL(OCTEON_CN38XX) || OCTEON_IS_MODEL(OCTEON_CN52XX) || OCTEON_IS_MODEL(OCTEON_CN56XX) || OCTEON_IS_MODEL(OCTEON_CN58XX) || OCTEON_IS_MODEL(OCTEON_CN63XX))) cvmx_warn("CVMX_TRA_TRIG0_DID not supported on this chip\n"); return CVMX_ADD_IO_SEG(0x00011800A8000090ull); } #else #define CVMX_TRA_TRIG0_DID (CVMX_ADD_IO_SEG(0x00011800A8000090ull)) #endif #if CVMX_ENABLE_CSR_ADDRESS_CHECKING #define CVMX_TRA_TRIG0_SID CVMX_TRA_TRIG0_SID_FUNC() static inline uint64_t CVMX_TRA_TRIG0_SID_FUNC(void) { if (!(OCTEON_IS_MODEL(OCTEON_CN31XX) || OCTEON_IS_MODEL(OCTEON_CN38XX) || OCTEON_IS_MODEL(OCTEON_CN52XX) || OCTEON_IS_MODEL(OCTEON_CN56XX) || OCTEON_IS_MODEL(OCTEON_CN58XX) || OCTEON_IS_MODEL(OCTEON_CN63XX))) cvmx_warn("CVMX_TRA_TRIG0_SID not supported on this chip\n"); return CVMX_ADD_IO_SEG(0x00011800A8000088ull); } #else #define CVMX_TRA_TRIG0_SID (CVMX_ADD_IO_SEG(0x00011800A8000088ull)) #endif #if CVMX_ENABLE_CSR_ADDRESS_CHECKING #define CVMX_TRA_TRIG1_ADR_ADR CVMX_TRA_TRIG1_ADR_ADR_FUNC() static inline uint64_t CVMX_TRA_TRIG1_ADR_ADR_FUNC(void) { if (!(OCTEON_IS_MODEL(OCTEON_CN31XX) || OCTEON_IS_MODEL(OCTEON_CN38XX) || OCTEON_IS_MODEL(OCTEON_CN52XX) || OCTEON_IS_MODEL(OCTEON_CN56XX) || OCTEON_IS_MODEL(OCTEON_CN58XX) || OCTEON_IS_MODEL(OCTEON_CN63XX))) cvmx_warn("CVMX_TRA_TRIG1_ADR_ADR not supported on this chip\n"); return CVMX_ADD_IO_SEG(0x00011800A80000D8ull); } #else #define CVMX_TRA_TRIG1_ADR_ADR (CVMX_ADD_IO_SEG(0x00011800A80000D8ull)) #endif #if CVMX_ENABLE_CSR_ADDRESS_CHECKING #define CVMX_TRA_TRIG1_ADR_MSK CVMX_TRA_TRIG1_ADR_MSK_FUNC() static inline uint64_t CVMX_TRA_TRIG1_ADR_MSK_FUNC(void) { if (!(OCTEON_IS_MODEL(OCTEON_CN31XX) || OCTEON_IS_MODEL(OCTEON_CN38XX) || OCTEON_IS_MODEL(OCTEON_CN52XX) || OCTEON_IS_MODEL(OCTEON_CN56XX) || OCTEON_IS_MODEL(OCTEON_CN58XX) || OCTEON_IS_MODEL(OCTEON_CN63XX))) cvmx_warn("CVMX_TRA_TRIG1_ADR_MSK not supported on this chip\n"); return CVMX_ADD_IO_SEG(0x00011800A80000E0ull); } #else #define CVMX_TRA_TRIG1_ADR_MSK (CVMX_ADD_IO_SEG(0x00011800A80000E0ull)) #endif #if CVMX_ENABLE_CSR_ADDRESS_CHECKING #define CVMX_TRA_TRIG1_CMD CVMX_TRA_TRIG1_CMD_FUNC() static inline uint64_t CVMX_TRA_TRIG1_CMD_FUNC(void) { if (!(OCTEON_IS_MODEL(OCTEON_CN31XX) || OCTEON_IS_MODEL(OCTEON_CN38XX) || OCTEON_IS_MODEL(OCTEON_CN52XX) || OCTEON_IS_MODEL(OCTEON_CN56XX) || OCTEON_IS_MODEL(OCTEON_CN58XX) || OCTEON_IS_MODEL(OCTEON_CN63XX))) cvmx_warn("CVMX_TRA_TRIG1_CMD not supported on this chip\n"); return CVMX_ADD_IO_SEG(0x00011800A80000C0ull); } #else #define CVMX_TRA_TRIG1_CMD (CVMX_ADD_IO_SEG(0x00011800A80000C0ull)) #endif #if CVMX_ENABLE_CSR_ADDRESS_CHECKING #define CVMX_TRA_TRIG1_DID CVMX_TRA_TRIG1_DID_FUNC() static inline uint64_t CVMX_TRA_TRIG1_DID_FUNC(void) { if (!(OCTEON_IS_MODEL(OCTEON_CN31XX) || OCTEON_IS_MODEL(OCTEON_CN38XX) || OCTEON_IS_MODEL(OCTEON_CN52XX) || OCTEON_IS_MODEL(OCTEON_CN56XX) || OCTEON_IS_MODEL(OCTEON_CN58XX) || OCTEON_IS_MODEL(OCTEON_CN63XX))) cvmx_warn("CVMX_TRA_TRIG1_DID not supported on this chip\n"); return CVMX_ADD_IO_SEG(0x00011800A80000D0ull); } #else #define CVMX_TRA_TRIG1_DID (CVMX_ADD_IO_SEG(0x00011800A80000D0ull)) #endif #if CVMX_ENABLE_CSR_ADDRESS_CHECKING #define CVMX_TRA_TRIG1_SID CVMX_TRA_TRIG1_SID_FUNC() static inline uint64_t CVMX_TRA_TRIG1_SID_FUNC(void) { if (!(OCTEON_IS_MODEL(OCTEON_CN31XX) || OCTEON_IS_MODEL(OCTEON_CN38XX) || OCTEON_IS_MODEL(OCTEON_CN52XX) || OCTEON_IS_MODEL(OCTEON_CN56XX) || OCTEON_IS_MODEL(OCTEON_CN58XX) || OCTEON_IS_MODEL(OCTEON_CN63XX))) cvmx_warn("CVMX_TRA_TRIG1_SID not supported on this chip\n"); return CVMX_ADD_IO_SEG(0x00011800A80000C8ull); } #else #define CVMX_TRA_TRIG1_SID (CVMX_ADD_IO_SEG(0x00011800A80000C8ull)) #endif /** * cvmx_tra_bist_status * * TRA_BIST_STATUS = Trace Buffer BiST Status * * Description: */ union cvmx_tra_bist_status { uint64_t u64; struct cvmx_tra_bist_status_s { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t reserved_3_63 : 61; uint64_t tcf : 1; /**< Bist Results for TCF memory - 0: GOOD (or bist in progress/never run) - 1: BAD */ uint64_t tdf1 : 1; /**< Bist Results for TDF memory 1 - 0: GOOD (or bist in progress/never run) - 1: BAD */ uint64_t reserved_0_0 : 1; #else uint64_t reserved_0_0 : 1; uint64_t tdf1 : 1; uint64_t tcf : 1; uint64_t reserved_3_63 : 61; #endif } s; struct cvmx_tra_bist_status_cn31xx { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t reserved_3_63 : 61; uint64_t tcf : 1; /**< Bist Results for TCF memory - 0: GOOD (or bist in progress/never run) - 1: BAD */ uint64_t tdf1 : 1; /**< Bist Results for TDF memory 1 - 0: GOOD (or bist in progress/never run) - 1: BAD */ uint64_t tdf0 : 1; /**< Bist Results for TCF memory 0 - 0: GOOD (or bist in progress/never run) - 1: BAD */ #else uint64_t tdf0 : 1; uint64_t tdf1 : 1; uint64_t tcf : 1; uint64_t reserved_3_63 : 61; #endif } cn31xx; struct cvmx_tra_bist_status_cn31xx cn38xx; struct cvmx_tra_bist_status_cn31xx cn38xxp2; struct cvmx_tra_bist_status_cn31xx cn52xx; struct cvmx_tra_bist_status_cn31xx cn52xxp1; struct cvmx_tra_bist_status_cn31xx cn56xx; struct cvmx_tra_bist_status_cn31xx cn56xxp1; struct cvmx_tra_bist_status_cn31xx cn58xx; struct cvmx_tra_bist_status_cn31xx cn58xxp1; struct cvmx_tra_bist_status_cn63xx { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t reserved_1_63 : 63; uint64_t tdf : 1; /**< Bist Results for TCF memory - 0: GOOD (or bist in progress/never run) - 1: BAD */ #else uint64_t tdf : 1; uint64_t reserved_1_63 : 63; #endif } cn63xx; struct cvmx_tra_bist_status_cn63xx cn63xxp1; }; typedef union cvmx_tra_bist_status cvmx_tra_bist_status_t; /** * cvmx_tra_ctl * * TRA_CTL = Trace Buffer Control * * Description: * * Notes: * It is illegal to change the values of WRAP, TRIG_CTL, IGNORE_O while tracing (i.e. when ENA=1). * Note that the following fields are present only in chip revisions beginning with pass2: IGNORE_O */ union cvmx_tra_ctl { uint64_t u64; struct cvmx_tra_ctl_s { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t reserved_17_63 : 47; uint64_t rdat_md : 1; /**< TRA_READ_DAT mode bit If set, the TRA_READ_DAT reads will return the lower 64 bits of the TRA entry and the upper bits must be read through TRA_READ_DAT_HI. If not set the return value from TRA_READ_DAT accesses will switch between the lower bits and the upper bits of the TRA entry. */ uint64_t clkalways : 1; /**< Conditional clock enable If set, the TRA clock is never disabled. */ uint64_t ignore_o : 1; /**< Ignore overflow during wrap mode If set and wrapping mode is enabled, then tracing will not stop at the overflow condition. Each write during an overflow will overwrite the oldest, unread entry and the read pointer is incremented by one entry. This bit has no effect if WRAP=0. */ uint64_t mcd0_ena : 1; /**< MCD0 enable If set and any PP sends the MCD0 signal, the tracing is disabled. */ uint64_t mcd0_thr : 1; /**< MCD0_threshold At a fill threshold event, sends an MCD0 wire pulse that can cause cores to enter debug mode, if enabled. This MCD0 wire pulse will not occur while (TRA_INT_STATUS.MCD0_THR == 1). */ uint64_t mcd0_trg : 1; /**< MCD0_trigger At an end trigger event, sends an MCD0 wire pulse that can cause cores to enter debug mode, if enabled. This MCD0 wire pulse will not occur while (TRA_INT_STATUS.MCD0_TRG == 1). */ uint64_t ciu_thr : 1; /**< CIU_threshold When set during a fill threshold event, TRA_INT_STATUS[CIU_THR] is set, which can cause core interrupts, if enabled. */ uint64_t ciu_trg : 1; /**< CIU_trigger When set during an end trigger event, TRA_INT_STATUS[CIU_TRG] is set, which can cause core interrupts, if enabled. */ uint64_t full_thr : 2; /**< Full Threshhold 0=none 1=1/2 full 2=3/4 full 3=4/4 full */ uint64_t time_grn : 3; /**< Timestamp granularity granularity=8^n cycles, n=0,1,2,3,4,5,6,7 */ uint64_t trig_ctl : 2; /**< Trigger Control Note: trigger events are written to the trace 0=no triggers 1=trigger0=start trigger, trigger1=stop trigger 2=(trigger0 || trigger1)=start trigger 3=(trigger0 || trigger1)=stop trigger */ uint64_t wrap : 1; /**< Wrap mode When WRAP=0, the trace buffer will disable itself after having logged 1024 entries. When WRAP=1, the trace buffer will never disable itself. In this case, tracing may or may not be temporarily suspended during the overflow condition (see IGNORE_O above). 0=do not wrap 1=wrap */ uint64_t ena : 1; /**< Enable Trace Master enable. Tracing only happens when ENA=1. When ENA changes from 0 to 1, the read and write pointers are reset to 0x00 to begin a new trace. The MCD0 event may set ENA=0 (see MCD0_ENA above). When using triggers, tracing occurs only between start and stop triggers (including the triggers themselves). 0=disable 1=enable */ #else uint64_t ena : 1; uint64_t wrap : 1; uint64_t trig_ctl : 2; uint64_t time_grn : 3; uint64_t full_thr : 2; uint64_t ciu_trg : 1; uint64_t ciu_thr : 1; uint64_t mcd0_trg : 1; uint64_t mcd0_thr : 1; uint64_t mcd0_ena : 1; uint64_t ignore_o : 1; uint64_t clkalways : 1; uint64_t rdat_md : 1; uint64_t reserved_17_63 : 47; #endif } s; struct cvmx_tra_ctl_cn31xx { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t reserved_15_63 : 49; uint64_t ignore_o : 1; /**< Ignore overflow during wrap mode If set and wrapping mode is enabled, then tracing will not stop at the overflow condition. Each write during an overflow will overwrite the oldest, unread entry and the read pointer is incremented by one entry. This bit has no effect if WRAP=0. */ uint64_t mcd0_ena : 1; /**< MCD0 enable If set and any PP sends the MCD0 signal, the tracing is disabled. */ uint64_t mcd0_thr : 1; /**< MCD0_threshold At a fill threshold event, sends an MCD0 wire pulse that can cause cores to enter debug mode, if enabled. This MCD0 wire pulse will not occur while (TRA_INT_STATUS.MCD0_THR == 1). */ uint64_t mcd0_trg : 1; /**< MCD0_trigger At an end trigger event, sends an MCD0 wire pulse that can cause cores to enter debug mode, if enabled. This MCD0 wire pulse will not occur while (TRA_INT_STATUS.MCD0_TRG == 1). */ uint64_t ciu_thr : 1; /**< CIU_threshold When set during a fill threshold event, TRA_INT_STATUS[CIU_THR] is set, which can cause core interrupts, if enabled. */ uint64_t ciu_trg : 1; /**< CIU_trigger When set during an end trigger event, TRA_INT_STATUS[CIU_TRG] is set, which can cause core interrupts, if enabled. */ uint64_t full_thr : 2; /**< Full Threshhold 0=none 1=1/2 full 2=3/4 full 3=4/4 full */ uint64_t time_grn : 3; /**< Timestamp granularity granularity=8^n cycles, n=0,1,2,3,4,5,6,7 */ uint64_t trig_ctl : 2; /**< Trigger Control Note: trigger events are written to the trace 0=no triggers 1=trigger0=start trigger, trigger1=stop trigger 2=(trigger0 || trigger1)=start trigger 3=(trigger0 || trigger1)=stop trigger */ uint64_t wrap : 1; /**< Wrap mode When WRAP=0, the trace buffer will disable itself after having logged 256 entries. When WRAP=1, the trace buffer will never disable itself. In this case, tracing may or may not be temporarily suspended during the overflow condition (see IGNORE_O above). 0=do not wrap 1=wrap */ uint64_t ena : 1; /**< Enable Trace Master enable. Tracing only happens when ENA=1. When ENA changes from 0 to 1, the read and write pointers are reset to 0x00 to begin a new trace. The MCD0 event may set ENA=0 (see MCD0_ENA above). When using triggers, tracing occurs only between start and stop triggers (including the triggers themselves). 0=disable 1=enable */ #else uint64_t ena : 1; uint64_t wrap : 1; uint64_t trig_ctl : 2; uint64_t time_grn : 3; uint64_t full_thr : 2; uint64_t ciu_trg : 1; uint64_t ciu_thr : 1; uint64_t mcd0_trg : 1; uint64_t mcd0_thr : 1; uint64_t mcd0_ena : 1; uint64_t ignore_o : 1; uint64_t reserved_15_63 : 49; #endif } cn31xx; struct cvmx_tra_ctl_cn31xx cn38xx; struct cvmx_tra_ctl_cn31xx cn38xxp2; struct cvmx_tra_ctl_cn31xx cn52xx; struct cvmx_tra_ctl_cn31xx cn52xxp1; struct cvmx_tra_ctl_cn31xx cn56xx; struct cvmx_tra_ctl_cn31xx cn56xxp1; struct cvmx_tra_ctl_cn31xx cn58xx; struct cvmx_tra_ctl_cn31xx cn58xxp1; struct cvmx_tra_ctl_s cn63xx; struct cvmx_tra_ctl_cn63xxp1 { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t reserved_16_63 : 48; uint64_t clkalways : 1; /**< Conditional clock enable If set, the TRA clock is never disabled. */ uint64_t ignore_o : 1; /**< Ignore overflow during wrap mode If set and wrapping mode is enabled, then tracing will not stop at the overflow condition. Each write during an overflow will overwrite the oldest, unread entry and the read pointer is incremented by one entry. This bit has no effect if WRAP=0. */ uint64_t mcd0_ena : 1; /**< MCD0 enable If set and any PP sends the MCD0 signal, the tracing is disabled. */ uint64_t mcd0_thr : 1; /**< MCD0_threshold At a fill threshold event, sends an MCD0 wire pulse that can cause cores to enter debug mode, if enabled. This MCD0 wire pulse will not occur while (TRA_INT_STATUS.MCD0_THR == 1). */ uint64_t mcd0_trg : 1; /**< MCD0_trigger At an end trigger event, sends an MCD0 wire pulse that can cause cores to enter debug mode, if enabled. This MCD0 wire pulse will not occur while (TRA_INT_STATUS.MCD0_TRG == 1). */ uint64_t ciu_thr : 1; /**< CIU_threshold When set during a fill threshold event, TRA_INT_STATUS[CIU_THR] is set, which can cause core interrupts, if enabled. */ uint64_t ciu_trg : 1; /**< CIU_trigger When set during an end trigger event, TRA_INT_STATUS[CIU_TRG] is set, which can cause core interrupts, if enabled. */ uint64_t full_thr : 2; /**< Full Threshhold 0=none 1=1/2 full 2=3/4 full 3=4/4 full */ uint64_t time_grn : 3; /**< Timestamp granularity granularity=8^n cycles, n=0,1,2,3,4,5,6,7 */ uint64_t trig_ctl : 2; /**< Trigger Control Note: trigger events are written to the trace 0=no triggers 1=trigger0=start trigger, trigger1=stop trigger 2=(trigger0 || trigger1)=start trigger 3=(trigger0 || trigger1)=stop trigger */ uint64_t wrap : 1; /**< Wrap mode When WRAP=0, the trace buffer will disable itself after having logged 1024 entries. When WRAP=1, the trace buffer will never disable itself. In this case, tracing may or may not be temporarily suspended during the overflow condition (see IGNORE_O above). 0=do not wrap 1=wrap */ uint64_t ena : 1; /**< Enable Trace Master enable. Tracing only happens when ENA=1. When ENA changes from 0 to 1, the read and write pointers are reset to 0x00 to begin a new trace. The MCD0 event may set ENA=0 (see MCD0_ENA above). When using triggers, tracing occurs only between start and stop triggers (including the triggers themselves). 0=disable 1=enable */ #else uint64_t ena : 1; uint64_t wrap : 1; uint64_t trig_ctl : 2; uint64_t time_grn : 3; uint64_t full_thr : 2; uint64_t ciu_trg : 1; uint64_t ciu_thr : 1; uint64_t mcd0_trg : 1; uint64_t mcd0_thr : 1; uint64_t mcd0_ena : 1; uint64_t ignore_o : 1; uint64_t clkalways : 1; uint64_t reserved_16_63 : 48; #endif } cn63xxp1; }; typedef union cvmx_tra_ctl cvmx_tra_ctl_t; /** * cvmx_tra_cycles_since * * TRA_CYCLES_SINCE = Trace Buffer Cycles Since Last Write, Read/Write pointers * * Description: * * Notes: * This CSR is obsolete. Use TRA_CYCLES_SINCE1 instead. * */ union cvmx_tra_cycles_since { uint64_t u64; struct cvmx_tra_cycles_since_s { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t cycles : 48; /**< Cycles since the last entry was written */ uint64_t rptr : 8; /**< Read pointer */ uint64_t wptr : 8; /**< Write pointer */ #else uint64_t wptr : 8; uint64_t rptr : 8; uint64_t cycles : 48; #endif } s; struct cvmx_tra_cycles_since_s cn31xx; struct cvmx_tra_cycles_since_s cn38xx; struct cvmx_tra_cycles_since_s cn38xxp2; struct cvmx_tra_cycles_since_s cn52xx; struct cvmx_tra_cycles_since_s cn52xxp1; struct cvmx_tra_cycles_since_s cn56xx; struct cvmx_tra_cycles_since_s cn56xxp1; struct cvmx_tra_cycles_since_s cn58xx; struct cvmx_tra_cycles_since_s cn58xxp1; struct cvmx_tra_cycles_since_s cn63xx; struct cvmx_tra_cycles_since_s cn63xxp1; }; typedef union cvmx_tra_cycles_since cvmx_tra_cycles_since_t; /** * cvmx_tra_cycles_since1 * * TRA_CYCLES_SINCE1 = Trace Buffer Cycles Since Last Write, Read/Write pointers * * Description: */ union cvmx_tra_cycles_since1 { uint64_t u64; struct cvmx_tra_cycles_since1_s { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t cycles : 40; /**< Cycles since the last entry was written */ uint64_t reserved_22_23 : 2; uint64_t rptr : 10; /**< Read pointer */ uint64_t reserved_10_11 : 2; uint64_t wptr : 10; /**< Write pointer */ #else uint64_t wptr : 10; uint64_t reserved_10_11 : 2; uint64_t rptr : 10; uint64_t reserved_22_23 : 2; uint64_t cycles : 40; #endif } s; struct cvmx_tra_cycles_since1_s cn52xx; struct cvmx_tra_cycles_since1_s cn52xxp1; struct cvmx_tra_cycles_since1_s cn56xx; struct cvmx_tra_cycles_since1_s cn56xxp1; struct cvmx_tra_cycles_since1_s cn58xx; struct cvmx_tra_cycles_since1_s cn58xxp1; struct cvmx_tra_cycles_since1_s cn63xx; struct cvmx_tra_cycles_since1_s cn63xxp1; }; typedef union cvmx_tra_cycles_since1 cvmx_tra_cycles_since1_t; /** * cvmx_tra_filt_adr_adr * * TRA_FILT_ADR_ADR = Trace Buffer Filter Address Address * * Description: */ union cvmx_tra_filt_adr_adr { uint64_t u64; struct cvmx_tra_filt_adr_adr_s { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t reserved_38_63 : 26; uint64_t adr : 38; /**< Unmasked Address The combination of TRA_FILT_ADR_ADR and TRA_FILT_ADR_MSK is a masked address to enable tracing of only those commands whose masked address matches */ #else uint64_t adr : 38; uint64_t reserved_38_63 : 26; #endif } s; struct cvmx_tra_filt_adr_adr_cn31xx { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t reserved_36_63 : 28; uint64_t adr : 36; /**< Unmasked Address The combination of TRA_FILT_ADR_ADR and TRA_FILT_ADR_MSK is a masked address to enable tracing of only those commands whose masked address matches */ #else uint64_t adr : 36; uint64_t reserved_36_63 : 28; #endif } cn31xx; struct cvmx_tra_filt_adr_adr_cn31xx cn38xx; struct cvmx_tra_filt_adr_adr_cn31xx cn38xxp2; struct cvmx_tra_filt_adr_adr_cn31xx cn52xx; struct cvmx_tra_filt_adr_adr_cn31xx cn52xxp1; struct cvmx_tra_filt_adr_adr_cn31xx cn56xx; struct cvmx_tra_filt_adr_adr_cn31xx cn56xxp1; struct cvmx_tra_filt_adr_adr_cn31xx cn58xx; struct cvmx_tra_filt_adr_adr_cn31xx cn58xxp1; struct cvmx_tra_filt_adr_adr_s cn63xx; struct cvmx_tra_filt_adr_adr_s cn63xxp1; }; typedef union cvmx_tra_filt_adr_adr cvmx_tra_filt_adr_adr_t; /** * cvmx_tra_filt_adr_msk * * TRA_FILT_ADR_MSK = Trace Buffer Filter Address Mask * * Description: */ union cvmx_tra_filt_adr_msk { uint64_t u64; struct cvmx_tra_filt_adr_msk_s { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t reserved_38_63 : 26; uint64_t adr : 38; /**< Address Mask The combination of TRA_FILT_ADR_ADR and TRA_FILT_ADR_MSK is a masked address to enable tracing of only those commands whose masked address matches. When a mask bit is not set, the corresponding address bits are assumed to match. Also, note that IOBDMAs do not have proper addresses, so when TRA_FILT_CMD[IOBDMA] is set, TRA_FILT_ADR_MSK must be zero to guarantee that any IOBDMAs enter the trace. */ #else uint64_t adr : 38; uint64_t reserved_38_63 : 26; #endif } s; struct cvmx_tra_filt_adr_msk_cn31xx { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t reserved_36_63 : 28; uint64_t adr : 36; /**< Address Mask The combination of TRA_FILT_ADR_ADR and TRA_FILT_ADR_MSK is a masked address to enable tracing of only those commands whose masked address matches. When a mask bit is not set, the corresponding address bits are assumed to match. Also, note that IOBDMAs do not have proper addresses, so when TRA_FILT_CMD[IOBDMA] is set, TRA_FILT_ADR_MSK must be zero to guarantee that any IOBDMAs enter the trace. */ #else uint64_t adr : 36; uint64_t reserved_36_63 : 28; #endif } cn31xx; struct cvmx_tra_filt_adr_msk_cn31xx cn38xx; struct cvmx_tra_filt_adr_msk_cn31xx cn38xxp2; struct cvmx_tra_filt_adr_msk_cn31xx cn52xx; struct cvmx_tra_filt_adr_msk_cn31xx cn52xxp1; struct cvmx_tra_filt_adr_msk_cn31xx cn56xx; struct cvmx_tra_filt_adr_msk_cn31xx cn56xxp1; struct cvmx_tra_filt_adr_msk_cn31xx cn58xx; struct cvmx_tra_filt_adr_msk_cn31xx cn58xxp1; struct cvmx_tra_filt_adr_msk_s cn63xx; struct cvmx_tra_filt_adr_msk_s cn63xxp1; }; typedef union cvmx_tra_filt_adr_msk cvmx_tra_filt_adr_msk_t; /** * cvmx_tra_filt_cmd * * TRA_FILT_CMD = Trace Buffer Filter Command Mask * * Description: * * Notes: * Note that the trace buffer does not do proper IOBDMA address compares. Thus, if IOBDMA is set, then * the address compare must be disabled (i.e. TRA_FILT_ADR_MSK set to zero) to guarantee that IOBDMAs * enter the trace. */ union cvmx_tra_filt_cmd { uint64_t u64; struct cvmx_tra_filt_cmd_s { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t saa64 : 1; /**< Enable SAA64 tracing 0=disable, 1=enable */ uint64_t saa32 : 1; /**< Enable SAA32 tracing 0=disable, 1=enable */ uint64_t reserved_60_61 : 2; uint64_t faa64 : 1; /**< Enable FAA64 tracing 0=disable, 1=enable */ uint64_t faa32 : 1; /**< Enable FAA32 tracing 0=disable, 1=enable */ uint64_t reserved_56_57 : 2; uint64_t decr64 : 1; /**< Enable DECR64 tracing 0=disable, 1=enable */ uint64_t decr32 : 1; /**< Enable DECR32 tracing 0=disable, 1=enable */ uint64_t decr16 : 1; /**< Enable DECR16 tracing 0=disable, 1=enable */ uint64_t decr8 : 1; /**< Enable DECR8 tracing 0=disable, 1=enable */ uint64_t incr64 : 1; /**< Enable INCR64 tracing 0=disable, 1=enable */ uint64_t incr32 : 1; /**< Enable INCR32 tracing 0=disable, 1=enable */ uint64_t incr16 : 1; /**< Enable INCR16 tracing 0=disable, 1=enable */ uint64_t incr8 : 1; /**< Enable INCR8 tracing 0=disable, 1=enable */ uint64_t clr64 : 1; /**< Enable CLR64 tracing 0=disable, 1=enable */ uint64_t clr32 : 1; /**< Enable CLR32 tracing 0=disable, 1=enable */ uint64_t clr16 : 1; /**< Enable CLR16 tracing 0=disable, 1=enable */ uint64_t clr8 : 1; /**< Enable CLR8 tracing 0=disable, 1=enable */ uint64_t set64 : 1; /**< Enable SET64 tracing 0=disable, 1=enable */ uint64_t set32 : 1; /**< Enable SET32 tracing 0=disable, 1=enable */ uint64_t set16 : 1; /**< Enable SET16 tracing 0=disable, 1=enable */ uint64_t set8 : 1; /**< Enable SET8 tracing 0=disable, 1=enable */ uint64_t iobst64 : 1; /**< Enable IOBST64 tracing 0=disable, 1=enable */ uint64_t iobst32 : 1; /**< Enable IOBST32 tracing 0=disable, 1=enable */ uint64_t iobst16 : 1; /**< Enable IOBST16 tracing 0=disable, 1=enable */ uint64_t iobst8 : 1; /**< Enable IOBST8 tracing 0=disable, 1=enable */ uint64_t reserved_32_35 : 4; uint64_t lckl2 : 1; /**< Enable LCKL2 tracing 0=disable, 1=enable */ uint64_t wbl2 : 1; /**< Enable WBL2 tracing 0=disable, 1=enable */ uint64_t wbil2 : 1; /**< Enable WBIL2 tracing 0=disable, 1=enable */ uint64_t invl2 : 1; /**< Enable INVL2 tracing 0=disable, 1=enable */ uint64_t reserved_27_27 : 1; uint64_t stgl2i : 1; /**< Enable STGL2I tracing 0=disable, 1=enable */ uint64_t ltgl2i : 1; /**< Enable LTGL2I tracing 0=disable, 1=enable */ uint64_t wbil2i : 1; /**< Enable WBIL2I tracing 0=disable, 1=enable */ uint64_t fas64 : 1; /**< Enable FAS64 tracing 0=disable, 1=enable */ uint64_t fas32 : 1; /**< Enable FAS32 tracing 0=disable, 1=enable */ uint64_t sttil1 : 1; /**< Enable STTIL1 tracing 0=disable, 1=enable */ uint64_t stfil1 : 1; /**< Enable STFIL1 tracing 0=disable, 1=enable */ uint64_t reserved_16_19 : 4; uint64_t iobdma : 1; /**< Enable IOBDMA tracing 0=disable, 1=enable */ uint64_t iobst : 1; /**< Enable IOBST tracing 0=disable, 1=enable */ uint64_t reserved_0_13 : 14; #else uint64_t reserved_0_13 : 14; uint64_t iobst : 1; uint64_t iobdma : 1; uint64_t reserved_16_19 : 4; uint64_t stfil1 : 1; uint64_t sttil1 : 1; uint64_t fas32 : 1; uint64_t fas64 : 1; uint64_t wbil2i : 1; uint64_t ltgl2i : 1; uint64_t stgl2i : 1; uint64_t reserved_27_27 : 1; uint64_t invl2 : 1; uint64_t wbil2 : 1; uint64_t wbl2 : 1; uint64_t lckl2 : 1; uint64_t reserved_32_35 : 4; uint64_t iobst8 : 1; uint64_t iobst16 : 1; uint64_t iobst32 : 1; uint64_t iobst64 : 1; uint64_t set8 : 1; uint64_t set16 : 1; uint64_t set32 : 1; uint64_t set64 : 1; uint64_t clr8 : 1; uint64_t clr16 : 1; uint64_t clr32 : 1; uint64_t clr64 : 1; uint64_t incr8 : 1; uint64_t incr16 : 1; uint64_t incr32 : 1; uint64_t incr64 : 1; uint64_t decr8 : 1; uint64_t decr16 : 1; uint64_t decr32 : 1; uint64_t decr64 : 1; uint64_t reserved_56_57 : 2; uint64_t faa32 : 1; uint64_t faa64 : 1; uint64_t reserved_60_61 : 2; uint64_t saa32 : 1; uint64_t saa64 : 1; #endif } s; struct cvmx_tra_filt_cmd_cn31xx { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t reserved_16_63 : 48; uint64_t iobdma : 1; /**< Enable IOBDMA tracing 0=disable, 1=enable */ uint64_t iobst : 1; /**< Enable IOBST tracing 0=disable, 1=enable */ uint64_t iobld64 : 1; /**< Enable IOBLD64 tracing 0=disable, 1=enable */ uint64_t iobld32 : 1; /**< Enable IOBLD32 tracing 0=disable, 1=enable */ uint64_t iobld16 : 1; /**< Enable IOBLD16 tracing 0=disable, 1=enable */ uint64_t iobld8 : 1; /**< Enable IOBLD8 tracing 0=disable, 1=enable */ uint64_t stt : 1; /**< Enable STT tracing 0=disable, 1=enable */ uint64_t stp : 1; /**< Enable STP tracing 0=disable, 1=enable */ uint64_t stc : 1; /**< Enable STC tracing 0=disable, 1=enable */ uint64_t stf : 1; /**< Enable STF tracing 0=disable, 1=enable */ uint64_t ldt : 1; /**< Enable LDT tracing 0=disable, 1=enable */ uint64_t ldi : 1; /**< Enable LDI tracing 0=disable, 1=enable */ uint64_t ldd : 1; /**< Enable LDD tracing 0=disable, 1=enable */ uint64_t psl1 : 1; /**< Enable PSL1 tracing 0=disable, 1=enable */ uint64_t pl2 : 1; /**< Enable PL2 tracing 0=disable, 1=enable */ uint64_t dwb : 1; /**< Enable DWB tracing 0=disable, 1=enable */ #else uint64_t dwb : 1; uint64_t pl2 : 1; uint64_t psl1 : 1; uint64_t ldd : 1; uint64_t ldi : 1; uint64_t ldt : 1; uint64_t stf : 1; uint64_t stc : 1; uint64_t stp : 1; uint64_t stt : 1; uint64_t iobld8 : 1; uint64_t iobld16 : 1; uint64_t iobld32 : 1; uint64_t iobld64 : 1; uint64_t iobst : 1; uint64_t iobdma : 1; uint64_t reserved_16_63 : 48; #endif } cn31xx; struct cvmx_tra_filt_cmd_cn31xx cn38xx; struct cvmx_tra_filt_cmd_cn31xx cn38xxp2; struct cvmx_tra_filt_cmd_cn52xx { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t reserved_17_63 : 47; uint64_t saa : 1; /**< Enable SAA tracing 0=disable, 1=enable */ uint64_t iobdma : 1; /**< Enable IOBDMA tracing 0=disable, 1=enable */ uint64_t iobst : 1; /**< Enable IOBST tracing 0=disable, 1=enable */ uint64_t iobld64 : 1; /**< Enable IOBLD64 tracing 0=disable, 1=enable */ uint64_t iobld32 : 1; /**< Enable IOBLD32 tracing 0=disable, 1=enable */ uint64_t iobld16 : 1; /**< Enable IOBLD16 tracing 0=disable, 1=enable */ uint64_t iobld8 : 1; /**< Enable IOBLD8 tracing 0=disable, 1=enable */ uint64_t stt : 1; /**< Enable STT tracing 0=disable, 1=enable */ uint64_t stp : 1; /**< Enable STP tracing 0=disable, 1=enable */ uint64_t stc : 1; /**< Enable STC tracing 0=disable, 1=enable */ uint64_t stf : 1; /**< Enable STF tracing 0=disable, 1=enable */ uint64_t ldt : 1; /**< Enable LDT tracing 0=disable, 1=enable */ uint64_t ldi : 1; /**< Enable LDI tracing 0=disable, 1=enable */ uint64_t ldd : 1; /**< Enable LDD tracing 0=disable, 1=enable */ uint64_t psl1 : 1; /**< Enable PSL1 tracing 0=disable, 1=enable */ uint64_t pl2 : 1; /**< Enable PL2 tracing 0=disable, 1=enable */ uint64_t dwb : 1; /**< Enable DWB tracing 0=disable, 1=enable */ #else uint64_t dwb : 1; uint64_t pl2 : 1; uint64_t psl1 : 1; uint64_t ldd : 1; uint64_t ldi : 1; uint64_t ldt : 1; uint64_t stf : 1; uint64_t stc : 1; uint64_t stp : 1; uint64_t stt : 1; uint64_t iobld8 : 1; uint64_t iobld16 : 1; uint64_t iobld32 : 1; uint64_t iobld64 : 1; uint64_t iobst : 1; uint64_t iobdma : 1; uint64_t saa : 1; uint64_t reserved_17_63 : 47; #endif } cn52xx; struct cvmx_tra_filt_cmd_cn52xx cn52xxp1; struct cvmx_tra_filt_cmd_cn52xx cn56xx; struct cvmx_tra_filt_cmd_cn52xx cn56xxp1; struct cvmx_tra_filt_cmd_cn52xx cn58xx; struct cvmx_tra_filt_cmd_cn52xx cn58xxp1; struct cvmx_tra_filt_cmd_cn63xx { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t saa64 : 1; /**< Enable SAA64 tracing 0=disable, 1=enable */ uint64_t saa32 : 1; /**< Enable SAA32 tracing 0=disable, 1=enable */ uint64_t reserved_60_61 : 2; uint64_t faa64 : 1; /**< Enable FAA64 tracing 0=disable, 1=enable */ uint64_t faa32 : 1; /**< Enable FAA32 tracing 0=disable, 1=enable */ uint64_t reserved_56_57 : 2; uint64_t decr64 : 1; /**< Enable DECR64 tracing 0=disable, 1=enable */ uint64_t decr32 : 1; /**< Enable DECR32 tracing 0=disable, 1=enable */ uint64_t decr16 : 1; /**< Enable DECR16 tracing 0=disable, 1=enable */ uint64_t decr8 : 1; /**< Enable DECR8 tracing 0=disable, 1=enable */ uint64_t incr64 : 1; /**< Enable INCR64 tracing 0=disable, 1=enable */ uint64_t incr32 : 1; /**< Enable INCR32 tracing 0=disable, 1=enable */ uint64_t incr16 : 1; /**< Enable INCR16 tracing 0=disable, 1=enable */ uint64_t incr8 : 1; /**< Enable INCR8 tracing 0=disable, 1=enable */ uint64_t clr64 : 1; /**< Enable CLR64 tracing 0=disable, 1=enable */ uint64_t clr32 : 1; /**< Enable CLR32 tracing 0=disable, 1=enable */ uint64_t clr16 : 1; /**< Enable CLR16 tracing 0=disable, 1=enable */ uint64_t clr8 : 1; /**< Enable CLR8 tracing 0=disable, 1=enable */ uint64_t set64 : 1; /**< Enable SET64 tracing 0=disable, 1=enable */ uint64_t set32 : 1; /**< Enable SET32 tracing 0=disable, 1=enable */ uint64_t set16 : 1; /**< Enable SET16 tracing 0=disable, 1=enable */ uint64_t set8 : 1; /**< Enable SET8 tracing 0=disable, 1=enable */ uint64_t iobst64 : 1; /**< Enable IOBST64 tracing 0=disable, 1=enable */ uint64_t iobst32 : 1; /**< Enable IOBST32 tracing 0=disable, 1=enable */ uint64_t iobst16 : 1; /**< Enable IOBST16 tracing 0=disable, 1=enable */ uint64_t iobst8 : 1; /**< Enable IOBST8 tracing 0=disable, 1=enable */ uint64_t iobld64 : 1; /**< Enable IOBLD64 tracing 0=disable, 1=enable */ uint64_t iobld32 : 1; /**< Enable IOBLD32 tracing 0=disable, 1=enable */ uint64_t iobld16 : 1; /**< Enable IOBLD16 tracing 0=disable, 1=enable */ uint64_t iobld8 : 1; /**< Enable IOBLD8 tracing 0=disable, 1=enable */ uint64_t lckl2 : 1; /**< Enable LCKL2 tracing 0=disable, 1=enable */ uint64_t wbl2 : 1; /**< Enable WBL2 tracing 0=disable, 1=enable */ uint64_t wbil2 : 1; /**< Enable WBIL2 tracing 0=disable, 1=enable */ uint64_t invl2 : 1; /**< Enable INVL2 tracing 0=disable, 1=enable */ uint64_t reserved_27_27 : 1; uint64_t stgl2i : 1; /**< Enable STGL2I tracing 0=disable, 1=enable */ uint64_t ltgl2i : 1; /**< Enable LTGL2I tracing 0=disable, 1=enable */ uint64_t wbil2i : 1; /**< Enable WBIL2I tracing 0=disable, 1=enable */ uint64_t fas64 : 1; /**< Enable FAS64 tracing 0=disable, 1=enable */ uint64_t fas32 : 1; /**< Enable FAS32 tracing 0=disable, 1=enable */ uint64_t sttil1 : 1; /**< Enable STTIL1 tracing 0=disable, 1=enable */ uint64_t stfil1 : 1; /**< Enable STFIL1 tracing 0=disable, 1=enable */ uint64_t stc : 1; /**< Enable STC tracing 0=disable, 1=enable */ uint64_t stp : 1; /**< Enable STP tracing 0=disable, 1=enable */ uint64_t stt : 1; /**< Enable STT tracing 0=disable, 1=enable */ uint64_t stf : 1; /**< Enable STF tracing 0=disable, 1=enable */ uint64_t iobdma : 1; /**< Enable IOBDMA tracing 0=disable, 1=enable */ uint64_t reserved_10_14 : 5; uint64_t psl1 : 1; /**< Enable PSL1 tracing 0=disable, 1=enable */ uint64_t ldd : 1; /**< Enable LDD tracing 0=disable, 1=enable */ uint64_t reserved_6_7 : 2; uint64_t dwb : 1; /**< Enable DWB tracing 0=disable, 1=enable */ uint64_t rpl2 : 1; /**< Enable RPL2 tracing 0=disable, 1=enable */ uint64_t pl2 : 1; /**< Enable PL2 tracing 0=disable, 1=enable */ uint64_t ldi : 1; /**< Enable LDI tracing 0=disable, 1=enable */ uint64_t ldt : 1; /**< Enable LDT tracing 0=disable, 1=enable */ uint64_t nop : 1; /**< Enable NOP tracing 0=disable, 1=enable */ #else uint64_t nop : 1; uint64_t ldt : 1; uint64_t ldi : 1; uint64_t pl2 : 1; uint64_t rpl2 : 1; uint64_t dwb : 1; uint64_t reserved_6_7 : 2; uint64_t ldd : 1; uint64_t psl1 : 1; uint64_t reserved_10_14 : 5; uint64_t iobdma : 1; uint64_t stf : 1; uint64_t stt : 1; uint64_t stp : 1; uint64_t stc : 1; uint64_t stfil1 : 1; uint64_t sttil1 : 1; uint64_t fas32 : 1; uint64_t fas64 : 1; uint64_t wbil2i : 1; uint64_t ltgl2i : 1; uint64_t stgl2i : 1; uint64_t reserved_27_27 : 1; uint64_t invl2 : 1; uint64_t wbil2 : 1; uint64_t wbl2 : 1; uint64_t lckl2 : 1; uint64_t iobld8 : 1; uint64_t iobld16 : 1; uint64_t iobld32 : 1; uint64_t iobld64 : 1; uint64_t iobst8 : 1; uint64_t iobst16 : 1; uint64_t iobst32 : 1; uint64_t iobst64 : 1; uint64_t set8 : 1; uint64_t set16 : 1; uint64_t set32 : 1; uint64_t set64 : 1; uint64_t clr8 : 1; uint64_t clr16 : 1; uint64_t clr32 : 1; uint64_t clr64 : 1; uint64_t incr8 : 1; uint64_t incr16 : 1; uint64_t incr32 : 1; uint64_t incr64 : 1; uint64_t decr8 : 1; uint64_t decr16 : 1; uint64_t decr32 : 1; uint64_t decr64 : 1; uint64_t reserved_56_57 : 2; uint64_t faa32 : 1; uint64_t faa64 : 1; uint64_t reserved_60_61 : 2; uint64_t saa32 : 1; uint64_t saa64 : 1; #endif } cn63xx; struct cvmx_tra_filt_cmd_cn63xx cn63xxp1; }; typedef union cvmx_tra_filt_cmd cvmx_tra_filt_cmd_t; /** * cvmx_tra_filt_did * * TRA_FILT_DID = Trace Buffer Filter DestinationId Mask * * Description: */ union cvmx_tra_filt_did { uint64_t u64; struct cvmx_tra_filt_did_s { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t reserved_13_63 : 51; uint64_t pow : 1; /**< Enable tracing of requests to POW (get work, add work, status/memory/index loads, NULLRd loads, CSR's) */ uint64_t reserved_9_11 : 3; uint64_t rng : 1; /**< Enable tracing of requests to RNG (loads/IOBDMA's are legal) */ uint64_t zip : 1; /**< Enable tracing of requests to ZIP (doorbell stores are legal) */ uint64_t dfa : 1; /**< Enable tracing of requests to DFA (CSR's and operations are legal) */ uint64_t fpa : 1; /**< Enable tracing of requests to FPA (alloc's (loads/IOBDMA's), frees (stores) are legal) */ uint64_t key : 1; /**< Enable tracing of requests to KEY memory (loads/IOBDMA's/stores are legal) */ uint64_t reserved_3_3 : 1; uint64_t illegal3 : 2; /**< Illegal destinations */ uint64_t mio : 1; /**< Enable tracing of MIO accesses (CIU and GPIO CSR's, boot bus accesses) */ #else uint64_t mio : 1; uint64_t illegal3 : 2; uint64_t reserved_3_3 : 1; uint64_t key : 1; uint64_t fpa : 1; uint64_t dfa : 1; uint64_t zip : 1; uint64_t rng : 1; uint64_t reserved_9_11 : 3; uint64_t pow : 1; uint64_t reserved_13_63 : 51; #endif } s; struct cvmx_tra_filt_did_cn31xx { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t reserved_32_63 : 32; uint64_t illegal : 19; /**< Illegal destinations */ uint64_t pow : 1; /**< Enable tracing of requests to POW (get work, add work, status/memory/index loads, NULLRd loads, CSR's) */ uint64_t illegal2 : 3; /**< Illegal destinations */ uint64_t rng : 1; /**< Enable tracing of requests to RNG (loads/IOBDMA's are legal) */ uint64_t zip : 1; /**< Enable tracing of requests to ZIP (doorbell stores are legal) */ uint64_t dfa : 1; /**< Enable tracing of requests to DFA (CSR's and operations are legal) */ uint64_t fpa : 1; /**< Enable tracing of requests to FPA (alloc's (loads/IOBDMA's), frees (stores) are legal) */ uint64_t key : 1; /**< Enable tracing of requests to KEY memory (loads/IOBDMA's/stores are legal) */ uint64_t pci : 1; /**< Enable tracing of requests to PCI and RSL-type CSR's (RSL CSR's, PCI bus operations, PCI CSR's) */ uint64_t illegal3 : 2; /**< Illegal destinations */ uint64_t mio : 1; /**< Enable tracing of CIU and GPIO CSR's */ #else uint64_t mio : 1; uint64_t illegal3 : 2; uint64_t pci : 1; uint64_t key : 1; uint64_t fpa : 1; uint64_t dfa : 1; uint64_t zip : 1; uint64_t rng : 1; uint64_t illegal2 : 3; uint64_t pow : 1; uint64_t illegal : 19; uint64_t reserved_32_63 : 32; #endif } cn31xx; struct cvmx_tra_filt_did_cn31xx cn38xx; struct cvmx_tra_filt_did_cn31xx cn38xxp2; struct cvmx_tra_filt_did_cn31xx cn52xx; struct cvmx_tra_filt_did_cn31xx cn52xxp1; struct cvmx_tra_filt_did_cn31xx cn56xx; struct cvmx_tra_filt_did_cn31xx cn56xxp1; struct cvmx_tra_filt_did_cn31xx cn58xx; struct cvmx_tra_filt_did_cn31xx cn58xxp1; struct cvmx_tra_filt_did_cn63xx { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t reserved_32_63 : 32; uint64_t illegal5 : 1; /**< Illegal destinations */ uint64_t fau : 1; /**< Enable tracing of FAU accesses */ uint64_t illegal4 : 2; /**< Illegal destinations */ uint64_t dpi : 1; /**< Enable tracing of DPI accesses (DPI NCB CSRs) */ uint64_t illegal : 12; /**< Illegal destinations */ uint64_t rad : 1; /**< Enable tracing of RAD accesses (doorbells) */ uint64_t usb0 : 1; /**< Enable tracing of USB0 accesses (UAHC0 EHCI and OHCI NCB CSRs) */ uint64_t pow : 1; /**< Enable tracing of requests to POW (get work, add work, status/memory/index loads, NULLRd loads, CSR's) */ uint64_t illegal2 : 1; /**< Illegal destination */ uint64_t pko : 1; /**< Enable tracing of PKO accesses (doorbells) */ uint64_t ipd : 1; /**< Enable tracing of IPD CSR accesses (IPD CSRs) */ uint64_t rng : 1; /**< Enable tracing of requests to RNG (loads/IOBDMA's are legal) */ uint64_t zip : 1; /**< Enable tracing of requests to ZIP (doorbell stores are legal) */ uint64_t dfa : 1; /**< Enable tracing of requests to DFA (CSR's and operations are legal) */ uint64_t fpa : 1; /**< Enable tracing of requests to FPA (alloc's (loads/IOBDMA's), frees (stores) are legal) */ uint64_t key : 1; /**< Enable tracing of requests to KEY memory (loads/IOBDMA's/stores are legal) */ uint64_t sli : 1; /**< Enable tracing of requests to SLI and RSL-type CSR's (RSL CSR's, PCI/sRIO bus operations, SLI CSR's) */ uint64_t illegal3 : 2; /**< Illegal destinations */ uint64_t mio : 1; /**< Enable tracing of MIO accesses (CIU and GPIO CSR's, boot bus accesses) */ #else uint64_t mio : 1; uint64_t illegal3 : 2; uint64_t sli : 1; uint64_t key : 1; uint64_t fpa : 1; uint64_t dfa : 1; uint64_t zip : 1; uint64_t rng : 1; uint64_t ipd : 1; uint64_t pko : 1; uint64_t illegal2 : 1; uint64_t pow : 1; uint64_t usb0 : 1; uint64_t rad : 1; uint64_t illegal : 12; uint64_t dpi : 1; uint64_t illegal4 : 2; uint64_t fau : 1; uint64_t illegal5 : 1; uint64_t reserved_32_63 : 32; #endif } cn63xx; struct cvmx_tra_filt_did_cn63xx cn63xxp1; }; typedef union cvmx_tra_filt_did cvmx_tra_filt_did_t; /** * cvmx_tra_filt_sid * * TRA_FILT_SID = Trace Buffer Filter SourceId Mask * * Description: */ union cvmx_tra_filt_sid { uint64_t u64; struct cvmx_tra_filt_sid_s { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t reserved_20_63 : 44; uint64_t dwb : 1; /**< Enable tracing of requests from the IOB DWB engine */ uint64_t iobreq : 1; /**< Enable tracing of requests from FPA,TIM,DFA, PCI,ZIP,POW, and PKO (writes) */ uint64_t pko : 1; /**< Enable tracing of read requests from PKO */ uint64_t pki : 1; /**< Enable tracing of write requests from PIP/IPD */ uint64_t pp : 16; /**< Enable tracing from PP[N] with matching SourceID 0=disable, 1=enableper bit N where 0<=N<=15 */ #else uint64_t pp : 16; uint64_t pki : 1; uint64_t pko : 1; uint64_t iobreq : 1; uint64_t dwb : 1; uint64_t reserved_20_63 : 44; #endif } s; struct cvmx_tra_filt_sid_s cn31xx; struct cvmx_tra_filt_sid_s cn38xx; struct cvmx_tra_filt_sid_s cn38xxp2; struct cvmx_tra_filt_sid_s cn52xx; struct cvmx_tra_filt_sid_s cn52xxp1; struct cvmx_tra_filt_sid_s cn56xx; struct cvmx_tra_filt_sid_s cn56xxp1; struct cvmx_tra_filt_sid_s cn58xx; struct cvmx_tra_filt_sid_s cn58xxp1; struct cvmx_tra_filt_sid_cn63xx { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t reserved_20_63 : 44; uint64_t dwb : 1; /**< Enable tracing of requests from the IOB DWB engine */ uint64_t iobreq : 1; /**< Enable tracing of requests from FPA,TIM,DFA, PCI,ZIP,POW, and PKO (writes) */ uint64_t pko : 1; /**< Enable tracing of read requests from PKO */ uint64_t pki : 1; /**< Enable tracing of write requests from PIP/IPD */ uint64_t reserved_8_15 : 8; uint64_t pp : 8; /**< Enable tracing from PP[N] with matching SourceID 0=disable, 1=enableper bit N where 0<=N<=15 */ #else uint64_t pp : 8; uint64_t reserved_8_15 : 8; uint64_t pki : 1; uint64_t pko : 1; uint64_t iobreq : 1; uint64_t dwb : 1; uint64_t reserved_20_63 : 44; #endif } cn63xx; struct cvmx_tra_filt_sid_cn63xx cn63xxp1; }; typedef union cvmx_tra_filt_sid cvmx_tra_filt_sid_t; /** * cvmx_tra_int_status * * TRA_INT_STATUS = Trace Buffer Interrupt Status * * Description: * * Notes: * During a CSR write to this register, the write data is used as a mask to clear the selected status * bits (status'[3:0] = status[3:0] & ~write_data[3:0]). */ union cvmx_tra_int_status { uint64_t u64; struct cvmx_tra_int_status_s { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t reserved_4_63 : 60; uint64_t mcd0_thr : 1; /**< MCD0 full threshold interrupt status 0=trace buffer did not generate MCD0 wire pulse 1=trace buffer did generate MCD0 wire pulse and prevents additional MCD0_THR MCD0 wire pulses */ uint64_t mcd0_trg : 1; /**< MCD0 end trigger interrupt status 0=trace buffer did not generate interrupt 1=trace buffer did generate interrupt and prevents additional MCD0_TRG MCD0 wire pulses */ uint64_t ciu_thr : 1; /**< CIU full threshold interrupt status 0=trace buffer did not generate interrupt 1=trace buffer did generate interrupt */ uint64_t ciu_trg : 1; /**< CIU end trigger interrupt status 0=trace buffer did not generate interrupt 1=trace buffer did generate interrupt */ #else uint64_t ciu_trg : 1; uint64_t ciu_thr : 1; uint64_t mcd0_trg : 1; uint64_t mcd0_thr : 1; uint64_t reserved_4_63 : 60; #endif } s; struct cvmx_tra_int_status_s cn31xx; struct cvmx_tra_int_status_s cn38xx; struct cvmx_tra_int_status_s cn38xxp2; struct cvmx_tra_int_status_s cn52xx; struct cvmx_tra_int_status_s cn52xxp1; struct cvmx_tra_int_status_s cn56xx; struct cvmx_tra_int_status_s cn56xxp1; struct cvmx_tra_int_status_s cn58xx; struct cvmx_tra_int_status_s cn58xxp1; struct cvmx_tra_int_status_s cn63xx; struct cvmx_tra_int_status_s cn63xxp1; }; typedef union cvmx_tra_int_status cvmx_tra_int_status_t; /** * cvmx_tra_read_dat * * TRA_READ_DAT = Trace Buffer Read Data * * Description: * * Notes: * This CSR is a memory of 1024 entries. When the trace was enabled, the read pointer was set to entry * 0 by hardware. Each read to this address increments the read pointer. */ union cvmx_tra_read_dat { uint64_t u64; struct cvmx_tra_read_dat_s { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t data : 64; /**< Trace buffer data for current entry */ #else uint64_t data : 64; #endif } s; struct cvmx_tra_read_dat_s cn31xx; struct cvmx_tra_read_dat_s cn38xx; struct cvmx_tra_read_dat_s cn38xxp2; struct cvmx_tra_read_dat_s cn52xx; struct cvmx_tra_read_dat_s cn52xxp1; struct cvmx_tra_read_dat_s cn56xx; struct cvmx_tra_read_dat_s cn56xxp1; struct cvmx_tra_read_dat_s cn58xx; struct cvmx_tra_read_dat_s cn58xxp1; struct cvmx_tra_read_dat_s cn63xx; struct cvmx_tra_read_dat_s cn63xxp1; }; typedef union cvmx_tra_read_dat cvmx_tra_read_dat_t; /** * cvmx_tra_read_dat_hi * * TRA_READ_DAT_HI = Trace Buffer Read Data- upper 5 bits do not use if TRA_CTL[16]==0 * * Description: * * Notes: * This CSR is a memory of 1024 entries. Reads to this address do not increment the read pointer. The * 5 bits read are the upper 5 bits of the TRA entry last read by the TRA_READ_DAT reg. */ union cvmx_tra_read_dat_hi { uint64_t u64; struct cvmx_tra_read_dat_hi_s { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t reserved_5_63 : 59; uint64_t data : 5; /**< Trace buffer data[68:64] for current entry */ #else uint64_t data : 5; uint64_t reserved_5_63 : 59; #endif } s; struct cvmx_tra_read_dat_hi_s cn63xx; }; typedef union cvmx_tra_read_dat_hi cvmx_tra_read_dat_hi_t; /** * cvmx_tra_trig0_adr_adr * * TRA_TRIG0_ADR_ADR = Trace Buffer Filter Address Address * * Description: */ union cvmx_tra_trig0_adr_adr { uint64_t u64; struct cvmx_tra_trig0_adr_adr_s { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t reserved_38_63 : 26; uint64_t adr : 38; /**< Unmasked Address The combination of TRA_TRIG0_ADR_ADR and TRA_TRIG0_ADR_MSK is a masked address to enable tracing of only those commands whose masked address matches */ #else uint64_t adr : 38; uint64_t reserved_38_63 : 26; #endif } s; struct cvmx_tra_trig0_adr_adr_cn31xx { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t reserved_36_63 : 28; uint64_t adr : 36; /**< Unmasked Address The combination of TRA_TRIG0_ADR_ADR and TRA_TRIG0_ADR_MSK is a masked address to enable tracing of only those commands whose masked address matches */ #else uint64_t adr : 36; uint64_t reserved_36_63 : 28; #endif } cn31xx; struct cvmx_tra_trig0_adr_adr_cn31xx cn38xx; struct cvmx_tra_trig0_adr_adr_cn31xx cn38xxp2; struct cvmx_tra_trig0_adr_adr_cn31xx cn52xx; struct cvmx_tra_trig0_adr_adr_cn31xx cn52xxp1; struct cvmx_tra_trig0_adr_adr_cn31xx cn56xx; struct cvmx_tra_trig0_adr_adr_cn31xx cn56xxp1; struct cvmx_tra_trig0_adr_adr_cn31xx cn58xx; struct cvmx_tra_trig0_adr_adr_cn31xx cn58xxp1; struct cvmx_tra_trig0_adr_adr_s cn63xx; struct cvmx_tra_trig0_adr_adr_s cn63xxp1; }; typedef union cvmx_tra_trig0_adr_adr cvmx_tra_trig0_adr_adr_t; /** * cvmx_tra_trig0_adr_msk * * TRA_TRIG0_ADR_MSK = Trace Buffer Filter Address Mask * * Description: */ union cvmx_tra_trig0_adr_msk { uint64_t u64; struct cvmx_tra_trig0_adr_msk_s { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t reserved_38_63 : 26; uint64_t adr : 38; /**< Address Mask The combination of TRA_TRIG0_ADR_ADR and TRA_TRIG0_ADR_MSK is a masked address to enable tracing of only those commands whose masked address matches. When a mask bit is not set, the corresponding address bits are assumed to match. Also, note that IOBDMAs do not have proper addresses, so when TRA_TRIG0_CMD[IOBDMA] is set, TRA_FILT_TRIG0_MSK must be zero to guarantee that any IOBDMAs are recognized as triggers. */ #else uint64_t adr : 38; uint64_t reserved_38_63 : 26; #endif } s; struct cvmx_tra_trig0_adr_msk_cn31xx { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t reserved_36_63 : 28; uint64_t adr : 36; /**< Address Mask The combination of TRA_TRIG0_ADR_ADR and TRA_TRIG0_ADR_MSK is a masked address to enable tracing of only those commands whose masked address matches. When a mask bit is not set, the corresponding address bits are assumed to match. Also, note that IOBDMAs do not have proper addresses, so when TRA_TRIG0_CMD[IOBDMA] is set, TRA_FILT_TRIG0_MSK must be zero to guarantee that any IOBDMAs are recognized as triggers. */ #else uint64_t adr : 36; uint64_t reserved_36_63 : 28; #endif } cn31xx; struct cvmx_tra_trig0_adr_msk_cn31xx cn38xx; struct cvmx_tra_trig0_adr_msk_cn31xx cn38xxp2; struct cvmx_tra_trig0_adr_msk_cn31xx cn52xx; struct cvmx_tra_trig0_adr_msk_cn31xx cn52xxp1; struct cvmx_tra_trig0_adr_msk_cn31xx cn56xx; struct cvmx_tra_trig0_adr_msk_cn31xx cn56xxp1; struct cvmx_tra_trig0_adr_msk_cn31xx cn58xx; struct cvmx_tra_trig0_adr_msk_cn31xx cn58xxp1; struct cvmx_tra_trig0_adr_msk_s cn63xx; struct cvmx_tra_trig0_adr_msk_s cn63xxp1; }; typedef union cvmx_tra_trig0_adr_msk cvmx_tra_trig0_adr_msk_t; /** * cvmx_tra_trig0_cmd * * TRA_TRIG0_CMD = Trace Buffer Filter Command Mask * * Description: * * Notes: * Note that the trace buffer does not do proper IOBDMA address compares. Thus, if IOBDMA is set, then * the address compare must be disabled (i.e. TRA_TRIG0_ADR_MSK set to zero) to guarantee that IOBDMAs * are recognized as triggers. */ union cvmx_tra_trig0_cmd { uint64_t u64; struct cvmx_tra_trig0_cmd_s { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t saa64 : 1; /**< Enable SAA64 tracing 0=disable, 1=enable */ uint64_t saa32 : 1; /**< Enable SAA32 tracing 0=disable, 1=enable */ uint64_t reserved_60_61 : 2; uint64_t faa64 : 1; /**< Enable FAA64 tracing 0=disable, 1=enable */ uint64_t faa32 : 1; /**< Enable FAA32 tracing 0=disable, 1=enable */ uint64_t reserved_56_57 : 2; uint64_t decr64 : 1; /**< Enable DECR64 tracing 0=disable, 1=enable */ uint64_t decr32 : 1; /**< Enable DECR32 tracing 0=disable, 1=enable */ uint64_t decr16 : 1; /**< Enable DECR16 tracing 0=disable, 1=enable */ uint64_t decr8 : 1; /**< Enable DECR8 tracing 0=disable, 1=enable */ uint64_t incr64 : 1; /**< Enable INCR64 tracing 0=disable, 1=enable */ uint64_t incr32 : 1; /**< Enable INCR32 tracing 0=disable, 1=enable */ uint64_t incr16 : 1; /**< Enable INCR16 tracing 0=disable, 1=enable */ uint64_t incr8 : 1; /**< Enable INCR8 tracing 0=disable, 1=enable */ uint64_t clr64 : 1; /**< Enable CLR64 tracing 0=disable, 1=enable */ uint64_t clr32 : 1; /**< Enable CLR32 tracing 0=disable, 1=enable */ uint64_t clr16 : 1; /**< Enable CLR16 tracing 0=disable, 1=enable */ uint64_t clr8 : 1; /**< Enable CLR8 tracing 0=disable, 1=enable */ uint64_t set64 : 1; /**< Enable SET64 tracing 0=disable, 1=enable */ uint64_t set32 : 1; /**< Enable SET32 tracing 0=disable, 1=enable */ uint64_t set16 : 1; /**< Enable SET16 tracing 0=disable, 1=enable */ uint64_t set8 : 1; /**< Enable SET8 tracing 0=disable, 1=enable */ uint64_t iobst64 : 1; /**< Enable IOBST64 tracing 0=disable, 1=enable */ uint64_t iobst32 : 1; /**< Enable IOBST32 tracing 0=disable, 1=enable */ uint64_t iobst16 : 1; /**< Enable IOBST16 tracing 0=disable, 1=enable */ uint64_t iobst8 : 1; /**< Enable IOBST8 tracing 0=disable, 1=enable */ uint64_t reserved_32_35 : 4; uint64_t lckl2 : 1; /**< Enable LCKL2 tracing 0=disable, 1=enable */ uint64_t wbl2 : 1; /**< Enable WBL2 tracing 0=disable, 1=enable */ uint64_t wbil2 : 1; /**< Enable WBIL2 tracing 0=disable, 1=enable */ uint64_t invl2 : 1; /**< Enable INVL2 tracing 0=disable, 1=enable */ uint64_t reserved_27_27 : 1; uint64_t stgl2i : 1; /**< Enable STGL2I tracing 0=disable, 1=enable */ uint64_t ltgl2i : 1; /**< Enable LTGL2I tracing 0=disable, 1=enable */ uint64_t wbil2i : 1; /**< Enable WBIL2I tracing 0=disable, 1=enable */ uint64_t fas64 : 1; /**< Enable FAS64 tracing 0=disable, 1=enable */ uint64_t fas32 : 1; /**< Enable FAS32 tracing 0=disable, 1=enable */ uint64_t sttil1 : 1; /**< Enable STTIL1 tracing 0=disable, 1=enable */ uint64_t stfil1 : 1; /**< Enable STFIL1 tracing 0=disable, 1=enable */ uint64_t reserved_16_19 : 4; uint64_t iobdma : 1; /**< Enable IOBDMA tracing 0=disable, 1=enable */ uint64_t iobst : 1; /**< Enable IOBST tracing 0=disable, 1=enable */ uint64_t reserved_0_13 : 14; #else uint64_t reserved_0_13 : 14; uint64_t iobst : 1; uint64_t iobdma : 1; uint64_t reserved_16_19 : 4; uint64_t stfil1 : 1; uint64_t sttil1 : 1; uint64_t fas32 : 1; uint64_t fas64 : 1; uint64_t wbil2i : 1; uint64_t ltgl2i : 1; uint64_t stgl2i : 1; uint64_t reserved_27_27 : 1; uint64_t invl2 : 1; uint64_t wbil2 : 1; uint64_t wbl2 : 1; uint64_t lckl2 : 1; uint64_t reserved_32_35 : 4; uint64_t iobst8 : 1; uint64_t iobst16 : 1; uint64_t iobst32 : 1; uint64_t iobst64 : 1; uint64_t set8 : 1; uint64_t set16 : 1; uint64_t set32 : 1; uint64_t set64 : 1; uint64_t clr8 : 1; uint64_t clr16 : 1; uint64_t clr32 : 1; uint64_t clr64 : 1; uint64_t incr8 : 1; uint64_t incr16 : 1; uint64_t incr32 : 1; uint64_t incr64 : 1; uint64_t decr8 : 1; uint64_t decr16 : 1; uint64_t decr32 : 1; uint64_t decr64 : 1; uint64_t reserved_56_57 : 2; uint64_t faa32 : 1; uint64_t faa64 : 1; uint64_t reserved_60_61 : 2; uint64_t saa32 : 1; uint64_t saa64 : 1; #endif } s; struct cvmx_tra_trig0_cmd_cn31xx { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t reserved_16_63 : 48; uint64_t iobdma : 1; /**< Enable IOBDMA tracing 0=disable, 1=enable */ uint64_t iobst : 1; /**< Enable IOBST tracing 0=disable, 1=enable */ uint64_t iobld64 : 1; /**< Enable IOBLD64 tracing 0=disable, 1=enable */ uint64_t iobld32 : 1; /**< Enable IOBLD32 tracing 0=disable, 1=enable */ uint64_t iobld16 : 1; /**< Enable IOBLD16 tracing 0=disable, 1=enable */ uint64_t iobld8 : 1; /**< Enable IOBLD8 tracing 0=disable, 1=enable */ uint64_t stt : 1; /**< Enable STT tracing 0=disable, 1=enable */ uint64_t stp : 1; /**< Enable STP tracing 0=disable, 1=enable */ uint64_t stc : 1; /**< Enable STC tracing 0=disable, 1=enable */ uint64_t stf : 1; /**< Enable STF tracing 0=disable, 1=enable */ uint64_t ldt : 1; /**< Enable LDT tracing 0=disable, 1=enable */ uint64_t ldi : 1; /**< Enable LDI tracing 0=disable, 1=enable */ uint64_t ldd : 1; /**< Enable LDD tracing 0=disable, 1=enable */ uint64_t psl1 : 1; /**< Enable PSL1 tracing 0=disable, 1=enable */ uint64_t pl2 : 1; /**< Enable PL2 tracing 0=disable, 1=enable */ uint64_t dwb : 1; /**< Enable DWB tracing 0=disable, 1=enable */ #else uint64_t dwb : 1; uint64_t pl2 : 1; uint64_t psl1 : 1; uint64_t ldd : 1; uint64_t ldi : 1; uint64_t ldt : 1; uint64_t stf : 1; uint64_t stc : 1; uint64_t stp : 1; uint64_t stt : 1; uint64_t iobld8 : 1; uint64_t iobld16 : 1; uint64_t iobld32 : 1; uint64_t iobld64 : 1; uint64_t iobst : 1; uint64_t iobdma : 1; uint64_t reserved_16_63 : 48; #endif } cn31xx; struct cvmx_tra_trig0_cmd_cn31xx cn38xx; struct cvmx_tra_trig0_cmd_cn31xx cn38xxp2; struct cvmx_tra_trig0_cmd_cn52xx { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t reserved_17_63 : 47; uint64_t saa : 1; /**< Enable SAA tracing 0=disable, 1=enable */ uint64_t iobdma : 1; /**< Enable IOBDMA tracing 0=disable, 1=enable */ uint64_t iobst : 1; /**< Enable IOBST tracing 0=disable, 1=enable */ uint64_t iobld64 : 1; /**< Enable IOBLD64 tracing 0=disable, 1=enable */ uint64_t iobld32 : 1; /**< Enable IOBLD32 tracing 0=disable, 1=enable */ uint64_t iobld16 : 1; /**< Enable IOBLD16 tracing 0=disable, 1=enable */ uint64_t iobld8 : 1; /**< Enable IOBLD8 tracing 0=disable, 1=enable */ uint64_t stt : 1; /**< Enable STT tracing 0=disable, 1=enable */ uint64_t stp : 1; /**< Enable STP tracing 0=disable, 1=enable */ uint64_t stc : 1; /**< Enable STC tracing 0=disable, 1=enable */ uint64_t stf : 1; /**< Enable STF tracing 0=disable, 1=enable */ uint64_t ldt : 1; /**< Enable LDT tracing 0=disable, 1=enable */ uint64_t ldi : 1; /**< Enable LDI tracing 0=disable, 1=enable */ uint64_t ldd : 1; /**< Enable LDD tracing 0=disable, 1=enable */ uint64_t psl1 : 1; /**< Enable PSL1 tracing 0=disable, 1=enable */ uint64_t pl2 : 1; /**< Enable PL2 tracing 0=disable, 1=enable */ uint64_t dwb : 1; /**< Enable DWB tracing 0=disable, 1=enable */ #else uint64_t dwb : 1; uint64_t pl2 : 1; uint64_t psl1 : 1; uint64_t ldd : 1; uint64_t ldi : 1; uint64_t ldt : 1; uint64_t stf : 1; uint64_t stc : 1; uint64_t stp : 1; uint64_t stt : 1; uint64_t iobld8 : 1; uint64_t iobld16 : 1; uint64_t iobld32 : 1; uint64_t iobld64 : 1; uint64_t iobst : 1; uint64_t iobdma : 1; uint64_t saa : 1; uint64_t reserved_17_63 : 47; #endif } cn52xx; struct cvmx_tra_trig0_cmd_cn52xx cn52xxp1; struct cvmx_tra_trig0_cmd_cn52xx cn56xx; struct cvmx_tra_trig0_cmd_cn52xx cn56xxp1; struct cvmx_tra_trig0_cmd_cn52xx cn58xx; struct cvmx_tra_trig0_cmd_cn52xx cn58xxp1; struct cvmx_tra_trig0_cmd_cn63xx { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t saa64 : 1; /**< Enable SAA64 tracing 0=disable, 1=enable */ uint64_t saa32 : 1; /**< Enable SAA32 tracing 0=disable, 1=enable */ uint64_t reserved_60_61 : 2; uint64_t faa64 : 1; /**< Enable FAA64 tracing 0=disable, 1=enable */ uint64_t faa32 : 1; /**< Enable FAA32 tracing 0=disable, 1=enable */ uint64_t reserved_56_57 : 2; uint64_t decr64 : 1; /**< Enable DECR64 tracing 0=disable, 1=enable */ uint64_t decr32 : 1; /**< Enable DECR32 tracing 0=disable, 1=enable */ uint64_t decr16 : 1; /**< Enable DECR16 tracing 0=disable, 1=enable */ uint64_t decr8 : 1; /**< Enable DECR8 tracing 0=disable, 1=enable */ uint64_t incr64 : 1; /**< Enable INCR64 tracing 0=disable, 1=enable */ uint64_t incr32 : 1; /**< Enable INCR32 tracing 0=disable, 1=enable */ uint64_t incr16 : 1; /**< Enable INCR16 tracing 0=disable, 1=enable */ uint64_t incr8 : 1; /**< Enable INCR8 tracing 0=disable, 1=enable */ uint64_t clr64 : 1; /**< Enable CLR64 tracing 0=disable, 1=enable */ uint64_t clr32 : 1; /**< Enable CLR32 tracing 0=disable, 1=enable */ uint64_t clr16 : 1; /**< Enable CLR16 tracing 0=disable, 1=enable */ uint64_t clr8 : 1; /**< Enable CLR8 tracing 0=disable, 1=enable */ uint64_t set64 : 1; /**< Enable SET64 tracing 0=disable, 1=enable */ uint64_t set32 : 1; /**< Enable SET32 tracing 0=disable, 1=enable */ uint64_t set16 : 1; /**< Enable SET16 tracing 0=disable, 1=enable */ uint64_t set8 : 1; /**< Enable SET8 tracing 0=disable, 1=enable */ uint64_t iobst64 : 1; /**< Enable IOBST64 tracing 0=disable, 1=enable */ uint64_t iobst32 : 1; /**< Enable IOBST32 tracing 0=disable, 1=enable */ uint64_t iobst16 : 1; /**< Enable IOBST16 tracing 0=disable, 1=enable */ uint64_t iobst8 : 1; /**< Enable IOBST8 tracing 0=disable, 1=enable */ uint64_t iobld64 : 1; /**< Enable IOBLD64 tracing 0=disable, 1=enable */ uint64_t iobld32 : 1; /**< Enable IOBLD32 tracing 0=disable, 1=enable */ uint64_t iobld16 : 1; /**< Enable IOBLD16 tracing 0=disable, 1=enable */ uint64_t iobld8 : 1; /**< Enable IOBLD8 tracing 0=disable, 1=enable */ uint64_t lckl2 : 1; /**< Enable LCKL2 tracing 0=disable, 1=enable */ uint64_t wbl2 : 1; /**< Enable WBL2 tracing 0=disable, 1=enable */ uint64_t wbil2 : 1; /**< Enable WBIL2 tracing 0=disable, 1=enable */ uint64_t invl2 : 1; /**< Enable INVL2 tracing 0=disable, 1=enable */ uint64_t reserved_27_27 : 1; uint64_t stgl2i : 1; /**< Enable STGL2I tracing 0=disable, 1=enable */ uint64_t ltgl2i : 1; /**< Enable LTGL2I tracing 0=disable, 1=enable */ uint64_t wbil2i : 1; /**< Enable WBIL2I tracing 0=disable, 1=enable */ uint64_t fas64 : 1; /**< Enable FAS64 tracing 0=disable, 1=enable */ uint64_t fas32 : 1; /**< Enable FAS32 tracing 0=disable, 1=enable */ uint64_t sttil1 : 1; /**< Enable STTIL1 tracing 0=disable, 1=enable */ uint64_t stfil1 : 1; /**< Enable STFIL1 tracing 0=disable, 1=enable */ uint64_t stc : 1; /**< Enable STC tracing 0=disable, 1=enable */ uint64_t stp : 1; /**< Enable STP tracing 0=disable, 1=enable */ uint64_t stt : 1; /**< Enable STT tracing 0=disable, 1=enable */ uint64_t stf : 1; /**< Enable STF tracing 0=disable, 1=enable */ uint64_t iobdma : 1; /**< Enable IOBDMA tracing 0=disable, 1=enable */ uint64_t reserved_10_14 : 5; uint64_t psl1 : 1; /**< Enable PSL1 tracing 0=disable, 1=enable */ uint64_t ldd : 1; /**< Enable LDD tracing 0=disable, 1=enable */ uint64_t reserved_6_7 : 2; uint64_t dwb : 1; /**< Enable DWB tracing 0=disable, 1=enable */ uint64_t rpl2 : 1; /**< Enable RPL2 tracing 0=disable, 1=enable */ uint64_t pl2 : 1; /**< Enable PL2 tracing 0=disable, 1=enable */ uint64_t ldi : 1; /**< Enable LDI tracing 0=disable, 1=enable */ uint64_t ldt : 1; /**< Enable LDT tracing 0=disable, 1=enable */ uint64_t nop : 1; /**< Enable NOP tracing 0=disable, 1=enable */ #else uint64_t nop : 1; uint64_t ldt : 1; uint64_t ldi : 1; uint64_t pl2 : 1; uint64_t rpl2 : 1; uint64_t dwb : 1; uint64_t reserved_6_7 : 2; uint64_t ldd : 1; uint64_t psl1 : 1; uint64_t reserved_10_14 : 5; uint64_t iobdma : 1; uint64_t stf : 1; uint64_t stt : 1; uint64_t stp : 1; uint64_t stc : 1; uint64_t stfil1 : 1; uint64_t sttil1 : 1; uint64_t fas32 : 1; uint64_t fas64 : 1; uint64_t wbil2i : 1; uint64_t ltgl2i : 1; uint64_t stgl2i : 1; uint64_t reserved_27_27 : 1; uint64_t invl2 : 1; uint64_t wbil2 : 1; uint64_t wbl2 : 1; uint64_t lckl2 : 1; uint64_t iobld8 : 1; uint64_t iobld16 : 1; uint64_t iobld32 : 1; uint64_t iobld64 : 1; uint64_t iobst8 : 1; uint64_t iobst16 : 1; uint64_t iobst32 : 1; uint64_t iobst64 : 1; uint64_t set8 : 1; uint64_t set16 : 1; uint64_t set32 : 1; uint64_t set64 : 1; uint64_t clr8 : 1; uint64_t clr16 : 1; uint64_t clr32 : 1; uint64_t clr64 : 1; uint64_t incr8 : 1; uint64_t incr16 : 1; uint64_t incr32 : 1; uint64_t incr64 : 1; uint64_t decr8 : 1; uint64_t decr16 : 1; uint64_t decr32 : 1; uint64_t decr64 : 1; uint64_t reserved_56_57 : 2; uint64_t faa32 : 1; uint64_t faa64 : 1; uint64_t reserved_60_61 : 2; uint64_t saa32 : 1; uint64_t saa64 : 1; #endif } cn63xx; struct cvmx_tra_trig0_cmd_cn63xx cn63xxp1; }; typedef union cvmx_tra_trig0_cmd cvmx_tra_trig0_cmd_t; /** * cvmx_tra_trig0_did * * TRA_TRIG0_DID = Trace Buffer Filter DestinationId Mask * * Description: */ union cvmx_tra_trig0_did { uint64_t u64; struct cvmx_tra_trig0_did_s { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t reserved_13_63 : 51; uint64_t pow : 1; /**< Enable triggering on requests to POW (get work, add work, status/memory/index loads, NULLRd loads, CSR's) */ uint64_t reserved_9_11 : 3; uint64_t rng : 1; /**< Enable triggering on requests to RNG (loads/IOBDMA's are legal) */ uint64_t zip : 1; /**< Enable triggering on requests to ZIP (doorbell stores are legal) */ uint64_t dfa : 1; /**< Enable triggering on requests to DFA (CSR's and operations are legal) */ uint64_t fpa : 1; /**< Enable triggering on requests to FPA (alloc's (loads/IOBDMA's), frees (stores) are legal) */ uint64_t key : 1; /**< Enable triggering on requests to KEY memory (loads/IOBDMA's/stores are legal) */ uint64_t reserved_3_3 : 1; uint64_t illegal3 : 2; /**< Illegal destinations */ uint64_t mio : 1; /**< Enable triggering on MIO accesses (CIU and GPIO CSR's, boot bus accesses) */ #else uint64_t mio : 1; uint64_t illegal3 : 2; uint64_t reserved_3_3 : 1; uint64_t key : 1; uint64_t fpa : 1; uint64_t dfa : 1; uint64_t zip : 1; uint64_t rng : 1; uint64_t reserved_9_11 : 3; uint64_t pow : 1; uint64_t reserved_13_63 : 51; #endif } s; struct cvmx_tra_trig0_did_cn31xx { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t reserved_32_63 : 32; uint64_t illegal : 19; /**< Illegal destinations */ uint64_t pow : 1; /**< Enable triggering on requests to POW (get work, add work, status/memory/index loads, NULLRd loads, CSR's) */ uint64_t illegal2 : 3; /**< Illegal destinations */ uint64_t rng : 1; /**< Enable triggering on requests to RNG (loads/IOBDMA's are legal) */ uint64_t zip : 1; /**< Enable triggering on requests to ZIP (doorbell stores are legal) */ uint64_t dfa : 1; /**< Enable triggering on requests to DFA (CSR's and operations are legal) */ uint64_t fpa : 1; /**< Enable triggering on requests to FPA (alloc's (loads/IOBDMA's), frees (stores) are legal) */ uint64_t key : 1; /**< Enable triggering on requests to KEY memory (loads/IOBDMA's/stores are legal) */ uint64_t pci : 1; /**< Enable triggering on requests to PCI and RSL-type CSR's (RSL CSR's, PCI bus operations, PCI CSR's) */ uint64_t illegal3 : 2; /**< Illegal destinations */ uint64_t mio : 1; /**< Enable triggering on CIU and GPIO CSR's */ #else uint64_t mio : 1; uint64_t illegal3 : 2; uint64_t pci : 1; uint64_t key : 1; uint64_t fpa : 1; uint64_t dfa : 1; uint64_t zip : 1; uint64_t rng : 1; uint64_t illegal2 : 3; uint64_t pow : 1; uint64_t illegal : 19; uint64_t reserved_32_63 : 32; #endif } cn31xx; struct cvmx_tra_trig0_did_cn31xx cn38xx; struct cvmx_tra_trig0_did_cn31xx cn38xxp2; struct cvmx_tra_trig0_did_cn31xx cn52xx; struct cvmx_tra_trig0_did_cn31xx cn52xxp1; struct cvmx_tra_trig0_did_cn31xx cn56xx; struct cvmx_tra_trig0_did_cn31xx cn56xxp1; struct cvmx_tra_trig0_did_cn31xx cn58xx; struct cvmx_tra_trig0_did_cn31xx cn58xxp1; struct cvmx_tra_trig0_did_cn63xx { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t reserved_32_63 : 32; uint64_t illegal5 : 1; /**< Illegal destinations */ uint64_t fau : 1; /**< Enable triggering on FAU accesses */ uint64_t illegal4 : 2; /**< Illegal destinations */ uint64_t dpi : 1; /**< Enable triggering on DPI accesses (DPI NCB CSRs) */ uint64_t illegal : 12; /**< Illegal destinations */ uint64_t rad : 1; /**< Enable triggering on RAD accesses (doorbells) */ uint64_t usb0 : 1; /**< Enable triggering on USB0 accesses (UAHC0 EHCI and OHCI NCB CSRs) */ uint64_t pow : 1; /**< Enable triggering on requests to POW (get work, add work, status/memory/index loads, NULLRd loads, CSR's) */ uint64_t illegal2 : 1; /**< Illegal destination */ uint64_t pko : 1; /**< Enable triggering on PKO accesses (doorbells) */ uint64_t ipd : 1; /**< Enable triggering on IPD CSR accesses (IPD CSRs) */ uint64_t rng : 1; /**< Enable triggering on requests to RNG (loads/IOBDMA's are legal) */ uint64_t zip : 1; /**< Enable triggering on requests to ZIP (doorbell stores are legal) */ uint64_t dfa : 1; /**< Enable triggering on requests to DFA (CSR's and operations are legal) */ uint64_t fpa : 1; /**< Enable triggering on requests to FPA (alloc's (loads/IOBDMA's), frees (stores) are legal) */ uint64_t key : 1; /**< Enable triggering on requests to KEY memory (loads/IOBDMA's/stores are legal) */ uint64_t sli : 1; /**< Enable triggering on requests to SLI and RSL-type CSR's (RSL CSR's, PCI/sRIO bus operations, SLI CSR's) */ uint64_t illegal3 : 2; /**< Illegal destinations */ uint64_t mio : 1; /**< Enable triggering on MIO accesses (CIU and GPIO CSR's, boot bus accesses) */ #else uint64_t mio : 1; uint64_t illegal3 : 2; uint64_t sli : 1; uint64_t key : 1; uint64_t fpa : 1; uint64_t dfa : 1; uint64_t zip : 1; uint64_t rng : 1; uint64_t ipd : 1; uint64_t pko : 1; uint64_t illegal2 : 1; uint64_t pow : 1; uint64_t usb0 : 1; uint64_t rad : 1; uint64_t illegal : 12; uint64_t dpi : 1; uint64_t illegal4 : 2; uint64_t fau : 1; uint64_t illegal5 : 1; uint64_t reserved_32_63 : 32; #endif } cn63xx; struct cvmx_tra_trig0_did_cn63xx cn63xxp1; }; typedef union cvmx_tra_trig0_did cvmx_tra_trig0_did_t; /** * cvmx_tra_trig0_sid * * TRA_TRIG0_SID = Trace Buffer Filter SourceId Mask * * Description: */ union cvmx_tra_trig0_sid { uint64_t u64; struct cvmx_tra_trig0_sid_s { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t reserved_20_63 : 44; uint64_t dwb : 1; /**< Enable triggering on requests from the IOB DWB engine */ uint64_t iobreq : 1; /**< Enable triggering on requests from FPA,TIM,DFA, PCI,ZIP,POW, and PKO (writes) */ uint64_t pko : 1; /**< Enable triggering on read requests from PKO */ uint64_t pki : 1; /**< Enable triggering on write requests from PIP/IPD */ uint64_t pp : 16; /**< Enable triggering from PP[N] with matching SourceID 0=disable, 1=enableper bit N where 0<=N<=15 */ #else uint64_t pp : 16; uint64_t pki : 1; uint64_t pko : 1; uint64_t iobreq : 1; uint64_t dwb : 1; uint64_t reserved_20_63 : 44; #endif } s; struct cvmx_tra_trig0_sid_s cn31xx; struct cvmx_tra_trig0_sid_s cn38xx; struct cvmx_tra_trig0_sid_s cn38xxp2; struct cvmx_tra_trig0_sid_s cn52xx; struct cvmx_tra_trig0_sid_s cn52xxp1; struct cvmx_tra_trig0_sid_s cn56xx; struct cvmx_tra_trig0_sid_s cn56xxp1; struct cvmx_tra_trig0_sid_s cn58xx; struct cvmx_tra_trig0_sid_s cn58xxp1; struct cvmx_tra_trig0_sid_cn63xx { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t reserved_20_63 : 44; uint64_t dwb : 1; /**< Enable triggering on requests from the IOB DWB engine */ uint64_t iobreq : 1; /**< Enable triggering on requests from FPA,TIM,DFA, PCI,ZIP,POW, and PKO (writes) */ uint64_t pko : 1; /**< Enable triggering on read requests from PKO */ uint64_t pki : 1; /**< Enable triggering on write requests from PIP/IPD */ uint64_t reserved_8_15 : 8; uint64_t pp : 8; /**< Enable triggering from PP[N] with matching SourceID 0=disable, 1=enableper bit N where 0<=N<=15 */ #else uint64_t pp : 8; uint64_t reserved_8_15 : 8; uint64_t pki : 1; uint64_t pko : 1; uint64_t iobreq : 1; uint64_t dwb : 1; uint64_t reserved_20_63 : 44; #endif } cn63xx; struct cvmx_tra_trig0_sid_cn63xx cn63xxp1; }; typedef union cvmx_tra_trig0_sid cvmx_tra_trig0_sid_t; /** * cvmx_tra_trig1_adr_adr * * TRA_TRIG1_ADR_ADR = Trace Buffer Filter Address Address * * Description: */ union cvmx_tra_trig1_adr_adr { uint64_t u64; struct cvmx_tra_trig1_adr_adr_s { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t reserved_38_63 : 26; uint64_t adr : 38; /**< Unmasked Address The combination of TRA_TRIG1_ADR_ADR and TRA_TRIG1_ADR_MSK is a masked address to enable tracing of only those commands whose masked address matches */ #else uint64_t adr : 38; uint64_t reserved_38_63 : 26; #endif } s; struct cvmx_tra_trig1_adr_adr_cn31xx { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t reserved_36_63 : 28; uint64_t adr : 36; /**< Unmasked Address The combination of TRA_TRIG1_ADR_ADR and TRA_TRIG1_ADR_MSK is a masked address to enable tracing of only those commands whose masked address matches */ #else uint64_t adr : 36; uint64_t reserved_36_63 : 28; #endif } cn31xx; struct cvmx_tra_trig1_adr_adr_cn31xx cn38xx; struct cvmx_tra_trig1_adr_adr_cn31xx cn38xxp2; struct cvmx_tra_trig1_adr_adr_cn31xx cn52xx; struct cvmx_tra_trig1_adr_adr_cn31xx cn52xxp1; struct cvmx_tra_trig1_adr_adr_cn31xx cn56xx; struct cvmx_tra_trig1_adr_adr_cn31xx cn56xxp1; struct cvmx_tra_trig1_adr_adr_cn31xx cn58xx; struct cvmx_tra_trig1_adr_adr_cn31xx cn58xxp1; struct cvmx_tra_trig1_adr_adr_s cn63xx; struct cvmx_tra_trig1_adr_adr_s cn63xxp1; }; typedef union cvmx_tra_trig1_adr_adr cvmx_tra_trig1_adr_adr_t; /** * cvmx_tra_trig1_adr_msk * * TRA_TRIG1_ADR_MSK = Trace Buffer Filter Address Mask * * Description: */ union cvmx_tra_trig1_adr_msk { uint64_t u64; struct cvmx_tra_trig1_adr_msk_s { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t reserved_38_63 : 26; uint64_t adr : 38; /**< Address Mask The combination of TRA_TRIG1_ADR_ADR and TRA_TRIG1_ADR_MSK is a masked address to enable tracing of only those commands whose masked address matches. When a mask bit is not set, the corresponding address bits are assumed to match. Also, note that IOBDMAs do not have proper addresses, so when TRA_TRIG1_CMD[IOBDMA] is set, TRA_FILT_TRIG1_MSK must be zero to guarantee that any IOBDMAs are recognized as triggers. */ #else uint64_t adr : 38; uint64_t reserved_38_63 : 26; #endif } s; struct cvmx_tra_trig1_adr_msk_cn31xx { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t reserved_36_63 : 28; uint64_t adr : 36; /**< Address Mask The combination of TRA_TRIG1_ADR_ADR and TRA_TRIG1_ADR_MSK is a masked address to enable tracing of only those commands whose masked address matches. When a mask bit is not set, the corresponding address bits are assumed to match. Also, note that IOBDMAs do not have proper addresses, so when TRA_TRIG1_CMD[IOBDMA] is set, TRA_FILT_TRIG1_MSK must be zero to guarantee that any IOBDMAs are recognized as triggers. */ #else uint64_t adr : 36; uint64_t reserved_36_63 : 28; #endif } cn31xx; struct cvmx_tra_trig1_adr_msk_cn31xx cn38xx; struct cvmx_tra_trig1_adr_msk_cn31xx cn38xxp2; struct cvmx_tra_trig1_adr_msk_cn31xx cn52xx; struct cvmx_tra_trig1_adr_msk_cn31xx cn52xxp1; struct cvmx_tra_trig1_adr_msk_cn31xx cn56xx; struct cvmx_tra_trig1_adr_msk_cn31xx cn56xxp1; struct cvmx_tra_trig1_adr_msk_cn31xx cn58xx; struct cvmx_tra_trig1_adr_msk_cn31xx cn58xxp1; struct cvmx_tra_trig1_adr_msk_s cn63xx; struct cvmx_tra_trig1_adr_msk_s cn63xxp1; }; typedef union cvmx_tra_trig1_adr_msk cvmx_tra_trig1_adr_msk_t; /** * cvmx_tra_trig1_cmd * * TRA_TRIG1_CMD = Trace Buffer Filter Command Mask * * Description: * * Notes: * Note that the trace buffer does not do proper IOBDMA address compares. Thus, if IOBDMA is set, then * the address compare must be disabled (i.e. TRA_TRIG1_ADR_MSK set to zero) to guarantee that IOBDMAs * are recognized as triggers. */ union cvmx_tra_trig1_cmd { uint64_t u64; struct cvmx_tra_trig1_cmd_s { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t saa64 : 1; /**< Enable SAA64 tracing 0=disable, 1=enable */ uint64_t saa32 : 1; /**< Enable SAA32 tracing 0=disable, 1=enable */ uint64_t reserved_60_61 : 2; uint64_t faa64 : 1; /**< Enable FAA64 tracing 0=disable, 1=enable */ uint64_t faa32 : 1; /**< Enable FAA32 tracing 0=disable, 1=enable */ uint64_t reserved_56_57 : 2; uint64_t decr64 : 1; /**< Enable DECR64 tracing 0=disable, 1=enable */ uint64_t decr32 : 1; /**< Enable DECR32 tracing 0=disable, 1=enable */ uint64_t decr16 : 1; /**< Enable DECR16 tracing 0=disable, 1=enable */ uint64_t decr8 : 1; /**< Enable DECR8 tracing 0=disable, 1=enable */ uint64_t incr64 : 1; /**< Enable INCR64 tracing 0=disable, 1=enable */ uint64_t incr32 : 1; /**< Enable INCR32 tracing 0=disable, 1=enable */ uint64_t incr16 : 1; /**< Enable INCR16 tracing 0=disable, 1=enable */ uint64_t incr8 : 1; /**< Enable INCR8 tracing 0=disable, 1=enable */ uint64_t clr64 : 1; /**< Enable CLR64 tracing 0=disable, 1=enable */ uint64_t clr32 : 1; /**< Enable CLR32 tracing 0=disable, 1=enable */ uint64_t clr16 : 1; /**< Enable CLR16 tracing 0=disable, 1=enable */ uint64_t clr8 : 1; /**< Enable CLR8 tracing 0=disable, 1=enable */ uint64_t set64 : 1; /**< Enable SET64 tracing 0=disable, 1=enable */ uint64_t set32 : 1; /**< Enable SET32 tracing 0=disable, 1=enable */ uint64_t set16 : 1; /**< Enable SET16 tracing 0=disable, 1=enable */ uint64_t set8 : 1; /**< Enable SET8 tracing 0=disable, 1=enable */ uint64_t iobst64 : 1; /**< Enable IOBST64 tracing 0=disable, 1=enable */ uint64_t iobst32 : 1; /**< Enable IOBST32 tracing 0=disable, 1=enable */ uint64_t iobst16 : 1; /**< Enable IOBST16 tracing 0=disable, 1=enable */ uint64_t iobst8 : 1; /**< Enable IOBST8 tracing 0=disable, 1=enable */ uint64_t reserved_32_35 : 4; uint64_t lckl2 : 1; /**< Enable LCKL2 tracing 0=disable, 1=enable */ uint64_t wbl2 : 1; /**< Enable WBL2 tracing 0=disable, 1=enable */ uint64_t wbil2 : 1; /**< Enable WBIL2 tracing 0=disable, 1=enable */ uint64_t invl2 : 1; /**< Enable INVL2 tracing 0=disable, 1=enable */ uint64_t reserved_27_27 : 1; uint64_t stgl2i : 1; /**< Enable STGL2I tracing 0=disable, 1=enable */ uint64_t ltgl2i : 1; /**< Enable LTGL2I tracing 0=disable, 1=enable */ uint64_t wbil2i : 1; /**< Enable WBIL2I tracing 0=disable, 1=enable */ uint64_t fas64 : 1; /**< Enable FAS64 tracing 0=disable, 1=enable */ uint64_t fas32 : 1; /**< Enable FAS32 tracing 0=disable, 1=enable */ uint64_t sttil1 : 1; /**< Enable STTIL1 tracing 0=disable, 1=enable */ uint64_t stfil1 : 1; /**< Enable STFIL1 tracing 0=disable, 1=enable */ uint64_t reserved_16_19 : 4; uint64_t iobdma : 1; /**< Enable IOBDMA tracing 0=disable, 1=enable */ uint64_t iobst : 1; /**< Enable IOBST tracing 0=disable, 1=enable */ uint64_t reserved_0_13 : 14; #else uint64_t reserved_0_13 : 14; uint64_t iobst : 1; uint64_t iobdma : 1; uint64_t reserved_16_19 : 4; uint64_t stfil1 : 1; uint64_t sttil1 : 1; uint64_t fas32 : 1; uint64_t fas64 : 1; uint64_t wbil2i : 1; uint64_t ltgl2i : 1; uint64_t stgl2i : 1; uint64_t reserved_27_27 : 1; uint64_t invl2 : 1; uint64_t wbil2 : 1; uint64_t wbl2 : 1; uint64_t lckl2 : 1; uint64_t reserved_32_35 : 4; uint64_t iobst8 : 1; uint64_t iobst16 : 1; uint64_t iobst32 : 1; uint64_t iobst64 : 1; uint64_t set8 : 1; uint64_t set16 : 1; uint64_t set32 : 1; uint64_t set64 : 1; uint64_t clr8 : 1; uint64_t clr16 : 1; uint64_t clr32 : 1; uint64_t clr64 : 1; uint64_t incr8 : 1; uint64_t incr16 : 1; uint64_t incr32 : 1; uint64_t incr64 : 1; uint64_t decr8 : 1; uint64_t decr16 : 1; uint64_t decr32 : 1; uint64_t decr64 : 1; uint64_t reserved_56_57 : 2; uint64_t faa32 : 1; uint64_t faa64 : 1; uint64_t reserved_60_61 : 2; uint64_t saa32 : 1; uint64_t saa64 : 1; #endif } s; struct cvmx_tra_trig1_cmd_cn31xx { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t reserved_16_63 : 48; uint64_t iobdma : 1; /**< Enable IOBDMA tracing 0=disable, 1=enable */ uint64_t iobst : 1; /**< Enable IOBST tracing 0=disable, 1=enable */ uint64_t iobld64 : 1; /**< Enable IOBLD64 tracing 0=disable, 1=enable */ uint64_t iobld32 : 1; /**< Enable IOBLD32 tracing 0=disable, 1=enable */ uint64_t iobld16 : 1; /**< Enable IOBLD16 tracing 0=disable, 1=enable */ uint64_t iobld8 : 1; /**< Enable IOBLD8 tracing 0=disable, 1=enable */ uint64_t stt : 1; /**< Enable STT tracing 0=disable, 1=enable */ uint64_t stp : 1; /**< Enable STP tracing 0=disable, 1=enable */ uint64_t stc : 1; /**< Enable STC tracing 0=disable, 1=enable */ uint64_t stf : 1; /**< Enable STF tracing 0=disable, 1=enable */ uint64_t ldt : 1; /**< Enable LDT tracing 0=disable, 1=enable */ uint64_t ldi : 1; /**< Enable LDI tracing 0=disable, 1=enable */ uint64_t ldd : 1; /**< Enable LDD tracing 0=disable, 1=enable */ uint64_t psl1 : 1; /**< Enable PSL1 tracing 0=disable, 1=enable */ uint64_t pl2 : 1; /**< Enable PL2 tracing 0=disable, 1=enable */ uint64_t dwb : 1; /**< Enable DWB tracing 0=disable, 1=enable */ #else uint64_t dwb : 1; uint64_t pl2 : 1; uint64_t psl1 : 1; uint64_t ldd : 1; uint64_t ldi : 1; uint64_t ldt : 1; uint64_t stf : 1; uint64_t stc : 1; uint64_t stp : 1; uint64_t stt : 1; uint64_t iobld8 : 1; uint64_t iobld16 : 1; uint64_t iobld32 : 1; uint64_t iobld64 : 1; uint64_t iobst : 1; uint64_t iobdma : 1; uint64_t reserved_16_63 : 48; #endif } cn31xx; struct cvmx_tra_trig1_cmd_cn31xx cn38xx; struct cvmx_tra_trig1_cmd_cn31xx cn38xxp2; struct cvmx_tra_trig1_cmd_cn52xx { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t reserved_17_63 : 47; uint64_t saa : 1; /**< Enable SAA tracing 0=disable, 1=enable */ uint64_t iobdma : 1; /**< Enable IOBDMA tracing 0=disable, 1=enable */ uint64_t iobst : 1; /**< Enable IOBST tracing 0=disable, 1=enable */ uint64_t iobld64 : 1; /**< Enable IOBLD64 tracing 0=disable, 1=enable */ uint64_t iobld32 : 1; /**< Enable IOBLD32 tracing 0=disable, 1=enable */ uint64_t iobld16 : 1; /**< Enable IOBLD16 tracing 0=disable, 1=enable */ uint64_t iobld8 : 1; /**< Enable IOBLD8 tracing 0=disable, 1=enable */ uint64_t stt : 1; /**< Enable STT tracing 0=disable, 1=enable */ uint64_t stp : 1; /**< Enable STP tracing 0=disable, 1=enable */ uint64_t stc : 1; /**< Enable STC tracing 0=disable, 1=enable */ uint64_t stf : 1; /**< Enable STF tracing 0=disable, 1=enable */ uint64_t ldt : 1; /**< Enable LDT tracing 0=disable, 1=enable */ uint64_t ldi : 1; /**< Enable LDI tracing 0=disable, 1=enable */ uint64_t ldd : 1; /**< Enable LDD tracing 0=disable, 1=enable */ uint64_t psl1 : 1; /**< Enable PSL1 tracing 0=disable, 1=enable */ uint64_t pl2 : 1; /**< Enable PL2 tracing 0=disable, 1=enable */ uint64_t dwb : 1; /**< Enable DWB tracing 0=disable, 1=enable */ #else uint64_t dwb : 1; uint64_t pl2 : 1; uint64_t psl1 : 1; uint64_t ldd : 1; uint64_t ldi : 1; uint64_t ldt : 1; uint64_t stf : 1; uint64_t stc : 1; uint64_t stp : 1; uint64_t stt : 1; uint64_t iobld8 : 1; uint64_t iobld16 : 1; uint64_t iobld32 : 1; uint64_t iobld64 : 1; uint64_t iobst : 1; uint64_t iobdma : 1; uint64_t saa : 1; uint64_t reserved_17_63 : 47; #endif } cn52xx; struct cvmx_tra_trig1_cmd_cn52xx cn52xxp1; struct cvmx_tra_trig1_cmd_cn52xx cn56xx; struct cvmx_tra_trig1_cmd_cn52xx cn56xxp1; struct cvmx_tra_trig1_cmd_cn52xx cn58xx; struct cvmx_tra_trig1_cmd_cn52xx cn58xxp1; struct cvmx_tra_trig1_cmd_cn63xx { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t saa64 : 1; /**< Enable SAA64 tracing 0=disable, 1=enable */ uint64_t saa32 : 1; /**< Enable SAA32 tracing 0=disable, 1=enable */ uint64_t reserved_60_61 : 2; uint64_t faa64 : 1; /**< Enable FAA64 tracing 0=disable, 1=enable */ uint64_t faa32 : 1; /**< Enable FAA32 tracing 0=disable, 1=enable */ uint64_t reserved_56_57 : 2; uint64_t decr64 : 1; /**< Enable DECR64 tracing 0=disable, 1=enable */ uint64_t decr32 : 1; /**< Enable DECR32 tracing 0=disable, 1=enable */ uint64_t decr16 : 1; /**< Enable DECR16 tracing 0=disable, 1=enable */ uint64_t decr8 : 1; /**< Enable DECR8 tracing 0=disable, 1=enable */ uint64_t incr64 : 1; /**< Enable INCR64 tracing 0=disable, 1=enable */ uint64_t incr32 : 1; /**< Enable INCR32 tracing 0=disable, 1=enable */ uint64_t incr16 : 1; /**< Enable INCR16 tracing 0=disable, 1=enable */ uint64_t incr8 : 1; /**< Enable INCR8 tracing 0=disable, 1=enable */ uint64_t clr64 : 1; /**< Enable CLR64 tracing 0=disable, 1=enable */ uint64_t clr32 : 1; /**< Enable CLR32 tracing 0=disable, 1=enable */ uint64_t clr16 : 1; /**< Enable CLR16 tracing 0=disable, 1=enable */ uint64_t clr8 : 1; /**< Enable CLR8 tracing 0=disable, 1=enable */ uint64_t set64 : 1; /**< Enable SET64 tracing 0=disable, 1=enable */ uint64_t set32 : 1; /**< Enable SET32 tracing 0=disable, 1=enable */ uint64_t set16 : 1; /**< Enable SET16 tracing 0=disable, 1=enable */ uint64_t set8 : 1; /**< Enable SET8 tracing 0=disable, 1=enable */ uint64_t iobst64 : 1; /**< Enable IOBST64 tracing 0=disable, 1=enable */ uint64_t iobst32 : 1; /**< Enable IOBST32 tracing 0=disable, 1=enable */ uint64_t iobst16 : 1; /**< Enable IOBST16 tracing 0=disable, 1=enable */ uint64_t iobst8 : 1; /**< Enable IOBST8 tracing 0=disable, 1=enable */ uint64_t iobld64 : 1; /**< Enable IOBLD64 tracing 0=disable, 1=enable */ uint64_t iobld32 : 1; /**< Enable IOBLD32 tracing 0=disable, 1=enable */ uint64_t iobld16 : 1; /**< Enable IOBLD16 tracing 0=disable, 1=enable */ uint64_t iobld8 : 1; /**< Enable IOBLD8 tracing 0=disable, 1=enable */ uint64_t lckl2 : 1; /**< Enable LCKL2 tracing 0=disable, 1=enable */ uint64_t wbl2 : 1; /**< Enable WBL2 tracing 0=disable, 1=enable */ uint64_t wbil2 : 1; /**< Enable WBIL2 tracing 0=disable, 1=enable */ uint64_t invl2 : 1; /**< Enable INVL2 tracing 0=disable, 1=enable */ uint64_t reserved_27_27 : 1; uint64_t stgl2i : 1; /**< Enable STGL2I tracing 0=disable, 1=enable */ uint64_t ltgl2i : 1; /**< Enable LTGL2I tracing 0=disable, 1=enable */ uint64_t wbil2i : 1; /**< Enable WBIL2I tracing 0=disable, 1=enable */ uint64_t fas64 : 1; /**< Enable FAS64 tracing 0=disable, 1=enable */ uint64_t fas32 : 1; /**< Enable FAS32 tracing 0=disable, 1=enable */ uint64_t sttil1 : 1; /**< Enable STTIL1 tracing 0=disable, 1=enable */ uint64_t stfil1 : 1; /**< Enable STFIL1 tracing 0=disable, 1=enable */ uint64_t stc : 1; /**< Enable STC tracing 0=disable, 1=enable */ uint64_t stp : 1; /**< Enable STP tracing 0=disable, 1=enable */ uint64_t stt : 1; /**< Enable STT tracing 0=disable, 1=enable */ uint64_t stf : 1; /**< Enable STF tracing 0=disable, 1=enable */ uint64_t iobdma : 1; /**< Enable IOBDMA tracing 0=disable, 1=enable */ uint64_t reserved_10_14 : 5; uint64_t psl1 : 1; /**< Enable PSL1 tracing 0=disable, 1=enable */ uint64_t ldd : 1; /**< Enable LDD tracing 0=disable, 1=enable */ uint64_t reserved_6_7 : 2; uint64_t dwb : 1; /**< Enable DWB tracing 0=disable, 1=enable */ uint64_t rpl2 : 1; /**< Enable RPL2 tracing 0=disable, 1=enable */ uint64_t pl2 : 1; /**< Enable PL2 tracing 0=disable, 1=enable */ uint64_t ldi : 1; /**< Enable LDI tracing 0=disable, 1=enable */ uint64_t ldt : 1; /**< Enable LDT tracing 0=disable, 1=enable */ uint64_t nop : 1; /**< Enable NOP tracing 0=disable, 1=enable */ #else uint64_t nop : 1; uint64_t ldt : 1; uint64_t ldi : 1; uint64_t pl2 : 1; uint64_t rpl2 : 1; uint64_t dwb : 1; uint64_t reserved_6_7 : 2; uint64_t ldd : 1; uint64_t psl1 : 1; uint64_t reserved_10_14 : 5; uint64_t iobdma : 1; uint64_t stf : 1; uint64_t stt : 1; uint64_t stp : 1; uint64_t stc : 1; uint64_t stfil1 : 1; uint64_t sttil1 : 1; uint64_t fas32 : 1; uint64_t fas64 : 1; uint64_t wbil2i : 1; uint64_t ltgl2i : 1; uint64_t stgl2i : 1; uint64_t reserved_27_27 : 1; uint64_t invl2 : 1; uint64_t wbil2 : 1; uint64_t wbl2 : 1; uint64_t lckl2 : 1; uint64_t iobld8 : 1; uint64_t iobld16 : 1; uint64_t iobld32 : 1; uint64_t iobld64 : 1; uint64_t iobst8 : 1; uint64_t iobst16 : 1; uint64_t iobst32 : 1; uint64_t iobst64 : 1; uint64_t set8 : 1; uint64_t set16 : 1; uint64_t set32 : 1; uint64_t set64 : 1; uint64_t clr8 : 1; uint64_t clr16 : 1; uint64_t clr32 : 1; uint64_t clr64 : 1; uint64_t incr8 : 1; uint64_t incr16 : 1; uint64_t incr32 : 1; uint64_t incr64 : 1; uint64_t decr8 : 1; uint64_t decr16 : 1; uint64_t decr32 : 1; uint64_t decr64 : 1; uint64_t reserved_56_57 : 2; uint64_t faa32 : 1; uint64_t faa64 : 1; uint64_t reserved_60_61 : 2; uint64_t saa32 : 1; uint64_t saa64 : 1; #endif } cn63xx; struct cvmx_tra_trig1_cmd_cn63xx cn63xxp1; }; typedef union cvmx_tra_trig1_cmd cvmx_tra_trig1_cmd_t; /** * cvmx_tra_trig1_did * * TRA_TRIG1_DID = Trace Buffer Filter DestinationId Mask * * Description: */ union cvmx_tra_trig1_did { uint64_t u64; struct cvmx_tra_trig1_did_s { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t reserved_13_63 : 51; uint64_t pow : 1; /**< Enable triggering on requests to POW (get work, add work, status/memory/index loads, NULLRd loads, CSR's) */ uint64_t reserved_9_11 : 3; uint64_t rng : 1; /**< Enable triggering on requests to RNG (loads/IOBDMA's are legal) */ uint64_t zip : 1; /**< Enable triggering on requests to ZIP (doorbell stores are legal) */ uint64_t dfa : 1; /**< Enable triggering on requests to DFA (CSR's and operations are legal) */ uint64_t fpa : 1; /**< Enable triggering on requests to FPA (alloc's (loads/IOBDMA's), frees (stores) are legal) */ uint64_t key : 1; /**< Enable triggering on requests to KEY memory (loads/IOBDMA's/stores are legal) */ uint64_t reserved_3_3 : 1; uint64_t illegal3 : 2; /**< Illegal destinations */ uint64_t mio : 1; /**< Enable triggering on MIO accesses (CIU and GPIO CSR's, boot bus accesses) */ #else uint64_t mio : 1; uint64_t illegal3 : 2; uint64_t reserved_3_3 : 1; uint64_t key : 1; uint64_t fpa : 1; uint64_t dfa : 1; uint64_t zip : 1; uint64_t rng : 1; uint64_t reserved_9_11 : 3; uint64_t pow : 1; uint64_t reserved_13_63 : 51; #endif } s; struct cvmx_tra_trig1_did_cn31xx { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t reserved_32_63 : 32; uint64_t illegal : 19; /**< Illegal destinations */ uint64_t pow : 1; /**< Enable triggering on requests to POW (get work, add work, status/memory/index loads, NULLRd loads, CSR's) */ uint64_t illegal2 : 3; /**< Illegal destinations */ uint64_t rng : 1; /**< Enable triggering on requests to RNG (loads/IOBDMA's are legal) */ uint64_t zip : 1; /**< Enable triggering on requests to ZIP (doorbell stores are legal) */ uint64_t dfa : 1; /**< Enable triggering on requests to DFA (CSR's and operations are legal) */ uint64_t fpa : 1; /**< Enable triggering on requests to FPA (alloc's (loads/IOBDMA's), frees (stores) are legal) */ uint64_t key : 1; /**< Enable triggering on requests to KEY memory (loads/IOBDMA's/stores are legal) */ uint64_t pci : 1; /**< Enable triggering on requests to PCI and RSL-type CSR's (RSL CSR's, PCI bus operations, PCI CSR's) */ uint64_t illegal3 : 2; /**< Illegal destinations */ uint64_t mio : 1; /**< Enable triggering on CIU and GPIO CSR's */ #else uint64_t mio : 1; uint64_t illegal3 : 2; uint64_t pci : 1; uint64_t key : 1; uint64_t fpa : 1; uint64_t dfa : 1; uint64_t zip : 1; uint64_t rng : 1; uint64_t illegal2 : 3; uint64_t pow : 1; uint64_t illegal : 19; uint64_t reserved_32_63 : 32; #endif } cn31xx; struct cvmx_tra_trig1_did_cn31xx cn38xx; struct cvmx_tra_trig1_did_cn31xx cn38xxp2; struct cvmx_tra_trig1_did_cn31xx cn52xx; struct cvmx_tra_trig1_did_cn31xx cn52xxp1; struct cvmx_tra_trig1_did_cn31xx cn56xx; struct cvmx_tra_trig1_did_cn31xx cn56xxp1; struct cvmx_tra_trig1_did_cn31xx cn58xx; struct cvmx_tra_trig1_did_cn31xx cn58xxp1; struct cvmx_tra_trig1_did_cn63xx { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t reserved_32_63 : 32; uint64_t illegal5 : 1; /**< Illegal destinations */ uint64_t fau : 1; /**< Enable triggering on FAU accesses */ uint64_t illegal4 : 2; /**< Illegal destinations */ uint64_t dpi : 1; /**< Enable triggering on DPI accesses (DPI NCB CSRs) */ uint64_t illegal : 12; /**< Illegal destinations */ uint64_t rad : 1; /**< Enable triggering on RAD accesses (doorbells) */ uint64_t usb0 : 1; /**< Enable triggering on USB0 accesses (UAHC0 EHCI and OHCI NCB CSRs) */ uint64_t pow : 1; /**< Enable triggering on requests to POW (get work, add work, status/memory/index loads, NULLRd loads, CSR's) */ uint64_t illegal2 : 1; /**< Illegal destination */ uint64_t pko : 1; /**< Enable triggering on PKO accesses (doorbells) */ uint64_t ipd : 1; /**< Enable triggering on IPD CSR accesses (IPD CSRs) */ uint64_t rng : 1; /**< Enable triggering on requests to RNG (loads/IOBDMA's are legal) */ uint64_t zip : 1; /**< Enable triggering on requests to ZIP (doorbell stores are legal) */ uint64_t dfa : 1; /**< Enable triggering on requests to DFA (CSR's and operations are legal) */ uint64_t fpa : 1; /**< Enable triggering on requests to FPA (alloc's (loads/IOBDMA's), frees (stores) are legal) */ uint64_t key : 1; /**< Enable triggering on requests to KEY memory (loads/IOBDMA's/stores are legal) */ uint64_t sli : 1; /**< Enable triggering on requests to SLI and RSL-type CSR's (RSL CSR's, PCI/sRIO bus operations, SLI CSR's) */ uint64_t illegal3 : 2; /**< Illegal destinations */ uint64_t mio : 1; /**< Enable triggering on MIO accesses (CIU and GPIO CSR's, boot bus accesses) */ #else uint64_t mio : 1; uint64_t illegal3 : 2; uint64_t sli : 1; uint64_t key : 1; uint64_t fpa : 1; uint64_t dfa : 1; uint64_t zip : 1; uint64_t rng : 1; uint64_t ipd : 1; uint64_t pko : 1; uint64_t illegal2 : 1; uint64_t pow : 1; uint64_t usb0 : 1; uint64_t rad : 1; uint64_t illegal : 12; uint64_t dpi : 1; uint64_t illegal4 : 2; uint64_t fau : 1; uint64_t illegal5 : 1; uint64_t reserved_32_63 : 32; #endif } cn63xx; struct cvmx_tra_trig1_did_cn63xx cn63xxp1; }; typedef union cvmx_tra_trig1_did cvmx_tra_trig1_did_t; /** * cvmx_tra_trig1_sid * * TRA_TRIG1_SID = Trace Buffer Filter SourceId Mask * * Description: */ union cvmx_tra_trig1_sid { uint64_t u64; struct cvmx_tra_trig1_sid_s { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t reserved_20_63 : 44; uint64_t dwb : 1; /**< Enable triggering on requests from the IOB DWB engine */ uint64_t iobreq : 1; /**< Enable triggering on requests from FPA,TIM,DFA, PCI,ZIP,POW, and PKO (writes) */ uint64_t pko : 1; /**< Enable triggering on read requests from PKO */ uint64_t pki : 1; /**< Enable triggering on write requests from PIP/IPD */ uint64_t pp : 16; /**< Enable trigering from PP[N] with matching SourceID 0=disable, 1=enableper bit N where 0<=N<=15 */ #else uint64_t pp : 16; uint64_t pki : 1; uint64_t pko : 1; uint64_t iobreq : 1; uint64_t dwb : 1; uint64_t reserved_20_63 : 44; #endif } s; struct cvmx_tra_trig1_sid_s cn31xx; struct cvmx_tra_trig1_sid_s cn38xx; struct cvmx_tra_trig1_sid_s cn38xxp2; struct cvmx_tra_trig1_sid_s cn52xx; struct cvmx_tra_trig1_sid_s cn52xxp1; struct cvmx_tra_trig1_sid_s cn56xx; struct cvmx_tra_trig1_sid_s cn56xxp1; struct cvmx_tra_trig1_sid_s cn58xx; struct cvmx_tra_trig1_sid_s cn58xxp1; struct cvmx_tra_trig1_sid_cn63xx { #if __BYTE_ORDER == __BIG_ENDIAN uint64_t reserved_20_63 : 44; uint64_t dwb : 1; /**< Enable triggering on requests from the IOB DWB engine */ uint64_t iobreq : 1; /**< Enable triggering on requests from FPA,TIM,DFA, PCI,ZIP,POW, and PKO (writes) */ uint64_t pko : 1; /**< Enable triggering on read requests from PKO */ uint64_t pki : 1; /**< Enable triggering on write requests from PIP/IPD */ uint64_t reserved_8_15 : 8; uint64_t pp : 8; /**< Enable trigering from PP[N] with matching SourceID 0=disable, 1=enableper bit N where 0<=N<=15 */ #else uint64_t pp : 8; uint64_t reserved_8_15 : 8; uint64_t pki : 1; uint64_t pko : 1; uint64_t iobreq : 1; uint64_t dwb : 1; uint64_t reserved_20_63 : 44; #endif } cn63xx; struct cvmx_tra_trig1_sid_cn63xx cn63xxp1; }; typedef union cvmx_tra_trig1_sid cvmx_tra_trig1_sid_t; #endif