blob: 50e779cf1ad8b42f2b720618f1ef94a0b9b36383 [file] [log] [blame]
/***********************license start***************
* Author: Cavium Networks
*
* Contact: support@caviumnetworks.com
* This file is part of the OCTEON SDK
*
* Copyright (c) 2003-2008 Cavium Networks
*
* 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 Networks for more information
***********************license end**************************************/
#ifndef __CVMX_PKO_DEFS_H__
#define __CVMX_PKO_DEFS_H__
#define CVMX_PKO_MEM_COUNT0 \
CVMX_ADD_IO_SEG(0x0001180050001080ull)
#define CVMX_PKO_MEM_COUNT1 \
CVMX_ADD_IO_SEG(0x0001180050001088ull)
#define CVMX_PKO_MEM_DEBUG0 \
CVMX_ADD_IO_SEG(0x0001180050001100ull)
#define CVMX_PKO_MEM_DEBUG1 \
CVMX_ADD_IO_SEG(0x0001180050001108ull)
#define CVMX_PKO_MEM_DEBUG10 \
CVMX_ADD_IO_SEG(0x0001180050001150ull)
#define CVMX_PKO_MEM_DEBUG11 \
CVMX_ADD_IO_SEG(0x0001180050001158ull)
#define CVMX_PKO_MEM_DEBUG12 \
CVMX_ADD_IO_SEG(0x0001180050001160ull)
#define CVMX_PKO_MEM_DEBUG13 \
CVMX_ADD_IO_SEG(0x0001180050001168ull)
#define CVMX_PKO_MEM_DEBUG14 \
CVMX_ADD_IO_SEG(0x0001180050001170ull)
#define CVMX_PKO_MEM_DEBUG2 \
CVMX_ADD_IO_SEG(0x0001180050001110ull)
#define CVMX_PKO_MEM_DEBUG3 \
CVMX_ADD_IO_SEG(0x0001180050001118ull)
#define CVMX_PKO_MEM_DEBUG4 \
CVMX_ADD_IO_SEG(0x0001180050001120ull)
#define CVMX_PKO_MEM_DEBUG5 \
CVMX_ADD_IO_SEG(0x0001180050001128ull)
#define CVMX_PKO_MEM_DEBUG6 \
CVMX_ADD_IO_SEG(0x0001180050001130ull)
#define CVMX_PKO_MEM_DEBUG7 \
CVMX_ADD_IO_SEG(0x0001180050001138ull)
#define CVMX_PKO_MEM_DEBUG8 \
CVMX_ADD_IO_SEG(0x0001180050001140ull)
#define CVMX_PKO_MEM_DEBUG9 \
CVMX_ADD_IO_SEG(0x0001180050001148ull)
#define CVMX_PKO_MEM_PORT_PTRS \
CVMX_ADD_IO_SEG(0x0001180050001010ull)
#define CVMX_PKO_MEM_PORT_QOS \
CVMX_ADD_IO_SEG(0x0001180050001018ull)
#define CVMX_PKO_MEM_PORT_RATE0 \
CVMX_ADD_IO_SEG(0x0001180050001020ull)
#define CVMX_PKO_MEM_PORT_RATE1 \
CVMX_ADD_IO_SEG(0x0001180050001028ull)
#define CVMX_PKO_MEM_QUEUE_PTRS \
CVMX_ADD_IO_SEG(0x0001180050001000ull)
#define CVMX_PKO_MEM_QUEUE_QOS \
CVMX_ADD_IO_SEG(0x0001180050001008ull)
#define CVMX_PKO_REG_BIST_RESULT \
CVMX_ADD_IO_SEG(0x0001180050000080ull)
#define CVMX_PKO_REG_CMD_BUF \
CVMX_ADD_IO_SEG(0x0001180050000010ull)
#define CVMX_PKO_REG_CRC_CTLX(offset) \
CVMX_ADD_IO_SEG(0x0001180050000028ull + (((offset) & 1) * 8))
#define CVMX_PKO_REG_CRC_ENABLE \
CVMX_ADD_IO_SEG(0x0001180050000020ull)
#define CVMX_PKO_REG_CRC_IVX(offset) \
CVMX_ADD_IO_SEG(0x0001180050000038ull + (((offset) & 1) * 8))
#define CVMX_PKO_REG_DEBUG0 \
CVMX_ADD_IO_SEG(0x0001180050000098ull)
#define CVMX_PKO_REG_DEBUG1 \
CVMX_ADD_IO_SEG(0x00011800500000A0ull)
#define CVMX_PKO_REG_DEBUG2 \
CVMX_ADD_IO_SEG(0x00011800500000A8ull)
#define CVMX_PKO_REG_DEBUG3 \
CVMX_ADD_IO_SEG(0x00011800500000B0ull)
#define CVMX_PKO_REG_ENGINE_INFLIGHT \
CVMX_ADD_IO_SEG(0x0001180050000050ull)
#define CVMX_PKO_REG_ENGINE_THRESH \
CVMX_ADD_IO_SEG(0x0001180050000058ull)
#define CVMX_PKO_REG_ERROR \
CVMX_ADD_IO_SEG(0x0001180050000088ull)
#define CVMX_PKO_REG_FLAGS \
CVMX_ADD_IO_SEG(0x0001180050000000ull)
#define CVMX_PKO_REG_GMX_PORT_MODE \
CVMX_ADD_IO_SEG(0x0001180050000018ull)
#define CVMX_PKO_REG_INT_MASK \
CVMX_ADD_IO_SEG(0x0001180050000090ull)
#define CVMX_PKO_REG_QUEUE_MODE \
CVMX_ADD_IO_SEG(0x0001180050000048ull)
#define CVMX_PKO_REG_QUEUE_PTRS1 \
CVMX_ADD_IO_SEG(0x0001180050000100ull)
#define CVMX_PKO_REG_READ_IDX \
CVMX_ADD_IO_SEG(0x0001180050000008ull)
union cvmx_pko_mem_count0 {
uint64_t u64;
struct cvmx_pko_mem_count0_s {
uint64_t reserved_32_63:32;
uint64_t count:32;
} s;
struct cvmx_pko_mem_count0_s cn30xx;
struct cvmx_pko_mem_count0_s cn31xx;
struct cvmx_pko_mem_count0_s cn38xx;
struct cvmx_pko_mem_count0_s cn38xxp2;
struct cvmx_pko_mem_count0_s cn50xx;
struct cvmx_pko_mem_count0_s cn52xx;
struct cvmx_pko_mem_count0_s cn52xxp1;
struct cvmx_pko_mem_count0_s cn56xx;
struct cvmx_pko_mem_count0_s cn56xxp1;
struct cvmx_pko_mem_count0_s cn58xx;
struct cvmx_pko_mem_count0_s cn58xxp1;
};
union cvmx_pko_mem_count1 {
uint64_t u64;
struct cvmx_pko_mem_count1_s {
uint64_t reserved_48_63:16;
uint64_t count:48;
} s;
struct cvmx_pko_mem_count1_s cn30xx;
struct cvmx_pko_mem_count1_s cn31xx;
struct cvmx_pko_mem_count1_s cn38xx;
struct cvmx_pko_mem_count1_s cn38xxp2;
struct cvmx_pko_mem_count1_s cn50xx;
struct cvmx_pko_mem_count1_s cn52xx;
struct cvmx_pko_mem_count1_s cn52xxp1;
struct cvmx_pko_mem_count1_s cn56xx;
struct cvmx_pko_mem_count1_s cn56xxp1;
struct cvmx_pko_mem_count1_s cn58xx;
struct cvmx_pko_mem_count1_s cn58xxp1;
};
union cvmx_pko_mem_debug0 {
uint64_t u64;
struct cvmx_pko_mem_debug0_s {
uint64_t fau:28;
uint64_t cmd:14;
uint64_t segs:6;
uint64_t size:16;
} s;
struct cvmx_pko_mem_debug0_s cn30xx;
struct cvmx_pko_mem_debug0_s cn31xx;
struct cvmx_pko_mem_debug0_s cn38xx;
struct cvmx_pko_mem_debug0_s cn38xxp2;
struct cvmx_pko_mem_debug0_s cn50xx;
struct cvmx_pko_mem_debug0_s cn52xx;
struct cvmx_pko_mem_debug0_s cn52xxp1;
struct cvmx_pko_mem_debug0_s cn56xx;
struct cvmx_pko_mem_debug0_s cn56xxp1;
struct cvmx_pko_mem_debug0_s cn58xx;
struct cvmx_pko_mem_debug0_s cn58xxp1;
};
union cvmx_pko_mem_debug1 {
uint64_t u64;
struct cvmx_pko_mem_debug1_s {
uint64_t i:1;
uint64_t back:4;
uint64_t pool:3;
uint64_t size:16;
uint64_t ptr:40;
} s;
struct cvmx_pko_mem_debug1_s cn30xx;
struct cvmx_pko_mem_debug1_s cn31xx;
struct cvmx_pko_mem_debug1_s cn38xx;
struct cvmx_pko_mem_debug1_s cn38xxp2;
struct cvmx_pko_mem_debug1_s cn50xx;
struct cvmx_pko_mem_debug1_s cn52xx;
struct cvmx_pko_mem_debug1_s cn52xxp1;
struct cvmx_pko_mem_debug1_s cn56xx;
struct cvmx_pko_mem_debug1_s cn56xxp1;
struct cvmx_pko_mem_debug1_s cn58xx;
struct cvmx_pko_mem_debug1_s cn58xxp1;
};
union cvmx_pko_mem_debug10 {
uint64_t u64;
struct cvmx_pko_mem_debug10_s {
uint64_t reserved_0_63:64;
} s;
struct cvmx_pko_mem_debug10_cn30xx {
uint64_t fau:28;
uint64_t cmd:14;
uint64_t segs:6;
uint64_t size:16;
} cn30xx;
struct cvmx_pko_mem_debug10_cn30xx cn31xx;
struct cvmx_pko_mem_debug10_cn30xx cn38xx;
struct cvmx_pko_mem_debug10_cn30xx cn38xxp2;
struct cvmx_pko_mem_debug10_cn50xx {
uint64_t reserved_49_63:15;
uint64_t ptrs1:17;
uint64_t reserved_17_31:15;
uint64_t ptrs2:17;
} cn50xx;
struct cvmx_pko_mem_debug10_cn50xx cn52xx;
struct cvmx_pko_mem_debug10_cn50xx cn52xxp1;
struct cvmx_pko_mem_debug10_cn50xx cn56xx;
struct cvmx_pko_mem_debug10_cn50xx cn56xxp1;
struct cvmx_pko_mem_debug10_cn50xx cn58xx;
struct cvmx_pko_mem_debug10_cn50xx cn58xxp1;
};
union cvmx_pko_mem_debug11 {
uint64_t u64;
struct cvmx_pko_mem_debug11_s {
uint64_t i:1;
uint64_t back:4;
uint64_t pool:3;
uint64_t size:16;
uint64_t reserved_0_39:40;
} s;
struct cvmx_pko_mem_debug11_cn30xx {
uint64_t i:1;
uint64_t back:4;
uint64_t pool:3;
uint64_t size:16;
uint64_t ptr:40;
} cn30xx;
struct cvmx_pko_mem_debug11_cn30xx cn31xx;
struct cvmx_pko_mem_debug11_cn30xx cn38xx;
struct cvmx_pko_mem_debug11_cn30xx cn38xxp2;
struct cvmx_pko_mem_debug11_cn50xx {
uint64_t reserved_23_63:41;
uint64_t maj:1;
uint64_t uid:3;
uint64_t sop:1;
uint64_t len:1;
uint64_t chk:1;
uint64_t cnt:13;
uint64_t mod:3;
} cn50xx;
struct cvmx_pko_mem_debug11_cn50xx cn52xx;
struct cvmx_pko_mem_debug11_cn50xx cn52xxp1;
struct cvmx_pko_mem_debug11_cn50xx cn56xx;
struct cvmx_pko_mem_debug11_cn50xx cn56xxp1;
struct cvmx_pko_mem_debug11_cn50xx cn58xx;
struct cvmx_pko_mem_debug11_cn50xx cn58xxp1;
};
union cvmx_pko_mem_debug12 {
uint64_t u64;
struct cvmx_pko_mem_debug12_s {
uint64_t reserved_0_63:64;
} s;
struct cvmx_pko_mem_debug12_cn30xx {
uint64_t data:64;
} cn30xx;
struct cvmx_pko_mem_debug12_cn30xx cn31xx;
struct cvmx_pko_mem_debug12_cn30xx cn38xx;
struct cvmx_pko_mem_debug12_cn30xx cn38xxp2;
struct cvmx_pko_mem_debug12_cn50xx {
uint64_t fau:28;
uint64_t cmd:14;
uint64_t segs:6;
uint64_t size:16;
} cn50xx;
struct cvmx_pko_mem_debug12_cn50xx cn52xx;
struct cvmx_pko_mem_debug12_cn50xx cn52xxp1;
struct cvmx_pko_mem_debug12_cn50xx cn56xx;
struct cvmx_pko_mem_debug12_cn50xx cn56xxp1;
struct cvmx_pko_mem_debug12_cn50xx cn58xx;
struct cvmx_pko_mem_debug12_cn50xx cn58xxp1;
};
union cvmx_pko_mem_debug13 {
uint64_t u64;
struct cvmx_pko_mem_debug13_s {
uint64_t i:1;
uint64_t back:4;
uint64_t pool:3;
uint64_t reserved_0_55:56;
} s;
struct cvmx_pko_mem_debug13_cn30xx {
uint64_t reserved_51_63:13;
uint64_t widx:17;
uint64_t ridx2:17;
uint64_t widx2:17;
} cn30xx;
struct cvmx_pko_mem_debug13_cn30xx cn31xx;
struct cvmx_pko_mem_debug13_cn30xx cn38xx;
struct cvmx_pko_mem_debug13_cn30xx cn38xxp2;
struct cvmx_pko_mem_debug13_cn50xx {
uint64_t i:1;
uint64_t back:4;
uint64_t pool:3;
uint64_t size:16;
uint64_t ptr:40;
} cn50xx;
struct cvmx_pko_mem_debug13_cn50xx cn52xx;
struct cvmx_pko_mem_debug13_cn50xx cn52xxp1;
struct cvmx_pko_mem_debug13_cn50xx cn56xx;
struct cvmx_pko_mem_debug13_cn50xx cn56xxp1;
struct cvmx_pko_mem_debug13_cn50xx cn58xx;
struct cvmx_pko_mem_debug13_cn50xx cn58xxp1;
};
union cvmx_pko_mem_debug14 {
uint64_t u64;
struct cvmx_pko_mem_debug14_s {
uint64_t reserved_0_63:64;
} s;
struct cvmx_pko_mem_debug14_cn30xx {
uint64_t reserved_17_63:47;
uint64_t ridx:17;
} cn30xx;
struct cvmx_pko_mem_debug14_cn30xx cn31xx;
struct cvmx_pko_mem_debug14_cn30xx cn38xx;
struct cvmx_pko_mem_debug14_cn30xx cn38xxp2;
struct cvmx_pko_mem_debug14_cn52xx {
uint64_t data:64;
} cn52xx;
struct cvmx_pko_mem_debug14_cn52xx cn52xxp1;
struct cvmx_pko_mem_debug14_cn52xx cn56xx;
struct cvmx_pko_mem_debug14_cn52xx cn56xxp1;
};
union cvmx_pko_mem_debug2 {
uint64_t u64;
struct cvmx_pko_mem_debug2_s {
uint64_t i:1;
uint64_t back:4;
uint64_t pool:3;
uint64_t size:16;
uint64_t ptr:40;
} s;
struct cvmx_pko_mem_debug2_s cn30xx;
struct cvmx_pko_mem_debug2_s cn31xx;
struct cvmx_pko_mem_debug2_s cn38xx;
struct cvmx_pko_mem_debug2_s cn38xxp2;
struct cvmx_pko_mem_debug2_s cn50xx;
struct cvmx_pko_mem_debug2_s cn52xx;
struct cvmx_pko_mem_debug2_s cn52xxp1;
struct cvmx_pko_mem_debug2_s cn56xx;
struct cvmx_pko_mem_debug2_s cn56xxp1;
struct cvmx_pko_mem_debug2_s cn58xx;
struct cvmx_pko_mem_debug2_s cn58xxp1;
};
union cvmx_pko_mem_debug3 {
uint64_t u64;
struct cvmx_pko_mem_debug3_s {
uint64_t reserved_0_63:64;
} s;
struct cvmx_pko_mem_debug3_cn30xx {
uint64_t i:1;
uint64_t back:4;
uint64_t pool:3;
uint64_t size:16;
uint64_t ptr:40;
} cn30xx;
struct cvmx_pko_mem_debug3_cn30xx cn31xx;
struct cvmx_pko_mem_debug3_cn30xx cn38xx;
struct cvmx_pko_mem_debug3_cn30xx cn38xxp2;
struct cvmx_pko_mem_debug3_cn50xx {
uint64_t data:64;
} cn50xx;
struct cvmx_pko_mem_debug3_cn50xx cn52xx;
struct cvmx_pko_mem_debug3_cn50xx cn52xxp1;
struct cvmx_pko_mem_debug3_cn50xx cn56xx;
struct cvmx_pko_mem_debug3_cn50xx cn56xxp1;
struct cvmx_pko_mem_debug3_cn50xx cn58xx;
struct cvmx_pko_mem_debug3_cn50xx cn58xxp1;
};
union cvmx_pko_mem_debug4 {
uint64_t u64;
struct cvmx_pko_mem_debug4_s {
uint64_t reserved_0_63:64;
} s;
struct cvmx_pko_mem_debug4_cn30xx {
uint64_t data:64;
} cn30xx;
struct cvmx_pko_mem_debug4_cn30xx cn31xx;
struct cvmx_pko_mem_debug4_cn30xx cn38xx;
struct cvmx_pko_mem_debug4_cn30xx cn38xxp2;
struct cvmx_pko_mem_debug4_cn50xx {
uint64_t cmnd_segs:3;
uint64_t cmnd_siz:16;
uint64_t cmnd_off:6;
uint64_t uid:3;
uint64_t dread_sop:1;
uint64_t init_dwrite:1;
uint64_t chk_once:1;
uint64_t chk_mode:1;
uint64_t active:1;
uint64_t static_p:1;
uint64_t qos:3;
uint64_t qcb_ridx:5;
uint64_t qid_off_max:4;
uint64_t qid_off:4;
uint64_t qid_base:8;
uint64_t wait:1;
uint64_t minor:2;
uint64_t major:3;
} cn50xx;
struct cvmx_pko_mem_debug4_cn52xx {
uint64_t curr_siz:8;
uint64_t curr_off:16;
uint64_t cmnd_segs:6;
uint64_t cmnd_siz:16;
uint64_t cmnd_off:6;
uint64_t uid:2;
uint64_t dread_sop:1;
uint64_t init_dwrite:1;
uint64_t chk_once:1;
uint64_t chk_mode:1;
uint64_t wait:1;
uint64_t minor:2;
uint64_t major:3;
} cn52xx;
struct cvmx_pko_mem_debug4_cn52xx cn52xxp1;
struct cvmx_pko_mem_debug4_cn52xx cn56xx;
struct cvmx_pko_mem_debug4_cn52xx cn56xxp1;
struct cvmx_pko_mem_debug4_cn50xx cn58xx;
struct cvmx_pko_mem_debug4_cn50xx cn58xxp1;
};
union cvmx_pko_mem_debug5 {
uint64_t u64;
struct cvmx_pko_mem_debug5_s {
uint64_t reserved_0_63:64;
} s;
struct cvmx_pko_mem_debug5_cn30xx {
uint64_t dwri_mod:1;
uint64_t dwri_sop:1;
uint64_t dwri_len:1;
uint64_t dwri_cnt:13;
uint64_t cmnd_siz:16;
uint64_t uid:1;
uint64_t xfer_wor:1;
uint64_t xfer_dwr:1;
uint64_t cbuf_fre:1;
uint64_t reserved_27_27:1;
uint64_t chk_mode:1;
uint64_t active:1;
uint64_t qos:3;
uint64_t qcb_ridx:5;
uint64_t qid_off:3;
uint64_t qid_base:7;
uint64_t wait:1;
uint64_t minor:2;
uint64_t major:4;
} cn30xx;
struct cvmx_pko_mem_debug5_cn30xx cn31xx;
struct cvmx_pko_mem_debug5_cn30xx cn38xx;
struct cvmx_pko_mem_debug5_cn30xx cn38xxp2;
struct cvmx_pko_mem_debug5_cn50xx {
uint64_t curr_ptr:29;
uint64_t curr_siz:16;
uint64_t curr_off:16;
uint64_t cmnd_segs:3;
} cn50xx;
struct cvmx_pko_mem_debug5_cn52xx {
uint64_t reserved_54_63:10;
uint64_t nxt_inflt:6;
uint64_t curr_ptr:40;
uint64_t curr_siz:8;
} cn52xx;
struct cvmx_pko_mem_debug5_cn52xx cn52xxp1;
struct cvmx_pko_mem_debug5_cn52xx cn56xx;
struct cvmx_pko_mem_debug5_cn52xx cn56xxp1;
struct cvmx_pko_mem_debug5_cn50xx cn58xx;
struct cvmx_pko_mem_debug5_cn50xx cn58xxp1;
};
union cvmx_pko_mem_debug6 {
uint64_t u64;
struct cvmx_pko_mem_debug6_s {
uint64_t reserved_37_63:27;
uint64_t qid_offres:4;
uint64_t qid_offths:4;
uint64_t preempter:1;
uint64_t preemptee:1;
uint64_t preempted:1;
uint64_t active:1;
uint64_t statc:1;
uint64_t qos:3;
uint64_t qcb_ridx:5;
uint64_t qid_offmax:4;
uint64_t reserved_0_11:12;
} s;
struct cvmx_pko_mem_debug6_cn30xx {
uint64_t reserved_11_63:53;
uint64_t qid_offm:3;
uint64_t static_p:1;
uint64_t work_min:3;
uint64_t dwri_chk:1;
uint64_t dwri_uid:1;
uint64_t dwri_mod:2;
} cn30xx;
struct cvmx_pko_mem_debug6_cn30xx cn31xx;
struct cvmx_pko_mem_debug6_cn30xx cn38xx;
struct cvmx_pko_mem_debug6_cn30xx cn38xxp2;
struct cvmx_pko_mem_debug6_cn50xx {
uint64_t reserved_11_63:53;
uint64_t curr_ptr:11;
} cn50xx;
struct cvmx_pko_mem_debug6_cn52xx {
uint64_t reserved_37_63:27;
uint64_t qid_offres:4;
uint64_t qid_offths:4;
uint64_t preempter:1;
uint64_t preemptee:1;
uint64_t preempted:1;
uint64_t active:1;
uint64_t statc:1;
uint64_t qos:3;
uint64_t qcb_ridx:5;
uint64_t qid_offmax:4;
uint64_t qid_off:4;
uint64_t qid_base:8;
} cn52xx;
struct cvmx_pko_mem_debug6_cn52xx cn52xxp1;
struct cvmx_pko_mem_debug6_cn52xx cn56xx;
struct cvmx_pko_mem_debug6_cn52xx cn56xxp1;
struct cvmx_pko_mem_debug6_cn50xx cn58xx;
struct cvmx_pko_mem_debug6_cn50xx cn58xxp1;
};
union cvmx_pko_mem_debug7 {
uint64_t u64;
struct cvmx_pko_mem_debug7_s {
uint64_t qos:5;
uint64_t tail:1;
uint64_t reserved_0_57:58;
} s;
struct cvmx_pko_mem_debug7_cn30xx {
uint64_t reserved_58_63:6;
uint64_t dwb:9;
uint64_t start:33;
uint64_t size:16;
} cn30xx;
struct cvmx_pko_mem_debug7_cn30xx cn31xx;
struct cvmx_pko_mem_debug7_cn30xx cn38xx;
struct cvmx_pko_mem_debug7_cn30xx cn38xxp2;
struct cvmx_pko_mem_debug7_cn50xx {
uint64_t qos:5;
uint64_t tail:1;
uint64_t buf_siz:13;
uint64_t buf_ptr:33;
uint64_t qcb_widx:6;
uint64_t qcb_ridx:6;
} cn50xx;
struct cvmx_pko_mem_debug7_cn50xx cn52xx;
struct cvmx_pko_mem_debug7_cn50xx cn52xxp1;
struct cvmx_pko_mem_debug7_cn50xx cn56xx;
struct cvmx_pko_mem_debug7_cn50xx cn56xxp1;
struct cvmx_pko_mem_debug7_cn50xx cn58xx;
struct cvmx_pko_mem_debug7_cn50xx cn58xxp1;
};
union cvmx_pko_mem_debug8 {
uint64_t u64;
struct cvmx_pko_mem_debug8_s {
uint64_t reserved_59_63:5;
uint64_t tail:1;
uint64_t buf_siz:13;
uint64_t reserved_0_44:45;
} s;
struct cvmx_pko_mem_debug8_cn30xx {
uint64_t qos:5;
uint64_t tail:1;
uint64_t buf_siz:13;
uint64_t buf_ptr:33;
uint64_t qcb_widx:6;
uint64_t qcb_ridx:6;
} cn30xx;
struct cvmx_pko_mem_debug8_cn30xx cn31xx;
struct cvmx_pko_mem_debug8_cn30xx cn38xx;
struct cvmx_pko_mem_debug8_cn30xx cn38xxp2;
struct cvmx_pko_mem_debug8_cn50xx {
uint64_t reserved_28_63:36;
uint64_t doorbell:20;
uint64_t reserved_6_7:2;
uint64_t static_p:1;
uint64_t s_tail:1;
uint64_t static_q:1;
uint64_t qos:3;
} cn50xx;
struct cvmx_pko_mem_debug8_cn52xx {
uint64_t reserved_29_63:35;
uint64_t preempter:1;
uint64_t doorbell:20;
uint64_t reserved_7_7:1;
uint64_t preemptee:1;
uint64_t static_p:1;
uint64_t s_tail:1;
uint64_t static_q:1;
uint64_t qos:3;
} cn52xx;
struct cvmx_pko_mem_debug8_cn52xx cn52xxp1;
struct cvmx_pko_mem_debug8_cn52xx cn56xx;
struct cvmx_pko_mem_debug8_cn52xx cn56xxp1;
struct cvmx_pko_mem_debug8_cn50xx cn58xx;
struct cvmx_pko_mem_debug8_cn50xx cn58xxp1;
};
union cvmx_pko_mem_debug9 {
uint64_t u64;
struct cvmx_pko_mem_debug9_s {
uint64_t reserved_49_63:15;
uint64_t ptrs0:17;
uint64_t reserved_0_31:32;
} s;
struct cvmx_pko_mem_debug9_cn30xx {
uint64_t reserved_28_63:36;
uint64_t doorbell:20;
uint64_t reserved_5_7:3;
uint64_t s_tail:1;
uint64_t static_q:1;
uint64_t qos:3;
} cn30xx;
struct cvmx_pko_mem_debug9_cn30xx cn31xx;
struct cvmx_pko_mem_debug9_cn38xx {
uint64_t reserved_28_63:36;
uint64_t doorbell:20;
uint64_t reserved_6_7:2;
uint64_t static_p:1;
uint64_t s_tail:1;
uint64_t static_q:1;
uint64_t qos:3;
} cn38xx;
struct cvmx_pko_mem_debug9_cn38xx cn38xxp2;
struct cvmx_pko_mem_debug9_cn50xx {
uint64_t reserved_49_63:15;
uint64_t ptrs0:17;
uint64_t reserved_17_31:15;
uint64_t ptrs3:17;
} cn50xx;
struct cvmx_pko_mem_debug9_cn50xx cn52xx;
struct cvmx_pko_mem_debug9_cn50xx cn52xxp1;
struct cvmx_pko_mem_debug9_cn50xx cn56xx;
struct cvmx_pko_mem_debug9_cn50xx cn56xxp1;
struct cvmx_pko_mem_debug9_cn50xx cn58xx;
struct cvmx_pko_mem_debug9_cn50xx cn58xxp1;
};
union cvmx_pko_mem_port_ptrs {
uint64_t u64;
struct cvmx_pko_mem_port_ptrs_s {
uint64_t reserved_62_63:2;
uint64_t static_p:1;
uint64_t qos_mask:8;
uint64_t reserved_16_52:37;
uint64_t bp_port:6;
uint64_t eid:4;
uint64_t pid:6;
} s;
struct cvmx_pko_mem_port_ptrs_s cn52xx;
struct cvmx_pko_mem_port_ptrs_s cn52xxp1;
struct cvmx_pko_mem_port_ptrs_s cn56xx;
struct cvmx_pko_mem_port_ptrs_s cn56xxp1;
};
union cvmx_pko_mem_port_qos {
uint64_t u64;
struct cvmx_pko_mem_port_qos_s {
uint64_t reserved_61_63:3;
uint64_t qos_mask:8;
uint64_t reserved_10_52:43;
uint64_t eid:4;
uint64_t pid:6;
} s;
struct cvmx_pko_mem_port_qos_s cn52xx;
struct cvmx_pko_mem_port_qos_s cn52xxp1;
struct cvmx_pko_mem_port_qos_s cn56xx;
struct cvmx_pko_mem_port_qos_s cn56xxp1;
};
union cvmx_pko_mem_port_rate0 {
uint64_t u64;
struct cvmx_pko_mem_port_rate0_s {
uint64_t reserved_51_63:13;
uint64_t rate_word:19;
uint64_t rate_pkt:24;
uint64_t reserved_6_7:2;
uint64_t pid:6;
} s;
struct cvmx_pko_mem_port_rate0_s cn52xx;
struct cvmx_pko_mem_port_rate0_s cn52xxp1;
struct cvmx_pko_mem_port_rate0_s cn56xx;
struct cvmx_pko_mem_port_rate0_s cn56xxp1;
};
union cvmx_pko_mem_port_rate1 {
uint64_t u64;
struct cvmx_pko_mem_port_rate1_s {
uint64_t reserved_32_63:32;
uint64_t rate_lim:24;
uint64_t reserved_6_7:2;
uint64_t pid:6;
} s;
struct cvmx_pko_mem_port_rate1_s cn52xx;
struct cvmx_pko_mem_port_rate1_s cn52xxp1;
struct cvmx_pko_mem_port_rate1_s cn56xx;
struct cvmx_pko_mem_port_rate1_s cn56xxp1;
};
union cvmx_pko_mem_queue_ptrs {
uint64_t u64;
struct cvmx_pko_mem_queue_ptrs_s {
uint64_t s_tail:1;
uint64_t static_p:1;
uint64_t static_q:1;
uint64_t qos_mask:8;
uint64_t buf_ptr:36;
uint64_t tail:1;
uint64_t index:3;
uint64_t port:6;
uint64_t queue:7;
} s;
struct cvmx_pko_mem_queue_ptrs_s cn30xx;
struct cvmx_pko_mem_queue_ptrs_s cn31xx;
struct cvmx_pko_mem_queue_ptrs_s cn38xx;
struct cvmx_pko_mem_queue_ptrs_s cn38xxp2;
struct cvmx_pko_mem_queue_ptrs_s cn50xx;
struct cvmx_pko_mem_queue_ptrs_s cn52xx;
struct cvmx_pko_mem_queue_ptrs_s cn52xxp1;
struct cvmx_pko_mem_queue_ptrs_s cn56xx;
struct cvmx_pko_mem_queue_ptrs_s cn56xxp1;
struct cvmx_pko_mem_queue_ptrs_s cn58xx;
struct cvmx_pko_mem_queue_ptrs_s cn58xxp1;
};
union cvmx_pko_mem_queue_qos {
uint64_t u64;
struct cvmx_pko_mem_queue_qos_s {
uint64_t reserved_61_63:3;
uint64_t qos_mask:8;
uint64_t reserved_13_52:40;
uint64_t pid:6;
uint64_t qid:7;
} s;
struct cvmx_pko_mem_queue_qos_s cn30xx;
struct cvmx_pko_mem_queue_qos_s cn31xx;
struct cvmx_pko_mem_queue_qos_s cn38xx;
struct cvmx_pko_mem_queue_qos_s cn38xxp2;
struct cvmx_pko_mem_queue_qos_s cn50xx;
struct cvmx_pko_mem_queue_qos_s cn52xx;
struct cvmx_pko_mem_queue_qos_s cn52xxp1;
struct cvmx_pko_mem_queue_qos_s cn56xx;
struct cvmx_pko_mem_queue_qos_s cn56xxp1;
struct cvmx_pko_mem_queue_qos_s cn58xx;
struct cvmx_pko_mem_queue_qos_s cn58xxp1;
};
union cvmx_pko_reg_bist_result {
uint64_t u64;
struct cvmx_pko_reg_bist_result_s {
uint64_t reserved_0_63:64;
} s;
struct cvmx_pko_reg_bist_result_cn30xx {
uint64_t reserved_27_63:37;
uint64_t psb2:5;
uint64_t count:1;
uint64_t rif:1;
uint64_t wif:1;
uint64_t ncb:1;
uint64_t out:1;
uint64_t crc:1;
uint64_t chk:1;
uint64_t qsb:2;
uint64_t qcb:2;
uint64_t pdb:4;
uint64_t psb:7;
} cn30xx;
struct cvmx_pko_reg_bist_result_cn30xx cn31xx;
struct cvmx_pko_reg_bist_result_cn30xx cn38xx;
struct cvmx_pko_reg_bist_result_cn30xx cn38xxp2;
struct cvmx_pko_reg_bist_result_cn50xx {
uint64_t reserved_33_63:31;
uint64_t csr:1;
uint64_t iob:1;
uint64_t out_crc:1;
uint64_t out_ctl:3;
uint64_t out_sta:1;
uint64_t out_wif:1;
uint64_t prt_chk:3;
uint64_t prt_nxt:1;
uint64_t prt_psb:6;
uint64_t ncb_inb:2;
uint64_t prt_qcb:2;
uint64_t prt_qsb:3;
uint64_t dat_dat:4;
uint64_t dat_ptr:4;
} cn50xx;
struct cvmx_pko_reg_bist_result_cn52xx {
uint64_t reserved_35_63:29;
uint64_t csr:1;
uint64_t iob:1;
uint64_t out_dat:1;
uint64_t out_ctl:3;
uint64_t out_sta:1;
uint64_t out_wif:1;
uint64_t prt_chk:3;
uint64_t prt_nxt:1;
uint64_t prt_psb:8;
uint64_t ncb_inb:2;
uint64_t prt_qcb:2;
uint64_t prt_qsb:3;
uint64_t prt_ctl:2;
uint64_t dat_dat:2;
uint64_t dat_ptr:4;
} cn52xx;
struct cvmx_pko_reg_bist_result_cn52xx cn52xxp1;
struct cvmx_pko_reg_bist_result_cn52xx cn56xx;
struct cvmx_pko_reg_bist_result_cn52xx cn56xxp1;
struct cvmx_pko_reg_bist_result_cn50xx cn58xx;
struct cvmx_pko_reg_bist_result_cn50xx cn58xxp1;
};
union cvmx_pko_reg_cmd_buf {
uint64_t u64;
struct cvmx_pko_reg_cmd_buf_s {
uint64_t reserved_23_63:41;
uint64_t pool:3;
uint64_t reserved_13_19:7;
uint64_t size:13;
} s;
struct cvmx_pko_reg_cmd_buf_s cn30xx;
struct cvmx_pko_reg_cmd_buf_s cn31xx;
struct cvmx_pko_reg_cmd_buf_s cn38xx;
struct cvmx_pko_reg_cmd_buf_s cn38xxp2;
struct cvmx_pko_reg_cmd_buf_s cn50xx;
struct cvmx_pko_reg_cmd_buf_s cn52xx;
struct cvmx_pko_reg_cmd_buf_s cn52xxp1;
struct cvmx_pko_reg_cmd_buf_s cn56xx;
struct cvmx_pko_reg_cmd_buf_s cn56xxp1;
struct cvmx_pko_reg_cmd_buf_s cn58xx;
struct cvmx_pko_reg_cmd_buf_s cn58xxp1;
};
union cvmx_pko_reg_crc_ctlx {
uint64_t u64;
struct cvmx_pko_reg_crc_ctlx_s {
uint64_t reserved_2_63:62;
uint64_t invres:1;
uint64_t refin:1;
} s;
struct cvmx_pko_reg_crc_ctlx_s cn38xx;
struct cvmx_pko_reg_crc_ctlx_s cn38xxp2;
struct cvmx_pko_reg_crc_ctlx_s cn58xx;
struct cvmx_pko_reg_crc_ctlx_s cn58xxp1;
};
union cvmx_pko_reg_crc_enable {
uint64_t u64;
struct cvmx_pko_reg_crc_enable_s {
uint64_t reserved_32_63:32;
uint64_t enable:32;
} s;
struct cvmx_pko_reg_crc_enable_s cn38xx;
struct cvmx_pko_reg_crc_enable_s cn38xxp2;
struct cvmx_pko_reg_crc_enable_s cn58xx;
struct cvmx_pko_reg_crc_enable_s cn58xxp1;
};
union cvmx_pko_reg_crc_ivx {
uint64_t u64;
struct cvmx_pko_reg_crc_ivx_s {
uint64_t reserved_32_63:32;
uint64_t iv:32;
} s;
struct cvmx_pko_reg_crc_ivx_s cn38xx;
struct cvmx_pko_reg_crc_ivx_s cn38xxp2;
struct cvmx_pko_reg_crc_ivx_s cn58xx;
struct cvmx_pko_reg_crc_ivx_s cn58xxp1;
};
union cvmx_pko_reg_debug0 {
uint64_t u64;
struct cvmx_pko_reg_debug0_s {
uint64_t asserts:64;
} s;
struct cvmx_pko_reg_debug0_cn30xx {
uint64_t reserved_17_63:47;
uint64_t asserts:17;
} cn30xx;
struct cvmx_pko_reg_debug0_cn30xx cn31xx;
struct cvmx_pko_reg_debug0_cn30xx cn38xx;
struct cvmx_pko_reg_debug0_cn30xx cn38xxp2;
struct cvmx_pko_reg_debug0_s cn50xx;
struct cvmx_pko_reg_debug0_s cn52xx;
struct cvmx_pko_reg_debug0_s cn52xxp1;
struct cvmx_pko_reg_debug0_s cn56xx;
struct cvmx_pko_reg_debug0_s cn56xxp1;
struct cvmx_pko_reg_debug0_s cn58xx;
struct cvmx_pko_reg_debug0_s cn58xxp1;
};
union cvmx_pko_reg_debug1 {
uint64_t u64;
struct cvmx_pko_reg_debug1_s {
uint64_t asserts:64;
} s;
struct cvmx_pko_reg_debug1_s cn50xx;
struct cvmx_pko_reg_debug1_s cn52xx;
struct cvmx_pko_reg_debug1_s cn52xxp1;
struct cvmx_pko_reg_debug1_s cn56xx;
struct cvmx_pko_reg_debug1_s cn56xxp1;
struct cvmx_pko_reg_debug1_s cn58xx;
struct cvmx_pko_reg_debug1_s cn58xxp1;
};
union cvmx_pko_reg_debug2 {
uint64_t u64;
struct cvmx_pko_reg_debug2_s {
uint64_t asserts:64;
} s;
struct cvmx_pko_reg_debug2_s cn50xx;
struct cvmx_pko_reg_debug2_s cn52xx;
struct cvmx_pko_reg_debug2_s cn52xxp1;
struct cvmx_pko_reg_debug2_s cn56xx;
struct cvmx_pko_reg_debug2_s cn56xxp1;
struct cvmx_pko_reg_debug2_s cn58xx;
struct cvmx_pko_reg_debug2_s cn58xxp1;
};
union cvmx_pko_reg_debug3 {
uint64_t u64;
struct cvmx_pko_reg_debug3_s {
uint64_t asserts:64;
} s;
struct cvmx_pko_reg_debug3_s cn50xx;
struct cvmx_pko_reg_debug3_s cn52xx;
struct cvmx_pko_reg_debug3_s cn52xxp1;
struct cvmx_pko_reg_debug3_s cn56xx;
struct cvmx_pko_reg_debug3_s cn56xxp1;
struct cvmx_pko_reg_debug3_s cn58xx;
struct cvmx_pko_reg_debug3_s cn58xxp1;
};
union cvmx_pko_reg_engine_inflight {
uint64_t u64;
struct cvmx_pko_reg_engine_inflight_s {
uint64_t reserved_40_63:24;
uint64_t engine9:4;
uint64_t engine8:4;
uint64_t engine7:4;
uint64_t engine6:4;
uint64_t engine5:4;
uint64_t engine4:4;
uint64_t engine3:4;
uint64_t engine2:4;
uint64_t engine1:4;
uint64_t engine0:4;
} s;
struct cvmx_pko_reg_engine_inflight_s cn52xx;
struct cvmx_pko_reg_engine_inflight_s cn52xxp1;
struct cvmx_pko_reg_engine_inflight_s cn56xx;
struct cvmx_pko_reg_engine_inflight_s cn56xxp1;
};
union cvmx_pko_reg_engine_thresh {
uint64_t u64;
struct cvmx_pko_reg_engine_thresh_s {
uint64_t reserved_10_63:54;
uint64_t mask:10;
} s;
struct cvmx_pko_reg_engine_thresh_s cn52xx;
struct cvmx_pko_reg_engine_thresh_s cn52xxp1;
struct cvmx_pko_reg_engine_thresh_s cn56xx;
struct cvmx_pko_reg_engine_thresh_s cn56xxp1;
};
union cvmx_pko_reg_error {
uint64_t u64;
struct cvmx_pko_reg_error_s {
uint64_t reserved_3_63:61;
uint64_t currzero:1;
uint64_t doorbell:1;
uint64_t parity:1;
} s;
struct cvmx_pko_reg_error_cn30xx {
uint64_t reserved_2_63:62;
uint64_t doorbell:1;
uint64_t parity:1;
} cn30xx;
struct cvmx_pko_reg_error_cn30xx cn31xx;
struct cvmx_pko_reg_error_cn30xx cn38xx;
struct cvmx_pko_reg_error_cn30xx cn38xxp2;
struct cvmx_pko_reg_error_s cn50xx;
struct cvmx_pko_reg_error_s cn52xx;
struct cvmx_pko_reg_error_s cn52xxp1;
struct cvmx_pko_reg_error_s cn56xx;
struct cvmx_pko_reg_error_s cn56xxp1;
struct cvmx_pko_reg_error_s cn58xx;
struct cvmx_pko_reg_error_s cn58xxp1;
};
union cvmx_pko_reg_flags {
uint64_t u64;
struct cvmx_pko_reg_flags_s {
uint64_t reserved_4_63:60;
uint64_t reset:1;
uint64_t store_be:1;
uint64_t ena_dwb:1;
uint64_t ena_pko:1;
} s;
struct cvmx_pko_reg_flags_s cn30xx;
struct cvmx_pko_reg_flags_s cn31xx;
struct cvmx_pko_reg_flags_s cn38xx;
struct cvmx_pko_reg_flags_s cn38xxp2;
struct cvmx_pko_reg_flags_s cn50xx;
struct cvmx_pko_reg_flags_s cn52xx;
struct cvmx_pko_reg_flags_s cn52xxp1;
struct cvmx_pko_reg_flags_s cn56xx;
struct cvmx_pko_reg_flags_s cn56xxp1;
struct cvmx_pko_reg_flags_s cn58xx;
struct cvmx_pko_reg_flags_s cn58xxp1;
};
union cvmx_pko_reg_gmx_port_mode {
uint64_t u64;
struct cvmx_pko_reg_gmx_port_mode_s {
uint64_t reserved_6_63:58;
uint64_t mode1:3;
uint64_t mode0:3;
} s;
struct cvmx_pko_reg_gmx_port_mode_s cn30xx;
struct cvmx_pko_reg_gmx_port_mode_s cn31xx;
struct cvmx_pko_reg_gmx_port_mode_s cn38xx;
struct cvmx_pko_reg_gmx_port_mode_s cn38xxp2;
struct cvmx_pko_reg_gmx_port_mode_s cn50xx;
struct cvmx_pko_reg_gmx_port_mode_s cn52xx;
struct cvmx_pko_reg_gmx_port_mode_s cn52xxp1;
struct cvmx_pko_reg_gmx_port_mode_s cn56xx;
struct cvmx_pko_reg_gmx_port_mode_s cn56xxp1;
struct cvmx_pko_reg_gmx_port_mode_s cn58xx;
struct cvmx_pko_reg_gmx_port_mode_s cn58xxp1;
};
union cvmx_pko_reg_int_mask {
uint64_t u64;
struct cvmx_pko_reg_int_mask_s {
uint64_t reserved_3_63:61;
uint64_t currzero:1;
uint64_t doorbell:1;
uint64_t parity:1;
} s;
struct cvmx_pko_reg_int_mask_cn30xx {
uint64_t reserved_2_63:62;
uint64_t doorbell:1;
uint64_t parity:1;
} cn30xx;
struct cvmx_pko_reg_int_mask_cn30xx cn31xx;
struct cvmx_pko_reg_int_mask_cn30xx cn38xx;
struct cvmx_pko_reg_int_mask_cn30xx cn38xxp2;
struct cvmx_pko_reg_int_mask_s cn50xx;
struct cvmx_pko_reg_int_mask_s cn52xx;
struct cvmx_pko_reg_int_mask_s cn52xxp1;
struct cvmx_pko_reg_int_mask_s cn56xx;
struct cvmx_pko_reg_int_mask_s cn56xxp1;
struct cvmx_pko_reg_int_mask_s cn58xx;
struct cvmx_pko_reg_int_mask_s cn58xxp1;
};
union cvmx_pko_reg_queue_mode {
uint64_t u64;
struct cvmx_pko_reg_queue_mode_s {
uint64_t reserved_2_63:62;
uint64_t mode:2;
} s;
struct cvmx_pko_reg_queue_mode_s cn30xx;
struct cvmx_pko_reg_queue_mode_s cn31xx;
struct cvmx_pko_reg_queue_mode_s cn38xx;
struct cvmx_pko_reg_queue_mode_s cn38xxp2;
struct cvmx_pko_reg_queue_mode_s cn50xx;
struct cvmx_pko_reg_queue_mode_s cn52xx;
struct cvmx_pko_reg_queue_mode_s cn52xxp1;
struct cvmx_pko_reg_queue_mode_s cn56xx;
struct cvmx_pko_reg_queue_mode_s cn56xxp1;
struct cvmx_pko_reg_queue_mode_s cn58xx;
struct cvmx_pko_reg_queue_mode_s cn58xxp1;
};
union cvmx_pko_reg_queue_ptrs1 {
uint64_t u64;
struct cvmx_pko_reg_queue_ptrs1_s {
uint64_t reserved_2_63:62;
uint64_t idx3:1;
uint64_t qid7:1;
} s;
struct cvmx_pko_reg_queue_ptrs1_s cn50xx;
struct cvmx_pko_reg_queue_ptrs1_s cn52xx;
struct cvmx_pko_reg_queue_ptrs1_s cn52xxp1;
struct cvmx_pko_reg_queue_ptrs1_s cn56xx;
struct cvmx_pko_reg_queue_ptrs1_s cn56xxp1;
struct cvmx_pko_reg_queue_ptrs1_s cn58xx;
struct cvmx_pko_reg_queue_ptrs1_s cn58xxp1;
};
union cvmx_pko_reg_read_idx {
uint64_t u64;
struct cvmx_pko_reg_read_idx_s {
uint64_t reserved_16_63:48;
uint64_t inc:8;
uint64_t index:8;
} s;
struct cvmx_pko_reg_read_idx_s cn30xx;
struct cvmx_pko_reg_read_idx_s cn31xx;
struct cvmx_pko_reg_read_idx_s cn38xx;
struct cvmx_pko_reg_read_idx_s cn38xxp2;
struct cvmx_pko_reg_read_idx_s cn50xx;
struct cvmx_pko_reg_read_idx_s cn52xx;
struct cvmx_pko_reg_read_idx_s cn52xxp1;
struct cvmx_pko_reg_read_idx_s cn56xx;
struct cvmx_pko_reg_read_idx_s cn56xxp1;
struct cvmx_pko_reg_read_idx_s cn58xx;
struct cvmx_pko_reg_read_idx_s cn58xxp1;
};
#endif