mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2025-01-24 15:49:42 +07:00
4089caa7d0
For most OCTEON SoCs there is a repeated and redundant register definition for almost every hardware register, although the register bit fields would not differ from other SoCs. Since the driver code should use only one definition for simplicity, these other fields are just redundant and can be deleted. Signed-off-by: Aaro Koskinen <aaro.koskinen@iki.fi> Signed-off-by: Paul Burton <paul.burton@mips.com> Cc: Ralf Baechle <ralf@linux-mips.org> Cc: James Hogan <jhogan@kernel.org> Cc: linux-mips@vger.kernel.org
2944 lines
68 KiB
C
2944 lines
68 KiB
C
/***********************license start***************
|
|
* Author: Cavium Inc.
|
|
*
|
|
* Contact: support@cavium.com
|
|
* This file is part of the OCTEON SDK
|
|
*
|
|
* Copyright (c) 2003-2012 Cavium Inc.
|
|
*
|
|
* This file is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License, Version 2, as
|
|
* published by the Free Software Foundation.
|
|
*
|
|
* This file is distributed in the hope that it will be useful, but
|
|
* AS-IS and WITHOUT ANY WARRANTY; without even the implied warranty
|
|
* of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE, TITLE, or
|
|
* NONINFRINGEMENT. See the GNU General Public License for more
|
|
* details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this file; if not, write to the Free Software
|
|
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
* or visit http://www.gnu.org/licenses/.
|
|
*
|
|
* This file may also be available under a different license from Cavium.
|
|
* Contact Cavium Inc. for more information
|
|
***********************license end**************************************/
|
|
|
|
#ifndef __CVMX_LMCX_DEFS_H__
|
|
#define __CVMX_LMCX_DEFS_H__
|
|
|
|
#define CVMX_LMCX_BIST_CTL(block_id) (CVMX_ADD_IO_SEG(0x00011800880000F0ull) + ((block_id) & 1) * 0x60000000ull)
|
|
#define CVMX_LMCX_BIST_RESULT(block_id) (CVMX_ADD_IO_SEG(0x00011800880000F8ull) + ((block_id) & 1) * 0x60000000ull)
|
|
#define CVMX_LMCX_CHAR_CTL(block_id) (CVMX_ADD_IO_SEG(0x0001180088000220ull) + ((block_id) & 3) * 0x1000000ull)
|
|
#define CVMX_LMCX_CHAR_MASK0(block_id) (CVMX_ADD_IO_SEG(0x0001180088000228ull) + ((block_id) & 3) * 0x1000000ull)
|
|
#define CVMX_LMCX_CHAR_MASK1(block_id) (CVMX_ADD_IO_SEG(0x0001180088000230ull) + ((block_id) & 3) * 0x1000000ull)
|
|
#define CVMX_LMCX_CHAR_MASK2(block_id) (CVMX_ADD_IO_SEG(0x0001180088000238ull) + ((block_id) & 3) * 0x1000000ull)
|
|
#define CVMX_LMCX_CHAR_MASK3(block_id) (CVMX_ADD_IO_SEG(0x0001180088000240ull) + ((block_id) & 3) * 0x1000000ull)
|
|
#define CVMX_LMCX_CHAR_MASK4(block_id) (CVMX_ADD_IO_SEG(0x0001180088000318ull) + ((block_id) & 3) * 0x1000000ull)
|
|
#define CVMX_LMCX_COMP_CTL(block_id) (CVMX_ADD_IO_SEG(0x0001180088000028ull) + ((block_id) & 1) * 0x60000000ull)
|
|
#define CVMX_LMCX_COMP_CTL2(block_id) (CVMX_ADD_IO_SEG(0x00011800880001B8ull) + ((block_id) & 3) * 0x1000000ull)
|
|
#define CVMX_LMCX_CONFIG(block_id) (CVMX_ADD_IO_SEG(0x0001180088000188ull) + ((block_id) & 3) * 0x1000000ull)
|
|
#define CVMX_LMCX_CONTROL(block_id) (CVMX_ADD_IO_SEG(0x0001180088000190ull) + ((block_id) & 3) * 0x1000000ull)
|
|
#define CVMX_LMCX_CTL(block_id) (CVMX_ADD_IO_SEG(0x0001180088000010ull) + ((block_id) & 1) * 0x60000000ull)
|
|
#define CVMX_LMCX_CTL1(block_id) (CVMX_ADD_IO_SEG(0x0001180088000090ull) + ((block_id) & 1) * 0x60000000ull)
|
|
#define CVMX_LMCX_DCLK_CNT(block_id) (CVMX_ADD_IO_SEG(0x00011800880001E0ull) + ((block_id) & 3) * 0x1000000ull)
|
|
#define CVMX_LMCX_DCLK_CNT_HI(block_id) (CVMX_ADD_IO_SEG(0x0001180088000070ull) + ((block_id) & 1) * 0x60000000ull)
|
|
#define CVMX_LMCX_DCLK_CNT_LO(block_id) (CVMX_ADD_IO_SEG(0x0001180088000068ull) + ((block_id) & 1) * 0x60000000ull)
|
|
#define CVMX_LMCX_DCLK_CTL(block_id) (CVMX_ADD_IO_SEG(0x00011800880000B8ull) + ((block_id) & 1) * 0x60000000ull)
|
|
#define CVMX_LMCX_DDR2_CTL(block_id) (CVMX_ADD_IO_SEG(0x0001180088000018ull) + ((block_id) & 1) * 0x60000000ull)
|
|
#define CVMX_LMCX_DDR_PLL_CTL(block_id) (CVMX_ADD_IO_SEG(0x0001180088000258ull) + ((block_id) & 3) * 0x1000000ull)
|
|
#define CVMX_LMCX_DELAY_CFG(block_id) (CVMX_ADD_IO_SEG(0x0001180088000088ull) + ((block_id) & 1) * 0x60000000ull)
|
|
#define CVMX_LMCX_DIMMX_PARAMS(offset, block_id) (CVMX_ADD_IO_SEG(0x0001180088000270ull) + (((offset) & 1) + ((block_id) & 3) * 0x200000ull) * 8)
|
|
#define CVMX_LMCX_DIMM_CTL(block_id) (CVMX_ADD_IO_SEG(0x0001180088000310ull) + ((block_id) & 3) * 0x1000000ull)
|
|
#define CVMX_LMCX_DLL_CTL(block_id) (CVMX_ADD_IO_SEG(0x00011800880000C0ull) + ((block_id) & 1) * 0x60000000ull)
|
|
#define CVMX_LMCX_DLL_CTL2(block_id) (CVMX_ADD_IO_SEG(0x00011800880001C8ull) + ((block_id) & 3) * 0x1000000ull)
|
|
#define CVMX_LMCX_DLL_CTL3(block_id) (CVMX_ADD_IO_SEG(0x0001180088000218ull) + ((block_id) & 3) * 0x1000000ull)
|
|
static inline uint64_t CVMX_LMCX_DUAL_MEMCFG(unsigned long block_id)
|
|
{
|
|
switch (cvmx_get_octeon_family()) {
|
|
case OCTEON_CNF71XX & OCTEON_FAMILY_MASK:
|
|
case OCTEON_CN50XX & OCTEON_FAMILY_MASK:
|
|
case OCTEON_CN58XX & OCTEON_FAMILY_MASK:
|
|
case OCTEON_CN66XX & OCTEON_FAMILY_MASK:
|
|
case OCTEON_CN52XX & OCTEON_FAMILY_MASK:
|
|
case OCTEON_CN61XX & OCTEON_FAMILY_MASK:
|
|
case OCTEON_CN63XX & OCTEON_FAMILY_MASK:
|
|
return CVMX_ADD_IO_SEG(0x0001180088000098ull) + (block_id) * 0x60000000ull;
|
|
case OCTEON_CN56XX & OCTEON_FAMILY_MASK:
|
|
return CVMX_ADD_IO_SEG(0x0001180088000098ull) + (block_id) * 0x60000000ull;
|
|
case OCTEON_CN68XX & OCTEON_FAMILY_MASK:
|
|
return CVMX_ADD_IO_SEG(0x0001180088000098ull) + (block_id) * 0x1000000ull;
|
|
}
|
|
return CVMX_ADD_IO_SEG(0x0001180088000098ull) + (block_id) * 0x60000000ull;
|
|
}
|
|
|
|
static inline uint64_t CVMX_LMCX_ECC_SYND(unsigned long block_id)
|
|
{
|
|
switch (cvmx_get_octeon_family()) {
|
|
case OCTEON_CN30XX & OCTEON_FAMILY_MASK:
|
|
case OCTEON_CN50XX & OCTEON_FAMILY_MASK:
|
|
case OCTEON_CN38XX & OCTEON_FAMILY_MASK:
|
|
case OCTEON_CN31XX & OCTEON_FAMILY_MASK:
|
|
case OCTEON_CN58XX & OCTEON_FAMILY_MASK:
|
|
case OCTEON_CN66XX & OCTEON_FAMILY_MASK:
|
|
case OCTEON_CN52XX & OCTEON_FAMILY_MASK:
|
|
case OCTEON_CN61XX & OCTEON_FAMILY_MASK:
|
|
case OCTEON_CNF71XX & OCTEON_FAMILY_MASK:
|
|
case OCTEON_CN63XX & OCTEON_FAMILY_MASK:
|
|
return CVMX_ADD_IO_SEG(0x0001180088000038ull) + (block_id) * 0x60000000ull;
|
|
case OCTEON_CN56XX & OCTEON_FAMILY_MASK:
|
|
return CVMX_ADD_IO_SEG(0x0001180088000038ull) + (block_id) * 0x60000000ull;
|
|
case OCTEON_CN68XX & OCTEON_FAMILY_MASK:
|
|
return CVMX_ADD_IO_SEG(0x0001180088000038ull) + (block_id) * 0x1000000ull;
|
|
}
|
|
return CVMX_ADD_IO_SEG(0x0001180088000038ull) + (block_id) * 0x60000000ull;
|
|
}
|
|
|
|
static inline uint64_t CVMX_LMCX_FADR(unsigned long block_id)
|
|
{
|
|
switch (cvmx_get_octeon_family()) {
|
|
case OCTEON_CN30XX & OCTEON_FAMILY_MASK:
|
|
case OCTEON_CN50XX & OCTEON_FAMILY_MASK:
|
|
case OCTEON_CN38XX & OCTEON_FAMILY_MASK:
|
|
case OCTEON_CN31XX & OCTEON_FAMILY_MASK:
|
|
case OCTEON_CN58XX & OCTEON_FAMILY_MASK:
|
|
case OCTEON_CN66XX & OCTEON_FAMILY_MASK:
|
|
case OCTEON_CN52XX & OCTEON_FAMILY_MASK:
|
|
case OCTEON_CN61XX & OCTEON_FAMILY_MASK:
|
|
case OCTEON_CNF71XX & OCTEON_FAMILY_MASK:
|
|
case OCTEON_CN63XX & OCTEON_FAMILY_MASK:
|
|
return CVMX_ADD_IO_SEG(0x0001180088000020ull) + (block_id) * 0x60000000ull;
|
|
case OCTEON_CN56XX & OCTEON_FAMILY_MASK:
|
|
return CVMX_ADD_IO_SEG(0x0001180088000020ull) + (block_id) * 0x60000000ull;
|
|
case OCTEON_CN68XX & OCTEON_FAMILY_MASK:
|
|
return CVMX_ADD_IO_SEG(0x0001180088000020ull) + (block_id) * 0x1000000ull;
|
|
}
|
|
return CVMX_ADD_IO_SEG(0x0001180088000020ull) + (block_id) * 0x60000000ull;
|
|
}
|
|
|
|
#define CVMX_LMCX_IFB_CNT(block_id) (CVMX_ADD_IO_SEG(0x00011800880001D0ull) + ((block_id) & 3) * 0x1000000ull)
|
|
#define CVMX_LMCX_IFB_CNT_HI(block_id) (CVMX_ADD_IO_SEG(0x0001180088000050ull) + ((block_id) & 1) * 0x60000000ull)
|
|
#define CVMX_LMCX_IFB_CNT_LO(block_id) (CVMX_ADD_IO_SEG(0x0001180088000048ull) + ((block_id) & 1) * 0x60000000ull)
|
|
#define CVMX_LMCX_INT(block_id) (CVMX_ADD_IO_SEG(0x00011800880001F0ull) + ((block_id) & 3) * 0x1000000ull)
|
|
#define CVMX_LMCX_INT_EN(block_id) (CVMX_ADD_IO_SEG(0x00011800880001E8ull) + ((block_id) & 3) * 0x1000000ull)
|
|
#define CVMX_LMCX_MEM_CFG0(block_id) (CVMX_ADD_IO_SEG(0x0001180088000000ull) + ((block_id) & 1) * 0x60000000ull)
|
|
#define CVMX_LMCX_MEM_CFG1(block_id) (CVMX_ADD_IO_SEG(0x0001180088000008ull) + ((block_id) & 1) * 0x60000000ull)
|
|
#define CVMX_LMCX_MODEREG_PARAMS0(block_id) (CVMX_ADD_IO_SEG(0x00011800880001A8ull) + ((block_id) & 3) * 0x1000000ull)
|
|
#define CVMX_LMCX_MODEREG_PARAMS1(block_id) (CVMX_ADD_IO_SEG(0x0001180088000260ull) + ((block_id) & 3) * 0x1000000ull)
|
|
static inline uint64_t CVMX_LMCX_NXM(unsigned long block_id)
|
|
{
|
|
switch (cvmx_get_octeon_family()) {
|
|
case OCTEON_CNF71XX & OCTEON_FAMILY_MASK:
|
|
case OCTEON_CN61XX & OCTEON_FAMILY_MASK:
|
|
case OCTEON_CN66XX & OCTEON_FAMILY_MASK:
|
|
case OCTEON_CN52XX & OCTEON_FAMILY_MASK:
|
|
case OCTEON_CN58XX & OCTEON_FAMILY_MASK:
|
|
case OCTEON_CN63XX & OCTEON_FAMILY_MASK:
|
|
return CVMX_ADD_IO_SEG(0x00011800880000C8ull) + (block_id) * 0x60000000ull;
|
|
case OCTEON_CN56XX & OCTEON_FAMILY_MASK:
|
|
return CVMX_ADD_IO_SEG(0x00011800880000C8ull) + (block_id) * 0x60000000ull;
|
|
case OCTEON_CN68XX & OCTEON_FAMILY_MASK:
|
|
return CVMX_ADD_IO_SEG(0x00011800880000C8ull) + (block_id) * 0x1000000ull;
|
|
}
|
|
return CVMX_ADD_IO_SEG(0x00011800880000C8ull) + (block_id) * 0x60000000ull;
|
|
}
|
|
|
|
#define CVMX_LMCX_OPS_CNT(block_id) (CVMX_ADD_IO_SEG(0x00011800880001D8ull) + ((block_id) & 3) * 0x1000000ull)
|
|
#define CVMX_LMCX_OPS_CNT_HI(block_id) (CVMX_ADD_IO_SEG(0x0001180088000060ull) + ((block_id) & 1) * 0x60000000ull)
|
|
#define CVMX_LMCX_OPS_CNT_LO(block_id) (CVMX_ADD_IO_SEG(0x0001180088000058ull) + ((block_id) & 1) * 0x60000000ull)
|
|
#define CVMX_LMCX_PHY_CTL(block_id) (CVMX_ADD_IO_SEG(0x0001180088000210ull) + ((block_id) & 3) * 0x1000000ull)
|
|
#define CVMX_LMCX_PLL_BWCTL(block_id) (CVMX_ADD_IO_SEG(0x0001180088000040ull))
|
|
#define CVMX_LMCX_PLL_CTL(block_id) (CVMX_ADD_IO_SEG(0x00011800880000A8ull) + ((block_id) & 1) * 0x60000000ull)
|
|
#define CVMX_LMCX_PLL_STATUS(block_id) (CVMX_ADD_IO_SEG(0x00011800880000B0ull) + ((block_id) & 1) * 0x60000000ull)
|
|
#define CVMX_LMCX_READ_LEVEL_CTL(block_id) (CVMX_ADD_IO_SEG(0x0001180088000140ull) + ((block_id) & 1) * 0x60000000ull)
|
|
#define CVMX_LMCX_READ_LEVEL_DBG(block_id) (CVMX_ADD_IO_SEG(0x0001180088000148ull) + ((block_id) & 1) * 0x60000000ull)
|
|
#define CVMX_LMCX_READ_LEVEL_RANKX(offset, block_id) (CVMX_ADD_IO_SEG(0x0001180088000100ull) + (((offset) & 3) + ((block_id) & 1) * 0xC000000ull) * 8)
|
|
#define CVMX_LMCX_RESET_CTL(block_id) (CVMX_ADD_IO_SEG(0x0001180088000180ull) + ((block_id) & 3) * 0x1000000ull)
|
|
#define CVMX_LMCX_RLEVEL_CTL(block_id) (CVMX_ADD_IO_SEG(0x00011800880002A0ull) + ((block_id) & 3) * 0x1000000ull)
|
|
#define CVMX_LMCX_RLEVEL_DBG(block_id) (CVMX_ADD_IO_SEG(0x00011800880002A8ull) + ((block_id) & 3) * 0x1000000ull)
|
|
#define CVMX_LMCX_RLEVEL_RANKX(offset, block_id) (CVMX_ADD_IO_SEG(0x0001180088000280ull) + (((offset) & 3) + ((block_id) & 3) * 0x200000ull) * 8)
|
|
#define CVMX_LMCX_RODT_COMP_CTL(block_id) (CVMX_ADD_IO_SEG(0x00011800880000A0ull) + ((block_id) & 1) * 0x60000000ull)
|
|
#define CVMX_LMCX_RODT_CTL(block_id) (CVMX_ADD_IO_SEG(0x0001180088000078ull) + ((block_id) & 1) * 0x60000000ull)
|
|
#define CVMX_LMCX_RODT_MASK(block_id) (CVMX_ADD_IO_SEG(0x0001180088000268ull) + ((block_id) & 3) * 0x1000000ull)
|
|
#define CVMX_LMCX_SCRAMBLED_FADR(block_id) (CVMX_ADD_IO_SEG(0x0001180088000330ull))
|
|
#define CVMX_LMCX_SCRAMBLE_CFG0(block_id) (CVMX_ADD_IO_SEG(0x0001180088000320ull))
|
|
#define CVMX_LMCX_SCRAMBLE_CFG1(block_id) (CVMX_ADD_IO_SEG(0x0001180088000328ull))
|
|
#define CVMX_LMCX_SLOT_CTL0(block_id) (CVMX_ADD_IO_SEG(0x00011800880001F8ull) + ((block_id) & 3) * 0x1000000ull)
|
|
#define CVMX_LMCX_SLOT_CTL1(block_id) (CVMX_ADD_IO_SEG(0x0001180088000200ull) + ((block_id) & 3) * 0x1000000ull)
|
|
#define CVMX_LMCX_SLOT_CTL2(block_id) (CVMX_ADD_IO_SEG(0x0001180088000208ull) + ((block_id) & 3) * 0x1000000ull)
|
|
#define CVMX_LMCX_TIMING_PARAMS0(block_id) (CVMX_ADD_IO_SEG(0x0001180088000198ull) + ((block_id) & 3) * 0x1000000ull)
|
|
#define CVMX_LMCX_TIMING_PARAMS1(block_id) (CVMX_ADD_IO_SEG(0x00011800880001A0ull) + ((block_id) & 3) * 0x1000000ull)
|
|
#define CVMX_LMCX_TRO_CTL(block_id) (CVMX_ADD_IO_SEG(0x0001180088000248ull) + ((block_id) & 3) * 0x1000000ull)
|
|
#define CVMX_LMCX_TRO_STAT(block_id) (CVMX_ADD_IO_SEG(0x0001180088000250ull) + ((block_id) & 3) * 0x1000000ull)
|
|
#define CVMX_LMCX_WLEVEL_CTL(block_id) (CVMX_ADD_IO_SEG(0x0001180088000300ull) + ((block_id) & 3) * 0x1000000ull)
|
|
#define CVMX_LMCX_WLEVEL_DBG(block_id) (CVMX_ADD_IO_SEG(0x0001180088000308ull) + ((block_id) & 3) * 0x1000000ull)
|
|
#define CVMX_LMCX_WLEVEL_RANKX(offset, block_id) (CVMX_ADD_IO_SEG(0x00011800880002B0ull) + (((offset) & 3) + ((block_id) & 3) * 0x200000ull) * 8)
|
|
#define CVMX_LMCX_WODT_CTL0(block_id) (CVMX_ADD_IO_SEG(0x0001180088000030ull) + ((block_id) & 1) * 0x60000000ull)
|
|
#define CVMX_LMCX_WODT_CTL1(block_id) (CVMX_ADD_IO_SEG(0x0001180088000080ull) + ((block_id) & 1) * 0x60000000ull)
|
|
#define CVMX_LMCX_WODT_MASK(block_id) (CVMX_ADD_IO_SEG(0x00011800880001B0ull) + ((block_id) & 3) * 0x1000000ull)
|
|
|
|
union cvmx_lmcx_bist_ctl {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_bist_ctl_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_1_63:63;
|
|
uint64_t start:1;
|
|
#else
|
|
uint64_t start:1;
|
|
uint64_t reserved_1_63:63;
|
|
#endif
|
|
} s;
|
|
};
|
|
|
|
union cvmx_lmcx_bist_result {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_bist_result_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_11_63:53;
|
|
uint64_t csrd2e:1;
|
|
uint64_t csre2d:1;
|
|
uint64_t mwf:1;
|
|
uint64_t mwd:3;
|
|
uint64_t mwc:1;
|
|
uint64_t mrf:1;
|
|
uint64_t mrd:3;
|
|
#else
|
|
uint64_t mrd:3;
|
|
uint64_t mrf:1;
|
|
uint64_t mwc:1;
|
|
uint64_t mwd:3;
|
|
uint64_t mwf:1;
|
|
uint64_t csre2d:1;
|
|
uint64_t csrd2e:1;
|
|
uint64_t reserved_11_63:53;
|
|
#endif
|
|
} s;
|
|
struct cvmx_lmcx_bist_result_cn50xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_9_63:55;
|
|
uint64_t mwf:1;
|
|
uint64_t mwd:3;
|
|
uint64_t mwc:1;
|
|
uint64_t mrf:1;
|
|
uint64_t mrd:3;
|
|
#else
|
|
uint64_t mrd:3;
|
|
uint64_t mrf:1;
|
|
uint64_t mwc:1;
|
|
uint64_t mwd:3;
|
|
uint64_t mwf:1;
|
|
uint64_t reserved_9_63:55;
|
|
#endif
|
|
} cn50xx;
|
|
};
|
|
|
|
union cvmx_lmcx_char_ctl {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_char_ctl_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_44_63:20;
|
|
uint64_t dr:1;
|
|
uint64_t skew_on:1;
|
|
uint64_t en:1;
|
|
uint64_t sel:1;
|
|
uint64_t prog:8;
|
|
uint64_t prbs:32;
|
|
#else
|
|
uint64_t prbs:32;
|
|
uint64_t prog:8;
|
|
uint64_t sel:1;
|
|
uint64_t en:1;
|
|
uint64_t skew_on:1;
|
|
uint64_t dr:1;
|
|
uint64_t reserved_44_63:20;
|
|
#endif
|
|
} s;
|
|
struct cvmx_lmcx_char_ctl_cn63xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_42_63:22;
|
|
uint64_t en:1;
|
|
uint64_t sel:1;
|
|
uint64_t prog:8;
|
|
uint64_t prbs:32;
|
|
#else
|
|
uint64_t prbs:32;
|
|
uint64_t prog:8;
|
|
uint64_t sel:1;
|
|
uint64_t en:1;
|
|
uint64_t reserved_42_63:22;
|
|
#endif
|
|
} cn63xx;
|
|
};
|
|
|
|
union cvmx_lmcx_char_mask0 {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_char_mask0_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t mask:64;
|
|
#else
|
|
uint64_t mask:64;
|
|
#endif
|
|
} s;
|
|
};
|
|
|
|
union cvmx_lmcx_char_mask1 {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_char_mask1_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_8_63:56;
|
|
uint64_t mask:8;
|
|
#else
|
|
uint64_t mask:8;
|
|
uint64_t reserved_8_63:56;
|
|
#endif
|
|
} s;
|
|
};
|
|
|
|
union cvmx_lmcx_char_mask2 {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_char_mask2_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t mask:64;
|
|
#else
|
|
uint64_t mask:64;
|
|
#endif
|
|
} s;
|
|
};
|
|
|
|
union cvmx_lmcx_char_mask3 {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_char_mask3_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_8_63:56;
|
|
uint64_t mask:8;
|
|
#else
|
|
uint64_t mask:8;
|
|
uint64_t reserved_8_63:56;
|
|
#endif
|
|
} s;
|
|
};
|
|
|
|
union cvmx_lmcx_char_mask4 {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_char_mask4_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_33_63:31;
|
|
uint64_t reset_n_mask:1;
|
|
uint64_t a_mask:16;
|
|
uint64_t ba_mask:3;
|
|
uint64_t we_n_mask:1;
|
|
uint64_t cas_n_mask:1;
|
|
uint64_t ras_n_mask:1;
|
|
uint64_t odt1_mask:2;
|
|
uint64_t odt0_mask:2;
|
|
uint64_t cs1_n_mask:2;
|
|
uint64_t cs0_n_mask:2;
|
|
uint64_t cke_mask:2;
|
|
#else
|
|
uint64_t cke_mask:2;
|
|
uint64_t cs0_n_mask:2;
|
|
uint64_t cs1_n_mask:2;
|
|
uint64_t odt0_mask:2;
|
|
uint64_t odt1_mask:2;
|
|
uint64_t ras_n_mask:1;
|
|
uint64_t cas_n_mask:1;
|
|
uint64_t we_n_mask:1;
|
|
uint64_t ba_mask:3;
|
|
uint64_t a_mask:16;
|
|
uint64_t reset_n_mask:1;
|
|
uint64_t reserved_33_63:31;
|
|
#endif
|
|
} s;
|
|
};
|
|
|
|
union cvmx_lmcx_comp_ctl {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_comp_ctl_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_32_63:32;
|
|
uint64_t nctl_csr:4;
|
|
uint64_t nctl_clk:4;
|
|
uint64_t nctl_cmd:4;
|
|
uint64_t nctl_dat:4;
|
|
uint64_t pctl_csr:4;
|
|
uint64_t pctl_clk:4;
|
|
uint64_t reserved_0_7:8;
|
|
#else
|
|
uint64_t reserved_0_7:8;
|
|
uint64_t pctl_clk:4;
|
|
uint64_t pctl_csr:4;
|
|
uint64_t nctl_dat:4;
|
|
uint64_t nctl_cmd:4;
|
|
uint64_t nctl_clk:4;
|
|
uint64_t nctl_csr:4;
|
|
uint64_t reserved_32_63:32;
|
|
#endif
|
|
} s;
|
|
struct cvmx_lmcx_comp_ctl_cn30xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_32_63:32;
|
|
uint64_t nctl_csr:4;
|
|
uint64_t nctl_clk:4;
|
|
uint64_t nctl_cmd:4;
|
|
uint64_t nctl_dat:4;
|
|
uint64_t pctl_csr:4;
|
|
uint64_t pctl_clk:4;
|
|
uint64_t pctl_cmd:4;
|
|
uint64_t pctl_dat:4;
|
|
#else
|
|
uint64_t pctl_dat:4;
|
|
uint64_t pctl_cmd:4;
|
|
uint64_t pctl_clk:4;
|
|
uint64_t pctl_csr:4;
|
|
uint64_t nctl_dat:4;
|
|
uint64_t nctl_cmd:4;
|
|
uint64_t nctl_clk:4;
|
|
uint64_t nctl_csr:4;
|
|
uint64_t reserved_32_63:32;
|
|
#endif
|
|
} cn30xx;
|
|
struct cvmx_lmcx_comp_ctl_cn50xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_32_63:32;
|
|
uint64_t nctl_csr:4;
|
|
uint64_t reserved_20_27:8;
|
|
uint64_t nctl_dat:4;
|
|
uint64_t pctl_csr:4;
|
|
uint64_t reserved_5_11:7;
|
|
uint64_t pctl_dat:5;
|
|
#else
|
|
uint64_t pctl_dat:5;
|
|
uint64_t reserved_5_11:7;
|
|
uint64_t pctl_csr:4;
|
|
uint64_t nctl_dat:4;
|
|
uint64_t reserved_20_27:8;
|
|
uint64_t nctl_csr:4;
|
|
uint64_t reserved_32_63:32;
|
|
#endif
|
|
} cn50xx;
|
|
struct cvmx_lmcx_comp_ctl_cn58xxp1 {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_32_63:32;
|
|
uint64_t nctl_csr:4;
|
|
uint64_t reserved_20_27:8;
|
|
uint64_t nctl_dat:4;
|
|
uint64_t pctl_csr:4;
|
|
uint64_t reserved_4_11:8;
|
|
uint64_t pctl_dat:4;
|
|
#else
|
|
uint64_t pctl_dat:4;
|
|
uint64_t reserved_4_11:8;
|
|
uint64_t pctl_csr:4;
|
|
uint64_t nctl_dat:4;
|
|
uint64_t reserved_20_27:8;
|
|
uint64_t nctl_csr:4;
|
|
uint64_t reserved_32_63:32;
|
|
#endif
|
|
} cn58xxp1;
|
|
};
|
|
|
|
union cvmx_lmcx_comp_ctl2 {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_comp_ctl2_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_34_63:30;
|
|
uint64_t ddr__ptune:4;
|
|
uint64_t ddr__ntune:4;
|
|
uint64_t m180:1;
|
|
uint64_t byp:1;
|
|
uint64_t ptune:4;
|
|
uint64_t ntune:4;
|
|
uint64_t rodt_ctl:4;
|
|
uint64_t cmd_ctl:4;
|
|
uint64_t ck_ctl:4;
|
|
uint64_t dqx_ctl:4;
|
|
#else
|
|
uint64_t dqx_ctl:4;
|
|
uint64_t ck_ctl:4;
|
|
uint64_t cmd_ctl:4;
|
|
uint64_t rodt_ctl:4;
|
|
uint64_t ntune:4;
|
|
uint64_t ptune:4;
|
|
uint64_t byp:1;
|
|
uint64_t m180:1;
|
|
uint64_t ddr__ntune:4;
|
|
uint64_t ddr__ptune:4;
|
|
uint64_t reserved_34_63:30;
|
|
#endif
|
|
} s;
|
|
};
|
|
|
|
union cvmx_lmcx_config {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_config_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_61_63:3;
|
|
uint64_t mode32b:1;
|
|
uint64_t scrz:1;
|
|
uint64_t early_unload_d1_r1:1;
|
|
uint64_t early_unload_d1_r0:1;
|
|
uint64_t early_unload_d0_r1:1;
|
|
uint64_t early_unload_d0_r0:1;
|
|
uint64_t init_status:4;
|
|
uint64_t mirrmask:4;
|
|
uint64_t rankmask:4;
|
|
uint64_t rank_ena:1;
|
|
uint64_t sref_with_dll:1;
|
|
uint64_t early_dqx:1;
|
|
uint64_t sequence:3;
|
|
uint64_t ref_zqcs_int:19;
|
|
uint64_t reset:1;
|
|
uint64_t ecc_adr:1;
|
|
uint64_t forcewrite:4;
|
|
uint64_t idlepower:3;
|
|
uint64_t pbank_lsb:4;
|
|
uint64_t row_lsb:3;
|
|
uint64_t ecc_ena:1;
|
|
uint64_t init_start:1;
|
|
#else
|
|
uint64_t init_start:1;
|
|
uint64_t ecc_ena:1;
|
|
uint64_t row_lsb:3;
|
|
uint64_t pbank_lsb:4;
|
|
uint64_t idlepower:3;
|
|
uint64_t forcewrite:4;
|
|
uint64_t ecc_adr:1;
|
|
uint64_t reset:1;
|
|
uint64_t ref_zqcs_int:19;
|
|
uint64_t sequence:3;
|
|
uint64_t early_dqx:1;
|
|
uint64_t sref_with_dll:1;
|
|
uint64_t rank_ena:1;
|
|
uint64_t rankmask:4;
|
|
uint64_t mirrmask:4;
|
|
uint64_t init_status:4;
|
|
uint64_t early_unload_d0_r0:1;
|
|
uint64_t early_unload_d0_r1:1;
|
|
uint64_t early_unload_d1_r0:1;
|
|
uint64_t early_unload_d1_r1:1;
|
|
uint64_t scrz:1;
|
|
uint64_t mode32b:1;
|
|
uint64_t reserved_61_63:3;
|
|
#endif
|
|
} s;
|
|
struct cvmx_lmcx_config_cn63xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_59_63:5;
|
|
uint64_t early_unload_d1_r1:1;
|
|
uint64_t early_unload_d1_r0:1;
|
|
uint64_t early_unload_d0_r1:1;
|
|
uint64_t early_unload_d0_r0:1;
|
|
uint64_t init_status:4;
|
|
uint64_t mirrmask:4;
|
|
uint64_t rankmask:4;
|
|
uint64_t rank_ena:1;
|
|
uint64_t sref_with_dll:1;
|
|
uint64_t early_dqx:1;
|
|
uint64_t sequence:3;
|
|
uint64_t ref_zqcs_int:19;
|
|
uint64_t reset:1;
|
|
uint64_t ecc_adr:1;
|
|
uint64_t forcewrite:4;
|
|
uint64_t idlepower:3;
|
|
uint64_t pbank_lsb:4;
|
|
uint64_t row_lsb:3;
|
|
uint64_t ecc_ena:1;
|
|
uint64_t init_start:1;
|
|
#else
|
|
uint64_t init_start:1;
|
|
uint64_t ecc_ena:1;
|
|
uint64_t row_lsb:3;
|
|
uint64_t pbank_lsb:4;
|
|
uint64_t idlepower:3;
|
|
uint64_t forcewrite:4;
|
|
uint64_t ecc_adr:1;
|
|
uint64_t reset:1;
|
|
uint64_t ref_zqcs_int:19;
|
|
uint64_t sequence:3;
|
|
uint64_t early_dqx:1;
|
|
uint64_t sref_with_dll:1;
|
|
uint64_t rank_ena:1;
|
|
uint64_t rankmask:4;
|
|
uint64_t mirrmask:4;
|
|
uint64_t init_status:4;
|
|
uint64_t early_unload_d0_r0:1;
|
|
uint64_t early_unload_d0_r1:1;
|
|
uint64_t early_unload_d1_r0:1;
|
|
uint64_t early_unload_d1_r1:1;
|
|
uint64_t reserved_59_63:5;
|
|
#endif
|
|
} cn63xx;
|
|
struct cvmx_lmcx_config_cn63xxp1 {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_55_63:9;
|
|
uint64_t init_status:4;
|
|
uint64_t mirrmask:4;
|
|
uint64_t rankmask:4;
|
|
uint64_t rank_ena:1;
|
|
uint64_t sref_with_dll:1;
|
|
uint64_t early_dqx:1;
|
|
uint64_t sequence:3;
|
|
uint64_t ref_zqcs_int:19;
|
|
uint64_t reset:1;
|
|
uint64_t ecc_adr:1;
|
|
uint64_t forcewrite:4;
|
|
uint64_t idlepower:3;
|
|
uint64_t pbank_lsb:4;
|
|
uint64_t row_lsb:3;
|
|
uint64_t ecc_ena:1;
|
|
uint64_t init_start:1;
|
|
#else
|
|
uint64_t init_start:1;
|
|
uint64_t ecc_ena:1;
|
|
uint64_t row_lsb:3;
|
|
uint64_t pbank_lsb:4;
|
|
uint64_t idlepower:3;
|
|
uint64_t forcewrite:4;
|
|
uint64_t ecc_adr:1;
|
|
uint64_t reset:1;
|
|
uint64_t ref_zqcs_int:19;
|
|
uint64_t sequence:3;
|
|
uint64_t early_dqx:1;
|
|
uint64_t sref_with_dll:1;
|
|
uint64_t rank_ena:1;
|
|
uint64_t rankmask:4;
|
|
uint64_t mirrmask:4;
|
|
uint64_t init_status:4;
|
|
uint64_t reserved_55_63:9;
|
|
#endif
|
|
} cn63xxp1;
|
|
struct cvmx_lmcx_config_cn66xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_60_63:4;
|
|
uint64_t scrz:1;
|
|
uint64_t early_unload_d1_r1:1;
|
|
uint64_t early_unload_d1_r0:1;
|
|
uint64_t early_unload_d0_r1:1;
|
|
uint64_t early_unload_d0_r0:1;
|
|
uint64_t init_status:4;
|
|
uint64_t mirrmask:4;
|
|
uint64_t rankmask:4;
|
|
uint64_t rank_ena:1;
|
|
uint64_t sref_with_dll:1;
|
|
uint64_t early_dqx:1;
|
|
uint64_t sequence:3;
|
|
uint64_t ref_zqcs_int:19;
|
|
uint64_t reset:1;
|
|
uint64_t ecc_adr:1;
|
|
uint64_t forcewrite:4;
|
|
uint64_t idlepower:3;
|
|
uint64_t pbank_lsb:4;
|
|
uint64_t row_lsb:3;
|
|
uint64_t ecc_ena:1;
|
|
uint64_t init_start:1;
|
|
#else
|
|
uint64_t init_start:1;
|
|
uint64_t ecc_ena:1;
|
|
uint64_t row_lsb:3;
|
|
uint64_t pbank_lsb:4;
|
|
uint64_t idlepower:3;
|
|
uint64_t forcewrite:4;
|
|
uint64_t ecc_adr:1;
|
|
uint64_t reset:1;
|
|
uint64_t ref_zqcs_int:19;
|
|
uint64_t sequence:3;
|
|
uint64_t early_dqx:1;
|
|
uint64_t sref_with_dll:1;
|
|
uint64_t rank_ena:1;
|
|
uint64_t rankmask:4;
|
|
uint64_t mirrmask:4;
|
|
uint64_t init_status:4;
|
|
uint64_t early_unload_d0_r0:1;
|
|
uint64_t early_unload_d0_r1:1;
|
|
uint64_t early_unload_d1_r0:1;
|
|
uint64_t early_unload_d1_r1:1;
|
|
uint64_t scrz:1;
|
|
uint64_t reserved_60_63:4;
|
|
#endif
|
|
} cn66xx;
|
|
};
|
|
|
|
union cvmx_lmcx_control {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_control_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t scramble_ena:1;
|
|
uint64_t thrcnt:12;
|
|
uint64_t persub:8;
|
|
uint64_t thrmax:4;
|
|
uint64_t crm_cnt:5;
|
|
uint64_t crm_thr:5;
|
|
uint64_t crm_max:5;
|
|
uint64_t rodt_bprch:1;
|
|
uint64_t wodt_bprch:1;
|
|
uint64_t bprch:2;
|
|
uint64_t ext_zqcs_dis:1;
|
|
uint64_t int_zqcs_dis:1;
|
|
uint64_t auto_dclkdis:1;
|
|
uint64_t xor_bank:1;
|
|
uint64_t max_write_batch:4;
|
|
uint64_t nxm_write_en:1;
|
|
uint64_t elev_prio_dis:1;
|
|
uint64_t inorder_wr:1;
|
|
uint64_t inorder_rd:1;
|
|
uint64_t throttle_wr:1;
|
|
uint64_t throttle_rd:1;
|
|
uint64_t fprch2:2;
|
|
uint64_t pocas:1;
|
|
uint64_t ddr2t:1;
|
|
uint64_t bwcnt:1;
|
|
uint64_t rdimm_ena:1;
|
|
#else
|
|
uint64_t rdimm_ena:1;
|
|
uint64_t bwcnt:1;
|
|
uint64_t ddr2t:1;
|
|
uint64_t pocas:1;
|
|
uint64_t fprch2:2;
|
|
uint64_t throttle_rd:1;
|
|
uint64_t throttle_wr:1;
|
|
uint64_t inorder_rd:1;
|
|
uint64_t inorder_wr:1;
|
|
uint64_t elev_prio_dis:1;
|
|
uint64_t nxm_write_en:1;
|
|
uint64_t max_write_batch:4;
|
|
uint64_t xor_bank:1;
|
|
uint64_t auto_dclkdis:1;
|
|
uint64_t int_zqcs_dis:1;
|
|
uint64_t ext_zqcs_dis:1;
|
|
uint64_t bprch:2;
|
|
uint64_t wodt_bprch:1;
|
|
uint64_t rodt_bprch:1;
|
|
uint64_t crm_max:5;
|
|
uint64_t crm_thr:5;
|
|
uint64_t crm_cnt:5;
|
|
uint64_t thrmax:4;
|
|
uint64_t persub:8;
|
|
uint64_t thrcnt:12;
|
|
uint64_t scramble_ena:1;
|
|
#endif
|
|
} s;
|
|
struct cvmx_lmcx_control_cn63xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_24_63:40;
|
|
uint64_t rodt_bprch:1;
|
|
uint64_t wodt_bprch:1;
|
|
uint64_t bprch:2;
|
|
uint64_t ext_zqcs_dis:1;
|
|
uint64_t int_zqcs_dis:1;
|
|
uint64_t auto_dclkdis:1;
|
|
uint64_t xor_bank:1;
|
|
uint64_t max_write_batch:4;
|
|
uint64_t nxm_write_en:1;
|
|
uint64_t elev_prio_dis:1;
|
|
uint64_t inorder_wr:1;
|
|
uint64_t inorder_rd:1;
|
|
uint64_t throttle_wr:1;
|
|
uint64_t throttle_rd:1;
|
|
uint64_t fprch2:2;
|
|
uint64_t pocas:1;
|
|
uint64_t ddr2t:1;
|
|
uint64_t bwcnt:1;
|
|
uint64_t rdimm_ena:1;
|
|
#else
|
|
uint64_t rdimm_ena:1;
|
|
uint64_t bwcnt:1;
|
|
uint64_t ddr2t:1;
|
|
uint64_t pocas:1;
|
|
uint64_t fprch2:2;
|
|
uint64_t throttle_rd:1;
|
|
uint64_t throttle_wr:1;
|
|
uint64_t inorder_rd:1;
|
|
uint64_t inorder_wr:1;
|
|
uint64_t elev_prio_dis:1;
|
|
uint64_t nxm_write_en:1;
|
|
uint64_t max_write_batch:4;
|
|
uint64_t xor_bank:1;
|
|
uint64_t auto_dclkdis:1;
|
|
uint64_t int_zqcs_dis:1;
|
|
uint64_t ext_zqcs_dis:1;
|
|
uint64_t bprch:2;
|
|
uint64_t wodt_bprch:1;
|
|
uint64_t rodt_bprch:1;
|
|
uint64_t reserved_24_63:40;
|
|
#endif
|
|
} cn63xx;
|
|
struct cvmx_lmcx_control_cn66xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t scramble_ena:1;
|
|
uint64_t reserved_24_62:39;
|
|
uint64_t rodt_bprch:1;
|
|
uint64_t wodt_bprch:1;
|
|
uint64_t bprch:2;
|
|
uint64_t ext_zqcs_dis:1;
|
|
uint64_t int_zqcs_dis:1;
|
|
uint64_t auto_dclkdis:1;
|
|
uint64_t xor_bank:1;
|
|
uint64_t max_write_batch:4;
|
|
uint64_t nxm_write_en:1;
|
|
uint64_t elev_prio_dis:1;
|
|
uint64_t inorder_wr:1;
|
|
uint64_t inorder_rd:1;
|
|
uint64_t throttle_wr:1;
|
|
uint64_t throttle_rd:1;
|
|
uint64_t fprch2:2;
|
|
uint64_t pocas:1;
|
|
uint64_t ddr2t:1;
|
|
uint64_t bwcnt:1;
|
|
uint64_t rdimm_ena:1;
|
|
#else
|
|
uint64_t rdimm_ena:1;
|
|
uint64_t bwcnt:1;
|
|
uint64_t ddr2t:1;
|
|
uint64_t pocas:1;
|
|
uint64_t fprch2:2;
|
|
uint64_t throttle_rd:1;
|
|
uint64_t throttle_wr:1;
|
|
uint64_t inorder_rd:1;
|
|
uint64_t inorder_wr:1;
|
|
uint64_t elev_prio_dis:1;
|
|
uint64_t nxm_write_en:1;
|
|
uint64_t max_write_batch:4;
|
|
uint64_t xor_bank:1;
|
|
uint64_t auto_dclkdis:1;
|
|
uint64_t int_zqcs_dis:1;
|
|
uint64_t ext_zqcs_dis:1;
|
|
uint64_t bprch:2;
|
|
uint64_t wodt_bprch:1;
|
|
uint64_t rodt_bprch:1;
|
|
uint64_t reserved_24_62:39;
|
|
uint64_t scramble_ena:1;
|
|
#endif
|
|
} cn66xx;
|
|
struct cvmx_lmcx_control_cn68xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_63_63:1;
|
|
uint64_t thrcnt:12;
|
|
uint64_t persub:8;
|
|
uint64_t thrmax:4;
|
|
uint64_t crm_cnt:5;
|
|
uint64_t crm_thr:5;
|
|
uint64_t crm_max:5;
|
|
uint64_t rodt_bprch:1;
|
|
uint64_t wodt_bprch:1;
|
|
uint64_t bprch:2;
|
|
uint64_t ext_zqcs_dis:1;
|
|
uint64_t int_zqcs_dis:1;
|
|
uint64_t auto_dclkdis:1;
|
|
uint64_t xor_bank:1;
|
|
uint64_t max_write_batch:4;
|
|
uint64_t nxm_write_en:1;
|
|
uint64_t elev_prio_dis:1;
|
|
uint64_t inorder_wr:1;
|
|
uint64_t inorder_rd:1;
|
|
uint64_t throttle_wr:1;
|
|
uint64_t throttle_rd:1;
|
|
uint64_t fprch2:2;
|
|
uint64_t pocas:1;
|
|
uint64_t ddr2t:1;
|
|
uint64_t bwcnt:1;
|
|
uint64_t rdimm_ena:1;
|
|
#else
|
|
uint64_t rdimm_ena:1;
|
|
uint64_t bwcnt:1;
|
|
uint64_t ddr2t:1;
|
|
uint64_t pocas:1;
|
|
uint64_t fprch2:2;
|
|
uint64_t throttle_rd:1;
|
|
uint64_t throttle_wr:1;
|
|
uint64_t inorder_rd:1;
|
|
uint64_t inorder_wr:1;
|
|
uint64_t elev_prio_dis:1;
|
|
uint64_t nxm_write_en:1;
|
|
uint64_t max_write_batch:4;
|
|
uint64_t xor_bank:1;
|
|
uint64_t auto_dclkdis:1;
|
|
uint64_t int_zqcs_dis:1;
|
|
uint64_t ext_zqcs_dis:1;
|
|
uint64_t bprch:2;
|
|
uint64_t wodt_bprch:1;
|
|
uint64_t rodt_bprch:1;
|
|
uint64_t crm_max:5;
|
|
uint64_t crm_thr:5;
|
|
uint64_t crm_cnt:5;
|
|
uint64_t thrmax:4;
|
|
uint64_t persub:8;
|
|
uint64_t thrcnt:12;
|
|
uint64_t reserved_63_63:1;
|
|
#endif
|
|
} cn68xx;
|
|
};
|
|
|
|
union cvmx_lmcx_ctl {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_ctl_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_32_63:32;
|
|
uint64_t ddr__nctl:4;
|
|
uint64_t ddr__pctl:4;
|
|
uint64_t slow_scf:1;
|
|
uint64_t xor_bank:1;
|
|
uint64_t max_write_batch:4;
|
|
uint64_t pll_div2:1;
|
|
uint64_t pll_bypass:1;
|
|
uint64_t rdimm_ena:1;
|
|
uint64_t r2r_slot:1;
|
|
uint64_t inorder_mwf:1;
|
|
uint64_t inorder_mrf:1;
|
|
uint64_t reserved_10_11:2;
|
|
uint64_t fprch2:1;
|
|
uint64_t bprch:1;
|
|
uint64_t sil_lat:2;
|
|
uint64_t tskw:2;
|
|
uint64_t qs_dic:2;
|
|
uint64_t dic:2;
|
|
#else
|
|
uint64_t dic:2;
|
|
uint64_t qs_dic:2;
|
|
uint64_t tskw:2;
|
|
uint64_t sil_lat:2;
|
|
uint64_t bprch:1;
|
|
uint64_t fprch2:1;
|
|
uint64_t reserved_10_11:2;
|
|
uint64_t inorder_mrf:1;
|
|
uint64_t inorder_mwf:1;
|
|
uint64_t r2r_slot:1;
|
|
uint64_t rdimm_ena:1;
|
|
uint64_t pll_bypass:1;
|
|
uint64_t pll_div2:1;
|
|
uint64_t max_write_batch:4;
|
|
uint64_t xor_bank:1;
|
|
uint64_t slow_scf:1;
|
|
uint64_t ddr__pctl:4;
|
|
uint64_t ddr__nctl:4;
|
|
uint64_t reserved_32_63:32;
|
|
#endif
|
|
} s;
|
|
struct cvmx_lmcx_ctl_cn30xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_32_63:32;
|
|
uint64_t ddr__nctl:4;
|
|
uint64_t ddr__pctl:4;
|
|
uint64_t slow_scf:1;
|
|
uint64_t xor_bank:1;
|
|
uint64_t max_write_batch:4;
|
|
uint64_t pll_div2:1;
|
|
uint64_t pll_bypass:1;
|
|
uint64_t rdimm_ena:1;
|
|
uint64_t r2r_slot:1;
|
|
uint64_t inorder_mwf:1;
|
|
uint64_t inorder_mrf:1;
|
|
uint64_t dreset:1;
|
|
uint64_t mode32b:1;
|
|
uint64_t fprch2:1;
|
|
uint64_t bprch:1;
|
|
uint64_t sil_lat:2;
|
|
uint64_t tskw:2;
|
|
uint64_t qs_dic:2;
|
|
uint64_t dic:2;
|
|
#else
|
|
uint64_t dic:2;
|
|
uint64_t qs_dic:2;
|
|
uint64_t tskw:2;
|
|
uint64_t sil_lat:2;
|
|
uint64_t bprch:1;
|
|
uint64_t fprch2:1;
|
|
uint64_t mode32b:1;
|
|
uint64_t dreset:1;
|
|
uint64_t inorder_mrf:1;
|
|
uint64_t inorder_mwf:1;
|
|
uint64_t r2r_slot:1;
|
|
uint64_t rdimm_ena:1;
|
|
uint64_t pll_bypass:1;
|
|
uint64_t pll_div2:1;
|
|
uint64_t max_write_batch:4;
|
|
uint64_t xor_bank:1;
|
|
uint64_t slow_scf:1;
|
|
uint64_t ddr__pctl:4;
|
|
uint64_t ddr__nctl:4;
|
|
uint64_t reserved_32_63:32;
|
|
#endif
|
|
} cn30xx;
|
|
struct cvmx_lmcx_ctl_cn38xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_32_63:32;
|
|
uint64_t ddr__nctl:4;
|
|
uint64_t ddr__pctl:4;
|
|
uint64_t slow_scf:1;
|
|
uint64_t xor_bank:1;
|
|
uint64_t max_write_batch:4;
|
|
uint64_t reserved_16_17:2;
|
|
uint64_t rdimm_ena:1;
|
|
uint64_t r2r_slot:1;
|
|
uint64_t inorder_mwf:1;
|
|
uint64_t inorder_mrf:1;
|
|
uint64_t set_zero:1;
|
|
uint64_t mode128b:1;
|
|
uint64_t fprch2:1;
|
|
uint64_t bprch:1;
|
|
uint64_t sil_lat:2;
|
|
uint64_t tskw:2;
|
|
uint64_t qs_dic:2;
|
|
uint64_t dic:2;
|
|
#else
|
|
uint64_t dic:2;
|
|
uint64_t qs_dic:2;
|
|
uint64_t tskw:2;
|
|
uint64_t sil_lat:2;
|
|
uint64_t bprch:1;
|
|
uint64_t fprch2:1;
|
|
uint64_t mode128b:1;
|
|
uint64_t set_zero:1;
|
|
uint64_t inorder_mrf:1;
|
|
uint64_t inorder_mwf:1;
|
|
uint64_t r2r_slot:1;
|
|
uint64_t rdimm_ena:1;
|
|
uint64_t reserved_16_17:2;
|
|
uint64_t max_write_batch:4;
|
|
uint64_t xor_bank:1;
|
|
uint64_t slow_scf:1;
|
|
uint64_t ddr__pctl:4;
|
|
uint64_t ddr__nctl:4;
|
|
uint64_t reserved_32_63:32;
|
|
#endif
|
|
} cn38xx;
|
|
struct cvmx_lmcx_ctl_cn50xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_32_63:32;
|
|
uint64_t ddr__nctl:4;
|
|
uint64_t ddr__pctl:4;
|
|
uint64_t slow_scf:1;
|
|
uint64_t xor_bank:1;
|
|
uint64_t max_write_batch:4;
|
|
uint64_t reserved_17_17:1;
|
|
uint64_t pll_bypass:1;
|
|
uint64_t rdimm_ena:1;
|
|
uint64_t r2r_slot:1;
|
|
uint64_t inorder_mwf:1;
|
|
uint64_t inorder_mrf:1;
|
|
uint64_t dreset:1;
|
|
uint64_t mode32b:1;
|
|
uint64_t fprch2:1;
|
|
uint64_t bprch:1;
|
|
uint64_t sil_lat:2;
|
|
uint64_t tskw:2;
|
|
uint64_t qs_dic:2;
|
|
uint64_t dic:2;
|
|
#else
|
|
uint64_t dic:2;
|
|
uint64_t qs_dic:2;
|
|
uint64_t tskw:2;
|
|
uint64_t sil_lat:2;
|
|
uint64_t bprch:1;
|
|
uint64_t fprch2:1;
|
|
uint64_t mode32b:1;
|
|
uint64_t dreset:1;
|
|
uint64_t inorder_mrf:1;
|
|
uint64_t inorder_mwf:1;
|
|
uint64_t r2r_slot:1;
|
|
uint64_t rdimm_ena:1;
|
|
uint64_t pll_bypass:1;
|
|
uint64_t reserved_17_17:1;
|
|
uint64_t max_write_batch:4;
|
|
uint64_t xor_bank:1;
|
|
uint64_t slow_scf:1;
|
|
uint64_t ddr__pctl:4;
|
|
uint64_t ddr__nctl:4;
|
|
uint64_t reserved_32_63:32;
|
|
#endif
|
|
} cn50xx;
|
|
struct cvmx_lmcx_ctl_cn52xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_32_63:32;
|
|
uint64_t ddr__nctl:4;
|
|
uint64_t ddr__pctl:4;
|
|
uint64_t slow_scf:1;
|
|
uint64_t xor_bank:1;
|
|
uint64_t max_write_batch:4;
|
|
uint64_t reserved_16_17:2;
|
|
uint64_t rdimm_ena:1;
|
|
uint64_t r2r_slot:1;
|
|
uint64_t inorder_mwf:1;
|
|
uint64_t inorder_mrf:1;
|
|
uint64_t dreset:1;
|
|
uint64_t mode32b:1;
|
|
uint64_t fprch2:1;
|
|
uint64_t bprch:1;
|
|
uint64_t sil_lat:2;
|
|
uint64_t tskw:2;
|
|
uint64_t qs_dic:2;
|
|
uint64_t dic:2;
|
|
#else
|
|
uint64_t dic:2;
|
|
uint64_t qs_dic:2;
|
|
uint64_t tskw:2;
|
|
uint64_t sil_lat:2;
|
|
uint64_t bprch:1;
|
|
uint64_t fprch2:1;
|
|
uint64_t mode32b:1;
|
|
uint64_t dreset:1;
|
|
uint64_t inorder_mrf:1;
|
|
uint64_t inorder_mwf:1;
|
|
uint64_t r2r_slot:1;
|
|
uint64_t rdimm_ena:1;
|
|
uint64_t reserved_16_17:2;
|
|
uint64_t max_write_batch:4;
|
|
uint64_t xor_bank:1;
|
|
uint64_t slow_scf:1;
|
|
uint64_t ddr__pctl:4;
|
|
uint64_t ddr__nctl:4;
|
|
uint64_t reserved_32_63:32;
|
|
#endif
|
|
} cn52xx;
|
|
struct cvmx_lmcx_ctl_cn58xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_32_63:32;
|
|
uint64_t ddr__nctl:4;
|
|
uint64_t ddr__pctl:4;
|
|
uint64_t slow_scf:1;
|
|
uint64_t xor_bank:1;
|
|
uint64_t max_write_batch:4;
|
|
uint64_t reserved_16_17:2;
|
|
uint64_t rdimm_ena:1;
|
|
uint64_t r2r_slot:1;
|
|
uint64_t inorder_mwf:1;
|
|
uint64_t inorder_mrf:1;
|
|
uint64_t dreset:1;
|
|
uint64_t mode128b:1;
|
|
uint64_t fprch2:1;
|
|
uint64_t bprch:1;
|
|
uint64_t sil_lat:2;
|
|
uint64_t tskw:2;
|
|
uint64_t qs_dic:2;
|
|
uint64_t dic:2;
|
|
#else
|
|
uint64_t dic:2;
|
|
uint64_t qs_dic:2;
|
|
uint64_t tskw:2;
|
|
uint64_t sil_lat:2;
|
|
uint64_t bprch:1;
|
|
uint64_t fprch2:1;
|
|
uint64_t mode128b:1;
|
|
uint64_t dreset:1;
|
|
uint64_t inorder_mrf:1;
|
|
uint64_t inorder_mwf:1;
|
|
uint64_t r2r_slot:1;
|
|
uint64_t rdimm_ena:1;
|
|
uint64_t reserved_16_17:2;
|
|
uint64_t max_write_batch:4;
|
|
uint64_t xor_bank:1;
|
|
uint64_t slow_scf:1;
|
|
uint64_t ddr__pctl:4;
|
|
uint64_t ddr__nctl:4;
|
|
uint64_t reserved_32_63:32;
|
|
#endif
|
|
} cn58xx;
|
|
};
|
|
|
|
union cvmx_lmcx_ctl1 {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_ctl1_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_21_63:43;
|
|
uint64_t ecc_adr:1;
|
|
uint64_t forcewrite:4;
|
|
uint64_t idlepower:3;
|
|
uint64_t sequence:3;
|
|
uint64_t sil_mode:1;
|
|
uint64_t dcc_enable:1;
|
|
uint64_t reserved_2_7:6;
|
|
uint64_t data_layout:2;
|
|
#else
|
|
uint64_t data_layout:2;
|
|
uint64_t reserved_2_7:6;
|
|
uint64_t dcc_enable:1;
|
|
uint64_t sil_mode:1;
|
|
uint64_t sequence:3;
|
|
uint64_t idlepower:3;
|
|
uint64_t forcewrite:4;
|
|
uint64_t ecc_adr:1;
|
|
uint64_t reserved_21_63:43;
|
|
#endif
|
|
} s;
|
|
struct cvmx_lmcx_ctl1_cn30xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_2_63:62;
|
|
uint64_t data_layout:2;
|
|
#else
|
|
uint64_t data_layout:2;
|
|
uint64_t reserved_2_63:62;
|
|
#endif
|
|
} cn30xx;
|
|
struct cvmx_lmcx_ctl1_cn50xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_10_63:54;
|
|
uint64_t sil_mode:1;
|
|
uint64_t dcc_enable:1;
|
|
uint64_t reserved_2_7:6;
|
|
uint64_t data_layout:2;
|
|
#else
|
|
uint64_t data_layout:2;
|
|
uint64_t reserved_2_7:6;
|
|
uint64_t dcc_enable:1;
|
|
uint64_t sil_mode:1;
|
|
uint64_t reserved_10_63:54;
|
|
#endif
|
|
} cn50xx;
|
|
struct cvmx_lmcx_ctl1_cn52xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_21_63:43;
|
|
uint64_t ecc_adr:1;
|
|
uint64_t forcewrite:4;
|
|
uint64_t idlepower:3;
|
|
uint64_t sequence:3;
|
|
uint64_t sil_mode:1;
|
|
uint64_t dcc_enable:1;
|
|
uint64_t reserved_0_7:8;
|
|
#else
|
|
uint64_t reserved_0_7:8;
|
|
uint64_t dcc_enable:1;
|
|
uint64_t sil_mode:1;
|
|
uint64_t sequence:3;
|
|
uint64_t idlepower:3;
|
|
uint64_t forcewrite:4;
|
|
uint64_t ecc_adr:1;
|
|
uint64_t reserved_21_63:43;
|
|
#endif
|
|
} cn52xx;
|
|
struct cvmx_lmcx_ctl1_cn58xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_10_63:54;
|
|
uint64_t sil_mode:1;
|
|
uint64_t dcc_enable:1;
|
|
uint64_t reserved_0_7:8;
|
|
#else
|
|
uint64_t reserved_0_7:8;
|
|
uint64_t dcc_enable:1;
|
|
uint64_t sil_mode:1;
|
|
uint64_t reserved_10_63:54;
|
|
#endif
|
|
} cn58xx;
|
|
};
|
|
|
|
union cvmx_lmcx_dclk_cnt {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_dclk_cnt_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t dclkcnt:64;
|
|
#else
|
|
uint64_t dclkcnt:64;
|
|
#endif
|
|
} s;
|
|
};
|
|
|
|
union cvmx_lmcx_dclk_cnt_hi {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_dclk_cnt_hi_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_32_63:32;
|
|
uint64_t dclkcnt_hi:32;
|
|
#else
|
|
uint64_t dclkcnt_hi:32;
|
|
uint64_t reserved_32_63:32;
|
|
#endif
|
|
} s;
|
|
};
|
|
|
|
union cvmx_lmcx_dclk_cnt_lo {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_dclk_cnt_lo_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_32_63:32;
|
|
uint64_t dclkcnt_lo:32;
|
|
#else
|
|
uint64_t dclkcnt_lo:32;
|
|
uint64_t reserved_32_63:32;
|
|
#endif
|
|
} s;
|
|
};
|
|
|
|
union cvmx_lmcx_dclk_ctl {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_dclk_ctl_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_8_63:56;
|
|
uint64_t off90_ena:1;
|
|
uint64_t dclk90_byp:1;
|
|
uint64_t dclk90_ld:1;
|
|
uint64_t dclk90_vlu:5;
|
|
#else
|
|
uint64_t dclk90_vlu:5;
|
|
uint64_t dclk90_ld:1;
|
|
uint64_t dclk90_byp:1;
|
|
uint64_t off90_ena:1;
|
|
uint64_t reserved_8_63:56;
|
|
#endif
|
|
} s;
|
|
};
|
|
|
|
union cvmx_lmcx_ddr2_ctl {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_ddr2_ctl_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_32_63:32;
|
|
uint64_t bank8:1;
|
|
uint64_t burst8:1;
|
|
uint64_t addlat:3;
|
|
uint64_t pocas:1;
|
|
uint64_t bwcnt:1;
|
|
uint64_t twr:3;
|
|
uint64_t silo_hc:1;
|
|
uint64_t ddr_eof:4;
|
|
uint64_t tfaw:5;
|
|
uint64_t crip_mode:1;
|
|
uint64_t ddr2t:1;
|
|
uint64_t odt_ena:1;
|
|
uint64_t qdll_ena:1;
|
|
uint64_t dll90_vlu:5;
|
|
uint64_t dll90_byp:1;
|
|
uint64_t rdqs:1;
|
|
uint64_t ddr2:1;
|
|
#else
|
|
uint64_t ddr2:1;
|
|
uint64_t rdqs:1;
|
|
uint64_t dll90_byp:1;
|
|
uint64_t dll90_vlu:5;
|
|
uint64_t qdll_ena:1;
|
|
uint64_t odt_ena:1;
|
|
uint64_t ddr2t:1;
|
|
uint64_t crip_mode:1;
|
|
uint64_t tfaw:5;
|
|
uint64_t ddr_eof:4;
|
|
uint64_t silo_hc:1;
|
|
uint64_t twr:3;
|
|
uint64_t bwcnt:1;
|
|
uint64_t pocas:1;
|
|
uint64_t addlat:3;
|
|
uint64_t burst8:1;
|
|
uint64_t bank8:1;
|
|
uint64_t reserved_32_63:32;
|
|
#endif
|
|
} s;
|
|
struct cvmx_lmcx_ddr2_ctl_cn30xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_32_63:32;
|
|
uint64_t bank8:1;
|
|
uint64_t burst8:1;
|
|
uint64_t addlat:3;
|
|
uint64_t pocas:1;
|
|
uint64_t bwcnt:1;
|
|
uint64_t twr:3;
|
|
uint64_t silo_hc:1;
|
|
uint64_t ddr_eof:4;
|
|
uint64_t tfaw:5;
|
|
uint64_t crip_mode:1;
|
|
uint64_t ddr2t:1;
|
|
uint64_t odt_ena:1;
|
|
uint64_t qdll_ena:1;
|
|
uint64_t dll90_vlu:5;
|
|
uint64_t dll90_byp:1;
|
|
uint64_t reserved_1_1:1;
|
|
uint64_t ddr2:1;
|
|
#else
|
|
uint64_t ddr2:1;
|
|
uint64_t reserved_1_1:1;
|
|
uint64_t dll90_byp:1;
|
|
uint64_t dll90_vlu:5;
|
|
uint64_t qdll_ena:1;
|
|
uint64_t odt_ena:1;
|
|
uint64_t ddr2t:1;
|
|
uint64_t crip_mode:1;
|
|
uint64_t tfaw:5;
|
|
uint64_t ddr_eof:4;
|
|
uint64_t silo_hc:1;
|
|
uint64_t twr:3;
|
|
uint64_t bwcnt:1;
|
|
uint64_t pocas:1;
|
|
uint64_t addlat:3;
|
|
uint64_t burst8:1;
|
|
uint64_t bank8:1;
|
|
uint64_t reserved_32_63:32;
|
|
#endif
|
|
} cn30xx;
|
|
};
|
|
|
|
union cvmx_lmcx_ddr_pll_ctl {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_ddr_pll_ctl_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_27_63:37;
|
|
uint64_t jtg_test_mode:1;
|
|
uint64_t dfm_div_reset:1;
|
|
uint64_t dfm_ps_en:3;
|
|
uint64_t ddr_div_reset:1;
|
|
uint64_t ddr_ps_en:3;
|
|
uint64_t diffamp:4;
|
|
uint64_t cps:3;
|
|
uint64_t cpb:3;
|
|
uint64_t reset_n:1;
|
|
uint64_t clkf:7;
|
|
#else
|
|
uint64_t clkf:7;
|
|
uint64_t reset_n:1;
|
|
uint64_t cpb:3;
|
|
uint64_t cps:3;
|
|
uint64_t diffamp:4;
|
|
uint64_t ddr_ps_en:3;
|
|
uint64_t ddr_div_reset:1;
|
|
uint64_t dfm_ps_en:3;
|
|
uint64_t dfm_div_reset:1;
|
|
uint64_t jtg_test_mode:1;
|
|
uint64_t reserved_27_63:37;
|
|
#endif
|
|
} s;
|
|
};
|
|
|
|
union cvmx_lmcx_delay_cfg {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_delay_cfg_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_15_63:49;
|
|
uint64_t dq:5;
|
|
uint64_t cmd:5;
|
|
uint64_t clk:5;
|
|
#else
|
|
uint64_t clk:5;
|
|
uint64_t cmd:5;
|
|
uint64_t dq:5;
|
|
uint64_t reserved_15_63:49;
|
|
#endif
|
|
} s;
|
|
struct cvmx_lmcx_delay_cfg_cn38xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_14_63:50;
|
|
uint64_t dq:4;
|
|
uint64_t reserved_9_9:1;
|
|
uint64_t cmd:4;
|
|
uint64_t reserved_4_4:1;
|
|
uint64_t clk:4;
|
|
#else
|
|
uint64_t clk:4;
|
|
uint64_t reserved_4_4:1;
|
|
uint64_t cmd:4;
|
|
uint64_t reserved_9_9:1;
|
|
uint64_t dq:4;
|
|
uint64_t reserved_14_63:50;
|
|
#endif
|
|
} cn38xx;
|
|
};
|
|
|
|
union cvmx_lmcx_dimmx_params {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_dimmx_params_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t rc15:4;
|
|
uint64_t rc14:4;
|
|
uint64_t rc13:4;
|
|
uint64_t rc12:4;
|
|
uint64_t rc11:4;
|
|
uint64_t rc10:4;
|
|
uint64_t rc9:4;
|
|
uint64_t rc8:4;
|
|
uint64_t rc7:4;
|
|
uint64_t rc6:4;
|
|
uint64_t rc5:4;
|
|
uint64_t rc4:4;
|
|
uint64_t rc3:4;
|
|
uint64_t rc2:4;
|
|
uint64_t rc1:4;
|
|
uint64_t rc0:4;
|
|
#else
|
|
uint64_t rc0:4;
|
|
uint64_t rc1:4;
|
|
uint64_t rc2:4;
|
|
uint64_t rc3:4;
|
|
uint64_t rc4:4;
|
|
uint64_t rc5:4;
|
|
uint64_t rc6:4;
|
|
uint64_t rc7:4;
|
|
uint64_t rc8:4;
|
|
uint64_t rc9:4;
|
|
uint64_t rc10:4;
|
|
uint64_t rc11:4;
|
|
uint64_t rc12:4;
|
|
uint64_t rc13:4;
|
|
uint64_t rc14:4;
|
|
uint64_t rc15:4;
|
|
#endif
|
|
} s;
|
|
};
|
|
|
|
union cvmx_lmcx_dimm_ctl {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_dimm_ctl_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_46_63:18;
|
|
uint64_t parity:1;
|
|
uint64_t tcws:13;
|
|
uint64_t dimm1_wmask:16;
|
|
uint64_t dimm0_wmask:16;
|
|
#else
|
|
uint64_t dimm0_wmask:16;
|
|
uint64_t dimm1_wmask:16;
|
|
uint64_t tcws:13;
|
|
uint64_t parity:1;
|
|
uint64_t reserved_46_63:18;
|
|
#endif
|
|
} s;
|
|
};
|
|
|
|
union cvmx_lmcx_dll_ctl {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_dll_ctl_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_8_63:56;
|
|
uint64_t dreset:1;
|
|
uint64_t dll90_byp:1;
|
|
uint64_t dll90_ena:1;
|
|
uint64_t dll90_vlu:5;
|
|
#else
|
|
uint64_t dll90_vlu:5;
|
|
uint64_t dll90_ena:1;
|
|
uint64_t dll90_byp:1;
|
|
uint64_t dreset:1;
|
|
uint64_t reserved_8_63:56;
|
|
#endif
|
|
} s;
|
|
};
|
|
|
|
union cvmx_lmcx_dll_ctl2 {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_dll_ctl2_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_16_63:48;
|
|
uint64_t intf_en:1;
|
|
uint64_t dll_bringup:1;
|
|
uint64_t dreset:1;
|
|
uint64_t quad_dll_ena:1;
|
|
uint64_t byp_sel:4;
|
|
uint64_t byp_setting:8;
|
|
#else
|
|
uint64_t byp_setting:8;
|
|
uint64_t byp_sel:4;
|
|
uint64_t quad_dll_ena:1;
|
|
uint64_t dreset:1;
|
|
uint64_t dll_bringup:1;
|
|
uint64_t intf_en:1;
|
|
uint64_t reserved_16_63:48;
|
|
#endif
|
|
} s;
|
|
struct cvmx_lmcx_dll_ctl2_cn63xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_15_63:49;
|
|
uint64_t dll_bringup:1;
|
|
uint64_t dreset:1;
|
|
uint64_t quad_dll_ena:1;
|
|
uint64_t byp_sel:4;
|
|
uint64_t byp_setting:8;
|
|
#else
|
|
uint64_t byp_setting:8;
|
|
uint64_t byp_sel:4;
|
|
uint64_t quad_dll_ena:1;
|
|
uint64_t dreset:1;
|
|
uint64_t dll_bringup:1;
|
|
uint64_t reserved_15_63:49;
|
|
#endif
|
|
} cn63xx;
|
|
};
|
|
|
|
union cvmx_lmcx_dll_ctl3 {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_dll_ctl3_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_41_63:23;
|
|
uint64_t dclk90_fwd:1;
|
|
uint64_t ddr_90_dly_byp:1;
|
|
uint64_t dclk90_recal_dis:1;
|
|
uint64_t dclk90_byp_sel:1;
|
|
uint64_t dclk90_byp_setting:8;
|
|
uint64_t dll_fast:1;
|
|
uint64_t dll90_setting:8;
|
|
uint64_t fine_tune_mode:1;
|
|
uint64_t dll_mode:1;
|
|
uint64_t dll90_byte_sel:4;
|
|
uint64_t offset_ena:1;
|
|
uint64_t load_offset:1;
|
|
uint64_t mode_sel:2;
|
|
uint64_t byte_sel:4;
|
|
uint64_t offset:6;
|
|
#else
|
|
uint64_t offset:6;
|
|
uint64_t byte_sel:4;
|
|
uint64_t mode_sel:2;
|
|
uint64_t load_offset:1;
|
|
uint64_t offset_ena:1;
|
|
uint64_t dll90_byte_sel:4;
|
|
uint64_t dll_mode:1;
|
|
uint64_t fine_tune_mode:1;
|
|
uint64_t dll90_setting:8;
|
|
uint64_t dll_fast:1;
|
|
uint64_t dclk90_byp_setting:8;
|
|
uint64_t dclk90_byp_sel:1;
|
|
uint64_t dclk90_recal_dis:1;
|
|
uint64_t ddr_90_dly_byp:1;
|
|
uint64_t dclk90_fwd:1;
|
|
uint64_t reserved_41_63:23;
|
|
#endif
|
|
} s;
|
|
struct cvmx_lmcx_dll_ctl3_cn63xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_29_63:35;
|
|
uint64_t dll_fast:1;
|
|
uint64_t dll90_setting:8;
|
|
uint64_t fine_tune_mode:1;
|
|
uint64_t dll_mode:1;
|
|
uint64_t dll90_byte_sel:4;
|
|
uint64_t offset_ena:1;
|
|
uint64_t load_offset:1;
|
|
uint64_t mode_sel:2;
|
|
uint64_t byte_sel:4;
|
|
uint64_t offset:6;
|
|
#else
|
|
uint64_t offset:6;
|
|
uint64_t byte_sel:4;
|
|
uint64_t mode_sel:2;
|
|
uint64_t load_offset:1;
|
|
uint64_t offset_ena:1;
|
|
uint64_t dll90_byte_sel:4;
|
|
uint64_t dll_mode:1;
|
|
uint64_t fine_tune_mode:1;
|
|
uint64_t dll90_setting:8;
|
|
uint64_t dll_fast:1;
|
|
uint64_t reserved_29_63:35;
|
|
#endif
|
|
} cn63xx;
|
|
};
|
|
|
|
union cvmx_lmcx_dual_memcfg {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_dual_memcfg_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_20_63:44;
|
|
uint64_t bank8:1;
|
|
uint64_t row_lsb:3;
|
|
uint64_t reserved_8_15:8;
|
|
uint64_t cs_mask:8;
|
|
#else
|
|
uint64_t cs_mask:8;
|
|
uint64_t reserved_8_15:8;
|
|
uint64_t row_lsb:3;
|
|
uint64_t bank8:1;
|
|
uint64_t reserved_20_63:44;
|
|
#endif
|
|
} s;
|
|
struct cvmx_lmcx_dual_memcfg_cn61xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_19_63:45;
|
|
uint64_t row_lsb:3;
|
|
uint64_t reserved_8_15:8;
|
|
uint64_t cs_mask:8;
|
|
#else
|
|
uint64_t cs_mask:8;
|
|
uint64_t reserved_8_15:8;
|
|
uint64_t row_lsb:3;
|
|
uint64_t reserved_19_63:45;
|
|
#endif
|
|
} cn61xx;
|
|
};
|
|
|
|
union cvmx_lmcx_ecc_synd {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_ecc_synd_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_32_63:32;
|
|
uint64_t mrdsyn3:8;
|
|
uint64_t mrdsyn2:8;
|
|
uint64_t mrdsyn1:8;
|
|
uint64_t mrdsyn0:8;
|
|
#else
|
|
uint64_t mrdsyn0:8;
|
|
uint64_t mrdsyn1:8;
|
|
uint64_t mrdsyn2:8;
|
|
uint64_t mrdsyn3:8;
|
|
uint64_t reserved_32_63:32;
|
|
#endif
|
|
} s;
|
|
};
|
|
|
|
union cvmx_lmcx_fadr {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_fadr_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_0_63:64;
|
|
#else
|
|
uint64_t reserved_0_63:64;
|
|
#endif
|
|
} s;
|
|
struct cvmx_lmcx_fadr_cn30xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_32_63:32;
|
|
uint64_t fdimm:2;
|
|
uint64_t fbunk:1;
|
|
uint64_t fbank:3;
|
|
uint64_t frow:14;
|
|
uint64_t fcol:12;
|
|
#else
|
|
uint64_t fcol:12;
|
|
uint64_t frow:14;
|
|
uint64_t fbank:3;
|
|
uint64_t fbunk:1;
|
|
uint64_t fdimm:2;
|
|
uint64_t reserved_32_63:32;
|
|
#endif
|
|
} cn30xx;
|
|
struct cvmx_lmcx_fadr_cn61xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_36_63:28;
|
|
uint64_t fdimm:2;
|
|
uint64_t fbunk:1;
|
|
uint64_t fbank:3;
|
|
uint64_t frow:16;
|
|
uint64_t fcol:14;
|
|
#else
|
|
uint64_t fcol:14;
|
|
uint64_t frow:16;
|
|
uint64_t fbank:3;
|
|
uint64_t fbunk:1;
|
|
uint64_t fdimm:2;
|
|
uint64_t reserved_36_63:28;
|
|
#endif
|
|
} cn61xx;
|
|
};
|
|
|
|
union cvmx_lmcx_ifb_cnt {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_ifb_cnt_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t ifbcnt:64;
|
|
#else
|
|
uint64_t ifbcnt:64;
|
|
#endif
|
|
} s;
|
|
};
|
|
|
|
union cvmx_lmcx_ifb_cnt_hi {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_ifb_cnt_hi_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_32_63:32;
|
|
uint64_t ifbcnt_hi:32;
|
|
#else
|
|
uint64_t ifbcnt_hi:32;
|
|
uint64_t reserved_32_63:32;
|
|
#endif
|
|
} s;
|
|
};
|
|
|
|
union cvmx_lmcx_ifb_cnt_lo {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_ifb_cnt_lo_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_32_63:32;
|
|
uint64_t ifbcnt_lo:32;
|
|
#else
|
|
uint64_t ifbcnt_lo:32;
|
|
uint64_t reserved_32_63:32;
|
|
#endif
|
|
} s;
|
|
};
|
|
|
|
union cvmx_lmcx_int {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_int_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_9_63:55;
|
|
uint64_t ded_err:4;
|
|
uint64_t sec_err:4;
|
|
uint64_t nxm_wr_err:1;
|
|
#else
|
|
uint64_t nxm_wr_err:1;
|
|
uint64_t sec_err:4;
|
|
uint64_t ded_err:4;
|
|
uint64_t reserved_9_63:55;
|
|
#endif
|
|
} s;
|
|
};
|
|
|
|
union cvmx_lmcx_int_en {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_int_en_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_3_63:61;
|
|
uint64_t intr_ded_ena:1;
|
|
uint64_t intr_sec_ena:1;
|
|
uint64_t intr_nxm_wr_ena:1;
|
|
#else
|
|
uint64_t intr_nxm_wr_ena:1;
|
|
uint64_t intr_sec_ena:1;
|
|
uint64_t intr_ded_ena:1;
|
|
uint64_t reserved_3_63:61;
|
|
#endif
|
|
} s;
|
|
};
|
|
|
|
union cvmx_lmcx_mem_cfg0 {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_mem_cfg0_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_32_63:32;
|
|
uint64_t reset:1;
|
|
uint64_t silo_qc:1;
|
|
uint64_t bunk_ena:1;
|
|
uint64_t ded_err:4;
|
|
uint64_t sec_err:4;
|
|
uint64_t intr_ded_ena:1;
|
|
uint64_t intr_sec_ena:1;
|
|
uint64_t tcl:4;
|
|
uint64_t ref_int:6;
|
|
uint64_t pbank_lsb:4;
|
|
uint64_t row_lsb:3;
|
|
uint64_t ecc_ena:1;
|
|
uint64_t init_start:1;
|
|
#else
|
|
uint64_t init_start:1;
|
|
uint64_t ecc_ena:1;
|
|
uint64_t row_lsb:3;
|
|
uint64_t pbank_lsb:4;
|
|
uint64_t ref_int:6;
|
|
uint64_t tcl:4;
|
|
uint64_t intr_sec_ena:1;
|
|
uint64_t intr_ded_ena:1;
|
|
uint64_t sec_err:4;
|
|
uint64_t ded_err:4;
|
|
uint64_t bunk_ena:1;
|
|
uint64_t silo_qc:1;
|
|
uint64_t reset:1;
|
|
uint64_t reserved_32_63:32;
|
|
#endif
|
|
} s;
|
|
};
|
|
|
|
union cvmx_lmcx_mem_cfg1 {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_mem_cfg1_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_32_63:32;
|
|
uint64_t comp_bypass:1;
|
|
uint64_t trrd:3;
|
|
uint64_t caslat:3;
|
|
uint64_t tmrd:3;
|
|
uint64_t trfc:5;
|
|
uint64_t trp:4;
|
|
uint64_t twtr:4;
|
|
uint64_t trcd:4;
|
|
uint64_t tras:5;
|
|
#else
|
|
uint64_t tras:5;
|
|
uint64_t trcd:4;
|
|
uint64_t twtr:4;
|
|
uint64_t trp:4;
|
|
uint64_t trfc:5;
|
|
uint64_t tmrd:3;
|
|
uint64_t caslat:3;
|
|
uint64_t trrd:3;
|
|
uint64_t comp_bypass:1;
|
|
uint64_t reserved_32_63:32;
|
|
#endif
|
|
} s;
|
|
struct cvmx_lmcx_mem_cfg1_cn38xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_31_63:33;
|
|
uint64_t trrd:3;
|
|
uint64_t caslat:3;
|
|
uint64_t tmrd:3;
|
|
uint64_t trfc:5;
|
|
uint64_t trp:4;
|
|
uint64_t twtr:4;
|
|
uint64_t trcd:4;
|
|
uint64_t tras:5;
|
|
#else
|
|
uint64_t tras:5;
|
|
uint64_t trcd:4;
|
|
uint64_t twtr:4;
|
|
uint64_t trp:4;
|
|
uint64_t trfc:5;
|
|
uint64_t tmrd:3;
|
|
uint64_t caslat:3;
|
|
uint64_t trrd:3;
|
|
uint64_t reserved_31_63:33;
|
|
#endif
|
|
} cn38xx;
|
|
};
|
|
|
|
union cvmx_lmcx_modereg_params0 {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_modereg_params0_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_25_63:39;
|
|
uint64_t ppd:1;
|
|
uint64_t wrp:3;
|
|
uint64_t dllr:1;
|
|
uint64_t tm:1;
|
|
uint64_t rbt:1;
|
|
uint64_t cl:4;
|
|
uint64_t bl:2;
|
|
uint64_t qoff:1;
|
|
uint64_t tdqs:1;
|
|
uint64_t wlev:1;
|
|
uint64_t al:2;
|
|
uint64_t dll:1;
|
|
uint64_t mpr:1;
|
|
uint64_t mprloc:2;
|
|
uint64_t cwl:3;
|
|
#else
|
|
uint64_t cwl:3;
|
|
uint64_t mprloc:2;
|
|
uint64_t mpr:1;
|
|
uint64_t dll:1;
|
|
uint64_t al:2;
|
|
uint64_t wlev:1;
|
|
uint64_t tdqs:1;
|
|
uint64_t qoff:1;
|
|
uint64_t bl:2;
|
|
uint64_t cl:4;
|
|
uint64_t rbt:1;
|
|
uint64_t tm:1;
|
|
uint64_t dllr:1;
|
|
uint64_t wrp:3;
|
|
uint64_t ppd:1;
|
|
uint64_t reserved_25_63:39;
|
|
#endif
|
|
} s;
|
|
};
|
|
|
|
union cvmx_lmcx_modereg_params1 {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_modereg_params1_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_48_63:16;
|
|
uint64_t rtt_nom_11:3;
|
|
uint64_t dic_11:2;
|
|
uint64_t rtt_wr_11:2;
|
|
uint64_t srt_11:1;
|
|
uint64_t asr_11:1;
|
|
uint64_t pasr_11:3;
|
|
uint64_t rtt_nom_10:3;
|
|
uint64_t dic_10:2;
|
|
uint64_t rtt_wr_10:2;
|
|
uint64_t srt_10:1;
|
|
uint64_t asr_10:1;
|
|
uint64_t pasr_10:3;
|
|
uint64_t rtt_nom_01:3;
|
|
uint64_t dic_01:2;
|
|
uint64_t rtt_wr_01:2;
|
|
uint64_t srt_01:1;
|
|
uint64_t asr_01:1;
|
|
uint64_t pasr_01:3;
|
|
uint64_t rtt_nom_00:3;
|
|
uint64_t dic_00:2;
|
|
uint64_t rtt_wr_00:2;
|
|
uint64_t srt_00:1;
|
|
uint64_t asr_00:1;
|
|
uint64_t pasr_00:3;
|
|
#else
|
|
uint64_t pasr_00:3;
|
|
uint64_t asr_00:1;
|
|
uint64_t srt_00:1;
|
|
uint64_t rtt_wr_00:2;
|
|
uint64_t dic_00:2;
|
|
uint64_t rtt_nom_00:3;
|
|
uint64_t pasr_01:3;
|
|
uint64_t asr_01:1;
|
|
uint64_t srt_01:1;
|
|
uint64_t rtt_wr_01:2;
|
|
uint64_t dic_01:2;
|
|
uint64_t rtt_nom_01:3;
|
|
uint64_t pasr_10:3;
|
|
uint64_t asr_10:1;
|
|
uint64_t srt_10:1;
|
|
uint64_t rtt_wr_10:2;
|
|
uint64_t dic_10:2;
|
|
uint64_t rtt_nom_10:3;
|
|
uint64_t pasr_11:3;
|
|
uint64_t asr_11:1;
|
|
uint64_t srt_11:1;
|
|
uint64_t rtt_wr_11:2;
|
|
uint64_t dic_11:2;
|
|
uint64_t rtt_nom_11:3;
|
|
uint64_t reserved_48_63:16;
|
|
#endif
|
|
} s;
|
|
};
|
|
|
|
union cvmx_lmcx_nxm {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_nxm_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_40_63:24;
|
|
uint64_t mem_msb_d3_r1:4;
|
|
uint64_t mem_msb_d3_r0:4;
|
|
uint64_t mem_msb_d2_r1:4;
|
|
uint64_t mem_msb_d2_r0:4;
|
|
uint64_t mem_msb_d1_r1:4;
|
|
uint64_t mem_msb_d1_r0:4;
|
|
uint64_t mem_msb_d0_r1:4;
|
|
uint64_t mem_msb_d0_r0:4;
|
|
uint64_t cs_mask:8;
|
|
#else
|
|
uint64_t cs_mask:8;
|
|
uint64_t mem_msb_d0_r0:4;
|
|
uint64_t mem_msb_d0_r1:4;
|
|
uint64_t mem_msb_d1_r0:4;
|
|
uint64_t mem_msb_d1_r1:4;
|
|
uint64_t mem_msb_d2_r0:4;
|
|
uint64_t mem_msb_d2_r1:4;
|
|
uint64_t mem_msb_d3_r0:4;
|
|
uint64_t mem_msb_d3_r1:4;
|
|
uint64_t reserved_40_63:24;
|
|
#endif
|
|
} s;
|
|
struct cvmx_lmcx_nxm_cn52xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_8_63:56;
|
|
uint64_t cs_mask:8;
|
|
#else
|
|
uint64_t cs_mask:8;
|
|
uint64_t reserved_8_63:56;
|
|
#endif
|
|
} cn52xx;
|
|
};
|
|
|
|
union cvmx_lmcx_ops_cnt {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_ops_cnt_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t opscnt:64;
|
|
#else
|
|
uint64_t opscnt:64;
|
|
#endif
|
|
} s;
|
|
};
|
|
|
|
union cvmx_lmcx_ops_cnt_hi {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_ops_cnt_hi_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_32_63:32;
|
|
uint64_t opscnt_hi:32;
|
|
#else
|
|
uint64_t opscnt_hi:32;
|
|
uint64_t reserved_32_63:32;
|
|
#endif
|
|
} s;
|
|
};
|
|
|
|
union cvmx_lmcx_ops_cnt_lo {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_ops_cnt_lo_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_32_63:32;
|
|
uint64_t opscnt_lo:32;
|
|
#else
|
|
uint64_t opscnt_lo:32;
|
|
uint64_t reserved_32_63:32;
|
|
#endif
|
|
} s;
|
|
};
|
|
|
|
union cvmx_lmcx_phy_ctl {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_phy_ctl_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_15_63:49;
|
|
uint64_t rx_always_on:1;
|
|
uint64_t lv_mode:1;
|
|
uint64_t ck_tune1:1;
|
|
uint64_t ck_dlyout1:4;
|
|
uint64_t ck_tune0:1;
|
|
uint64_t ck_dlyout0:4;
|
|
uint64_t loopback:1;
|
|
uint64_t loopback_pos:1;
|
|
uint64_t ts_stagger:1;
|
|
#else
|
|
uint64_t ts_stagger:1;
|
|
uint64_t loopback_pos:1;
|
|
uint64_t loopback:1;
|
|
uint64_t ck_dlyout0:4;
|
|
uint64_t ck_tune0:1;
|
|
uint64_t ck_dlyout1:4;
|
|
uint64_t ck_tune1:1;
|
|
uint64_t lv_mode:1;
|
|
uint64_t rx_always_on:1;
|
|
uint64_t reserved_15_63:49;
|
|
#endif
|
|
} s;
|
|
struct cvmx_lmcx_phy_ctl_cn63xxp1 {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_14_63:50;
|
|
uint64_t lv_mode:1;
|
|
uint64_t ck_tune1:1;
|
|
uint64_t ck_dlyout1:4;
|
|
uint64_t ck_tune0:1;
|
|
uint64_t ck_dlyout0:4;
|
|
uint64_t loopback:1;
|
|
uint64_t loopback_pos:1;
|
|
uint64_t ts_stagger:1;
|
|
#else
|
|
uint64_t ts_stagger:1;
|
|
uint64_t loopback_pos:1;
|
|
uint64_t loopback:1;
|
|
uint64_t ck_dlyout0:4;
|
|
uint64_t ck_tune0:1;
|
|
uint64_t ck_dlyout1:4;
|
|
uint64_t ck_tune1:1;
|
|
uint64_t lv_mode:1;
|
|
uint64_t reserved_14_63:50;
|
|
#endif
|
|
} cn63xxp1;
|
|
};
|
|
|
|
union cvmx_lmcx_pll_bwctl {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_pll_bwctl_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_5_63:59;
|
|
uint64_t bwupd:1;
|
|
uint64_t bwctl:4;
|
|
#else
|
|
uint64_t bwctl:4;
|
|
uint64_t bwupd:1;
|
|
uint64_t reserved_5_63:59;
|
|
#endif
|
|
} s;
|
|
};
|
|
|
|
union cvmx_lmcx_pll_ctl {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_pll_ctl_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_30_63:34;
|
|
uint64_t bypass:1;
|
|
uint64_t fasten_n:1;
|
|
uint64_t div_reset:1;
|
|
uint64_t reset_n:1;
|
|
uint64_t clkf:12;
|
|
uint64_t clkr:6;
|
|
uint64_t reserved_6_7:2;
|
|
uint64_t en16:1;
|
|
uint64_t en12:1;
|
|
uint64_t en8:1;
|
|
uint64_t en6:1;
|
|
uint64_t en4:1;
|
|
uint64_t en2:1;
|
|
#else
|
|
uint64_t en2:1;
|
|
uint64_t en4:1;
|
|
uint64_t en6:1;
|
|
uint64_t en8:1;
|
|
uint64_t en12:1;
|
|
uint64_t en16:1;
|
|
uint64_t reserved_6_7:2;
|
|
uint64_t clkr:6;
|
|
uint64_t clkf:12;
|
|
uint64_t reset_n:1;
|
|
uint64_t div_reset:1;
|
|
uint64_t fasten_n:1;
|
|
uint64_t bypass:1;
|
|
uint64_t reserved_30_63:34;
|
|
#endif
|
|
} s;
|
|
struct cvmx_lmcx_pll_ctl_cn50xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_29_63:35;
|
|
uint64_t fasten_n:1;
|
|
uint64_t div_reset:1;
|
|
uint64_t reset_n:1;
|
|
uint64_t clkf:12;
|
|
uint64_t clkr:6;
|
|
uint64_t reserved_6_7:2;
|
|
uint64_t en16:1;
|
|
uint64_t en12:1;
|
|
uint64_t en8:1;
|
|
uint64_t en6:1;
|
|
uint64_t en4:1;
|
|
uint64_t en2:1;
|
|
#else
|
|
uint64_t en2:1;
|
|
uint64_t en4:1;
|
|
uint64_t en6:1;
|
|
uint64_t en8:1;
|
|
uint64_t en12:1;
|
|
uint64_t en16:1;
|
|
uint64_t reserved_6_7:2;
|
|
uint64_t clkr:6;
|
|
uint64_t clkf:12;
|
|
uint64_t reset_n:1;
|
|
uint64_t div_reset:1;
|
|
uint64_t fasten_n:1;
|
|
uint64_t reserved_29_63:35;
|
|
#endif
|
|
} cn50xx;
|
|
struct cvmx_lmcx_pll_ctl_cn56xxp1 {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_28_63:36;
|
|
uint64_t div_reset:1;
|
|
uint64_t reset_n:1;
|
|
uint64_t clkf:12;
|
|
uint64_t clkr:6;
|
|
uint64_t reserved_6_7:2;
|
|
uint64_t en16:1;
|
|
uint64_t en12:1;
|
|
uint64_t en8:1;
|
|
uint64_t en6:1;
|
|
uint64_t en4:1;
|
|
uint64_t en2:1;
|
|
#else
|
|
uint64_t en2:1;
|
|
uint64_t en4:1;
|
|
uint64_t en6:1;
|
|
uint64_t en8:1;
|
|
uint64_t en12:1;
|
|
uint64_t en16:1;
|
|
uint64_t reserved_6_7:2;
|
|
uint64_t clkr:6;
|
|
uint64_t clkf:12;
|
|
uint64_t reset_n:1;
|
|
uint64_t div_reset:1;
|
|
uint64_t reserved_28_63:36;
|
|
#endif
|
|
} cn56xxp1;
|
|
};
|
|
|
|
union cvmx_lmcx_pll_status {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_pll_status_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_32_63:32;
|
|
uint64_t ddr__nctl:5;
|
|
uint64_t ddr__pctl:5;
|
|
uint64_t reserved_2_21:20;
|
|
uint64_t rfslip:1;
|
|
uint64_t fbslip:1;
|
|
#else
|
|
uint64_t fbslip:1;
|
|
uint64_t rfslip:1;
|
|
uint64_t reserved_2_21:20;
|
|
uint64_t ddr__pctl:5;
|
|
uint64_t ddr__nctl:5;
|
|
uint64_t reserved_32_63:32;
|
|
#endif
|
|
} s;
|
|
struct cvmx_lmcx_pll_status_cn58xxp1 {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_2_63:62;
|
|
uint64_t rfslip:1;
|
|
uint64_t fbslip:1;
|
|
#else
|
|
uint64_t fbslip:1;
|
|
uint64_t rfslip:1;
|
|
uint64_t reserved_2_63:62;
|
|
#endif
|
|
} cn58xxp1;
|
|
};
|
|
|
|
union cvmx_lmcx_read_level_ctl {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_read_level_ctl_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_44_63:20;
|
|
uint64_t rankmask:4;
|
|
uint64_t pattern:8;
|
|
uint64_t row:16;
|
|
uint64_t col:12;
|
|
uint64_t reserved_3_3:1;
|
|
uint64_t bnk:3;
|
|
#else
|
|
uint64_t bnk:3;
|
|
uint64_t reserved_3_3:1;
|
|
uint64_t col:12;
|
|
uint64_t row:16;
|
|
uint64_t pattern:8;
|
|
uint64_t rankmask:4;
|
|
uint64_t reserved_44_63:20;
|
|
#endif
|
|
} s;
|
|
};
|
|
|
|
union cvmx_lmcx_read_level_dbg {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_read_level_dbg_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_32_63:32;
|
|
uint64_t bitmask:16;
|
|
uint64_t reserved_4_15:12;
|
|
uint64_t byte:4;
|
|
#else
|
|
uint64_t byte:4;
|
|
uint64_t reserved_4_15:12;
|
|
uint64_t bitmask:16;
|
|
uint64_t reserved_32_63:32;
|
|
#endif
|
|
} s;
|
|
};
|
|
|
|
union cvmx_lmcx_read_level_rankx {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_read_level_rankx_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_38_63:26;
|
|
uint64_t status:2;
|
|
uint64_t byte8:4;
|
|
uint64_t byte7:4;
|
|
uint64_t byte6:4;
|
|
uint64_t byte5:4;
|
|
uint64_t byte4:4;
|
|
uint64_t byte3:4;
|
|
uint64_t byte2:4;
|
|
uint64_t byte1:4;
|
|
uint64_t byte0:4;
|
|
#else
|
|
uint64_t byte0:4;
|
|
uint64_t byte1:4;
|
|
uint64_t byte2:4;
|
|
uint64_t byte3:4;
|
|
uint64_t byte4:4;
|
|
uint64_t byte5:4;
|
|
uint64_t byte6:4;
|
|
uint64_t byte7:4;
|
|
uint64_t byte8:4;
|
|
uint64_t status:2;
|
|
uint64_t reserved_38_63:26;
|
|
#endif
|
|
} s;
|
|
};
|
|
|
|
union cvmx_lmcx_reset_ctl {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_reset_ctl_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_4_63:60;
|
|
uint64_t ddr3psv:1;
|
|
uint64_t ddr3psoft:1;
|
|
uint64_t ddr3pwarm:1;
|
|
uint64_t ddr3rst:1;
|
|
#else
|
|
uint64_t ddr3rst:1;
|
|
uint64_t ddr3pwarm:1;
|
|
uint64_t ddr3psoft:1;
|
|
uint64_t ddr3psv:1;
|
|
uint64_t reserved_4_63:60;
|
|
#endif
|
|
} s;
|
|
};
|
|
|
|
union cvmx_lmcx_rlevel_ctl {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_rlevel_ctl_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_22_63:42;
|
|
uint64_t delay_unload_3:1;
|
|
uint64_t delay_unload_2:1;
|
|
uint64_t delay_unload_1:1;
|
|
uint64_t delay_unload_0:1;
|
|
uint64_t bitmask:8;
|
|
uint64_t or_dis:1;
|
|
uint64_t offset_en:1;
|
|
uint64_t offset:4;
|
|
uint64_t byte:4;
|
|
#else
|
|
uint64_t byte:4;
|
|
uint64_t offset:4;
|
|
uint64_t offset_en:1;
|
|
uint64_t or_dis:1;
|
|
uint64_t bitmask:8;
|
|
uint64_t delay_unload_0:1;
|
|
uint64_t delay_unload_1:1;
|
|
uint64_t delay_unload_2:1;
|
|
uint64_t delay_unload_3:1;
|
|
uint64_t reserved_22_63:42;
|
|
#endif
|
|
} s;
|
|
struct cvmx_lmcx_rlevel_ctl_cn63xxp1 {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_9_63:55;
|
|
uint64_t offset_en:1;
|
|
uint64_t offset:4;
|
|
uint64_t byte:4;
|
|
#else
|
|
uint64_t byte:4;
|
|
uint64_t offset:4;
|
|
uint64_t offset_en:1;
|
|
uint64_t reserved_9_63:55;
|
|
#endif
|
|
} cn63xxp1;
|
|
};
|
|
|
|
union cvmx_lmcx_rlevel_dbg {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_rlevel_dbg_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t bitmask:64;
|
|
#else
|
|
uint64_t bitmask:64;
|
|
#endif
|
|
} s;
|
|
};
|
|
|
|
union cvmx_lmcx_rlevel_rankx {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_rlevel_rankx_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_56_63:8;
|
|
uint64_t status:2;
|
|
uint64_t byte8:6;
|
|
uint64_t byte7:6;
|
|
uint64_t byte6:6;
|
|
uint64_t byte5:6;
|
|
uint64_t byte4:6;
|
|
uint64_t byte3:6;
|
|
uint64_t byte2:6;
|
|
uint64_t byte1:6;
|
|
uint64_t byte0:6;
|
|
#else
|
|
uint64_t byte0:6;
|
|
uint64_t byte1:6;
|
|
uint64_t byte2:6;
|
|
uint64_t byte3:6;
|
|
uint64_t byte4:6;
|
|
uint64_t byte5:6;
|
|
uint64_t byte6:6;
|
|
uint64_t byte7:6;
|
|
uint64_t byte8:6;
|
|
uint64_t status:2;
|
|
uint64_t reserved_56_63:8;
|
|
#endif
|
|
} s;
|
|
};
|
|
|
|
union cvmx_lmcx_rodt_comp_ctl {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_rodt_comp_ctl_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_17_63:47;
|
|
uint64_t enable:1;
|
|
uint64_t reserved_12_15:4;
|
|
uint64_t nctl:4;
|
|
uint64_t reserved_5_7:3;
|
|
uint64_t pctl:5;
|
|
#else
|
|
uint64_t pctl:5;
|
|
uint64_t reserved_5_7:3;
|
|
uint64_t nctl:4;
|
|
uint64_t reserved_12_15:4;
|
|
uint64_t enable:1;
|
|
uint64_t reserved_17_63:47;
|
|
#endif
|
|
} s;
|
|
};
|
|
|
|
union cvmx_lmcx_rodt_ctl {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_rodt_ctl_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_32_63:32;
|
|
uint64_t rodt_hi3:4;
|
|
uint64_t rodt_hi2:4;
|
|
uint64_t rodt_hi1:4;
|
|
uint64_t rodt_hi0:4;
|
|
uint64_t rodt_lo3:4;
|
|
uint64_t rodt_lo2:4;
|
|
uint64_t rodt_lo1:4;
|
|
uint64_t rodt_lo0:4;
|
|
#else
|
|
uint64_t rodt_lo0:4;
|
|
uint64_t rodt_lo1:4;
|
|
uint64_t rodt_lo2:4;
|
|
uint64_t rodt_lo3:4;
|
|
uint64_t rodt_hi0:4;
|
|
uint64_t rodt_hi1:4;
|
|
uint64_t rodt_hi2:4;
|
|
uint64_t rodt_hi3:4;
|
|
uint64_t reserved_32_63:32;
|
|
#endif
|
|
} s;
|
|
};
|
|
|
|
union cvmx_lmcx_rodt_mask {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_rodt_mask_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t rodt_d3_r1:8;
|
|
uint64_t rodt_d3_r0:8;
|
|
uint64_t rodt_d2_r1:8;
|
|
uint64_t rodt_d2_r0:8;
|
|
uint64_t rodt_d1_r1:8;
|
|
uint64_t rodt_d1_r0:8;
|
|
uint64_t rodt_d0_r1:8;
|
|
uint64_t rodt_d0_r0:8;
|
|
#else
|
|
uint64_t rodt_d0_r0:8;
|
|
uint64_t rodt_d0_r1:8;
|
|
uint64_t rodt_d1_r0:8;
|
|
uint64_t rodt_d1_r1:8;
|
|
uint64_t rodt_d2_r0:8;
|
|
uint64_t rodt_d2_r1:8;
|
|
uint64_t rodt_d3_r0:8;
|
|
uint64_t rodt_d3_r1:8;
|
|
#endif
|
|
} s;
|
|
};
|
|
|
|
union cvmx_lmcx_scramble_cfg0 {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_scramble_cfg0_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t key:64;
|
|
#else
|
|
uint64_t key:64;
|
|
#endif
|
|
} s;
|
|
};
|
|
|
|
union cvmx_lmcx_scramble_cfg1 {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_scramble_cfg1_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t key:64;
|
|
#else
|
|
uint64_t key:64;
|
|
#endif
|
|
} s;
|
|
};
|
|
|
|
union cvmx_lmcx_scrambled_fadr {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_scrambled_fadr_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_36_63:28;
|
|
uint64_t fdimm:2;
|
|
uint64_t fbunk:1;
|
|
uint64_t fbank:3;
|
|
uint64_t frow:16;
|
|
uint64_t fcol:14;
|
|
#else
|
|
uint64_t fcol:14;
|
|
uint64_t frow:16;
|
|
uint64_t fbank:3;
|
|
uint64_t fbunk:1;
|
|
uint64_t fdimm:2;
|
|
uint64_t reserved_36_63:28;
|
|
#endif
|
|
} s;
|
|
};
|
|
|
|
union cvmx_lmcx_slot_ctl0 {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_slot_ctl0_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_24_63:40;
|
|
uint64_t w2w_init:6;
|
|
uint64_t w2r_init:6;
|
|
uint64_t r2w_init:6;
|
|
uint64_t r2r_init:6;
|
|
#else
|
|
uint64_t r2r_init:6;
|
|
uint64_t r2w_init:6;
|
|
uint64_t w2r_init:6;
|
|
uint64_t w2w_init:6;
|
|
uint64_t reserved_24_63:40;
|
|
#endif
|
|
} s;
|
|
};
|
|
|
|
union cvmx_lmcx_slot_ctl1 {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_slot_ctl1_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_24_63:40;
|
|
uint64_t w2w_xrank_init:6;
|
|
uint64_t w2r_xrank_init:6;
|
|
uint64_t r2w_xrank_init:6;
|
|
uint64_t r2r_xrank_init:6;
|
|
#else
|
|
uint64_t r2r_xrank_init:6;
|
|
uint64_t r2w_xrank_init:6;
|
|
uint64_t w2r_xrank_init:6;
|
|
uint64_t w2w_xrank_init:6;
|
|
uint64_t reserved_24_63:40;
|
|
#endif
|
|
} s;
|
|
};
|
|
|
|
union cvmx_lmcx_slot_ctl2 {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_slot_ctl2_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_24_63:40;
|
|
uint64_t w2w_xdimm_init:6;
|
|
uint64_t w2r_xdimm_init:6;
|
|
uint64_t r2w_xdimm_init:6;
|
|
uint64_t r2r_xdimm_init:6;
|
|
#else
|
|
uint64_t r2r_xdimm_init:6;
|
|
uint64_t r2w_xdimm_init:6;
|
|
uint64_t w2r_xdimm_init:6;
|
|
uint64_t w2w_xdimm_init:6;
|
|
uint64_t reserved_24_63:40;
|
|
#endif
|
|
} s;
|
|
};
|
|
|
|
union cvmx_lmcx_timing_params0 {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_timing_params0_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_47_63:17;
|
|
uint64_t trp_ext:1;
|
|
uint64_t tcksre:4;
|
|
uint64_t trp:4;
|
|
uint64_t tzqinit:4;
|
|
uint64_t tdllk:4;
|
|
uint64_t tmod:4;
|
|
uint64_t tmrd:4;
|
|
uint64_t txpr:4;
|
|
uint64_t tcke:4;
|
|
uint64_t tzqcs:4;
|
|
uint64_t tckeon:10;
|
|
#else
|
|
uint64_t tckeon:10;
|
|
uint64_t tzqcs:4;
|
|
uint64_t tcke:4;
|
|
uint64_t txpr:4;
|
|
uint64_t tmrd:4;
|
|
uint64_t tmod:4;
|
|
uint64_t tdllk:4;
|
|
uint64_t tzqinit:4;
|
|
uint64_t trp:4;
|
|
uint64_t tcksre:4;
|
|
uint64_t trp_ext:1;
|
|
uint64_t reserved_47_63:17;
|
|
#endif
|
|
} s;
|
|
struct cvmx_lmcx_timing_params0_cn61xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_47_63:17;
|
|
uint64_t trp_ext:1;
|
|
uint64_t tcksre:4;
|
|
uint64_t trp:4;
|
|
uint64_t tzqinit:4;
|
|
uint64_t tdllk:4;
|
|
uint64_t tmod:4;
|
|
uint64_t tmrd:4;
|
|
uint64_t txpr:4;
|
|
uint64_t tcke:4;
|
|
uint64_t tzqcs:4;
|
|
uint64_t reserved_0_9:10;
|
|
#else
|
|
uint64_t reserved_0_9:10;
|
|
uint64_t tzqcs:4;
|
|
uint64_t tcke:4;
|
|
uint64_t txpr:4;
|
|
uint64_t tmrd:4;
|
|
uint64_t tmod:4;
|
|
uint64_t tdllk:4;
|
|
uint64_t tzqinit:4;
|
|
uint64_t trp:4;
|
|
uint64_t tcksre:4;
|
|
uint64_t trp_ext:1;
|
|
uint64_t reserved_47_63:17;
|
|
#endif
|
|
} cn61xx;
|
|
struct cvmx_lmcx_timing_params0_cn63xxp1 {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_46_63:18;
|
|
uint64_t tcksre:4;
|
|
uint64_t trp:4;
|
|
uint64_t tzqinit:4;
|
|
uint64_t tdllk:4;
|
|
uint64_t tmod:4;
|
|
uint64_t tmrd:4;
|
|
uint64_t txpr:4;
|
|
uint64_t tcke:4;
|
|
uint64_t tzqcs:4;
|
|
uint64_t tckeon:10;
|
|
#else
|
|
uint64_t tckeon:10;
|
|
uint64_t tzqcs:4;
|
|
uint64_t tcke:4;
|
|
uint64_t txpr:4;
|
|
uint64_t tmrd:4;
|
|
uint64_t tmod:4;
|
|
uint64_t tdllk:4;
|
|
uint64_t tzqinit:4;
|
|
uint64_t trp:4;
|
|
uint64_t tcksre:4;
|
|
uint64_t reserved_46_63:18;
|
|
#endif
|
|
} cn63xxp1;
|
|
};
|
|
|
|
union cvmx_lmcx_timing_params1 {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_timing_params1_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_47_63:17;
|
|
uint64_t tras_ext:1;
|
|
uint64_t txpdll:5;
|
|
uint64_t tfaw:5;
|
|
uint64_t twldqsen:4;
|
|
uint64_t twlmrd:4;
|
|
uint64_t txp:3;
|
|
uint64_t trrd:3;
|
|
uint64_t trfc:5;
|
|
uint64_t twtr:4;
|
|
uint64_t trcd:4;
|
|
uint64_t tras:5;
|
|
uint64_t tmprr:4;
|
|
#else
|
|
uint64_t tmprr:4;
|
|
uint64_t tras:5;
|
|
uint64_t trcd:4;
|
|
uint64_t twtr:4;
|
|
uint64_t trfc:5;
|
|
uint64_t trrd:3;
|
|
uint64_t txp:3;
|
|
uint64_t twlmrd:4;
|
|
uint64_t twldqsen:4;
|
|
uint64_t tfaw:5;
|
|
uint64_t txpdll:5;
|
|
uint64_t tras_ext:1;
|
|
uint64_t reserved_47_63:17;
|
|
#endif
|
|
} s;
|
|
struct cvmx_lmcx_timing_params1_cn63xxp1 {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_46_63:18;
|
|
uint64_t txpdll:5;
|
|
uint64_t tfaw:5;
|
|
uint64_t twldqsen:4;
|
|
uint64_t twlmrd:4;
|
|
uint64_t txp:3;
|
|
uint64_t trrd:3;
|
|
uint64_t trfc:5;
|
|
uint64_t twtr:4;
|
|
uint64_t trcd:4;
|
|
uint64_t tras:5;
|
|
uint64_t tmprr:4;
|
|
#else
|
|
uint64_t tmprr:4;
|
|
uint64_t tras:5;
|
|
uint64_t trcd:4;
|
|
uint64_t twtr:4;
|
|
uint64_t trfc:5;
|
|
uint64_t trrd:3;
|
|
uint64_t txp:3;
|
|
uint64_t twlmrd:4;
|
|
uint64_t twldqsen:4;
|
|
uint64_t tfaw:5;
|
|
uint64_t txpdll:5;
|
|
uint64_t reserved_46_63:18;
|
|
#endif
|
|
} cn63xxp1;
|
|
};
|
|
|
|
union cvmx_lmcx_tro_ctl {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_tro_ctl_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_33_63:31;
|
|
uint64_t rclk_cnt:32;
|
|
uint64_t treset:1;
|
|
#else
|
|
uint64_t treset:1;
|
|
uint64_t rclk_cnt:32;
|
|
uint64_t reserved_33_63:31;
|
|
#endif
|
|
} s;
|
|
};
|
|
|
|
union cvmx_lmcx_tro_stat {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_tro_stat_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_32_63:32;
|
|
uint64_t ring_cnt:32;
|
|
#else
|
|
uint64_t ring_cnt:32;
|
|
uint64_t reserved_32_63:32;
|
|
#endif
|
|
} s;
|
|
};
|
|
|
|
union cvmx_lmcx_wlevel_ctl {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_wlevel_ctl_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_22_63:42;
|
|
uint64_t rtt_nom:3;
|
|
uint64_t bitmask:8;
|
|
uint64_t or_dis:1;
|
|
uint64_t sset:1;
|
|
uint64_t lanemask:9;
|
|
#else
|
|
uint64_t lanemask:9;
|
|
uint64_t sset:1;
|
|
uint64_t or_dis:1;
|
|
uint64_t bitmask:8;
|
|
uint64_t rtt_nom:3;
|
|
uint64_t reserved_22_63:42;
|
|
#endif
|
|
} s;
|
|
struct cvmx_lmcx_wlevel_ctl_cn63xxp1 {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_10_63:54;
|
|
uint64_t sset:1;
|
|
uint64_t lanemask:9;
|
|
#else
|
|
uint64_t lanemask:9;
|
|
uint64_t sset:1;
|
|
uint64_t reserved_10_63:54;
|
|
#endif
|
|
} cn63xxp1;
|
|
};
|
|
|
|
union cvmx_lmcx_wlevel_dbg {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_wlevel_dbg_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_12_63:52;
|
|
uint64_t bitmask:8;
|
|
uint64_t byte:4;
|
|
#else
|
|
uint64_t byte:4;
|
|
uint64_t bitmask:8;
|
|
uint64_t reserved_12_63:52;
|
|
#endif
|
|
} s;
|
|
};
|
|
|
|
union cvmx_lmcx_wlevel_rankx {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_wlevel_rankx_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_47_63:17;
|
|
uint64_t status:2;
|
|
uint64_t byte8:5;
|
|
uint64_t byte7:5;
|
|
uint64_t byte6:5;
|
|
uint64_t byte5:5;
|
|
uint64_t byte4:5;
|
|
uint64_t byte3:5;
|
|
uint64_t byte2:5;
|
|
uint64_t byte1:5;
|
|
uint64_t byte0:5;
|
|
#else
|
|
uint64_t byte0:5;
|
|
uint64_t byte1:5;
|
|
uint64_t byte2:5;
|
|
uint64_t byte3:5;
|
|
uint64_t byte4:5;
|
|
uint64_t byte5:5;
|
|
uint64_t byte6:5;
|
|
uint64_t byte7:5;
|
|
uint64_t byte8:5;
|
|
uint64_t status:2;
|
|
uint64_t reserved_47_63:17;
|
|
#endif
|
|
} s;
|
|
};
|
|
|
|
union cvmx_lmcx_wodt_ctl0 {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_wodt_ctl0_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_0_63:64;
|
|
#else
|
|
uint64_t reserved_0_63:64;
|
|
#endif
|
|
} s;
|
|
struct cvmx_lmcx_wodt_ctl0_cn30xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_32_63:32;
|
|
uint64_t wodt_d1_r1:8;
|
|
uint64_t wodt_d1_r0:8;
|
|
uint64_t wodt_d0_r1:8;
|
|
uint64_t wodt_d0_r0:8;
|
|
#else
|
|
uint64_t wodt_d0_r0:8;
|
|
uint64_t wodt_d0_r1:8;
|
|
uint64_t wodt_d1_r0:8;
|
|
uint64_t wodt_d1_r1:8;
|
|
uint64_t reserved_32_63:32;
|
|
#endif
|
|
} cn30xx;
|
|
struct cvmx_lmcx_wodt_ctl0_cn38xx {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_32_63:32;
|
|
uint64_t wodt_hi3:4;
|
|
uint64_t wodt_hi2:4;
|
|
uint64_t wodt_hi1:4;
|
|
uint64_t wodt_hi0:4;
|
|
uint64_t wodt_lo3:4;
|
|
uint64_t wodt_lo2:4;
|
|
uint64_t wodt_lo1:4;
|
|
uint64_t wodt_lo0:4;
|
|
#else
|
|
uint64_t wodt_lo0:4;
|
|
uint64_t wodt_lo1:4;
|
|
uint64_t wodt_lo2:4;
|
|
uint64_t wodt_lo3:4;
|
|
uint64_t wodt_hi0:4;
|
|
uint64_t wodt_hi1:4;
|
|
uint64_t wodt_hi2:4;
|
|
uint64_t wodt_hi3:4;
|
|
uint64_t reserved_32_63:32;
|
|
#endif
|
|
} cn38xx;
|
|
};
|
|
|
|
union cvmx_lmcx_wodt_ctl1 {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_wodt_ctl1_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t reserved_32_63:32;
|
|
uint64_t wodt_d3_r1:8;
|
|
uint64_t wodt_d3_r0:8;
|
|
uint64_t wodt_d2_r1:8;
|
|
uint64_t wodt_d2_r0:8;
|
|
#else
|
|
uint64_t wodt_d2_r0:8;
|
|
uint64_t wodt_d2_r1:8;
|
|
uint64_t wodt_d3_r0:8;
|
|
uint64_t wodt_d3_r1:8;
|
|
uint64_t reserved_32_63:32;
|
|
#endif
|
|
} s;
|
|
};
|
|
|
|
union cvmx_lmcx_wodt_mask {
|
|
uint64_t u64;
|
|
struct cvmx_lmcx_wodt_mask_s {
|
|
#ifdef __BIG_ENDIAN_BITFIELD
|
|
uint64_t wodt_d3_r1:8;
|
|
uint64_t wodt_d3_r0:8;
|
|
uint64_t wodt_d2_r1:8;
|
|
uint64_t wodt_d2_r0:8;
|
|
uint64_t wodt_d1_r1:8;
|
|
uint64_t wodt_d1_r0:8;
|
|
uint64_t wodt_d0_r1:8;
|
|
uint64_t wodt_d0_r0:8;
|
|
#else
|
|
uint64_t wodt_d0_r0:8;
|
|
uint64_t wodt_d0_r1:8;
|
|
uint64_t wodt_d1_r0:8;
|
|
uint64_t wodt_d1_r1:8;
|
|
uint64_t wodt_d2_r0:8;
|
|
uint64_t wodt_d2_r1:8;
|
|
uint64_t wodt_d3_r0:8;
|
|
uint64_t wodt_d3_r1:8;
|
|
#endif
|
|
} s;
|
|
};
|
|
|
|
#endif
|