config root man

Current Path : /sys/amd64/compile/hs32/modules/usr/src/sys/modules/geom/geom_mbr/@/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
Upload File :
Current File : //sys/amd64/compile/hs32/modules/usr/src/sys/modules/geom/geom_mbr/@/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

Man Man