3591 lines
197 KiB
C
3591 lines
197 KiB
C
/***********************license start***************
|
|
* Copyright (c) 2003-2012 Cavium Inc. (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 Inc. 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 INC. 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-trax-defs.h
|
|
*
|
|
* Configuration and status register (CSR) type definitions for
|
|
* Octeon trax.
|
|
*
|
|
* This file is auto generated. Do not edit.
|
|
*
|
|
* <hr>$Revision$<hr>
|
|
*
|
|
*/
|
|
#ifndef __CVMX_TRAX_DEFS_H__
|
|
#define __CVMX_TRAX_DEFS_H__
|
|
|
|
#if CVMX_ENABLE_CSR_ADDRESS_CHECKING
|
|
static inline uint64_t CVMX_TRAX_BIST_STATUS(unsigned long block_id)
|
|
{
|
|
if (!(
|
|
(OCTEON_IS_MODEL(OCTEON_CN31XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN38XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN52XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN56XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN58XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN61XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN63XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN66XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN68XX) && ((block_id <= 3))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CNF71XX) && ((block_id == 0)))))
|
|
cvmx_warn("CVMX_TRAX_BIST_STATUS(%lu) is invalid on this chip\n", block_id);
|
|
return CVMX_ADD_IO_SEG(0x00011800A8000010ull) + ((block_id) & 3) * 0x100000ull;
|
|
}
|
|
#else
|
|
#define CVMX_TRAX_BIST_STATUS(block_id) (CVMX_ADD_IO_SEG(0x00011800A8000010ull) + ((block_id) & 3) * 0x100000ull)
|
|
#endif
|
|
#if CVMX_ENABLE_CSR_ADDRESS_CHECKING
|
|
static inline uint64_t CVMX_TRAX_CTL(unsigned long block_id)
|
|
{
|
|
if (!(
|
|
(OCTEON_IS_MODEL(OCTEON_CN31XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN38XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN52XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN56XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN58XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN61XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN63XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN66XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN68XX) && ((block_id <= 3))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CNF71XX) && ((block_id == 0)))))
|
|
cvmx_warn("CVMX_TRAX_CTL(%lu) is invalid on this chip\n", block_id);
|
|
return CVMX_ADD_IO_SEG(0x00011800A8000000ull) + ((block_id) & 3) * 0x100000ull;
|
|
}
|
|
#else
|
|
#define CVMX_TRAX_CTL(block_id) (CVMX_ADD_IO_SEG(0x00011800A8000000ull) + ((block_id) & 3) * 0x100000ull)
|
|
#endif
|
|
#if CVMX_ENABLE_CSR_ADDRESS_CHECKING
|
|
static inline uint64_t CVMX_TRAX_CYCLES_SINCE(unsigned long block_id)
|
|
{
|
|
if (!(
|
|
(OCTEON_IS_MODEL(OCTEON_CN31XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN38XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN52XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN56XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN58XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN61XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN63XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN66XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN68XX) && ((block_id <= 3))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CNF71XX) && ((block_id == 0)))))
|
|
cvmx_warn("CVMX_TRAX_CYCLES_SINCE(%lu) is invalid on this chip\n", block_id);
|
|
return CVMX_ADD_IO_SEG(0x00011800A8000018ull) + ((block_id) & 3) * 0x100000ull;
|
|
}
|
|
#else
|
|
#define CVMX_TRAX_CYCLES_SINCE(block_id) (CVMX_ADD_IO_SEG(0x00011800A8000018ull) + ((block_id) & 3) * 0x100000ull)
|
|
#endif
|
|
#if CVMX_ENABLE_CSR_ADDRESS_CHECKING
|
|
static inline uint64_t CVMX_TRAX_CYCLES_SINCE1(unsigned long block_id)
|
|
{
|
|
if (!(
|
|
(OCTEON_IS_MODEL(OCTEON_CN52XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN56XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN58XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN61XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN63XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN66XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN68XX) && ((block_id <= 3))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CNF71XX) && ((block_id == 0)))))
|
|
cvmx_warn("CVMX_TRAX_CYCLES_SINCE1(%lu) is invalid on this chip\n", block_id);
|
|
return CVMX_ADD_IO_SEG(0x00011800A8000028ull) + ((block_id) & 3) * 0x100000ull;
|
|
}
|
|
#else
|
|
#define CVMX_TRAX_CYCLES_SINCE1(block_id) (CVMX_ADD_IO_SEG(0x00011800A8000028ull) + ((block_id) & 3) * 0x100000ull)
|
|
#endif
|
|
#if CVMX_ENABLE_CSR_ADDRESS_CHECKING
|
|
static inline uint64_t CVMX_TRAX_FILT_ADR_ADR(unsigned long block_id)
|
|
{
|
|
if (!(
|
|
(OCTEON_IS_MODEL(OCTEON_CN31XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN38XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN52XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN56XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN58XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN61XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN63XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN66XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN68XX) && ((block_id <= 3))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CNF71XX) && ((block_id == 0)))))
|
|
cvmx_warn("CVMX_TRAX_FILT_ADR_ADR(%lu) is invalid on this chip\n", block_id);
|
|
return CVMX_ADD_IO_SEG(0x00011800A8000058ull) + ((block_id) & 3) * 0x100000ull;
|
|
}
|
|
#else
|
|
#define CVMX_TRAX_FILT_ADR_ADR(block_id) (CVMX_ADD_IO_SEG(0x00011800A8000058ull) + ((block_id) & 3) * 0x100000ull)
|
|
#endif
|
|
#if CVMX_ENABLE_CSR_ADDRESS_CHECKING
|
|
static inline uint64_t CVMX_TRAX_FILT_ADR_MSK(unsigned long block_id)
|
|
{
|
|
if (!(
|
|
(OCTEON_IS_MODEL(OCTEON_CN31XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN38XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN52XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN56XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN58XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN61XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN63XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN66XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN68XX) && ((block_id <= 3))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CNF71XX) && ((block_id == 0)))))
|
|
cvmx_warn("CVMX_TRAX_FILT_ADR_MSK(%lu) is invalid on this chip\n", block_id);
|
|
return CVMX_ADD_IO_SEG(0x00011800A8000060ull) + ((block_id) & 3) * 0x100000ull;
|
|
}
|
|
#else
|
|
#define CVMX_TRAX_FILT_ADR_MSK(block_id) (CVMX_ADD_IO_SEG(0x00011800A8000060ull) + ((block_id) & 3) * 0x100000ull)
|
|
#endif
|
|
#if CVMX_ENABLE_CSR_ADDRESS_CHECKING
|
|
static inline uint64_t CVMX_TRAX_FILT_CMD(unsigned long block_id)
|
|
{
|
|
if (!(
|
|
(OCTEON_IS_MODEL(OCTEON_CN31XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN38XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN52XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN56XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN58XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN61XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN63XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN66XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN68XX) && ((block_id <= 3))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CNF71XX) && ((block_id == 0)))))
|
|
cvmx_warn("CVMX_TRAX_FILT_CMD(%lu) is invalid on this chip\n", block_id);
|
|
return CVMX_ADD_IO_SEG(0x00011800A8000040ull) + ((block_id) & 3) * 0x100000ull;
|
|
}
|
|
#else
|
|
#define CVMX_TRAX_FILT_CMD(block_id) (CVMX_ADD_IO_SEG(0x00011800A8000040ull) + ((block_id) & 3) * 0x100000ull)
|
|
#endif
|
|
#if CVMX_ENABLE_CSR_ADDRESS_CHECKING
|
|
static inline uint64_t CVMX_TRAX_FILT_DID(unsigned long block_id)
|
|
{
|
|
if (!(
|
|
(OCTEON_IS_MODEL(OCTEON_CN31XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN38XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN52XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN56XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN58XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN61XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN63XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN66XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN68XX) && ((block_id <= 3))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CNF71XX) && ((block_id == 0)))))
|
|
cvmx_warn("CVMX_TRAX_FILT_DID(%lu) is invalid on this chip\n", block_id);
|
|
return CVMX_ADD_IO_SEG(0x00011800A8000050ull) + ((block_id) & 3) * 0x100000ull;
|
|
}
|
|
#else
|
|
#define CVMX_TRAX_FILT_DID(block_id) (CVMX_ADD_IO_SEG(0x00011800A8000050ull) + ((block_id) & 3) * 0x100000ull)
|
|
#endif
|
|
#if CVMX_ENABLE_CSR_ADDRESS_CHECKING
|
|
static inline uint64_t CVMX_TRAX_FILT_SID(unsigned long block_id)
|
|
{
|
|
if (!(
|
|
(OCTEON_IS_MODEL(OCTEON_CN31XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN38XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN52XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN56XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN58XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN61XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN63XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN66XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN68XX) && ((block_id <= 3))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CNF71XX) && ((block_id == 0)))))
|
|
cvmx_warn("CVMX_TRAX_FILT_SID(%lu) is invalid on this chip\n", block_id);
|
|
return CVMX_ADD_IO_SEG(0x00011800A8000048ull) + ((block_id) & 3) * 0x100000ull;
|
|
}
|
|
#else
|
|
#define CVMX_TRAX_FILT_SID(block_id) (CVMX_ADD_IO_SEG(0x00011800A8000048ull) + ((block_id) & 3) * 0x100000ull)
|
|
#endif
|
|
#if CVMX_ENABLE_CSR_ADDRESS_CHECKING
|
|
static inline uint64_t CVMX_TRAX_INT_STATUS(unsigned long block_id)
|
|
{
|
|
if (!(
|
|
(OCTEON_IS_MODEL(OCTEON_CN31XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN38XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN52XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN56XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN58XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN61XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN63XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN66XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN68XX) && ((block_id <= 3))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CNF71XX) && ((block_id == 0)))))
|
|
cvmx_warn("CVMX_TRAX_INT_STATUS(%lu) is invalid on this chip\n", block_id);
|
|
return CVMX_ADD_IO_SEG(0x00011800A8000008ull) + ((block_id) & 3) * 0x100000ull;
|
|
}
|
|
#else
|
|
#define CVMX_TRAX_INT_STATUS(block_id) (CVMX_ADD_IO_SEG(0x00011800A8000008ull) + ((block_id) & 3) * 0x100000ull)
|
|
#endif
|
|
#if CVMX_ENABLE_CSR_ADDRESS_CHECKING
|
|
static inline uint64_t CVMX_TRAX_READ_DAT(unsigned long block_id)
|
|
{
|
|
if (!(
|
|
(OCTEON_IS_MODEL(OCTEON_CN31XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN38XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN52XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN56XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN58XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN61XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN63XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN66XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN68XX) && ((block_id <= 3))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CNF71XX) && ((block_id == 0)))))
|
|
cvmx_warn("CVMX_TRAX_READ_DAT(%lu) is invalid on this chip\n", block_id);
|
|
return CVMX_ADD_IO_SEG(0x00011800A8000020ull) + ((block_id) & 3) * 0x100000ull;
|
|
}
|
|
#else
|
|
#define CVMX_TRAX_READ_DAT(block_id) (CVMX_ADD_IO_SEG(0x00011800A8000020ull) + ((block_id) & 3) * 0x100000ull)
|
|
#endif
|
|
#if CVMX_ENABLE_CSR_ADDRESS_CHECKING
|
|
static inline uint64_t CVMX_TRAX_READ_DAT_HI(unsigned long block_id)
|
|
{
|
|
if (!(
|
|
(OCTEON_IS_MODEL(OCTEON_CN61XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN63XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN66XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN68XX) && ((block_id <= 3))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CNF71XX) && ((block_id == 0)))))
|
|
cvmx_warn("CVMX_TRAX_READ_DAT_HI(%lu) is invalid on this chip\n", block_id);
|
|
return CVMX_ADD_IO_SEG(0x00011800A8000030ull) + ((block_id) & 3) * 0x100000ull;
|
|
}
|
|
#else
|
|
#define CVMX_TRAX_READ_DAT_HI(block_id) (CVMX_ADD_IO_SEG(0x00011800A8000030ull) + ((block_id) & 3) * 0x100000ull)
|
|
#endif
|
|
#if CVMX_ENABLE_CSR_ADDRESS_CHECKING
|
|
static inline uint64_t CVMX_TRAX_TRIG0_ADR_ADR(unsigned long block_id)
|
|
{
|
|
if (!(
|
|
(OCTEON_IS_MODEL(OCTEON_CN31XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN38XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN52XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN56XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN58XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN61XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN63XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN66XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN68XX) && ((block_id <= 3))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CNF71XX) && ((block_id == 0)))))
|
|
cvmx_warn("CVMX_TRAX_TRIG0_ADR_ADR(%lu) is invalid on this chip\n", block_id);
|
|
return CVMX_ADD_IO_SEG(0x00011800A8000098ull) + ((block_id) & 3) * 0x100000ull;
|
|
}
|
|
#else
|
|
#define CVMX_TRAX_TRIG0_ADR_ADR(block_id) (CVMX_ADD_IO_SEG(0x00011800A8000098ull) + ((block_id) & 3) * 0x100000ull)
|
|
#endif
|
|
#if CVMX_ENABLE_CSR_ADDRESS_CHECKING
|
|
static inline uint64_t CVMX_TRAX_TRIG0_ADR_MSK(unsigned long block_id)
|
|
{
|
|
if (!(
|
|
(OCTEON_IS_MODEL(OCTEON_CN31XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN38XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN52XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN56XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN58XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN61XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN63XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN66XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN68XX) && ((block_id <= 3))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CNF71XX) && ((block_id == 0)))))
|
|
cvmx_warn("CVMX_TRAX_TRIG0_ADR_MSK(%lu) is invalid on this chip\n", block_id);
|
|
return CVMX_ADD_IO_SEG(0x00011800A80000A0ull) + ((block_id) & 3) * 0x100000ull;
|
|
}
|
|
#else
|
|
#define CVMX_TRAX_TRIG0_ADR_MSK(block_id) (CVMX_ADD_IO_SEG(0x00011800A80000A0ull) + ((block_id) & 3) * 0x100000ull)
|
|
#endif
|
|
#if CVMX_ENABLE_CSR_ADDRESS_CHECKING
|
|
static inline uint64_t CVMX_TRAX_TRIG0_CMD(unsigned long block_id)
|
|
{
|
|
if (!(
|
|
(OCTEON_IS_MODEL(OCTEON_CN31XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN38XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN52XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN56XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN58XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN61XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN63XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN66XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN68XX) && ((block_id <= 3))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CNF71XX) && ((block_id == 0)))))
|
|
cvmx_warn("CVMX_TRAX_TRIG0_CMD(%lu) is invalid on this chip\n", block_id);
|
|
return CVMX_ADD_IO_SEG(0x00011800A8000080ull) + ((block_id) & 3) * 0x100000ull;
|
|
}
|
|
#else
|
|
#define CVMX_TRAX_TRIG0_CMD(block_id) (CVMX_ADD_IO_SEG(0x00011800A8000080ull) + ((block_id) & 3) * 0x100000ull)
|
|
#endif
|
|
#if CVMX_ENABLE_CSR_ADDRESS_CHECKING
|
|
static inline uint64_t CVMX_TRAX_TRIG0_DID(unsigned long block_id)
|
|
{
|
|
if (!(
|
|
(OCTEON_IS_MODEL(OCTEON_CN31XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN38XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN52XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN56XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN58XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN61XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN63XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN66XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN68XX) && ((block_id <= 3))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CNF71XX) && ((block_id == 0)))))
|
|
cvmx_warn("CVMX_TRAX_TRIG0_DID(%lu) is invalid on this chip\n", block_id);
|
|
return CVMX_ADD_IO_SEG(0x00011800A8000090ull) + ((block_id) & 3) * 0x100000ull;
|
|
}
|
|
#else
|
|
#define CVMX_TRAX_TRIG0_DID(block_id) (CVMX_ADD_IO_SEG(0x00011800A8000090ull) + ((block_id) & 3) * 0x100000ull)
|
|
#endif
|
|
#if CVMX_ENABLE_CSR_ADDRESS_CHECKING
|
|
static inline uint64_t CVMX_TRAX_TRIG0_SID(unsigned long block_id)
|
|
{
|
|
if (!(
|
|
(OCTEON_IS_MODEL(OCTEON_CN31XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN38XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN52XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN56XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN58XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN61XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN63XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN66XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN68XX) && ((block_id <= 3))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CNF71XX) && ((block_id == 0)))))
|
|
cvmx_warn("CVMX_TRAX_TRIG0_SID(%lu) is invalid on this chip\n", block_id);
|
|
return CVMX_ADD_IO_SEG(0x00011800A8000088ull) + ((block_id) & 3) * 0x100000ull;
|
|
}
|
|
#else
|
|
#define CVMX_TRAX_TRIG0_SID(block_id) (CVMX_ADD_IO_SEG(0x00011800A8000088ull) + ((block_id) & 3) * 0x100000ull)
|
|
#endif
|
|
#if CVMX_ENABLE_CSR_ADDRESS_CHECKING
|
|
static inline uint64_t CVMX_TRAX_TRIG1_ADR_ADR(unsigned long block_id)
|
|
{
|
|
if (!(
|
|
(OCTEON_IS_MODEL(OCTEON_CN31XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN38XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN52XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN56XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN58XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN61XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN63XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN66XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN68XX) && ((block_id <= 3))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CNF71XX) && ((block_id == 0)))))
|
|
cvmx_warn("CVMX_TRAX_TRIG1_ADR_ADR(%lu) is invalid on this chip\n", block_id);
|
|
return CVMX_ADD_IO_SEG(0x00011800A80000D8ull) + ((block_id) & 3) * 0x100000ull;
|
|
}
|
|
#else
|
|
#define CVMX_TRAX_TRIG1_ADR_ADR(block_id) (CVMX_ADD_IO_SEG(0x00011800A80000D8ull) + ((block_id) & 3) * 0x100000ull)
|
|
#endif
|
|
#if CVMX_ENABLE_CSR_ADDRESS_CHECKING
|
|
static inline uint64_t CVMX_TRAX_TRIG1_ADR_MSK(unsigned long block_id)
|
|
{
|
|
if (!(
|
|
(OCTEON_IS_MODEL(OCTEON_CN31XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN38XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN52XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN56XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN58XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN61XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN63XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN66XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN68XX) && ((block_id <= 3))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CNF71XX) && ((block_id == 0)))))
|
|
cvmx_warn("CVMX_TRAX_TRIG1_ADR_MSK(%lu) is invalid on this chip\n", block_id);
|
|
return CVMX_ADD_IO_SEG(0x00011800A80000E0ull) + ((block_id) & 3) * 0x100000ull;
|
|
}
|
|
#else
|
|
#define CVMX_TRAX_TRIG1_ADR_MSK(block_id) (CVMX_ADD_IO_SEG(0x00011800A80000E0ull) + ((block_id) & 3) * 0x100000ull)
|
|
#endif
|
|
#if CVMX_ENABLE_CSR_ADDRESS_CHECKING
|
|
static inline uint64_t CVMX_TRAX_TRIG1_CMD(unsigned long block_id)
|
|
{
|
|
if (!(
|
|
(OCTEON_IS_MODEL(OCTEON_CN31XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN38XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN52XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN56XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN58XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN61XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN63XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN66XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN68XX) && ((block_id <= 3))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CNF71XX) && ((block_id == 0)))))
|
|
cvmx_warn("CVMX_TRAX_TRIG1_CMD(%lu) is invalid on this chip\n", block_id);
|
|
return CVMX_ADD_IO_SEG(0x00011800A80000C0ull) + ((block_id) & 3) * 0x100000ull;
|
|
}
|
|
#else
|
|
#define CVMX_TRAX_TRIG1_CMD(block_id) (CVMX_ADD_IO_SEG(0x00011800A80000C0ull) + ((block_id) & 3) * 0x100000ull)
|
|
#endif
|
|
#if CVMX_ENABLE_CSR_ADDRESS_CHECKING
|
|
static inline uint64_t CVMX_TRAX_TRIG1_DID(unsigned long block_id)
|
|
{
|
|
if (!(
|
|
(OCTEON_IS_MODEL(OCTEON_CN31XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN38XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN52XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN56XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN58XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN61XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN63XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN66XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN68XX) && ((block_id <= 3))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CNF71XX) && ((block_id == 0)))))
|
|
cvmx_warn("CVMX_TRAX_TRIG1_DID(%lu) is invalid on this chip\n", block_id);
|
|
return CVMX_ADD_IO_SEG(0x00011800A80000D0ull) + ((block_id) & 3) * 0x100000ull;
|
|
}
|
|
#else
|
|
#define CVMX_TRAX_TRIG1_DID(block_id) (CVMX_ADD_IO_SEG(0x00011800A80000D0ull) + ((block_id) & 3) * 0x100000ull)
|
|
#endif
|
|
#if CVMX_ENABLE_CSR_ADDRESS_CHECKING
|
|
static inline uint64_t CVMX_TRAX_TRIG1_SID(unsigned long block_id)
|
|
{
|
|
if (!(
|
|
(OCTEON_IS_MODEL(OCTEON_CN31XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN38XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN52XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN56XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN58XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN61XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN63XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN66XX) && ((block_id == 0))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CN68XX) && ((block_id <= 3))) ||
|
|
(OCTEON_IS_MODEL(OCTEON_CNF71XX) && ((block_id == 0)))))
|
|
cvmx_warn("CVMX_TRAX_TRIG1_SID(%lu) is invalid on this chip\n", block_id);
|
|
return CVMX_ADD_IO_SEG(0x00011800A80000C8ull) + ((block_id) & 3) * 0x100000ull;
|
|
}
|
|
#else
|
|
#define CVMX_TRAX_TRIG1_SID(block_id) (CVMX_ADD_IO_SEG(0x00011800A80000C8ull) + ((block_id) & 3) * 0x100000ull)
|
|
#endif
|
|
|
|
/**
|
|
* cvmx_tra#_bist_status
|
|
*
|
|
* TRA_BIST_STATUS = Trace Buffer BiST Status
|
|
*
|
|
* Description:
|
|
*/
|
|
union cvmx_trax_bist_status {
|
|
uint64_t u64;
|
|
struct cvmx_trax_bist_status_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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_trax_bist_status_cn31xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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_trax_bist_status_cn31xx cn38xx;
|
|
struct cvmx_trax_bist_status_cn31xx cn38xxp2;
|
|
struct cvmx_trax_bist_status_cn31xx cn52xx;
|
|
struct cvmx_trax_bist_status_cn31xx cn52xxp1;
|
|
struct cvmx_trax_bist_status_cn31xx cn56xx;
|
|
struct cvmx_trax_bist_status_cn31xx cn56xxp1;
|
|
struct cvmx_trax_bist_status_cn31xx cn58xx;
|
|
struct cvmx_trax_bist_status_cn31xx cn58xxp1;
|
|
struct cvmx_trax_bist_status_cn61xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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
|
|
} cn61xx;
|
|
struct cvmx_trax_bist_status_cn61xx cn63xx;
|
|
struct cvmx_trax_bist_status_cn61xx cn63xxp1;
|
|
struct cvmx_trax_bist_status_cn61xx cn66xx;
|
|
struct cvmx_trax_bist_status_cn61xx cn68xx;
|
|
struct cvmx_trax_bist_status_cn61xx cn68xxp1;
|
|
struct cvmx_trax_bist_status_cn61xx cnf71xx;
|
|
};
|
|
typedef union cvmx_trax_bist_status cvmx_trax_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_trax_ctl {
|
|
uint64_t u64;
|
|
struct cvmx_trax_ctl_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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_trax_ctl_cn31xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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(0..0)_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(0..0)_INT_STATUS.MCD0_TRG == 1). */
|
|
uint64_t ciu_thr : 1; /**< CIU_threshold
|
|
When set during a fill threshold event,
|
|
TRA(0..0)_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(0..0)_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_trax_ctl_cn31xx cn38xx;
|
|
struct cvmx_trax_ctl_cn31xx cn38xxp2;
|
|
struct cvmx_trax_ctl_cn31xx cn52xx;
|
|
struct cvmx_trax_ctl_cn31xx cn52xxp1;
|
|
struct cvmx_trax_ctl_cn31xx cn56xx;
|
|
struct cvmx_trax_ctl_cn31xx cn56xxp1;
|
|
struct cvmx_trax_ctl_cn31xx cn58xx;
|
|
struct cvmx_trax_ctl_cn31xx cn58xxp1;
|
|
struct cvmx_trax_ctl_s cn61xx;
|
|
struct cvmx_trax_ctl_s cn63xx;
|
|
struct cvmx_trax_ctl_cn63xxp1 {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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;
|
|
struct cvmx_trax_ctl_s cn66xx;
|
|
struct cvmx_trax_ctl_s cn68xx;
|
|
struct cvmx_trax_ctl_s cn68xxp1;
|
|
struct cvmx_trax_ctl_s cnf71xx;
|
|
};
|
|
typedef union cvmx_trax_ctl cvmx_trax_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_trax_cycles_since {
|
|
uint64_t u64;
|
|
struct cvmx_trax_cycles_since_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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_trax_cycles_since_s cn31xx;
|
|
struct cvmx_trax_cycles_since_s cn38xx;
|
|
struct cvmx_trax_cycles_since_s cn38xxp2;
|
|
struct cvmx_trax_cycles_since_s cn52xx;
|
|
struct cvmx_trax_cycles_since_s cn52xxp1;
|
|
struct cvmx_trax_cycles_since_s cn56xx;
|
|
struct cvmx_trax_cycles_since_s cn56xxp1;
|
|
struct cvmx_trax_cycles_since_s cn58xx;
|
|
struct cvmx_trax_cycles_since_s cn58xxp1;
|
|
struct cvmx_trax_cycles_since_s cn61xx;
|
|
struct cvmx_trax_cycles_since_s cn63xx;
|
|
struct cvmx_trax_cycles_since_s cn63xxp1;
|
|
struct cvmx_trax_cycles_since_s cn66xx;
|
|
struct cvmx_trax_cycles_since_s cn68xx;
|
|
struct cvmx_trax_cycles_since_s cn68xxp1;
|
|
struct cvmx_trax_cycles_since_s cnf71xx;
|
|
};
|
|
typedef union cvmx_trax_cycles_since cvmx_trax_cycles_since_t;
|
|
|
|
/**
|
|
* cvmx_tra#_cycles_since1
|
|
*
|
|
* TRA_CYCLES_SINCE1 = Trace Buffer Cycles Since Last Write, Read/Write pointers
|
|
*
|
|
* Description:
|
|
*/
|
|
union cvmx_trax_cycles_since1 {
|
|
uint64_t u64;
|
|
struct cvmx_trax_cycles_since1_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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_trax_cycles_since1_s cn52xx;
|
|
struct cvmx_trax_cycles_since1_s cn52xxp1;
|
|
struct cvmx_trax_cycles_since1_s cn56xx;
|
|
struct cvmx_trax_cycles_since1_s cn56xxp1;
|
|
struct cvmx_trax_cycles_since1_s cn58xx;
|
|
struct cvmx_trax_cycles_since1_s cn58xxp1;
|
|
struct cvmx_trax_cycles_since1_s cn61xx;
|
|
struct cvmx_trax_cycles_since1_s cn63xx;
|
|
struct cvmx_trax_cycles_since1_s cn63xxp1;
|
|
struct cvmx_trax_cycles_since1_s cn66xx;
|
|
struct cvmx_trax_cycles_since1_s cn68xx;
|
|
struct cvmx_trax_cycles_since1_s cn68xxp1;
|
|
struct cvmx_trax_cycles_since1_s cnf71xx;
|
|
};
|
|
typedef union cvmx_trax_cycles_since1 cvmx_trax_cycles_since1_t;
|
|
|
|
/**
|
|
* cvmx_tra#_filt_adr_adr
|
|
*
|
|
* TRA_FILT_ADR_ADR = Trace Buffer Filter Address Address
|
|
*
|
|
* Description:
|
|
*/
|
|
union cvmx_trax_filt_adr_adr {
|
|
uint64_t u64;
|
|
struct cvmx_trax_filt_adr_adr_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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_trax_filt_adr_adr_cn31xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_36_63 : 28;
|
|
uint64_t adr : 36; /**< Unmasked Address
|
|
The combination of TRA(0..0)_FILT_ADR_ADR and
|
|
TRA(0..0)_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_trax_filt_adr_adr_cn31xx cn38xx;
|
|
struct cvmx_trax_filt_adr_adr_cn31xx cn38xxp2;
|
|
struct cvmx_trax_filt_adr_adr_cn31xx cn52xx;
|
|
struct cvmx_trax_filt_adr_adr_cn31xx cn52xxp1;
|
|
struct cvmx_trax_filt_adr_adr_cn31xx cn56xx;
|
|
struct cvmx_trax_filt_adr_adr_cn31xx cn56xxp1;
|
|
struct cvmx_trax_filt_adr_adr_cn31xx cn58xx;
|
|
struct cvmx_trax_filt_adr_adr_cn31xx cn58xxp1;
|
|
struct cvmx_trax_filt_adr_adr_s cn61xx;
|
|
struct cvmx_trax_filt_adr_adr_s cn63xx;
|
|
struct cvmx_trax_filt_adr_adr_s cn63xxp1;
|
|
struct cvmx_trax_filt_adr_adr_s cn66xx;
|
|
struct cvmx_trax_filt_adr_adr_s cn68xx;
|
|
struct cvmx_trax_filt_adr_adr_s cn68xxp1;
|
|
struct cvmx_trax_filt_adr_adr_s cnf71xx;
|
|
};
|
|
typedef union cvmx_trax_filt_adr_adr cvmx_trax_filt_adr_adr_t;
|
|
|
|
/**
|
|
* cvmx_tra#_filt_adr_msk
|
|
*
|
|
* TRA_FILT_ADR_MSK = Trace Buffer Filter Address Mask
|
|
*
|
|
* Description:
|
|
*/
|
|
union cvmx_trax_filt_adr_msk {
|
|
uint64_t u64;
|
|
struct cvmx_trax_filt_adr_msk_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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_trax_filt_adr_msk_cn31xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_36_63 : 28;
|
|
uint64_t adr : 36; /**< Address Mask
|
|
The combination of TRA(0..0)_FILT_ADR_ADR and
|
|
TRA(0..0)_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(0..0)_FILT_CMD[IOBDMA]
|
|
is set, TRA(0..0)_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_trax_filt_adr_msk_cn31xx cn38xx;
|
|
struct cvmx_trax_filt_adr_msk_cn31xx cn38xxp2;
|
|
struct cvmx_trax_filt_adr_msk_cn31xx cn52xx;
|
|
struct cvmx_trax_filt_adr_msk_cn31xx cn52xxp1;
|
|
struct cvmx_trax_filt_adr_msk_cn31xx cn56xx;
|
|
struct cvmx_trax_filt_adr_msk_cn31xx cn56xxp1;
|
|
struct cvmx_trax_filt_adr_msk_cn31xx cn58xx;
|
|
struct cvmx_trax_filt_adr_msk_cn31xx cn58xxp1;
|
|
struct cvmx_trax_filt_adr_msk_s cn61xx;
|
|
struct cvmx_trax_filt_adr_msk_s cn63xx;
|
|
struct cvmx_trax_filt_adr_msk_s cn63xxp1;
|
|
struct cvmx_trax_filt_adr_msk_s cn66xx;
|
|
struct cvmx_trax_filt_adr_msk_s cn68xx;
|
|
struct cvmx_trax_filt_adr_msk_s cn68xxp1;
|
|
struct cvmx_trax_filt_adr_msk_s cnf71xx;
|
|
};
|
|
typedef union cvmx_trax_filt_adr_msk cvmx_trax_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_trax_filt_cmd {
|
|
uint64_t u64;
|
|
struct cvmx_trax_filt_cmd_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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_trax_filt_cmd_cn31xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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_trax_filt_cmd_cn31xx cn38xx;
|
|
struct cvmx_trax_filt_cmd_cn31xx cn38xxp2;
|
|
struct cvmx_trax_filt_cmd_cn52xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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_trax_filt_cmd_cn52xx cn52xxp1;
|
|
struct cvmx_trax_filt_cmd_cn52xx cn56xx;
|
|
struct cvmx_trax_filt_cmd_cn52xx cn56xxp1;
|
|
struct cvmx_trax_filt_cmd_cn52xx cn58xx;
|
|
struct cvmx_trax_filt_cmd_cn52xx cn58xxp1;
|
|
struct cvmx_trax_filt_cmd_cn61xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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
|
|
} cn61xx;
|
|
struct cvmx_trax_filt_cmd_cn61xx cn63xx;
|
|
struct cvmx_trax_filt_cmd_cn61xx cn63xxp1;
|
|
struct cvmx_trax_filt_cmd_cn61xx cn66xx;
|
|
struct cvmx_trax_filt_cmd_cn61xx cn68xx;
|
|
struct cvmx_trax_filt_cmd_cn61xx cn68xxp1;
|
|
struct cvmx_trax_filt_cmd_cn61xx cnf71xx;
|
|
};
|
|
typedef union cvmx_trax_filt_cmd cvmx_trax_filt_cmd_t;
|
|
|
|
/**
|
|
* cvmx_tra#_filt_did
|
|
*
|
|
* TRA_FILT_DID = Trace Buffer Filter DestinationId Mask
|
|
*
|
|
* Description:
|
|
*/
|
|
union cvmx_trax_filt_did {
|
|
uint64_t u64;
|
|
struct cvmx_trax_filt_did_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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_trax_filt_did_cn31xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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_trax_filt_did_cn31xx cn38xx;
|
|
struct cvmx_trax_filt_did_cn31xx cn38xxp2;
|
|
struct cvmx_trax_filt_did_cn31xx cn52xx;
|
|
struct cvmx_trax_filt_did_cn31xx cn52xxp1;
|
|
struct cvmx_trax_filt_did_cn31xx cn56xx;
|
|
struct cvmx_trax_filt_did_cn31xx cn56xxp1;
|
|
struct cvmx_trax_filt_did_cn31xx cn58xx;
|
|
struct cvmx_trax_filt_did_cn31xx cn58xxp1;
|
|
struct cvmx_trax_filt_did_cn61xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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
|
|
} cn61xx;
|
|
struct cvmx_trax_filt_did_cn61xx cn63xx;
|
|
struct cvmx_trax_filt_did_cn61xx cn63xxp1;
|
|
struct cvmx_trax_filt_did_cn61xx cn66xx;
|
|
struct cvmx_trax_filt_did_cn61xx cn68xx;
|
|
struct cvmx_trax_filt_did_cn61xx cn68xxp1;
|
|
struct cvmx_trax_filt_did_cn61xx cnf71xx;
|
|
};
|
|
typedef union cvmx_trax_filt_did cvmx_trax_filt_did_t;
|
|
|
|
/**
|
|
* cvmx_tra#_filt_sid
|
|
*
|
|
* TRA_FILT_SID = Trace Buffer Filter SourceId Mask
|
|
*
|
|
* Description:
|
|
*/
|
|
union cvmx_trax_filt_sid {
|
|
uint64_t u64;
|
|
struct cvmx_trax_filt_sid_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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=enable per bit N where 0<=N<=3 */
|
|
#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_trax_filt_sid_s cn31xx;
|
|
struct cvmx_trax_filt_sid_s cn38xx;
|
|
struct cvmx_trax_filt_sid_s cn38xxp2;
|
|
struct cvmx_trax_filt_sid_s cn52xx;
|
|
struct cvmx_trax_filt_sid_s cn52xxp1;
|
|
struct cvmx_trax_filt_sid_s cn56xx;
|
|
struct cvmx_trax_filt_sid_s cn56xxp1;
|
|
struct cvmx_trax_filt_sid_s cn58xx;
|
|
struct cvmx_trax_filt_sid_s cn58xxp1;
|
|
struct cvmx_trax_filt_sid_cn61xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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_4_15 : 12;
|
|
uint64_t pp : 4; /**< Enable tracing from PP[N] with matching SourceID
|
|
0=disable, 1=enable per bit N where 0<=N<=3 */
|
|
#else
|
|
uint64_t pp : 4;
|
|
uint64_t reserved_4_15 : 12;
|
|
uint64_t pki : 1;
|
|
uint64_t pko : 1;
|
|
uint64_t iobreq : 1;
|
|
uint64_t dwb : 1;
|
|
uint64_t reserved_20_63 : 44;
|
|
#endif
|
|
} cn61xx;
|
|
struct cvmx_trax_filt_sid_cn63xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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_trax_filt_sid_cn63xxp1 {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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_6_15 : 10;
|
|
uint64_t pp : 6; /**< Enable tracing from PP[N] with matching SourceID
|
|
0=disable, 1=enable per bit N where 0<=N<=5 */
|
|
#else
|
|
uint64_t pp : 6;
|
|
uint64_t reserved_6_15 : 10;
|
|
uint64_t pki : 1;
|
|
uint64_t pko : 1;
|
|
uint64_t iobreq : 1;
|
|
uint64_t dwb : 1;
|
|
uint64_t reserved_20_63 : 44;
|
|
#endif
|
|
} cn63xxp1;
|
|
struct cvmx_trax_filt_sid_cn66xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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_10_15 : 6;
|
|
uint64_t pp : 10; /**< Enable tracing from PP[N] with matching SourceID
|
|
0=disable, 1=enableper bit N where 0<=N<=15 */
|
|
#else
|
|
uint64_t pp : 10;
|
|
uint64_t reserved_10_15 : 6;
|
|
uint64_t pki : 1;
|
|
uint64_t pko : 1;
|
|
uint64_t iobreq : 1;
|
|
uint64_t dwb : 1;
|
|
uint64_t reserved_20_63 : 44;
|
|
#endif
|
|
} cn66xx;
|
|
struct cvmx_trax_filt_sid_cn63xx cn68xx;
|
|
struct cvmx_trax_filt_sid_cn63xx cn68xxp1;
|
|
struct cvmx_trax_filt_sid_cn61xx cnf71xx;
|
|
};
|
|
typedef union cvmx_trax_filt_sid cvmx_trax_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_trax_int_status {
|
|
uint64_t u64;
|
|
struct cvmx_trax_int_status_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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_trax_int_status_s cn31xx;
|
|
struct cvmx_trax_int_status_s cn38xx;
|
|
struct cvmx_trax_int_status_s cn38xxp2;
|
|
struct cvmx_trax_int_status_s cn52xx;
|
|
struct cvmx_trax_int_status_s cn52xxp1;
|
|
struct cvmx_trax_int_status_s cn56xx;
|
|
struct cvmx_trax_int_status_s cn56xxp1;
|
|
struct cvmx_trax_int_status_s cn58xx;
|
|
struct cvmx_trax_int_status_s cn58xxp1;
|
|
struct cvmx_trax_int_status_s cn61xx;
|
|
struct cvmx_trax_int_status_s cn63xx;
|
|
struct cvmx_trax_int_status_s cn63xxp1;
|
|
struct cvmx_trax_int_status_s cn66xx;
|
|
struct cvmx_trax_int_status_s cn68xx;
|
|
struct cvmx_trax_int_status_s cn68xxp1;
|
|
struct cvmx_trax_int_status_s cnf71xx;
|
|
};
|
|
typedef union cvmx_trax_int_status cvmx_trax_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_trax_read_dat {
|
|
uint64_t u64;
|
|
struct cvmx_trax_read_dat_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t data : 64; /**< Trace buffer data for current entry
|
|
if TRA_CTL[16]== 1; returns lower 64 bits of entry
|
|
else two access are necessary to get all of 69bits
|
|
first access of a pair is the lower 64 bits and
|
|
second access is the upper 5 bits. */
|
|
#else
|
|
uint64_t data : 64;
|
|
#endif
|
|
} s;
|
|
struct cvmx_trax_read_dat_s cn31xx;
|
|
struct cvmx_trax_read_dat_s cn38xx;
|
|
struct cvmx_trax_read_dat_s cn38xxp2;
|
|
struct cvmx_trax_read_dat_s cn52xx;
|
|
struct cvmx_trax_read_dat_s cn52xxp1;
|
|
struct cvmx_trax_read_dat_s cn56xx;
|
|
struct cvmx_trax_read_dat_s cn56xxp1;
|
|
struct cvmx_trax_read_dat_s cn58xx;
|
|
struct cvmx_trax_read_dat_s cn58xxp1;
|
|
struct cvmx_trax_read_dat_s cn61xx;
|
|
struct cvmx_trax_read_dat_s cn63xx;
|
|
struct cvmx_trax_read_dat_s cn63xxp1;
|
|
struct cvmx_trax_read_dat_s cn66xx;
|
|
struct cvmx_trax_read_dat_s cn68xx;
|
|
struct cvmx_trax_read_dat_s cn68xxp1;
|
|
struct cvmx_trax_read_dat_s cnf71xx;
|
|
};
|
|
typedef union cvmx_trax_read_dat cvmx_trax_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_trax_read_dat_hi {
|
|
uint64_t u64;
|
|
struct cvmx_trax_read_dat_hi_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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_trax_read_dat_hi_s cn61xx;
|
|
struct cvmx_trax_read_dat_hi_s cn63xx;
|
|
struct cvmx_trax_read_dat_hi_s cn66xx;
|
|
struct cvmx_trax_read_dat_hi_s cn68xx;
|
|
struct cvmx_trax_read_dat_hi_s cn68xxp1;
|
|
struct cvmx_trax_read_dat_hi_s cnf71xx;
|
|
};
|
|
typedef union cvmx_trax_read_dat_hi cvmx_trax_read_dat_hi_t;
|
|
|
|
/**
|
|
* cvmx_tra#_trig0_adr_adr
|
|
*
|
|
* TRA_TRIG0_ADR_ADR = Trace Buffer Filter Address Address
|
|
*
|
|
* Description:
|
|
*/
|
|
union cvmx_trax_trig0_adr_adr {
|
|
uint64_t u64;
|
|
struct cvmx_trax_trig0_adr_adr_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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_trax_trig0_adr_adr_cn31xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_36_63 : 28;
|
|
uint64_t adr : 36; /**< Unmasked Address
|
|
The combination of TRA(0..0)_TRIG0_ADR_ADR and
|
|
TRA(0..0)_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_trax_trig0_adr_adr_cn31xx cn38xx;
|
|
struct cvmx_trax_trig0_adr_adr_cn31xx cn38xxp2;
|
|
struct cvmx_trax_trig0_adr_adr_cn31xx cn52xx;
|
|
struct cvmx_trax_trig0_adr_adr_cn31xx cn52xxp1;
|
|
struct cvmx_trax_trig0_adr_adr_cn31xx cn56xx;
|
|
struct cvmx_trax_trig0_adr_adr_cn31xx cn56xxp1;
|
|
struct cvmx_trax_trig0_adr_adr_cn31xx cn58xx;
|
|
struct cvmx_trax_trig0_adr_adr_cn31xx cn58xxp1;
|
|
struct cvmx_trax_trig0_adr_adr_s cn61xx;
|
|
struct cvmx_trax_trig0_adr_adr_s cn63xx;
|
|
struct cvmx_trax_trig0_adr_adr_s cn63xxp1;
|
|
struct cvmx_trax_trig0_adr_adr_s cn66xx;
|
|
struct cvmx_trax_trig0_adr_adr_s cn68xx;
|
|
struct cvmx_trax_trig0_adr_adr_s cn68xxp1;
|
|
struct cvmx_trax_trig0_adr_adr_s cnf71xx;
|
|
};
|
|
typedef union cvmx_trax_trig0_adr_adr cvmx_trax_trig0_adr_adr_t;
|
|
|
|
/**
|
|
* cvmx_tra#_trig0_adr_msk
|
|
*
|
|
* TRA_TRIG0_ADR_MSK = Trace Buffer Filter Address Mask
|
|
*
|
|
* Description:
|
|
*/
|
|
union cvmx_trax_trig0_adr_msk {
|
|
uint64_t u64;
|
|
struct cvmx_trax_trig0_adr_msk_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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_trax_trig0_adr_msk_cn31xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_36_63 : 28;
|
|
uint64_t adr : 36; /**< Address Mask
|
|
The combination of TRA(0..0)_TRIG0_ADR_ADR and
|
|
TRA(0..0)_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(0..0)_TRIG0_CMD[IOBDMA]
|
|
is set, TRA(0..0)_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_trax_trig0_adr_msk_cn31xx cn38xx;
|
|
struct cvmx_trax_trig0_adr_msk_cn31xx cn38xxp2;
|
|
struct cvmx_trax_trig0_adr_msk_cn31xx cn52xx;
|
|
struct cvmx_trax_trig0_adr_msk_cn31xx cn52xxp1;
|
|
struct cvmx_trax_trig0_adr_msk_cn31xx cn56xx;
|
|
struct cvmx_trax_trig0_adr_msk_cn31xx cn56xxp1;
|
|
struct cvmx_trax_trig0_adr_msk_cn31xx cn58xx;
|
|
struct cvmx_trax_trig0_adr_msk_cn31xx cn58xxp1;
|
|
struct cvmx_trax_trig0_adr_msk_s cn61xx;
|
|
struct cvmx_trax_trig0_adr_msk_s cn63xx;
|
|
struct cvmx_trax_trig0_adr_msk_s cn63xxp1;
|
|
struct cvmx_trax_trig0_adr_msk_s cn66xx;
|
|
struct cvmx_trax_trig0_adr_msk_s cn68xx;
|
|
struct cvmx_trax_trig0_adr_msk_s cn68xxp1;
|
|
struct cvmx_trax_trig0_adr_msk_s cnf71xx;
|
|
};
|
|
typedef union cvmx_trax_trig0_adr_msk cvmx_trax_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_trax_trig0_cmd {
|
|
uint64_t u64;
|
|
struct cvmx_trax_trig0_cmd_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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_trax_trig0_cmd_cn31xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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_trax_trig0_cmd_cn31xx cn38xx;
|
|
struct cvmx_trax_trig0_cmd_cn31xx cn38xxp2;
|
|
struct cvmx_trax_trig0_cmd_cn52xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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_trax_trig0_cmd_cn52xx cn52xxp1;
|
|
struct cvmx_trax_trig0_cmd_cn52xx cn56xx;
|
|
struct cvmx_trax_trig0_cmd_cn52xx cn56xxp1;
|
|
struct cvmx_trax_trig0_cmd_cn52xx cn58xx;
|
|
struct cvmx_trax_trig0_cmd_cn52xx cn58xxp1;
|
|
struct cvmx_trax_trig0_cmd_cn61xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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
|
|
} cn61xx;
|
|
struct cvmx_trax_trig0_cmd_cn61xx cn63xx;
|
|
struct cvmx_trax_trig0_cmd_cn61xx cn63xxp1;
|
|
struct cvmx_trax_trig0_cmd_cn61xx cn66xx;
|
|
struct cvmx_trax_trig0_cmd_cn61xx cn68xx;
|
|
struct cvmx_trax_trig0_cmd_cn61xx cn68xxp1;
|
|
struct cvmx_trax_trig0_cmd_cn61xx cnf71xx;
|
|
};
|
|
typedef union cvmx_trax_trig0_cmd cvmx_trax_trig0_cmd_t;
|
|
|
|
/**
|
|
* cvmx_tra#_trig0_did
|
|
*
|
|
* TRA_TRIG0_DID = Trace Buffer Filter DestinationId Mask
|
|
*
|
|
* Description:
|
|
*/
|
|
union cvmx_trax_trig0_did {
|
|
uint64_t u64;
|
|
struct cvmx_trax_trig0_did_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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_trax_trig0_did_cn31xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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_trax_trig0_did_cn31xx cn38xx;
|
|
struct cvmx_trax_trig0_did_cn31xx cn38xxp2;
|
|
struct cvmx_trax_trig0_did_cn31xx cn52xx;
|
|
struct cvmx_trax_trig0_did_cn31xx cn52xxp1;
|
|
struct cvmx_trax_trig0_did_cn31xx cn56xx;
|
|
struct cvmx_trax_trig0_did_cn31xx cn56xxp1;
|
|
struct cvmx_trax_trig0_did_cn31xx cn58xx;
|
|
struct cvmx_trax_trig0_did_cn31xx cn58xxp1;
|
|
struct cvmx_trax_trig0_did_cn61xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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
|
|
} cn61xx;
|
|
struct cvmx_trax_trig0_did_cn61xx cn63xx;
|
|
struct cvmx_trax_trig0_did_cn61xx cn63xxp1;
|
|
struct cvmx_trax_trig0_did_cn61xx cn66xx;
|
|
struct cvmx_trax_trig0_did_cn61xx cn68xx;
|
|
struct cvmx_trax_trig0_did_cn61xx cn68xxp1;
|
|
struct cvmx_trax_trig0_did_cn61xx cnf71xx;
|
|
};
|
|
typedef union cvmx_trax_trig0_did cvmx_trax_trig0_did_t;
|
|
|
|
/**
|
|
* cvmx_tra#_trig0_sid
|
|
*
|
|
* TRA_TRIG0_SID = Trace Buffer Filter SourceId Mask
|
|
*
|
|
* Description:
|
|
*/
|
|
union cvmx_trax_trig0_sid {
|
|
uint64_t u64;
|
|
struct cvmx_trax_trig0_sid_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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=enable per bit N where 0<=N<=3 */
|
|
#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_trax_trig0_sid_s cn31xx;
|
|
struct cvmx_trax_trig0_sid_s cn38xx;
|
|
struct cvmx_trax_trig0_sid_s cn38xxp2;
|
|
struct cvmx_trax_trig0_sid_s cn52xx;
|
|
struct cvmx_trax_trig0_sid_s cn52xxp1;
|
|
struct cvmx_trax_trig0_sid_s cn56xx;
|
|
struct cvmx_trax_trig0_sid_s cn56xxp1;
|
|
struct cvmx_trax_trig0_sid_s cn58xx;
|
|
struct cvmx_trax_trig0_sid_s cn58xxp1;
|
|
struct cvmx_trax_trig0_sid_cn61xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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_4_15 : 12;
|
|
uint64_t pp : 4; /**< Enable triggering from PP[N] with matching SourceID
|
|
0=disable, 1=enable per bit N where 0<=N<=3 */
|
|
#else
|
|
uint64_t pp : 4;
|
|
uint64_t reserved_4_15 : 12;
|
|
uint64_t pki : 1;
|
|
uint64_t pko : 1;
|
|
uint64_t iobreq : 1;
|
|
uint64_t dwb : 1;
|
|
uint64_t reserved_20_63 : 44;
|
|
#endif
|
|
} cn61xx;
|
|
struct cvmx_trax_trig0_sid_cn63xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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_trax_trig0_sid_cn63xxp1 {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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_6_15 : 10;
|
|
uint64_t pp : 6; /**< Enable triggering from PP[N] with matching SourceID
|
|
0=disable, 1=enable per bit N where 0<=N<=5 */
|
|
#else
|
|
uint64_t pp : 6;
|
|
uint64_t reserved_6_15 : 10;
|
|
uint64_t pki : 1;
|
|
uint64_t pko : 1;
|
|
uint64_t iobreq : 1;
|
|
uint64_t dwb : 1;
|
|
uint64_t reserved_20_63 : 44;
|
|
#endif
|
|
} cn63xxp1;
|
|
struct cvmx_trax_trig0_sid_cn66xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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_10_15 : 6;
|
|
uint64_t pp : 10; /**< Enable triggering from PP[N] with matching SourceID
|
|
0=disable, 1=enableper bit N where 0<=N<=15 */
|
|
#else
|
|
uint64_t pp : 10;
|
|
uint64_t reserved_10_15 : 6;
|
|
uint64_t pki : 1;
|
|
uint64_t pko : 1;
|
|
uint64_t iobreq : 1;
|
|
uint64_t dwb : 1;
|
|
uint64_t reserved_20_63 : 44;
|
|
#endif
|
|
} cn66xx;
|
|
struct cvmx_trax_trig0_sid_cn63xx cn68xx;
|
|
struct cvmx_trax_trig0_sid_cn63xx cn68xxp1;
|
|
struct cvmx_trax_trig0_sid_cn61xx cnf71xx;
|
|
};
|
|
typedef union cvmx_trax_trig0_sid cvmx_trax_trig0_sid_t;
|
|
|
|
/**
|
|
* cvmx_tra#_trig1_adr_adr
|
|
*
|
|
* TRA_TRIG1_ADR_ADR = Trace Buffer Filter Address Address
|
|
*
|
|
* Description:
|
|
*/
|
|
union cvmx_trax_trig1_adr_adr {
|
|
uint64_t u64;
|
|
struct cvmx_trax_trig1_adr_adr_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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_trax_trig1_adr_adr_cn31xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_36_63 : 28;
|
|
uint64_t adr : 36; /**< Unmasked Address
|
|
The combination of TRA(0..0)_TRIG1_ADR_ADR and
|
|
TRA(0..0)_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_trax_trig1_adr_adr_cn31xx cn38xx;
|
|
struct cvmx_trax_trig1_adr_adr_cn31xx cn38xxp2;
|
|
struct cvmx_trax_trig1_adr_adr_cn31xx cn52xx;
|
|
struct cvmx_trax_trig1_adr_adr_cn31xx cn52xxp1;
|
|
struct cvmx_trax_trig1_adr_adr_cn31xx cn56xx;
|
|
struct cvmx_trax_trig1_adr_adr_cn31xx cn56xxp1;
|
|
struct cvmx_trax_trig1_adr_adr_cn31xx cn58xx;
|
|
struct cvmx_trax_trig1_adr_adr_cn31xx cn58xxp1;
|
|
struct cvmx_trax_trig1_adr_adr_s cn61xx;
|
|
struct cvmx_trax_trig1_adr_adr_s cn63xx;
|
|
struct cvmx_trax_trig1_adr_adr_s cn63xxp1;
|
|
struct cvmx_trax_trig1_adr_adr_s cn66xx;
|
|
struct cvmx_trax_trig1_adr_adr_s cn68xx;
|
|
struct cvmx_trax_trig1_adr_adr_s cn68xxp1;
|
|
struct cvmx_trax_trig1_adr_adr_s cnf71xx;
|
|
};
|
|
typedef union cvmx_trax_trig1_adr_adr cvmx_trax_trig1_adr_adr_t;
|
|
|
|
/**
|
|
* cvmx_tra#_trig1_adr_msk
|
|
*
|
|
* TRA_TRIG1_ADR_MSK = Trace Buffer Filter Address Mask
|
|
*
|
|
* Description:
|
|
*/
|
|
union cvmx_trax_trig1_adr_msk {
|
|
uint64_t u64;
|
|
struct cvmx_trax_trig1_adr_msk_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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_trax_trig1_adr_msk_cn31xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_36_63 : 28;
|
|
uint64_t adr : 36; /**< Address Mask
|
|
The combination of TRA(0..0)_TRIG1_ADR_ADR and
|
|
TRA(0..0)_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(0..0)_TRIG1_CMD[IOBDMA]
|
|
is set, TRA(0..0)_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_trax_trig1_adr_msk_cn31xx cn38xx;
|
|
struct cvmx_trax_trig1_adr_msk_cn31xx cn38xxp2;
|
|
struct cvmx_trax_trig1_adr_msk_cn31xx cn52xx;
|
|
struct cvmx_trax_trig1_adr_msk_cn31xx cn52xxp1;
|
|
struct cvmx_trax_trig1_adr_msk_cn31xx cn56xx;
|
|
struct cvmx_trax_trig1_adr_msk_cn31xx cn56xxp1;
|
|
struct cvmx_trax_trig1_adr_msk_cn31xx cn58xx;
|
|
struct cvmx_trax_trig1_adr_msk_cn31xx cn58xxp1;
|
|
struct cvmx_trax_trig1_adr_msk_s cn61xx;
|
|
struct cvmx_trax_trig1_adr_msk_s cn63xx;
|
|
struct cvmx_trax_trig1_adr_msk_s cn63xxp1;
|
|
struct cvmx_trax_trig1_adr_msk_s cn66xx;
|
|
struct cvmx_trax_trig1_adr_msk_s cn68xx;
|
|
struct cvmx_trax_trig1_adr_msk_s cn68xxp1;
|
|
struct cvmx_trax_trig1_adr_msk_s cnf71xx;
|
|
};
|
|
typedef union cvmx_trax_trig1_adr_msk cvmx_trax_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_trax_trig1_cmd {
|
|
uint64_t u64;
|
|
struct cvmx_trax_trig1_cmd_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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_trax_trig1_cmd_cn31xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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_trax_trig1_cmd_cn31xx cn38xx;
|
|
struct cvmx_trax_trig1_cmd_cn31xx cn38xxp2;
|
|
struct cvmx_trax_trig1_cmd_cn52xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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_trax_trig1_cmd_cn52xx cn52xxp1;
|
|
struct cvmx_trax_trig1_cmd_cn52xx cn56xx;
|
|
struct cvmx_trax_trig1_cmd_cn52xx cn56xxp1;
|
|
struct cvmx_trax_trig1_cmd_cn52xx cn58xx;
|
|
struct cvmx_trax_trig1_cmd_cn52xx cn58xxp1;
|
|
struct cvmx_trax_trig1_cmd_cn61xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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
|
|
} cn61xx;
|
|
struct cvmx_trax_trig1_cmd_cn61xx cn63xx;
|
|
struct cvmx_trax_trig1_cmd_cn61xx cn63xxp1;
|
|
struct cvmx_trax_trig1_cmd_cn61xx cn66xx;
|
|
struct cvmx_trax_trig1_cmd_cn61xx cn68xx;
|
|
struct cvmx_trax_trig1_cmd_cn61xx cn68xxp1;
|
|
struct cvmx_trax_trig1_cmd_cn61xx cnf71xx;
|
|
};
|
|
typedef union cvmx_trax_trig1_cmd cvmx_trax_trig1_cmd_t;
|
|
|
|
/**
|
|
* cvmx_tra#_trig1_did
|
|
*
|
|
* TRA_TRIG1_DID = Trace Buffer Filter DestinationId Mask
|
|
*
|
|
* Description:
|
|
*/
|
|
union cvmx_trax_trig1_did {
|
|
uint64_t u64;
|
|
struct cvmx_trax_trig1_did_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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_trax_trig1_did_cn31xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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_trax_trig1_did_cn31xx cn38xx;
|
|
struct cvmx_trax_trig1_did_cn31xx cn38xxp2;
|
|
struct cvmx_trax_trig1_did_cn31xx cn52xx;
|
|
struct cvmx_trax_trig1_did_cn31xx cn52xxp1;
|
|
struct cvmx_trax_trig1_did_cn31xx cn56xx;
|
|
struct cvmx_trax_trig1_did_cn31xx cn56xxp1;
|
|
struct cvmx_trax_trig1_did_cn31xx cn58xx;
|
|
struct cvmx_trax_trig1_did_cn31xx cn58xxp1;
|
|
struct cvmx_trax_trig1_did_cn61xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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
|
|
} cn61xx;
|
|
struct cvmx_trax_trig1_did_cn61xx cn63xx;
|
|
struct cvmx_trax_trig1_did_cn61xx cn63xxp1;
|
|
struct cvmx_trax_trig1_did_cn61xx cn66xx;
|
|
struct cvmx_trax_trig1_did_cn61xx cn68xx;
|
|
struct cvmx_trax_trig1_did_cn61xx cn68xxp1;
|
|
struct cvmx_trax_trig1_did_cn61xx cnf71xx;
|
|
};
|
|
typedef union cvmx_trax_trig1_did cvmx_trax_trig1_did_t;
|
|
|
|
/**
|
|
* cvmx_tra#_trig1_sid
|
|
*
|
|
* TRA_TRIG1_SID = Trace Buffer Filter SourceId Mask
|
|
*
|
|
* Description:
|
|
*/
|
|
union cvmx_trax_trig1_sid {
|
|
uint64_t u64;
|
|
struct cvmx_trax_trig1_sid_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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=enable per bit N where 0<=N<=3 */
|
|
#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_trax_trig1_sid_s cn31xx;
|
|
struct cvmx_trax_trig1_sid_s cn38xx;
|
|
struct cvmx_trax_trig1_sid_s cn38xxp2;
|
|
struct cvmx_trax_trig1_sid_s cn52xx;
|
|
struct cvmx_trax_trig1_sid_s cn52xxp1;
|
|
struct cvmx_trax_trig1_sid_s cn56xx;
|
|
struct cvmx_trax_trig1_sid_s cn56xxp1;
|
|
struct cvmx_trax_trig1_sid_s cn58xx;
|
|
struct cvmx_trax_trig1_sid_s cn58xxp1;
|
|
struct cvmx_trax_trig1_sid_cn61xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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_4_15 : 12;
|
|
uint64_t pp : 4; /**< Enable trigering from PP[N] with matching SourceID
|
|
0=disable, 1=enable per bit N where 0<=N<=3 */
|
|
#else
|
|
uint64_t pp : 4;
|
|
uint64_t reserved_4_15 : 12;
|
|
uint64_t pki : 1;
|
|
uint64_t pko : 1;
|
|
uint64_t iobreq : 1;
|
|
uint64_t dwb : 1;
|
|
uint64_t reserved_20_63 : 44;
|
|
#endif
|
|
} cn61xx;
|
|
struct cvmx_trax_trig1_sid_cn63xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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_trax_trig1_sid_cn63xxp1 {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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_6_15 : 10;
|
|
uint64_t pp : 6; /**< Enable trigering from PP[N] with matching SourceID
|
|
0=disable, 1=enable per bit N where 0<=N<=5 */
|
|
#else
|
|
uint64_t pp : 6;
|
|
uint64_t reserved_6_15 : 10;
|
|
uint64_t pki : 1;
|
|
uint64_t pko : 1;
|
|
uint64_t iobreq : 1;
|
|
uint64_t dwb : 1;
|
|
uint64_t reserved_20_63 : 44;
|
|
#endif
|
|
} cn63xxp1;
|
|
struct cvmx_trax_trig1_sid_cn66xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
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_10_15 : 6;
|
|
uint64_t pp : 10; /**< Enable trigering from PP[N] with matching SourceID
|
|
0=disable, 1=enableper bit N where 0<=N<=15 */
|
|
#else
|
|
uint64_t pp : 10;
|
|
uint64_t reserved_10_15 : 6;
|
|
uint64_t pki : 1;
|
|
uint64_t pko : 1;
|
|
uint64_t iobreq : 1;
|
|
uint64_t dwb : 1;
|
|
uint64_t reserved_20_63 : 44;
|
|
#endif
|
|
} cn66xx;
|
|
struct cvmx_trax_trig1_sid_cn63xx cn68xx;
|
|
struct cvmx_trax_trig1_sid_cn63xx cn68xxp1;
|
|
struct cvmx_trax_trig1_sid_cn61xx cnf71xx;
|
|
};
|
|
typedef union cvmx_trax_trig1_sid cvmx_trax_trig1_sid_t;
|
|
|
|
#include "cvmx-tra-defs.h"
|
|
#endif
|