// SPDX-License-Identifier: GPL-2.0
/*
* Copyright (c) 2021-2025, NVIDIA CORPORATION. All rights reserved
*
* The driver handles Error's from Control Backbone(CBB) generated due to
* illegal accesses. When an error is reported from a NOC within CBB,
* the driver checks ErrVld status of all three Error Logger's of that NOC.
* It then prints debug information about failed transaction using ErrLog
* registers of error logger which has ErrVld set. Currently, SLV, DEC,
* TMO, SEC, UNS are the codes which are supported by CBB.
*/
#include <linux/clk.h>
#include <linux/cpufeature.h>
#include <linux/debugfs.h>
#include <linux/module.h>
#include <linux/of.h>
#include <linux/of_address.h>
#include <linux/platform_device.h>
#include <linux/device.h>
#include <linux/io.h>
#include <linux/interrupt.h>
#include <linux/ioport.h>
#include <soc/tegra/fuse.h>
#include <soc/tegra/tegra-cbb.h>
#define ERRLOGGER_0_ID_COREID_0 0x00000000
#define ERRLOGGER_0_ID_REVISIONID_0 0x00000004
#define ERRLOGGER_0_FAULTEN_0 0x00000008
#define ERRLOGGER_0_ERRVLD_0 0x0000000c
#define ERRLOGGER_0_ERRCLR_0 0x00000010
#define ERRLOGGER_0_ERRLOG0_0 0x00000014
#define ERRLOGGER_0_ERRLOG1_0 0x00000018
#define ERRLOGGER_0_RSVD_00_0 0x0000001c
#define ERRLOGGER_0_ERRLOG3_0 0x00000020
#define ERRLOGGER_0_ERRLOG4_0 0x00000024
#define ERRLOGGER_0_ERRLOG5_0 0x00000028
#define ERRLOGGER_0_STALLEN_0 0x00000038
#define ERRLOGGER_1_ID_COREID_0 0x00000080
#define ERRLOGGER_1_ID_REVISIONID_0 0x00000084
#define ERRLOGGER_1_FAULTEN_0 0x00000088
#define ERRLOGGER_1_ERRVLD_0 0x0000008c
#define ERRLOGGER_1_ERRCLR_0 0x00000090
#define ERRLOGGER_1_ERRLOG0_0 0x00000094
#define ERRLOGGER_1_ERRLOG1_0 0x00000098
#define ERRLOGGER_1_RSVD_00_0 0x0000009c
#define ERRLOGGER_1_ERRLOG3_0 0x000000a0
#define ERRLOGGER_1_ERRLOG4_0 0x000000a4
#define ERRLOGGER_1_ERRLOG5_0 0x000000a8
#define ERRLOGGER_1_STALLEN_0 0x000000b8
#define ERRLOGGER_2_ID_COREID_0 0x00000100
#define ERRLOGGER_2_ID_REVISIONID_0 0x00000104
#define ERRLOGGER_2_FAULTEN_0 0x00000108
#define ERRLOGGER_2_ERRVLD_0 0x0000010c
#define ERRLOGGER_2_ERRCLR_0 0x00000110
#define ERRLOGGER_2_ERRLOG0_0 0x00000114
#define ERRLOGGER_2_ERRLOG1_0 0x00000118
#define ERRLOGGER_2_RSVD_00_0 0x0000011c
#define ERRLOGGER_2_ERRLOG3_0 0x00000120
#define ERRLOGGER_2_ERRLOG4_0 0x00000124
#define ERRLOGGER_2_ERRLOG5_0 0x00000128
#define ERRLOGGER_2_STALLEN_0 0x00000138
#define CBB_NOC_INITFLOW GENMASK(23, 20)
#define CBB_NOC_TARGFLOW GENMASK(19, 16)
#define CBB_NOC_TARG_SUBRANGE GENMASK(15, 9)
#define CBB_NOC_SEQID GENMASK(8, 0)
#define BPMP_NOC_INITFLOW GENMASK(20, 18)
#define BPMP_NOC_TARGFLOW GENMASK(17, 13)
#define BPMP_NOC_TARG_SUBRANGE GENMASK(12, 9)
#define BPMP_NOC_SEQID GENMASK(8, 0)
#define AON_NOC_INITFLOW GENMASK(22, 21)
#define AON_NOC_TARGFLOW GENMASK(20, 15)
#define AON_NOC_TARG_SUBRANGE GENMASK(14, 9)
#define AON_NOC_SEQID GENMASK(8, 0)
#define SCE_NOC_INITFLOW GENMASK(21, 19)
#define SCE_NOC_TARGFLOW GENMASK(18, 14)
#define SCE_NOC_TARG_SUBRANGE GENMASK(13, 9)
#define SCE_NOC_SEQID GENMASK(8, 0)
#define CBB_NOC_AXCACHE GENMASK(3, 0)
#define CBB_NOC_NON_MOD GENMASK(4, 4)
#define CBB_NOC_AXPROT GENMASK(7, 5)
#define CBB_NOC_FALCONSEC GENMASK(9, 8)
#define CBB_NOC_GRPSEC GENMASK(16, 10)
#define CBB_NOC_VQC GENMASK(18, 17)
#define CBB_NOC_MSTR_ID GENMASK(22, 19)
#define CBB_NOC_AXI_ID GENMASK(30, 23)
#define CLUSTER_NOC_AXCACHE GENMASK(3, 0)
#define CLUSTER_NOC_AXPROT GENMASK(6, 4)
#define CLUSTER_NOC_FALCONSEC GENMASK(8, 7)
#define CLUSTER_NOC_GRPSEC GENMASK(15, 9)
#define CLUSTER_NOC_VQC GENMASK(17, 16)
#define CLUSTER_NOC_MSTR_ID GENMASK(21, 18)
#define CBB_ERR_OPC GENMASK(4, 1)
#define CBB_ERR_ERRCODE GENMASK(10, 8)
#define CBB_ERR_LEN1 GENMASK(27, 16)
#define DMAAPB_X_RAW_INTERRUPT_STATUS 0x2ec
struct tegra194_cbb_packet_header {
bool lock; // [0]
u8 opc; // [4:1]
u8 errcode; // [10:8]= RD, RDW, RDL, RDX, WR, WRW, WRC, PRE, URG
u16 len1; // [27:16]
bool format; // [31] = 1 -> FlexNoC versions 2.7 & above
};
struct tegra194_cbb_aperture {
u8 initflow;
u8 targflow;
u8 targ_subrange;
u8 init_mapping;
u32 init_localaddress;
u8 targ_mapping;
u32 targ_localaddress;
u16 seqid;
};
struct tegra194_cbb_userbits {
u8 axcache;
u8 non_mod;
u8 axprot;
u8 falconsec;
u8 grpsec;
u8 vqc;
u8 mstr_id;
u8 axi_id;
};
struct tegra194_cbb_noc_data {
const char *name;
bool erd_mask_inband_err;
const char * const *initiator_id;
unsigned int max_aperture;
const struct tegra194_cbb_aperture *noc_aperture;
const char * const *routeid_initflow;
const char * const *routeid_targflow;
void (*parse_routeid)(struct tegra194_cbb_aperture *info, u64 routeid);
void (*parse_userbits)(struct tegra194_cbb_userbits *usrbits, u32 elog_5);
};
struct tegra194_axi2apb_bridge {
struct resource res;
void __iomem *base;
};
struct tegra194_cbb {
struct tegra_cbb base;
const struct tegra194_cbb_noc_data *noc;
struct resource *res;
void __iomem *regs;
unsigned int num_intr;
unsigned int sec_irq;
unsigned int nonsec_irq;
u32 errlog0;
u32 errlog1;
u32 errlog2;
u32 errlog3;
u32 errlog4;
u32 errlog5;
struct tegra194_axi2apb_bridge *bridges;
unsigned int num_bridges;
};
static inline struct tegra194_cbb *to_tegra194_cbb(struct tegra_cbb *cbb)
{
return container_of(cbb, struct tegra194_cbb, base);
}
static LIST_HEAD(cbb_list);
static DEFINE_SPINLOCK(cbb_lock);
static const char * const tegra194_cbb_trantype[] = {
"RD - Read, Incrementing" ,
"RDW - Read, Wrap" , /* Not Supported */
"RDX - Exclusive Read" , /* Not Supported */
"RDL - Linked Read" , /* Not Supported */
"WR - Write, Incrementing" ,
"WRW - Write, Wrap" , /* Not Supported */
"WRC - Exclusive Write" , /* Not Supported */
"PRE - Preamble Sequence for Fixed Accesses"
};
static const char * const tegra194_axi2apb_error[] = {
"SFIFONE - Status FIFO Not Empty interrupt" ,
"SFIFOF - Status FIFO Full interrupt" ,
"TIM - Timer(Timeout) interrupt" ,
"SLV - SLVERR interrupt" ,
"NULL" ,
"ERBF - Early response buffer Full interrupt" ,
"NULL" ,
"RDFIFOF - Read Response FIFO Full interrupt" ,
"WRFIFOF - Write Response FIFO Full interrupt" ,
"CH0DFIFOF - Ch0 Data FIFO Full interrupt" ,
"CH1DFIFOF - Ch1 Data FIFO Full interrupt" ,
"CH2DFIFOF - Ch2 Data FIFO Full interrupt" ,
"UAT - Unsupported alignment type error" ,
"UBS - Unsupported burst size error" ,
"UBE - Unsupported Byte Enable error" ,
"UBT - Unsupported burst type error" ,
"BFS - Block Firewall security error" ,
"ARFS - Address Range Firewall security error" ,
"CH0RFIFOF - Ch0 Request FIFO Full interrupt" ,
"CH1RFIFOF - Ch1 Request FIFO Full interrupt" ,
"CH2RFIFOF - Ch2 Request FIFO Full interrupt"
};
static const char * const tegra194_initiator_id[] = {
[0x0] = "CCPLEX" ,
[0x1] = "CCPLEX_DPMU" ,
[0x2] = "BPMP" ,
[0x3] = "AON" ,
[0x4] = "SCE" ,
[0x5] = "GPCDMA_PERIPHERAL" ,
[0x6] = "TSECA" ,
[0x7] = "TSECB" ,
[0x8] = "JTAGM_DFT" ,
[0x9] = "CORESIGHT_AXIAP" ,
[0xa] = "APE" ,
[0xb] = "PEATR" ,
[0xc] = "NVDEC" ,
[0xd] = "RCE" ,
[0xe] = "NVDEC1"
};
static const struct tegra_cbb_error tegra194_cbb_errors[] = {
{
.code = "SLV" ,
.source = "Target" ,
.desc = "Target error detected by CBB target"
}, {
.code = "DEC" ,
.source = "Initiator NIU" ,
.desc = "Address decode error"
}, {
.code = "UNS" ,
.source = "Target NIU" ,
.desc = "Unsupported request. Not a valid transaction"
}, {
.code = "DISC" , /* Not Supported by CBB */
.source = "Power Disconnect" ,
.desc = "Disconnected target or domain"
}, {
.code = "SEC" ,
.source = "Initiator NIU or Firewall" ,
.desc = "Security violation. Firewall error"
}, {
.code = "HIDE" , /* Not Supported by CBB */
.source = "Firewall" ,
.desc = "Hidden security violation, reported as OK to initiator"
}, {
.code = "TMO" ,
.source = "Target NIU" ,
.desc = "Target time-out error"
}, {
.code = "RSV" ,
.source = "None" ,
.desc = "Reserved"
}
};
/*
* CBB NOC aperture lookup table as per file "cbb_central_noc_Structure.info".
*/
static const char * const tegra194_cbbcentralnoc_routeid_initflow[] = {
[0x0] = "aon_p2ps/I/aon" ,
[0x1] = "ape_p2ps/I/ape_p2ps" ,
[0x2] = "bpmp_p2ps/I/bpmp_p2ps" ,
[0x3] = "ccroc_p2ps/I/ccroc_p2ps" ,
[0x4] = "csite_p2ps/I/0" ,
[0x5] = "gpcdma_mmio_p2ps/I/0" ,
[0x6] = "jtag_p2ps/I/0" ,
[0x7] = "nvdec1_p2ps/I/0" ,
[0x8] = "nvdec_p2ps/I/0" ,
[0x9] = "rce_p2ps/I/rce_p2ps" ,
[0xa] = "sce_p2ps/I/sce_p2ps" ,
[0xb] = "tseca_p2ps/I/0" ,
[0xc] = "tsecb_p2ps/I/0" ,
[0xd] = "RESERVED" ,
[0xe] = "RESERVED" ,
[0xf] = "RESERVED"
};
static const char * const tegra194_cbbcentralnoc_routeid_targflow[] = {
[0x0] = "SVC/T/intreg" ,
[0x1] = "axis_satellite_axi2apb_p2pm/T/axis_satellite_axi2apb_p2pm" ,
[0x2] = "axis_satellite_grout/T/axis_satellite_grout" ,
[0x3] = "cbb_firewall/T/cbb_firewall" ,
[0x4] = "gpu_p2pm/T/gpu_p2pm" ,
[0x5] = "host1x_p2pm/T/host1x_p2pm" ,
[0x6] = "sapb_3_p2pm/T/sapb_3_p2pm" ,
[0x7] = "smmu0_p2pm/T/smmu0_p2pm" ,
[0x8] = "smmu1_p2pm/T/smmu1_p2pm" ,
[0x9] = "smmu2_p2pm/T/smmu2_p2pm" ,
[0xa] = "stm_p2pm/T/stm_p2pm" ,
[0xb] = "RESERVED" ,
[0xc] = "RESERVED" ,
[0xd] = "RESERVED" ,
[0xe] = "RESERVED" ,
[0xf] = "RESERVED"
};
/*
* Fields of CBB NOC lookup table:
* Init flow, Targ flow, Targ subrange, Init mapping, Init localAddress,
* Targ mapping, Targ localAddress
* ----------------------------------------------------------------------------
*/
static const struct tegra194_cbb_aperture tegra194_cbbcentralnoc_apert_lookup[] = {
{ 0x0, 0x0, 0x00, 0x0, 0x02300000, 0, 0x00000000 },
{ 0x0, 0x1, 0x00, 0x0, 0x02003000, 0, 0x02003000 },
{ 0x0, 0x1, 0x01, 0x0, 0x02006000, 2, 0x02006000 },
{ 0x0, 0x1, 0x02, 0x0, 0x02016000, 3, 0x02016000 },
{ 0x0, 0x1, 0x03, 0x0, 0x0201d000, 4, 0x0201d000 },
{ 0x0, 0x1, 0x04, 0x0, 0x0202b000, 6, 0x0202b000 },
{ 0x0, 0x1, 0x05, 0x0, 0x02434000, 20, 0x02434000 },
{ 0x0, 0x1, 0x06, 0x0, 0x02436000, 21, 0x02436000 },
{ 0x0, 0x1, 0x07, 0x0, 0x02438000, 22, 0x02438000 },
{ 0x0, 0x1, 0x08, 0x0, 0x02445000, 24, 0x02445000 },
{ 0x0, 0x1, 0x09, 0x0, 0x02446000, 25, 0x02446000 },
{ 0x0, 0x1, 0x0a, 0x0, 0x02004000, 1, 0x02004000 },
{ 0x0, 0x1, 0x0b, 0x0, 0x0201e000, 5, 0x0201e000 },
{ 0x0, 0x1, 0x0c, 0x0, 0x0202c000, 7, 0x0202c000 },
{ 0x0, 0x1, 0x0d, 0x0, 0x02204000, 8, 0x02204000 },
{ 0x0, 0x1, 0x0e, 0x0, 0x02214000, 9, 0x02214000 },
{ 0x0, 0x1, 0x0f, 0x0, 0x02224000, 10, 0x02224000 },
{ 0x0, 0x1, 0x10, 0x0, 0x02234000, 11, 0x02234000 },
{ 0x0, 0x1, 0x11, 0x0, 0x02244000, 12, 0x02244000 },
{ 0x0, 0x1, 0x12, 0x0, 0x02254000, 13, 0x02254000 },
{ 0x0, 0x1, 0x13, 0x0, 0x02264000, 14, 0x02264000 },
{ 0x0, 0x1, 0x14, 0x0, 0x02274000, 15, 0x02274000 },
{ 0x0, 0x1, 0x15, 0x0, 0x02284000, 16, 0x02284000 },
{ 0x0, 0x1, 0x16, 0x0, 0x0243a000, 23, 0x0243a000 },
{ 0x0, 0x1, 0x17, 0x0, 0x02370000, 17, 0x02370000 },
{ 0x0, 0x1, 0x18, 0x0, 0x023d0000, 18, 0x023d0000 },
{ 0x0, 0x1, 0x19, 0x0, 0x023e0000, 19, 0x023e0000 },
{ 0x0, 0x1, 0x1a, 0x0, 0x02450000, 26, 0x02450000 },
{ 0x0, 0x1, 0x1b, 0x0, 0x02460000, 27, 0x02460000 },
{ 0x0, 0x1, 0x1c, 0x0, 0x02490000, 28, 0x02490000 },
{ 0x0, 0x1, 0x1d, 0x0, 0x03130000, 31, 0x03130000 },
{ 0x0, 0x1, 0x1e, 0x0, 0x03160000, 32, 0x03160000 },
{ 0x0, 0x1, 0x1f, 0x0, 0x03270000, 33, 0x03270000 },
{ 0x0, 0x1, 0x20, 0x0, 0x032e0000, 35, 0x032e0000 },
{ 0x0, 0x1, 0x21, 0x0, 0x03300000, 36, 0x03300000 },
{ 0x0, 0x1, 0x22, 0x0, 0x13090000, 40, 0x13090000 },
{ 0x0, 0x1, 0x23, 0x0, 0x20120000, 43, 0x20120000 },
{ 0x0, 0x1, 0x24, 0x0, 0x20170000, 44, 0x20170000 },
{ 0x0, 0x1, 0x25, 0x0, 0x20190000, 45, 0x20190000 },
{ 0x0, 0x1, 0x26, 0x0, 0x201b0000, 46, 0x201b0000 },
{ 0x0, 0x1, 0x27, 0x0, 0x20250000, 47, 0x20250000 },
{ 0x0, 0x1, 0x28, 0x0, 0x20260000, 48, 0x20260000 },
{ 0x0, 0x1, 0x29, 0x0, 0x20420000, 49, 0x20420000 },
{ 0x0, 0x1, 0x2a, 0x0, 0x20460000, 50, 0x20460000 },
{ 0x0, 0x1, 0x2b, 0x0, 0x204f0000, 51, 0x204f0000 },
{ 0x0, 0x1, 0x2c, 0x0, 0x20520000, 52, 0x20520000 },
{ 0x0, 0x1, 0x2d, 0x0, 0x20580000, 53, 0x20580000 },
{ 0x0, 0x1, 0x2e, 0x0, 0x205a0000, 54, 0x205a0000 },
{ 0x0, 0x1, 0x2f, 0x0, 0x205c0000, 55, 0x205c0000 },
{ 0x0, 0x1, 0x30, 0x0, 0x20690000, 56, 0x20690000 },
{ 0x0, 0x1, 0x31, 0x0, 0x20770000, 57, 0x20770000 },
{ 0x0, 0x1, 0x32, 0x0, 0x20790000, 58, 0x20790000 },
{ 0x0, 0x1, 0x33, 0x0, 0x20880000, 59, 0x20880000 },
{ 0x0, 0x1, 0x34, 0x0, 0x20990000, 62, 0x20990000 },
{ 0x0, 0x1, 0x35, 0x0, 0x20e10000, 65, 0x20e10000 },
{ 0x0, 0x1, 0x36, 0x0, 0x20e70000, 66, 0x20e70000 },
{ 0x0, 0x1, 0x37, 0x0, 0x20e80000, 67, 0x20e80000 },
{ 0x0, 0x1, 0x38, 0x0, 0x20f30000, 68, 0x20f30000 },
{ 0x0, 0x1, 0x39, 0x0, 0x20f50000, 69, 0x20f50000 },
{ 0x0, 0x1, 0x3a, 0x0, 0x20fc0000, 70, 0x20fc0000 },
{ 0x0, 0x1, 0x3b, 0x0, 0x21110000, 72, 0x21110000 },
{ 0x0, 0x1, 0x3c, 0x0, 0x21270000, 73, 0x21270000 },
{ 0x0, 0x1, 0x3d, 0x0, 0x21290000, 74, 0x21290000 },
{ 0x0, 0x1, 0x3e, 0x0, 0x21840000, 75, 0x21840000 },
{ 0x0, 0x1, 0x3f, 0x0, 0x21880000, 76, 0x21880000 },
{ 0x0, 0x1, 0x40, 0x0, 0x218d0000, 77, 0x218d0000 },
{ 0x0, 0x1, 0x41, 0x0, 0x21950000, 78, 0x21950000 },
{ 0x0, 0x1, 0x42, 0x0, 0x21960000, 79, 0x21960000 },
{ 0x0, 0x1, 0x43, 0x0, 0x21a10000, 80, 0x21a10000 },
{ 0x0, 0x1, 0x44, 0x0, 0x024a0000, 29, 0x024a0000 },
{ 0x0, 0x1, 0x45, 0x0, 0x024c0000, 30, 0x024c0000 },
{ 0x0, 0x1, 0x46, 0x0, 0x032c0000, 34, 0x032c0000 },
{ 0x0, 0x1, 0x47, 0x0, 0x03400000, 37, 0x03400000 },
{ 0x0, 0x1, 0x48, 0x0, 0x130a0000, 41, 0x130a0000 },
{ 0x0, 0x1, 0x49, 0x0, 0x130c0000, 42, 0x130c0000 },
{ 0x0, 0x1, 0x4a, 0x0, 0x208a0000, 60, 0x208a0000 },
{ 0x0, 0x1, 0x4b, 0x0, 0x208c0000, 61, 0x208c0000 },
{ 0x0, 0x1, 0x4c, 0x0, 0x209a0000, 63, 0x209a0000 },
{ 0x0, 0x1, 0x4d, 0x0, 0x21a40000, 81, 0x21a40000 },
{ 0x0, 0x1, 0x4e, 0x0, 0x03440000, 38, 0x03440000 },
{ 0x0, 0x1, 0x4f, 0x0, 0x20d00000, 64, 0x20d00000 },
{ 0x0, 0x1, 0x50, 0x0, 0x21000000, 71, 0x21000000 },
{ 0x0, 0x1, 0x51, 0x0, 0x0b000000, 39, 0x0b000000 },
{ 0x0, 0x2, 0x00, 0x0, 0x00000000, 0, 0x00000000 },
{ 0x0, 0x3, 0x00, 0x0, 0x02340000, 0, 0x00000000 },
{ 0x0, 0x4, 0x00, 0x0, 0x17000000, 0, 0x17000000 },
{ 0x0, 0x4, 0x01, 0x0, 0x18000000, 1, 0x18000000 },
{ 0x0, 0x5, 0x00, 0x0, 0x13e80000, 1, 0x13e80000 },
{ 0x0, 0x5, 0x01, 0x0, 0x15810000, 12, 0x15810000 },
{ 0x0, 0x5, 0x02, 0x0, 0x15840000, 14, 0x15840000 },
{ 0x0, 0x5, 0x03, 0x0, 0x15a40000, 17, 0x15a40000 },
{ 0x0, 0x5, 0x04, 0x0, 0x13f00000, 3, 0x13f00000 },
{ 0x0, 0x5, 0x05, 0x0, 0x15820000, 13, 0x15820000 },
{ 0x0, 0x5, 0x06, 0x0, 0x13ec0000, 2, 0x13ec0000 },
{ 0x0, 0x5, 0x07, 0x0, 0x15200000, 6, 0x15200000 },
{ 0x0, 0x5, 0x08, 0x0, 0x15340000, 7, 0x15340000 },
{ 0x0, 0x5, 0x09, 0x0, 0x15380000, 8, 0x15380000 },
{ 0x0, 0x5, 0x0a, 0x0, 0x15500000, 10, 0x15500000 },
{ 0x0, 0x5, 0x0b, 0x0, 0x155c0000, 11, 0x155c0000 },
{ 0x0, 0x5, 0x0c, 0x0, 0x15a00000, 16, 0x15a00000 },
{ 0x0, 0x5, 0x0d, 0x0, 0x13e00000, 0, 0x13e00000 },
{ 0x0, 0x5, 0x0e, 0x0, 0x15100000, 5, 0x15100000 },
{ 0x0, 0x5, 0x0f, 0x0, 0x15480000, 9, 0x15480000 },
{ 0x0, 0x5, 0x10, 0x0, 0x15880000, 15, 0x15880000 },
{ 0x0, 0x5, 0x11, 0x0, 0x15a80000, 18, 0x15a80000 },
{ 0x0, 0x5, 0x12, 0x0, 0x15b00000, 19, 0x15b00000 },
{ 0x0, 0x5, 0x13, 0x0, 0x14800000, 4, 0x14800000 },
{ 0x0, 0x5, 0x14, 0x0, 0x15c00000, 20, 0x15c00000 },
{ 0x0, 0x5, 0x15, 0x0, 0x16000000, 21, 0x16000000 },
{ 0x0, 0x6, 0x00, 0x0, 0x02000000, 4, 0x02000000 },
{ 0x0, 0x6, 0x01, 0x0, 0x02007000, 5, 0x02007000 },
{ 0x0, 0x6, 0x02, 0x0, 0x02008000, 6, 0x02008000 },
{ 0x0, 0x6, 0x03, 0x0, 0x02013000, 7, 0x02013000 },
{ 0x0, 0x6, 0x04, 0x0, 0x0201c000, 8, 0x0201c000 },
{ 0x0, 0x6, 0x05, 0x0, 0x02020000, 9, 0x02020000 },
{ 0x0, 0x6, 0x06, 0x0, 0x0202a000, 10, 0x0202a000 },
{ 0x0, 0x6, 0x07, 0x0, 0x0202e000, 11, 0x0202e000 },
{ 0x0, 0x6, 0x08, 0x0, 0x06400000, 33, 0x06400000 },
{ 0x0, 0x6, 0x09, 0x0, 0x02038000, 12, 0x02038000 },
{ 0x0, 0x6, 0x0a, 0x0, 0x00100000, 0, 0x00100000 },
{ 0x0, 0x6, 0x0b, 0x0, 0x023b0000, 13, 0x023b0000 },
{ 0x0, 0x6, 0x0c, 0x0, 0x02800000, 16, 0x02800000 },
{ 0x0, 0x6, 0x0d, 0x0, 0x030e0000, 22, 0x030e0000 },
{ 0x0, 0x6, 0x0e, 0x0, 0x03800000, 23, 0x03800000 },
{ 0x0, 0x6, 0x0f, 0x0, 0x03980000, 25, 0x03980000 },
{ 0x0, 0x6, 0x10, 0x0, 0x03a60000, 26, 0x03a60000 },
{ 0x0, 0x6, 0x11, 0x0, 0x03d80000, 31, 0x03d80000 },
{ 0x0, 0x6, 0x12, 0x0, 0x20000000, 36, 0x20000000 },
{ 0x0, 0x6, 0x13, 0x0, 0x20050000, 38, 0x20050000 },
{ 0x0, 0x6, 0x14, 0x0, 0x201e0000, 40, 0x201e0000 },
{ 0x0, 0x6, 0x15, 0x0, 0x20280000, 42, 0x20280000 },
{ 0x0, 0x6, 0x16, 0x0, 0x202c0000, 43, 0x202c0000 },
{ 0x0, 0x6, 0x17, 0x0, 0x20390000, 44, 0x20390000 },
{ 0x0, 0x6, 0x18, 0x0, 0x20430000, 45, 0x20430000 },
{ 0x0, 0x6, 0x19, 0x0, 0x20440000, 46, 0x20440000 },
{ 0x0, 0x6, 0x1a, 0x0, 0x204e0000, 47, 0x204e0000 },
{ 0x0, 0x6, 0x1b, 0x0, 0x20550000, 48, 0x20550000 },
{ 0x0, 0x6, 0x1c, 0x0, 0x20570000, 49, 0x20570000 },
{ 0x0, 0x6, 0x1d, 0x0, 0x20590000, 50, 0x20590000 },
{ 0x0, 0x6, 0x1e, 0x0, 0x20730000, 52, 0x20730000 },
{ 0x0, 0x6, 0x1f, 0x0, 0x209f0000, 54, 0x209f0000 },
{ 0x0, 0x6, 0x20, 0x0, 0x20e20000, 55, 0x20e20000 },
{ 0x0, 0x6, 0x21, 0x0, 0x20ed0000, 56, 0x20ed0000 },
{ 0x0, 0x6, 0x22, 0x0, 0x20fd0000, 57, 0x20fd0000 },
{ 0x0, 0x6, 0x23, 0x0, 0x21120000, 59, 0x21120000 },
{ 0x0, 0x6, 0x24, 0x0, 0x211a0000, 60, 0x211a0000 },
{ 0x0, 0x6, 0x25, 0x0, 0x21850000, 61, 0x21850000 },
{ 0x0, 0x6, 0x26, 0x0, 0x21860000, 62, 0x21860000 },
{ 0x0, 0x6, 0x27, 0x0, 0x21890000, 63, 0x21890000 },
{ 0x0, 0x6, 0x28, 0x0, 0x21970000, 64, 0x21970000 },
{ 0x0, 0x6, 0x29, 0x0, 0x21990000, 65, 0x21990000 },
{ 0x0, 0x6, 0x2a, 0x0, 0x21a00000, 66, 0x21a00000 },
{ 0x0, 0x6, 0x2b, 0x0, 0x21a90000, 68, 0x21a90000 },
{ 0x0, 0x6, 0x2c, 0x0, 0x21ac0000, 70, 0x21ac0000 },
{ 0x0, 0x6, 0x2d, 0x0, 0x01f80000, 3, 0x01f80000 },
{ 0x0, 0x6, 0x2e, 0x0, 0x024e0000, 14, 0x024e0000 },
{ 0x0, 0x6, 0x2f, 0x0, 0x030c0000, 21, 0x030c0000 },
{ 0x0, 0x6, 0x30, 0x0, 0x03820000, 24, 0x03820000 },
{ 0x0, 0x6, 0x31, 0x0, 0x03aa0000, 27, 0x03aa0000 },
{ 0x0, 0x6, 0x32, 0x0, 0x03c80000, 29, 0x03c80000 },
{ 0x0, 0x6, 0x33, 0x0, 0x130e0000, 34, 0x130e0000 },
{ 0x0, 0x6, 0x34, 0x0, 0x20020000, 37, 0x20020000 },
{ 0x0, 0x6, 0x35, 0x0, 0x20060000, 39, 0x20060000 },
{ 0x0, 0x6, 0x36, 0x0, 0x20200000, 41, 0x20200000 },
{ 0x0, 0x6, 0x37, 0x0, 0x206a0000, 51, 0x206a0000 },
{ 0x0, 0x6, 0x38, 0x0, 0x20740000, 53, 0x20740000 },
{ 0x0, 0x6, 0x39, 0x0, 0x20fe0000, 58, 0x20fe0000 },
{ 0x0, 0x6, 0x3a, 0x0, 0x21a20000, 67, 0x21a20000 },
{ 0x0, 0x6, 0x3b, 0x0, 0x21aa0000, 69, 0x21aa0000 },
{ 0x0, 0x6, 0x3c, 0x0, 0x02b80000, 17, 0x02b80000 },
{ 0x0, 0x6, 0x3d, 0x0, 0x03080000, 20, 0x03080000 },
{ 0x0, 0x6, 0x3e, 0x0, 0x13100000, 35, 0x13100000 },
{ 0x0, 0x6, 0x3f, 0x0, 0x01f00000, 2, 0x01f00000 },
{ 0x0, 0x6, 0x40, 0x0, 0x03000000, 19, 0x03000000 },
{ 0x0, 0x6, 0x41, 0x0, 0x03c00000, 28, 0x03c00000 },
{ 0x0, 0x6, 0x42, 0x0, 0x03d00000, 30, 0x03d00000 },
{ 0x0, 0x6, 0x43, 0x0, 0x01700000, 1, 0x01700000 },
{ 0x0, 0x6, 0x44, 0x0, 0x02c00000, 18, 0x02c00000 },
{ 0x0, 0x6, 0x45, 0x0, 0x02600000, 15, 0x02600000 },
{ 0x0, 0x6, 0x46, 0x0, 0x06000000, 32, 0x06000000 },
{ 0x0, 0x6, 0x47, 0x0, 0x24000000, 71, 0x24000000 },
{ 0x0, 0x7, 0x00, 0x0, 0x12000000, 0, 0x12000000 },
{ 0x0, 0x8, 0x00, 0x0, 0x11000000, 0, 0x11000000 },
{ 0x0, 0x9, 0x00, 0x0, 0x10000000, 0, 0x10000000 },
{ 0x0, 0xa, 0x00, 0x0, 0x22000000, 0, 0x22000000 }
};
/*
* BPMP NOC aperture lookup table as per file "BPMP_NOC_Structure.info".
*/
static const char * const tegra194_bpmpnoc_routeid_initflow[] = {
[0x0] = "cbb_i/I/0" ,
[0x1] = "cpu_m_i/I/0" ,
[0x2] = "cpu_p_i/I/0" ,
[0x3] = "cvc_i/I/0" ,
[0x4] = "dma_m_i/I/0" ,
[0x5] = "dma_p_i/I/0" ,
[0x6] = "RESERVED" ,
[0x7] = "RESERVED"
};
static const char * const tegra194_bpmpnoc_routeid_targflow[] = {
[0x00] = "multiport0_t/T/actmon" ,
[0x01] = "multiport0_t/T/ast_0" ,
[0x02] = "multiport0_t/T/ast_1" ,
[0x03] = "multiport0_t/T/atcm_cfg" ,
[0x04] = "multiport0_t/T/car" ,
[0x05] = "multiport0_t/T/central_pwr_mgr" ,
[0x06] = "multiport0_t/T/central_vtg_ctlr" ,
[0x07] = "multiport0_t/T/cfg" ,
[0x08] = "multiport0_t/T/dma" ,
[0x09] = "multiport0_t/T/err_collator" ,
[0x0a] = "multiport0_t/T/err_collator_car" ,
[0x0b] = "multiport0_t/T/fpga_misc" ,
[0x0c] = "multiport0_t/T/fpga_uart" ,
[0x0d] = "multiport0_t/T/gte" ,
[0x0e] = "multiport0_t/T/hsp" ,
[0x0f] = "multiport0_t/T/misc" ,
[0x10] = "multiport0_t/T/pm" ,
[0x11] = "multiport0_t/T/simon0" ,
[0x12] = "multiport0_t/T/simon1" ,
[0x13] = "multiport0_t/T/simon2" ,
[0x14] = "multiport0_t/T/simon3" ,
[0x15] = "multiport0_t/T/simon4" ,
[0x16] = "multiport0_t/T/soc_therm" ,
[0x17] = "multiport0_t/T/tke" ,
[0x18] = "multiport0_t/T/vic_0" ,
[0x19] = "multiport0_t/T/vic_1" ,
[0x1a] = "ast0_t/T/0" ,
[0x1b] = "ast1_t/T/0" ,
[0x1c] = "bpmp_noc_firewall/T/0" ,
[0x1d] = "cbb_t/T/0" ,
[0x1e] = "cpu_t/T/0" ,
[0x1f] = "svc_t/T/0"
};
/*
* Fields of BPMP NOC lookup table:
* Init flow, Targ flow, Targ subrange, Init mapping, Init localAddress,
* Targ mapping, Targ localAddress
* ----------------------------------------------------------------------------
*/
static const struct tegra194_cbb_aperture tegra194_bpmpnoc_apert_lookup[] = {
{ 0x0, 0x1c, 0x0, 0x0, 0x0d640000, 0, 0x00000000 },
{ 0x0, 0x1e, 0x0, 0x0, 0x0d400000, 0, 0x0d400000 },
{ 0x0, 0x00, 0x0, 0x0, 0x0d230000, 0, 0x00000000 },
{ 0x0, 0x01, 0x0, 0x0, 0x0d040000, 0, 0x00000000 },
{ 0x0, 0x02, 0x0, 0x0, 0x0d050000, 0, 0x00000000 },
{ 0x0, 0x03, 0x0, 0x0, 0x0d000000, 0, 0x00000000 },
{ 0x0, 0x04, 0x0, 0x0, 0x20ae0000, 3, 0x000e0000 },
{ 0x0, 0x04, 0x1, 0x0, 0x20ac0000, 2, 0x000c0000 },
{ 0x0, 0x04, 0x2, 0x0, 0x20a80000, 1, 0x00080000 },
{ 0x0, 0x04, 0x3, 0x0, 0x20a00000, 0, 0x00000000 },
{ 0x0, 0x05, 0x0, 0x0, 0x0d2a0000, 0, 0x00000000 },
{ 0x0, 0x06, 0x0, 0x0, 0x0d290000, 0, 0x00000000 },
{ 0x0, 0x07, 0x0, 0x0, 0x0d2c0000, 0, 0x00000000 },
{ 0x0, 0x08, 0x0, 0x0, 0x0d0e0000, 4, 0x00080000 },
{ 0x0, 0x08, 0x1, 0x0, 0x0d060000, 0, 0x00000000 },
{ 0x0, 0x08, 0x2, 0x0, 0x0d080000, 1, 0x00020000 },
{ 0x0, 0x08, 0x3, 0x0, 0x0d0a0000, 2, 0x00040000 },
{ 0x0, 0x08, 0x4, 0x0, 0x0d0c0000, 3, 0x00060000 },
{ 0x0, 0x09, 0x0, 0x0, 0x0d650000, 0, 0x00000000 },
{ 0x0, 0x0a, 0x0, 0x0, 0x20af0000, 0, 0x00000000 },
{ 0x0, 0x0b, 0x0, 0x0, 0x0d3e0000, 0, 0x00000000 },
{ 0x0, 0x0c, 0x0, 0x0, 0x0d3d0000, 0, 0x00000000 },
{ 0x0, 0x0d, 0x0, 0x0, 0x0d1e0000, 0, 0x00000000 },
{ 0x0, 0x0e, 0x0, 0x0, 0x0d150000, 0, 0x00000000 },
{ 0x0, 0x0e, 0x1, 0x0, 0x0d160000, 1, 0x00010000 },
{ 0x0, 0x0e, 0x2, 0x0, 0x0d170000, 2, 0x00020000 },
{ 0x0, 0x0e, 0x3, 0x0, 0x0d180000, 3, 0x00030000 },
{ 0x0, 0x0e, 0x4, 0x0, 0x0d190000, 4, 0x00040000 },
{ 0x0, 0x0e, 0x5, 0x0, 0x0d1a0000, 5, 0x00050000 },
{ 0x0, 0x0e, 0x6, 0x0, 0x0d1b0000, 6, 0x00060000 },
{ 0x0, 0x0e, 0x7, 0x0, 0x0d1c0000, 7, 0x00070000 },
{ 0x0, 0x0e, 0x8, 0x0, 0x0d1d0000, 8, 0x00080000 },
{ 0x0, 0x0f, 0x0, 0x0, 0x0d660000, 0, 0x00000000 },
{ 0x0, 0x10, 0x0, 0x0, 0x0d1f0000, 0, 0x00000000 },
{ 0x0, 0x10, 0x1, 0x0, 0x0d200000, 1, 0x00010000 },
{ 0x0, 0x10, 0x2, 0x0, 0x0d210000, 2, 0x00020000 },
{ 0x0, 0x10, 0x3, 0x0, 0x0d220000, 3, 0x00030000 },
{ 0x0, 0x11, 0x0, 0x0, 0x0d240000, 0, 0x00000000 },
{ 0x0, 0x12, 0x0, 0x0, 0x0d250000, 0, 0x00000000 },
{ 0x0, 0x13, 0x0, 0x0, 0x0d260000, 0, 0x00000000 },
{ 0x0, 0x14, 0x0, 0x0, 0x0d270000, 0, 0x00000000 },
{ 0x0, 0x15, 0x0, 0x0, 0x0d2b0000, 0, 0x00000000 },
{ 0x0, 0x16, 0x0, 0x0, 0x0d280000, 0, 0x00000000 },
{ 0x0, 0x17, 0x0, 0x0, 0x0d0f0000, 0, 0x00000000 },
{ 0x0, 0x17, 0x1, 0x0, 0x0d100000, 1, 0x00010000 },
{ 0x0, 0x17, 0x2, 0x0, 0x0d110000, 2, 0x00020000 },
{ 0x0, 0x17, 0x3, 0x0, 0x0d120000, 3, 0x00030000 },
{ 0x0, 0x17, 0x4, 0x0, 0x0d130000, 4, 0x00040000 },
{ 0x0, 0x17, 0x5, 0x0, 0x0d140000, 5, 0x00050000 },
{ 0x0, 0x18, 0x0, 0x0, 0x0d020000, 0, 0x00000000 },
{ 0x0, 0x19, 0x0, 0x0, 0x0d030000, 0, 0x00000000 },
{ 0x0, 0x1f, 0x0, 0x0, 0x0d600000, 0, 0x00000000 },
{ 0x0, 0x1f, 0x1, 0x0, 0x00000000, 0, 0x00000000 },
{ 0x1, 0x1a, 0x0, 0x0, 0x40000000, 0, 0x40000000 },
{ 0x1, 0x1a, 0x1, 0x1, 0x80000000, 1, 0x80000000 },
{ 0x1, 0x1a, 0x2, 0x0, 0x00000000, 0, 0x00000000 },
{ 0x2, 0x1c, 0x0, 0x0, 0x0d640000, 0, 0x00000000 },
{ 0x2, 0x1d, 0x0, 0x0, 0x20b00000, 8, 0x20b00000 },
{ 0x2, 0x1d, 0x1, 0x0, 0x20800000, 7, 0x20800000 },
{ 0x2, 0x1d, 0x2, 0x0, 0x20c00000, 9, 0x20c00000 },
{ 0x2, 0x1d, 0x3, 0x0, 0x0d800000, 3, 0x0d800000 },
{ 0x2, 0x1d, 0x4, 0x0, 0x20000000, 6, 0x20000000 },
{ 0x2, 0x1d, 0x5, 0x0, 0x0c000000, 2, 0x0c000000 },
{ 0x2, 0x1d, 0x6, 0x0, 0x21000000, 10, 0x21000000 },
{ 0x2, 0x1d, 0x7, 0x0, 0x0e000000, 4, 0x0e000000 },
{ 0x2, 0x1d, 0x8, 0x0, 0x22000000, 11, 0x22000000 },
{ 0x2, 0x1d, 0x9, 0x0, 0x08000000, 1, 0x08000000 },
{ 0x2, 0x1d, 0xa, 0x0, 0x24000000, 12, 0x24000000 },
{ 0x2, 0x1d, 0xb, 0x0, 0x00000000, 0, 0x00000000 },
{ 0x2, 0x1d, 0xc, 0x0, 0x28000000, 13, 0x28000000 },
{ 0x2, 0x1d, 0xd, 0x0, 0x10000000, 5, 0x10000000 },
{ 0x2, 0x1d, 0xe, 0x0, 0x30000000, 14, 0x30000000 },
{ 0x2, 0x00, 0x0, 0x0, 0x0d230000, 0, 0x00000000 },
{ 0x2, 0x01, 0x0, 0x0, 0x0d040000, 0, 0x00000000 },
{ 0x2, 0x02, 0x0, 0x0, 0x0d050000, 0, 0x00000000 },
{ 0x2, 0x03, 0x0, 0x0, 0x0d000000, 0, 0x00000000 },
{ 0x2, 0x04, 0x0, 0x0, 0x20ae0000, 3, 0x000e0000 },
{ 0x2, 0x04, 0x1, 0x0, 0x20ac0000, 2, 0x000c0000 },
{ 0x2, 0x04, 0x2, 0x0, 0x20a80000, 1, 0x00080000 },
{ 0x2, 0x04, 0x3, 0x0, 0x20a00000, 0, 0x00000000 },
{ 0x2, 0x05, 0x0, 0x0, 0x0d2a0000, 0, 0x00000000 },
{ 0x2, 0x06, 0x0, 0x0, 0x0d290000, 0, 0x00000000 },
{ 0x2, 0x07, 0x0, 0x0, 0x0d2c0000, 0, 0x00000000 },
{ 0x2, 0x08, 0x0, 0x0, 0x0d0e0000, 4, 0x00080000 },
{ 0x2, 0x08, 0x1, 0x0, 0x0d060000, 0, 0x00000000 },
{ 0x2, 0x08, 0x2, 0x0, 0x0d080000, 1, 0x00020000 },
{ 0x2, 0x08, 0x3, 0x0, 0x0d0a0000, 2, 0x00040000 },
{ 0x2, 0x08, 0x4, 0x0, 0x0d0c0000, 3, 0x00060000 },
{ 0x2, 0x09, 0x0, 0x0, 0x0d650000, 0, 0x00000000 },
{ 0x2, 0x0a, 0x0, 0x0, 0x20af0000, 0, 0x00000000 },
{ 0x2, 0x0b, 0x0, 0x0, 0x0d3e0000, 0, 0x00000000 },
{ 0x2, 0x0c, 0x0, 0x0, 0x0d3d0000, 0, 0x00000000 },
{ 0x2, 0x0d, 0x0, 0x0, 0x0d1e0000, 0, 0x00000000 },
{ 0x2, 0x0e, 0x0, 0x0, 0x0d150000, 0, 0x00000000 },
{ 0x2, 0x0e, 0x1, 0x0, 0x0d160000, 1, 0x00010000 },
{ 0x2, 0x0e, 0x2, 0x0, 0x0d170000, 2, 0x00020000 },
{ 0x2, 0x0e, 0x3, 0x0, 0x0d180000, 3, 0x00030000 },
{ 0x2, 0x0e, 0x4, 0x0, 0x0d190000, 4, 0x00040000 },
{ 0x2, 0x0e, 0x5, 0x0, 0x0d1a0000, 5, 0x00050000 },
{ 0x2, 0x0e, 0x6, 0x0, 0x0d1b0000, 6, 0x00060000 },
{ 0x2, 0x0e, 0x7, 0x0, 0x0d1c0000, 7, 0x00070000 },
{ 0x2, 0x0e, 0x8, 0x0, 0x0d1d0000, 8, 0x00080000 },
{ 0x2, 0x0f, 0x0, 0x0, 0x0d660000, 0, 0x00000000 },
{ 0x2, 0x10, 0x0, 0x0, 0x0d1f0000, 0, 0x00000000 },
{ 0x2, 0x10, 0x1, 0x0, 0x0d200000, 1, 0x00010000 },
{ 0x2, 0x10, 0x2, 0x0, 0x0d210000, 2, 0x00020000 },
{ 0x2, 0x10, 0x3, 0x0, 0x0d220000, 3, 0x00030000 },
{ 0x2, 0x11, 0x0, 0x0, 0x0d240000, 0, 0x00000000 },
{ 0x2, 0x12, 0x0, 0x0, 0x0d250000, 0, 0x00000000 },
{ 0x2, 0x13, 0x0, 0x0, 0x0d260000, 0, 0x00000000 },
{ 0x2, 0x14, 0x0, 0x0, 0x0d270000, 0, 0x00000000 },
{ 0x2, 0x15, 0x0, 0x0, 0x0d2b0000, 0, 0x00000000 },
{ 0x2, 0x16, 0x0, 0x0, 0x0d280000, 0, 0x00000000 },
{ 0x2, 0x17, 0x0, 0x0, 0x0d0f0000, 0, 0x00000000 },
{ 0x2, 0x17, 0x1, 0x0, 0x0d100000, 1, 0x00010000 },
{ 0x2, 0x17, 0x2, 0x0, 0x0d110000, 2, 0x00020000 },
{ 0x2, 0x17, 0x3, 0x0, 0x0d120000, 3, 0x00030000 },
{ 0x2, 0x17, 0x4, 0x0, 0x0d130000, 4, 0x00040000 },
{ 0x2, 0x17, 0x5, 0x0, 0x0d140000, 5, 0x00050000 },
{ 0x2, 0x18, 0x0, 0x0, 0x0d020000, 0, 0x00000000 },
{ 0x2, 0x19, 0x0, 0x0, 0x0d030000, 0, 0x00000000 },
{ 0x2, 0x1f, 0x0, 0x0, 0x0d600000, 0, 0x00000000 },
{ 0x2, 0x1f, 0x1, 0x0, 0x00000000, 0, 0x00000000 },
{ 0x3, 0x1b, 0x0, 0x0, 0x40000000, 0, 0x40000000 },
{ 0x3, 0x1b, 0x1, 0x1, 0x80000000, 1, 0x80000000 },
{ 0x3, 0x1c, 0x0, 0x2, 0x0d640000, 0, 0x00000000 },
{ 0x3, 0x1d, 0x0, 0x2, 0x20b00000, 8, 0x20b00000 },
{ 0x3, 0x1d, 0x1, 0x2, 0x20800000, 7, 0x20800000 },
{ 0x3, 0x1d, 0x2, 0x2, 0x20c00000, 9, 0x20c00000 },
{ 0x3, 0x1d, 0x3, 0x2, 0x0d800000, 3, 0x0d800000 },
{ 0x3, 0x1d, 0x4, 0x2, 0x20000000, 6, 0x20000000 },
{ 0x3, 0x1d, 0x5, 0x2, 0x0c000000, 2, 0x0c000000 },
{ 0x3, 0x1d, 0x6, 0x2, 0x21000000, 10, 0x21000000 },
{ 0x3, 0x1d, 0x7, 0x2, 0x0e000000, 4, 0x0e000000 },
{ 0x3, 0x1d, 0x8, 0x2, 0x22000000, 11, 0x22000000 },
{ 0x3, 0x1d, 0x9, 0x2, 0x08000000, 1, 0x08000000 },
{ 0x3, 0x1d, 0xa, 0x2, 0x24000000, 12, 0x24000000 },
{ 0x3, 0x1d, 0xb, 0x2, 0x00000000, 0, 0x00000000 },
{ 0x3, 0x1d, 0xc, 0x2, 0x28000000, 13, 0x28000000 },
{ 0x3, 0x1d, 0xd, 0x2, 0x10000000, 5, 0x10000000 },
{ 0x3, 0x1d, 0xe, 0x2, 0x30000000, 14, 0x30000000 },
{ 0x3, 0x1e, 0x0, 0x2, 0x0d400000, 0, 0x0d400000 },
{ 0x3, 0x00, 0x0, 0x2, 0x0d230000, 0, 0x00000000 },
{ 0x3, 0x01, 0x0, 0x2, 0x0d040000, 0, 0x00000000 },
{ 0x3, 0x02, 0x0, 0x2, 0x0d050000, 0, 0x00000000 },
{ 0x3, 0x03, 0x0, 0x2, 0x0d000000, 0, 0x00000000 },
{ 0x3, 0x04, 0x0, 0x2, 0x20ae0000, 3, 0x000e0000 },
{ 0x3, 0x04, 0x1, 0x2, 0x20ac0000, 2, 0x000c0000 },
{ 0x3, 0x04, 0x2, 0x2, 0x20a80000, 1, 0x00080000 },
{ 0x3, 0x04, 0x3, 0x2, 0x20a00000, 0, 0x00000000 },
{ 0x3, 0x05, 0x0, 0x2, 0x0d2a0000, 0, 0x00000000 },
{ 0x3, 0x06, 0x0, 0x2, 0x0d290000, 0, 0x00000000 },
{ 0x3, 0x07, 0x0, 0x2, 0x0d2c0000, 0, 0x00000000 },
{ 0x3, 0x08, 0x0, 0x2, 0x0d0e0000, 4, 0x00080000 },
{ 0x3, 0x08, 0x1, 0x2, 0x0d060000, 0, 0x00000000 },
{ 0x3, 0x08, 0x2, 0x2, 0x0d080000, 1, 0x00020000 },
{ 0x3, 0x08, 0x3, 0x2, 0x0d0a0000, 2, 0x00040000 },
{ 0x3, 0x08, 0x4, 0x2, 0x0d0c0000, 3, 0x00060000 },
{ 0x3, 0x09, 0x0, 0x2, 0x0d650000, 0, 0x00000000 },
{ 0x3, 0x0a, 0x0, 0x2, 0x20af0000, 0, 0x00000000 },
{ 0x3, 0x0b, 0x0, 0x2, 0x0d3e0000, 0, 0x00000000 },
{ 0x3, 0x0c, 0x0, 0x2, 0x0d3d0000, 0, 0x00000000 },
{ 0x3, 0x0d, 0x0, 0x2, 0x0d1e0000, 0, 0x00000000 },
{ 0x3, 0x0e, 0x0, 0x2, 0x0d150000, 0, 0x00000000 },
{ 0x3, 0x0e, 0x1, 0x2, 0x0d160000, 1, 0x00010000 },
{ 0x3, 0x0e, 0x2, 0x2, 0x0d170000, 2, 0x00020000 },
{ 0x3, 0x0e, 0x3, 0x2, 0x0d180000, 3, 0x00030000 },
{ 0x3, 0x0e, 0x4, 0x2, 0x0d190000, 4, 0x00040000 },
{ 0x3, 0x0e, 0x5, 0x2, 0x0d1a0000, 5, 0x00050000 },
{ 0x3, 0x0e, 0x6, 0x2, 0x0d1b0000, 6, 0x00060000 },
{ 0x3, 0x0e, 0x7, 0x2, 0x0d1c0000, 7, 0x00070000 },
{ 0x3, 0x0e, 0x8, 0x2, 0x0d1d0000, 8, 0x00080000 },
{ 0x3, 0x0f, 0x0, 0x2, 0x0d660000, 0, 0x00000000 },
{ 0x3, 0x10, 0x0, 0x2, 0x0d1f0000, 0, 0x00000000 },
{ 0x3, 0x10, 0x1, 0x2, 0x0d200000, 1, 0x00010000 },
{ 0x3, 0x10, 0x2, 0x2, 0x0d210000, 2, 0x00020000 },
{ 0x3, 0x10, 0x3, 0x2, 0x0d220000, 3, 0x00030000 },
{ 0x3, 0x11, 0x0, 0x2, 0x0d240000, 0, 0x00000000 },
{ 0x3, 0x12, 0x0, 0x2, 0x0d250000, 0, 0x00000000 },
{ 0x3, 0x13, 0x0, 0x2, 0x0d260000, 0, 0x00000000 },
{ 0x3, 0x14, 0x0, 0x2, 0x0d270000, 0, 0x00000000 },
{ 0x3, 0x15, 0x0, 0x2, 0x0d2b0000, 0, 0x00000000 },
{ 0x3, 0x16, 0x0, 0x2, 0x0d280000, 0, 0x00000000 },
{ 0x3, 0x17, 0x0, 0x2, 0x0d0f0000, 0, 0x00000000 },
{ 0x3, 0x17, 0x1, 0x2, 0x0d100000, 1, 0x00010000 },
{ 0x3, 0x17, 0x2, 0x2, 0x0d110000, 2, 0x00020000 },
{ 0x3, 0x17, 0x3, 0x2, 0x0d120000, 3, 0x00030000 },
{ 0x3, 0x17, 0x4, 0x2, 0x0d130000, 4, 0x00040000 },
{ 0x3, 0x17, 0x5, 0x2, 0x0d140000, 5, 0x00050000 },
{ 0x3, 0x18, 0x0, 0x2, 0x0d020000, 0, 0x00000000 },
{ 0x3, 0x19, 0x0, 0x2, 0x0d030000, 0, 0x00000000 },
{ 0x3, 0x1f, 0x0, 0x2, 0x0d600000, 0, 0x00000000 },
{ 0x3, 0x1f, 0x1, 0x0, 0x00000000, 0, 0x00000000 },
{ 0x4, 0x1b, 0x0, 0x0, 0x40000000, 0, 0x40000000 },
{ 0x4, 0x1b, 0x1, 0x1, 0x80000000, 1, 0x80000000 },
{ 0x4, 0x1e, 0x0, 0x2, 0x0d400000, 0, 0x0d400000 },
{ 0x4, 0x1e, 0x1, 0x0, 0x00000000, 0, 0x00000000 },
{ 0x5, 0x1c, 0x0, 0x0, 0x0d640000, 0, 0x00000000 },
{ 0x5, 0x1d, 0x0, 0x0, 0x20b00000, 8, 0x20b00000 },
{ 0x5, 0x1d, 0x1, 0x0, 0x20800000, 7, 0x20800000 },
{ 0x5, 0x1d, 0x2, 0x0, 0x20c00000, 9, 0x20c00000 },
{ 0x5, 0x1d, 0x3, 0x0, 0x0d800000, 3, 0x0d800000 },
{ 0x5, 0x1d, 0x4, 0x0, 0x20000000, 6, 0x20000000 },
{ 0x5, 0x1d, 0x5, 0x0, 0x0c000000, 2, 0x0c000000 },
{ 0x5, 0x1d, 0x6, 0x0, 0x21000000, 10, 0x21000000 },
{ 0x5, 0x1d, 0x7, 0x0, 0x0e000000, 4, 0x0e000000 },
{ 0x5, 0x1d, 0x8, 0x0, 0x22000000, 11, 0x22000000 },
{ 0x5, 0x1d, 0x9, 0x0, 0x08000000, 1, 0x08000000 },
{ 0x5, 0x1d, 0xa, 0x0, 0x24000000, 12, 0x24000000 },
{ 0x5, 0x1d, 0xb, 0x0, 0x00000000, 0, 0x00000000 },
{ 0x5, 0x1d, 0xc, 0x0, 0x28000000, 13, 0x28000000 },
{ 0x5, 0x1d, 0xd, 0x0, 0x10000000, 5, 0x10000000 },
{ 0x5, 0x1d, 0xe, 0x0, 0x30000000, 14, 0x30000000 },
{ 0x5, 0x00, 0x0, 0x0, 0x0d230000, 0, 0x00000000 },
{ 0x5, 0x01, 0x0, 0x0, 0x0d040000, 0, 0x00000000 },
{ 0x5, 0x02, 0x0, 0x0, 0x0d050000, 0, 0x00000000 },
{ 0x5, 0x03, 0x0, 0x0, 0x0d000000, 0, 0x00000000 },
{ 0x5, 0x04, 0x0, 0x0, 0x20ae0000, 3, 0x000e0000 },
{ 0x5, 0x04, 0x1, 0x0, 0x20ac0000, 2, 0x000c0000 },
{ 0x5, 0x04, 0x2, 0x0, 0x20a80000, 1, 0x00080000 },
{ 0x5, 0x04, 0x3, 0x0, 0x20a00000, 0, 0x00000000 },
{ 0x5, 0x05, 0x0, 0x0, 0x0d2a0000, 0, 0x00000000 },
{ 0x5, 0x06, 0x0, 0x0, 0x0d290000, 0, 0x00000000 },
{ 0x5, 0x07, 0x0, 0x0, 0x0d2c0000, 0, 0x00000000 },
{ 0x5, 0x08, 0x0, 0x0, 0x0d0e0000, 4, 0x00080000 },
{ 0x5, 0x08, 0x1, 0x0, 0x0d060000, 0, 0x00000000 },
{ 0x5, 0x08, 0x2, 0x0, 0x0d080000, 1, 0x00020000 },
{ 0x5, 0x08, 0x3, 0x0, 0x0d0a0000, 2, 0x00040000 },
{ 0x5, 0x08, 0x4, 0x0, 0x0d0c0000, 3, 0x00060000 },
{ 0x5, 0x09, 0x0, 0x0, 0x0d650000, 0, 0x00000000 },
{ 0x5, 0x0a, 0x0, 0x0, 0x20af0000, 0, 0x00000000 },
{ 0x5, 0x0b, 0x0, 0x0, 0x0d3e0000, 0, 0x00000000 },
{ 0x5, 0x0c, 0x0, 0x0, 0x0d3d0000, 0, 0x00000000 },
{ 0x5, 0x0d, 0x0, 0x0, 0x0d1e0000, 0, 0x00000000 },
{ 0x5, 0x0e, 0x0, 0x0, 0x0d150000, 0, 0x00000000 },
{ 0x5, 0x0e, 0x1, 0x0, 0x0d160000, 1, 0x00010000 },
{ 0x5, 0x0e, 0x2, 0x0, 0x0d170000, 2, 0x00020000 },
{ 0x5, 0x0e, 0x3, 0x0, 0x0d180000, 3, 0x00030000 },
{ 0x5, 0x0e, 0x4, 0x0, 0x0d190000, 4, 0x00040000 },
{ 0x5, 0x0e, 0x5, 0x0, 0x0d1a0000, 5, 0x00050000 },
{ 0x5, 0x0e, 0x6, 0x0, 0x0d1b0000, 6, 0x00060000 },
{ 0x5, 0x0e, 0x7, 0x0, 0x0d1c0000, 7, 0x00070000 },
{ 0x5, 0x0e, 0x8, 0x0, 0x0d1d0000, 8, 0x00080000 },
{ 0x5, 0x0f, 0x0, 0x0, 0x0d660000, 0, 0x00000000 },
{ 0x5, 0x10, 0x0, 0x0, 0x0d1f0000, 0, 0x00000000 },
{ 0x5, 0x10, 0x1, 0x0, 0x0d200000, 1, 0x00010000 },
{ 0x5, 0x10, 0x2, 0x0, 0x0d210000, 2, 0x00020000 },
{ 0x5, 0x10, 0x3, 0x0, 0x0d220000, 3, 0x00030000 },
{ 0x5, 0x11, 0x0, 0x0, 0x0d240000, 0, 0x00000000 },
{ 0x5, 0x12, 0x0, 0x0, 0x0d250000, 0, 0x00000000 },
{ 0x5, 0x13, 0x0, 0x0, 0x0d260000, 0, 0x00000000 },
{ 0x5, 0x14, 0x0, 0x0, 0x0d270000, 0, 0x00000000 },
{ 0x5, 0x15, 0x0, 0x0, 0x0d2b0000, 0, 0x00000000 },
{ 0x5, 0x16, 0x0, 0x0, 0x0d280000, 0, 0x00000000 },
{ 0x5, 0x17, 0x0, 0x0, 0x0d0f0000, 0, 0x00000000 },
{ 0x5, 0x17, 0x1, 0x0, 0x0d100000, 1, 0x00010000 },
{ 0x5, 0x17, 0x2, 0x0, 0x0d110000, 2, 0x00020000 },
{ 0x5, 0x17, 0x3, 0x0, 0x0d120000, 3, 0x00030000 },
{ 0x5, 0x17, 0x4, 0x0, 0x0d130000, 4, 0x00040000 },
{ 0x5, 0x17, 0x5, 0x0, 0x0d140000, 5, 0x00050000 },
{ 0x5, 0x18, 0x0, 0x0, 0x0d020000, 0, 0x00000000 },
{ 0x5, 0x19, 0x0, 0x0, 0x0d030000, 0, 0x00000000 },
{ 0x5, 0x1f, 0x0, 0x0, 0x0d600000, 0, 0x00000000 },
{ 0x5, 0x1f, 0x1, 0x0, 0x00000000, 0, 0x00000000 }
};
/*
* AON NOC aperture lookup table as per file "AON_NOC_Structure.info".
*/
static const char * const tegra194_aonnoc_routeid_initflow[] = {
[0x0] = "cbb_i/I/0" ,
[0x1] = "cpu_p_i/I/0" ,
[0x2] = "dma_m_i/I/0" ,
[0x3] = "dma_p_i/I/0"
};
static const char * const tegra194_aonnoc_routeid_targflow[] = {
[0x00] = "multiport1_t/T/aon_misc" ,
[0x01] = "multiport1_t/T/avic0" ,
[0x02] = "multiport1_t/T/avic1" ,
[0x03] = "multiport1_t/T/can1" ,
[0x04] = "multiport1_t/T/can2" ,
[0x05] = "multiport1_t/T/dma" ,
[0x06] = "multiport1_t/T/dmic" ,
[0x07] = "multiport1_t/T/err_collator" ,
[0x08] = "multiport1_t/T/fpga_misc" ,
[0x09] = "multiport1_t/T/gte" ,
[0x0a] = "multiport1_t/T/hsp" ,
[0x0b] = "multiport1_t/T/i2c2" ,
[0x0c] = "multiport1_t/T/i2c8" ,
[0x0d] = "multiport1_t/T/pwm" ,
[0x0e] = "multiport1_t/T/spi2" ,
[0x0f] = "multiport1_t/T/tke" ,
[0x10] = "multiport1_t/T/uartg" ,
[0x11] = "RESERVED" ,
[0x12] = "RESERVED" ,
[0x13] = "RESERVED" ,
[0x14] = "RESERVED" ,
[0x15] = "RESERVED" ,
[0x16] = "RESERVED" ,
[0x17] = "RESERVED" ,
[0x18] = "RESERVED" ,
[0x19] = "RESERVED" ,
[0x1a] = "RESERVED" ,
[0x1b] = "RESERVED" ,
[0x1c] = "RESERVED" ,
[0x1d] = "RESERVED" ,
[0x1e] = "RESERVED" ,
[0x1f] = "RESERVED" ,
[0x20] = "multiport0_t/T/aovc" ,
[0x21] = "multiport0_t/T/atcm" ,
[0x22] = "multiport0_t/T/cast" ,
[0x23] = "multiport0_t/T/dast" ,
[0x24] = "multiport0_t/T/err_collator_car" ,
[0x25] = "multiport0_t/T/gpio" ,
[0x26] = "multiport0_t/T/i2c10" ,
[0x27] = "multiport0_t/T/mss" ,
[0x28] = "multiport0_t/T/padctl_a12" ,
[0x29] = "multiport0_t/T/padctl_a14" ,
[0x2a] = "multiport0_t/T/padctl_a15" ,
[0x2b] = "multiport0_t/T/rtc" ,
[0x2c] = "multiport0_t/T/tsc" ,
[0x2d] = "RESERVED" ,
[0x2e] = "RESERVED" ,
[0x2f] = "RESERVED" ,
[0x30] = "multiport2_t/T/aon_vref_ro" ,
[0x31] = "multiport2_t/T/aopm" ,
[0x32] = "multiport2_t/T/car" ,
[0x33] = "multiport2_t/T/pmc" ,
[0x34] = "ast1_t/T/0" ,
[0x35] = "cbb_t/T/0" ,
[0x36] = "cpu_t/T/0" ,
[0x37] = "firewall_t/T/0" ,
[0x38] = "svc_t/T/0" ,
[0x39] = "uartc/T/uartc" ,
[0x3a] = "RESERVED" ,
[0x3b] = "RESERVED" ,
[0x3c] = "RESERVED" ,
[0x3d] = "RESERVED" ,
[0x3e] = "RESERVED" ,
[0x3f] = "RESERVED"
};
/*
* Fields of AON NOC lookup table:
* Init flow, Targ flow, Targ subrange, Init mapping, Init localAddress,
* Targ mapping, Targ localAddress
* ----------------------------------------------------------------------------
*/
static const struct tegra194_cbb_aperture tegra194_aonnoc_aperture_lookup[] = {
{ 0x0, 0x37, 0x00, 0, 0x0c640000, 0, 0x00000000 },
{ 0x0, 0x20, 0x00, 0, 0x0c3b0000, 0, 0x00000000 },
{ 0x0, 0x21, 0x00, 0, 0x0c000000, 0, 0x00000000 },
{ 0x0, 0x22, 0x00, 0, 0x0c040000, 0, 0x00000000 },
{ 0x0, 0x23, 0x00, 0, 0x0c050000, 0, 0x00000000 },
{ 0x0, 0x24, 0x00, 0, 0x20cf0000, 0, 0x00000000 },
{ 0x0, 0x25, 0x00, 0, 0x0c2f0000, 0, 0x00000000 },
{ 0x0, 0x26, 0x00, 0, 0x0c230000, 0, 0x00000000 },
{ 0x0, 0x27, 0x00, 0, 0x0c350000, 0, 0x00000000 },
{ 0x0, 0x28, 0x00, 0, 0x0c301000, 0, 0x00000000 },
{ 0x0, 0x29, 0x00, 0, 0x0c302000, 0, 0x00000000 },
{ 0x0, 0x2a, 0x00, 0, 0x0c303000, 0, 0x00000000 },
{ 0x0, 0x2b, 0x00, 0, 0x0c2a0000, 0, 0x00000000 },
{ 0x0, 0x2c, 0x00, 0, 0x0c2b0000, 0, 0x00000000 },
{ 0x0, 0x2c, 0x01, 0, 0x0c2c0000, 1, 0x00010000 },
{ 0x0, 0x2c, 0x02, 0, 0x0c2d0000, 2, 0x00020000 },
{ 0x0, 0x2c, 0x03, 0, 0x0c2e0000, 3, 0x00030000 },
{ 0x0, 0x00, 0x00, 0, 0x0c660000, 0, 0x00000000 },
{ 0x0, 0x01, 0x00, 0, 0x0c020000, 0, 0x00000000 },
{ 0x0, 0x02, 0x00, 0, 0x0c030000, 0, 0x00000000 },
{ 0x0, 0x03, 0x00, 0, 0x0c310000, 0, 0x00000000 },
{ 0x0, 0x04, 0x00, 0, 0x0c320000, 0, 0x00000000 },
{ 0x0, 0x05, 0x00, 0, 0x0c0a0000, 2, 0x00040000 },
{ 0x0, 0x05, 0x01, 0, 0x0c0b0000, 3, 0x00050000 },
{ 0x0, 0x05, 0x02, 0, 0x0c0e0000, 5, 0x00080000 },
{ 0x0, 0x05, 0x03, 0, 0x0c060000, 0, 0x00000000 },
{ 0x0, 0x05, 0x04, 0, 0x0c080000, 1, 0x00020000 },
{ 0x0, 0x05, 0x05, 0, 0x0c0c0000, 4, 0x00060000 },
{ 0x0, 0x06, 0x00, 0, 0x0c330000, 0, 0x00000000 },
{ 0x0, 0x07, 0x00, 0, 0x0c650000, 0, 0x00000000 },
{ 0x0, 0x08, 0x00, 0, 0x0c3e0000, 0, 0x00000000 },
{ 0x0, 0x09, 0x00, 0, 0x0c1e0000, 0, 0x00000000 },
{ 0x0, 0x0a, 0x00, 0, 0x0c150000, 0, 0x00000000 },
{ 0x0, 0x0a, 0x01, 0, 0x0c160000, 1, 0x00010000 },
{ 0x0, 0x0a, 0x02, 0, 0x0c170000, 2, 0x00020000 },
{ 0x0, 0x0a, 0x03, 0, 0x0c180000, 3, 0x00030000 },
{ 0x0, 0x0a, 0x04, 0, 0x0c190000, 4, 0x00040000 },
{ 0x0, 0x0a, 0x05, 0, 0x0c1a0000, 5, 0x00050000 },
{ 0x0, 0x0a, 0x06, 0, 0x0c1b0000, 6, 0x00060000 },
{ 0x0, 0x0a, 0x07, 0, 0x0c1c0000, 7, 0x00070000 },
{ 0x0, 0x0a, 0x08, 0, 0x0c1d0000, 8, 0x00080000 },
{ 0x0, 0x0b, 0x00, 0, 0x0c240000, 0, 0x00000000 },
{ 0x0, 0x0c, 0x00, 0, 0x0c250000, 0, 0x00000000 },
{ 0x0, 0x0d, 0x00, 0, 0x0c340000, 0, 0x00000000 },
{ 0x0, 0x0e, 0x00, 0, 0x0c260000, 0, 0x00000000 },
{ 0x0, 0x0f, 0x00, 0, 0x0c0f0000, 0, 0x00000000 },
{ 0x0, 0x0f, 0x01, 0, 0x0c100000, 1, 0x00010000 },
{ 0x0, 0x0f, 0x02, 0, 0x0c110000, 2, 0x00020000 },
{ 0x0, 0x0f, 0x03, 0, 0x0c120000, 3, 0x00030000 },
{ 0x0, 0x0f, 0x04, 0, 0x0c130000, 4, 0x00040000 },
{ 0x0, 0x0f, 0x05, 0, 0x0c140000, 5, 0x00050000 },
{ 0x0, 0x10, 0x00, 0, 0x0c290000, 0, 0x00000000 },
{ 0x0, 0x30, 0x00, 0, 0x20ce0000, 0, 0x00000000 },
{ 0x0, 0x31, 0x00, 0, 0x0c1f0000, 0, 0x00000000 },
{ 0x0, 0x31, 0x01, 0, 0x0c200000, 1, 0x00010000 },
{ 0x0, 0x31, 0x02, 0, 0x0c210000, 2, 0x00020000 },
{ 0x0, 0x31, 0x03, 0, 0x0c220000, 3, 0x00030000 },
{ 0x0, 0x32, 0x00, 0, 0x20cc0000, 3, 0x001c0000 },
{ 0x0, 0x32, 0x01, 0, 0x20c80000, 2, 0x00180000 },
{ 0x0, 0x32, 0x02, 0, 0x20c00000, 1, 0x00100000 },
{ 0x0, 0x32, 0x03, 0, 0x20b00000, 0, 0x00000000 },
{ 0x0, 0x33, 0x00, 0, 0x0c360000, 0, 0x00000000 },
{ 0x0, 0x33, 0x01, 0, 0x0c370000, 1, 0x00010000 },
{ 0x0, 0x33, 0x02, 0, 0x0c3a0000, 3, 0x00040000 },
{ 0x0, 0x33, 0x03, 0, 0x0c380000, 2, 0x00020000 },
{ 0x0, 0x38, 0x00, 0, 0x0c600000, 0, 0x00000000 },
{ 0x0, 0x38, 0x01, 0, 0x00000000, 0, 0x00000000 },
{ 0x0, 0x39, 0x00, 0, 0x0c280000, 0, 0x00000000 },
{ 0x1, 0x35, 0x00, 0, 0x00000000, 0, 0x00000000 },
{ 0x1, 0x35, 0x01, 0, 0x00100000, 1, 0x00100000 },
{ 0x1, 0x35, 0x02, 0, 0x05a00000, 11, 0x05a00000 },
{ 0x1, 0x35, 0x03, 0, 0x05b00000, 32, 0x05b00000 },
{ 0x1, 0x35, 0x04, 0, 0x05c00000, 33, 0x05c00000 },
{ 0x1, 0x35, 0x05, 0, 0x05d00000, 12, 0x05d00000 },
{ 0x1, 0x35, 0x06, 0, 0x20000000, 19, 0x20000000 },
{ 0x1, 0x35, 0x07, 0, 0x20100000, 20, 0x20100000 },
{ 0x1, 0x35, 0x08, 0, 0x20a00000, 24, 0x20a00000 },
{ 0x1, 0x35, 0x09, 0, 0x20d00000, 25, 0x20d00000 },
{ 0x1, 0x35, 0x0a, 0, 0x00200000, 2, 0x00200000 },
{ 0x1, 0x35, 0x0b, 0, 0x05800000, 10, 0x05800000 },
{ 0x1, 0x35, 0x0c, 0, 0x05e00000, 13, 0x05e00000 },
{ 0x1, 0x35, 0x0d, 0, 0x20200000, 21, 0x20200000 },
{ 0x1, 0x35, 0x0e, 0, 0x20800000, 23, 0x20800000 },
{ 0x1, 0x35, 0x0f, 0, 0x20e00000, 26, 0x20e00000 },
{ 0x1, 0x35, 0x10, 0, 0x00400000, 3, 0x00400000 },
{ 0x1, 0x35, 0x11, 0, 0x20400000, 22, 0x20400000 },
{ 0x1, 0x35, 0x12, 0, 0x00800000, 4, 0x00800000 },
{ 0x1, 0x35, 0x13, 0, 0x05000000, 9, 0x05000000 },
{ 0x1, 0x35, 0x14, 0, 0x0c800000, 34, 0x0c800000 },
{ 0x1, 0x35, 0x15, 0, 0x01000000, 5, 0x01000000 },
{ 0x1, 0x35, 0x16, 0, 0x03000000, 7, 0x03000000 },
{ 0x1, 0x35, 0x17, 0, 0x04000000, 8, 0x04000000 },
{ 0x1, 0x35, 0x18, 0, 0x0d000000, 16, 0x0d000000 },
{ 0x1, 0x35, 0x19, 0, 0x21000000, 27, 0x21000000 },
{ 0x1, 0x35, 0x1a, 0, 0x02000000, 6, 0x02000000 },
{ 0x1, 0x35, 0x1b, 0, 0x06000000, 14, 0x06000000 },
{ 0x1, 0x35, 0x1c, 0, 0x0e000000, 17, 0x0e000000 },
{ 0x1, 0x35, 0x1d, 0, 0x22000000, 28, 0x22000000 },
{ 0x1, 0x35, 0x1e, 0, 0x08000000, 15, 0x08000000 },
{ 0x1, 0x35, 0x1f, 0, 0x24000000, 29, 0x24000000 },
{ 0x1, 0x35, 0x20, 0, 0x28000000, 30, 0x28000000 },
{ 0x1, 0x35, 0x21, 0, 0x10000000, 18, 0x10000000 },
{ 0x1, 0x35, 0x22, 0, 0x30000000, 31, 0x30000000 },
{ 0x1, 0x37, 0x00, 0, 0x0c640000, 0, 0x00000000 },
{ 0x1, 0x20, 0x00, 0, 0x0c3b0000, 0, 0x00000000 },
{ 0x1, 0x21, 0x00, 0, 0x0c000000, 0, 0x00000000 },
{ 0x1, 0x22, 0x00, 0, 0x0c040000, 0, 0x00000000 },
{ 0x1, 0x23, 0x00, 0, 0x0c050000, 0, 0x00000000 },
{ 0x1, 0x24, 0x00, 0, 0x20cf0000, 0, 0x00000000 },
{ 0x1, 0x25, 0x00, 0, 0x0c2f0000, 0, 0x00000000 },
{ 0x1, 0x26, 0x00, 0, 0x0c230000, 0, 0x00000000 },
{ 0x1, 0x27, 0x00, 0, 0x0c350000, 0, 0x00000000 },
{ 0x1, 0x28, 0x00, 0, 0x0c301000, 0, 0x00000000 },
{ 0x1, 0x29, 0x00, 0, 0x0c302000, 0, 0x00000000 },
{ 0x1, 0x2a, 0x00, 0, 0x0c303000, 0, 0x00000000 },
{ 0x1, 0x2b, 0x00, 0, 0x0c2a0000, 0, 0x00000000 },
{ 0x1, 0x2c, 0x00, 0, 0x0c2b0000, 0, 0x00000000 },
{ 0x1, 0x2c, 0x01, 0, 0x0c2c0000, 1, 0x00010000 },
{ 0x1, 0x2c, 0x02, 0, 0x0c2d0000, 2, 0x00020000 },
{ 0x1, 0x2c, 0x03, 0, 0x0c2e0000, 3, 0x00030000 },
{ 0x1, 0x00, 0x00, 0, 0x0c660000, 0, 0x00000000 },
{ 0x1, 0x01, 0x00, 0, 0x0c020000, 0, 0x00000000 },
{ 0x1, 0x02, 0x00, 0, 0x0c030000, 0, 0x00000000 },
{ 0x1, 0x03, 0x00, 0, 0x0c310000, 0, 0x00000000 },
{ 0x1, 0x04, 0x00, 0, 0x0c320000, 0, 0x00000000 },
{ 0x1, 0x05, 0x00, 0, 0x0c0a0000, 2, 0x00040000 },
{ 0x1, 0x05, 0x01, 0, 0x0c0b0000, 3, 0x00050000 },
{ 0x1, 0x05, 0x02, 0, 0x0c0e0000, 5, 0x00080000 },
{ 0x1, 0x05, 0x03, 0, 0x0c060000, 0, 0x00000000 },
{ 0x1, 0x05, 0x04, 0, 0x0c080000, 1, 0x00020000 },
{ 0x1, 0x05, 0x05, 0, 0x0c0c0000, 4, 0x00060000 },
{ 0x1, 0x06, 0x00, 0, 0x0c330000, 0, 0x00000000 },
{ 0x1, 0x07, 0x00, 0, 0x0c650000, 0, 0x00000000 },
{ 0x1, 0x08, 0x00, 0, 0x0c3e0000, 0, 0x00000000 },
{ 0x1, 0x09, 0x00, 0, 0x0c1e0000, 0, 0x00000000 },
{ 0x1, 0x0a, 0x00, 0, 0x0c150000, 0, 0x00000000 },
{ 0x1, 0x0a, 0x01, 0, 0x0c160000, 1, 0x00010000 },
{ 0x1, 0x0a, 0x02, 0, 0x0c170000, 2, 0x00020000 },
{ 0x1, 0x0a, 0x03, 0, 0x0c180000, 3, 0x00030000 },
{ 0x1, 0x0a, 0x04, 0, 0x0c190000, 4, 0x00040000 },
{ 0x1, 0x0a, 0x05, 0, 0x0c1a0000, 5, 0x00050000 },
{ 0x1, 0x0a, 0x06, 0, 0x0c1b0000, 6, 0x00060000 },
{ 0x1, 0x0a, 0x07, 0, 0x0c1c0000, 7, 0x00070000 },
{ 0x1, 0x0a, 0x08, 0, 0x0c1d0000, 8, 0x00080000 },
{ 0x1, 0x0b, 0x00, 0, 0x0c240000, 0, 0x00000000 },
{ 0x1, 0x0c, 0x00, 0, 0x0c250000, 0, 0x00000000 },
{ 0x1, 0x0d, 0x00, 0, 0x0c340000, 0, 0x00000000 },
{ 0x1, 0x0e, 0x00, 0, 0x0c260000, 0, 0x00000000 },
{ 0x1, 0x0f, 0x00, 0, 0x0c0f0000, 0, 0x00000000 },
{ 0x1, 0x0f, 0x01, 0, 0x0c100000, 1, 0x00010000 },
{ 0x1, 0x0f, 0x02, 0, 0x0c110000, 2, 0x00020000 },
{ 0x1, 0x0f, 0x03, 0, 0x0c120000, 3, 0x00030000 },
{ 0x1, 0x0f, 0x04, 0, 0x0c130000, 4, 0x00040000 },
{ 0x1, 0x0f, 0x05, 0, 0x0c140000, 5, 0x00050000 },
{ 0x1, 0x10, 0x00, 0, 0x0c290000, 0, 0x00000000 },
{ 0x1, 0x30, 0x00, 0, 0x20ce0000, 0, 0x00000000 },
{ 0x1, 0x31, 0x00, 0, 0x0c1f0000, 0, 0x00000000 },
{ 0x1, 0x31, 0x01, 0, 0x0c200000, 1, 0x00010000 },
{ 0x1, 0x31, 0x02, 0, 0x0c210000, 2, 0x00020000 },
{ 0x1, 0x31, 0x03, 0, 0x0c220000, 3, 0x00030000 },
{ 0x1, 0x32, 0x00, 0, 0x20cc0000, 3, 0x001c0000 },
{ 0x1, 0x32, 0x01, 0, 0x20c80000, 2, 0x00180000 },
{ 0x1, 0x32, 0x02, 0, 0x20c00000, 1, 0x00100000 },
{ 0x1, 0x32, 0x03, 0, 0x20b00000, 0, 0x00000000 },
{ 0x1, 0x33, 0x00, 0, 0x0c360000, 0, 0x00000000 },
{ 0x1, 0x33, 0x01, 0, 0x0c370000, 1, 0x00010000 },
{ 0x1, 0x33, 0x02, 0, 0x0c3a0000, 3, 0x00040000 },
{ 0x1, 0x33, 0x03, 0, 0x0c380000, 2, 0x00020000 },
{ 0x1, 0x38, 0x00, 0, 0x0c600000, 0, 0x00000000 },
{ 0x1, 0x38, 0x01, 0, 0x00000000, 0, 0x00000000 },
{ 0x1, 0x39, 0x00, 0, 0x0c280000, 0, 0x00000000 },
{ 0x2, 0x34, 0x00, 0, 0x40000000, 0, 0x40000000 },
{ 0x2, 0x34, 0x01, 0, 0x80000000, 1, 0x80000000 },
{ 0x2, 0x36, 0x00, 0, 0x0c400000, 0, 0x0c400000 },
{ 0x2, 0x36, 0x01, 0, 0x00000000, 0, 0x00000000 },
{ 0x3, 0x35, 0x00, 0, 0x00000000, 0, 0x00000000 },
{ 0x3, 0x35, 0x01, 0, 0x00100000, 1, 0x00100000 },
{ 0x3, 0x35, 0x02, 0, 0x05a00000, 11, 0x05a00000 },
{ 0x3, 0x35, 0x03, 0, 0x05b00000, 32, 0x05b00000 },
{ 0x3, 0x35, 0x04, 0, 0x05c00000, 33, 0x05c00000 },
{ 0x3, 0x35, 0x05, 0, 0x05d00000, 12, 0x05d00000 },
{ 0x3, 0x35, 0x06, 0, 0x20000000, 19, 0x20000000 },
{ 0x3, 0x35, 0x07, 0, 0x20100000, 20, 0x20100000 },
{ 0x3, 0x35, 0x08, 0, 0x20a00000, 24, 0x20a00000 },
{ 0x3, 0x35, 0x09, 0, 0x20d00000, 25, 0x20d00000 },
{ 0x3, 0x35, 0x0a, 0, 0x00200000, 2, 0x00200000 },
{ 0x3, 0x35, 0x0b, 0, 0x05800000, 10, 0x05800000 },
{ 0x3, 0x35, 0x0c, 0, 0x05e00000, 13, 0x05e00000 },
{ 0x3, 0x35, 0x0d, 0, 0x20200000, 21, 0x20200000 },
{ 0x3, 0x35, 0x0e, 0, 0x20800000, 23, 0x20800000 },
{ 0x3, 0x35, 0x0f, 0, 0x20e00000, 26, 0x20e00000 },
{ 0x3, 0x35, 0x10, 0, 0x00400000, 3, 0x00400000 },
{ 0x3, 0x35, 0x11, 0, 0x20400000, 22, 0x20400000 },
{ 0x3, 0x35, 0x12, 0, 0x00800000, 4, 0x00800000 },
{ 0x3, 0x35, 0x13, 0, 0x50000000, 9, 0x05000000 },
{ 0x3, 0x35, 0x14, 0, 0xc0800000, 34, 0x0c800000 },
{ 0x3, 0x35, 0x15, 0, 0x10000000, 5, 0x01000000 },
{ 0x3, 0x35, 0x16, 0, 0x30000000, 7, 0x03000000 },
{ 0x3, 0x35, 0x17, 0, 0x04000000, 8, 0x04000000 },
{ 0x3, 0x35, 0x18, 0, 0x0d000000, 16, 0x0d000000 },
{ 0x3, 0x35, 0x19, 0, 0x21000000, 27, 0x21000000 },
{ 0x3, 0x35, 0x1a, 0, 0x02000000, 6, 0x02000000 },
{ 0x3, 0x35, 0x1b, 0, 0x06000000, 14, 0x06000000 },
{ 0x3, 0x35, 0x1c, 0, 0x0e000000, 17, 0x0e000000 },
{ 0x3, 0x35, 0x1d, 0, 0x22000000, 28, 0x22000000 },
{ 0x3, 0x35, 0x1e, 0, 0x08000000, 15, 0x08000000 },
{ 0x3, 0x35, 0x1f, 0, 0x24000000, 29, 0x24000000 },
{ 0x3, 0x35, 0x20, 0, 0x28000000, 30, 0x28000000 },
{ 0x3, 0x35, 0x21, 0, 0x10000000, 18, 0x10000000 },
{ 0x3, 0x35, 0x22, 0, 0x30000000, 31, 0x30000000 },
{ 0x3, 0x37, 0x00, 0, 0x0c640000, 0, 0x00000000 },
{ 0x3, 0x20, 0x00, 0, 0x0c3b0000, 0, 0x00000000 },
{ 0x3, 0x21, 0x00, 0, 0x0c000000, 0, 0x00000000 },
{ 0x3, 0x22, 0x00, 0, 0x0c040000, 0, 0x00000000 },
{ 0x3, 0x23, 0x00, 0, 0x0c050000, 0, 0x00000000 },
{ 0x3, 0x24, 0x00, 0, 0x20cf0000, 0, 0x00000000 },
{ 0x3, 0x25, 0x00, 0, 0x0c2f0000, 0, 0x00000000 },
{ 0x3, 0x26, 0x00, 0, 0x0c230000, 0, 0x00000000 },
{ 0x3, 0x27, 0x00, 0, 0x0c350000, 0, 0x00000000 },
{ 0x3, 0x28, 0x00, 0, 0x0c301000, 0, 0x00000000 },
{ 0x3, 0x29, 0x00, 0, 0x0c302000, 0, 0x00000000 },
{ 0x3, 0x2a, 0x00, 0, 0x0c303000, 0, 0x00000000 },
{ 0x3, 0x2b, 0x00, 0, 0x0c2a0000, 0, 0x00000000 },
{ 0x3, 0x2c, 0x00, 0, 0x0c2b0000, 0, 0x00000000 },
{ 0x3, 0x2c, 0x01, 0, 0x0c2c0000, 1, 0x00010000 },
{ 0x3, 0x2c, 0x02, 0, 0x0c2d0000, 2, 0x00020000 },
{ 0x3, 0x2c, 0x03, 0, 0x0c2e0000, 3, 0x00030000 },
{ 0x3, 0x00, 0x00, 0, 0x0c660000, 0, 0x00000000 },
{ 0x3, 0x01, 0x00, 0, 0x0c020000, 0, 0x00000000 },
{ 0x3, 0x02, 0x00, 0, 0x0c030000, 0, 0x00000000 },
{ 0x3, 0x03, 0x00, 0, 0x0c310000, 0, 0x00000000 },
{ 0x3, 0x04, 0x00, 0, 0x0c320000, 0, 0x00000000 },
{ 0x3, 0x05, 0x00, 0, 0x0c0a0000, 2, 0x00040000 },
{ 0x3, 0x05, 0x01, 0, 0x0c0b0000, 3, 0x00050000 },
{ 0x3, 0x05, 0x02, 0, 0x0c0e0000, 5, 0x00080000 },
{ 0x3, 0x05, 0x03, 0, 0x0c060000, 0, 0x00000000 },
{ 0x3, 0x05, 0x04, 0, 0x0c080000, 1, 0x00020000 },
{ 0x3, 0x05, 0x05, 0, 0x0c0c0000, 4, 0x00060000 },
{ 0x3, 0x06, 0x00, 0, 0x0c330000, 0, 0x00000000 },
{ 0x3, 0x07, 0x00, 0, 0x0c650000, 0, 0x00000000 },
{ 0x3, 0x08, 0x00, 0, 0x0c3e0000, 0, 0x00000000 },
{ 0x3, 0x09, 0x00, 0, 0x0c1e0000, 0, 0x00000000 },
{ 0x3, 0x0a, 0x00, 0, 0x0c150000, 0, 0x00000000 },
{ 0x3, 0x0a, 0x01, 0, 0x0c160000, 1, 0x00010000 },
{ 0x3, 0x0a, 0x02, 0, 0x0c170000, 2, 0x00020000 },
{ 0x3, 0x0a, 0x03, 0, 0x0c180000, 3, 0x00030000 },
{ 0x3, 0x0a, 0x04, 0, 0x0c190000, 4, 0x00040000 },
{ 0x3, 0x0a, 0x05, 0, 0x0c1a0000, 5, 0x00050000 },
{ 0x3, 0x0a, 0x06, 0, 0x0c1b0000, 6, 0x00060000 },
{ 0x3, 0x0a, 0x07, 0, 0x0c1c0000, 7, 0x00070000 },
{ 0x3, 0x0a, 0x08, 0, 0x0c1d0000, 8, 0x00080000 },
{ 0x3, 0x0b, 0x00, 0, 0x0c240000, 0, 0x00000000 },
{ 0x3, 0x0c, 0x00, 0, 0x0c250000, 0, 0x00000000 },
{ 0x3, 0x0d, 0x00, 0, 0x0c340000, 0, 0x00000000 },
{ 0x3, 0x0e, 0x00, 0, 0x0c260000, 0, 0x00000000 },
{ 0x3, 0x0f, 0x00, 0, 0x0c0f0000, 0, 0x00000000 },
{ 0x3, 0x0f, 0x01, 0, 0x0c100000, 1, 0x00010000 },
{ 0x3, 0x0f, 0x02, 0, 0x0c110000, 2, 0x00020000 },
{ 0x3, 0x0f, 0x03, 0, 0x0c120000, 3, 0x00030000 },
{ 0x3, 0x0f, 0x04, 0, 0x0c130000, 4, 0x00040000 },
{ 0x3, 0x0f, 0x05, 0, 0x0c140000, 5, 0x00050000 },
{ 0x3, 0x10, 0x00, 0, 0x0c290000, 0, 0x00000000 },
{ 0x3, 0x30, 0x00, 0, 0x20ce0000, 0, 0x00000000 },
{ 0x3, 0x31, 0x00, 0, 0x0c1f0000, 0, 0x00000000 },
{ 0x3, 0x31, 0x01, 0, 0x0c200000, 1, 0x00010000 },
{ 0x3, 0x31, 0x02, 0, 0x0c210000, 2, 0x00020000 },
{ 0x3, 0x31, 0x03, 0, 0x0c220000, 3, 0x00030000 },
{ 0x3, 0x32, 0x00, 0, 0x20cc0000, 3, 0x001c0000 },
{ 0x3, 0x32, 0x01, 0, 0x20c80000, 2, 0x00180000 },
{ 0x3, 0x32, 0x02, 0, 0x20c00000, 1, 0x00100000 },
{ 0x3, 0x32, 0x03, 0, 0x20b00000, 0, 0x00000000 },
{ 0x3, 0x33, 0x00, 0, 0x0c360000, 0, 0x00000000 },
{ 0x3, 0x33, 0x01, 0, 0x0c370000, 1, 0x00010000 },
{ 0x3, 0x33, 0x02, 0, 0x0c3a0000, 3, 0x00040000 },
{ 0x3, 0x33, 0x03, 0, 0x0c380000, 2, 0x00020000 },
{ 0x3, 0x38, 0x00, 0, 0x0c600000, 0, 0x00000000 },
{ 0x3, 0x38, 0x01, 0, 0x00000000, 0, 0x00000000 },
{ 0x3, 0x39, 0x00, 0, 0x0c280000, 0, 0x00000000 }
};
/*
* SCE/RCE NOC aperture lookup table as per file "AON_NOC_Structure.info".
*/
static const char * const tegra194_scenoc_routeid_initflow[] = {
[0x0] = "cbb_i/I/0" ,
[0x1] = "cpu_m_i/I/0" ,
[0x2] = "cpu_p_i/I/0" ,
[0x3] = "dma_m_i/I/0" ,
[0x4] = "dma_p_i/I/0" ,
[0x5] = "RESERVED" ,
[0x6] = "RESERVED" ,
[0x7] = "RESERVED"
};
static const char * const tegra194_scenoc_routeid_targflow[] = {
[0x00] = "multiport0_t/T/atcm_cfg" ,
[0x01] = "multiport0_t/T/car" ,
[0x02] = "multiport0_t/T/cast" ,
[0x03] = "multiport0_t/T/cfg" ,
[0x04] = "multiport0_t/T/dast" ,
[0x05] = "multiport0_t/T/dma" ,
[0x06] = "multiport0_t/T/err_collator" ,
[0x07] = "multiport0_t/T/err_collator_car" ,
[0x08] = "multiport0_t/T/fpga_misc" ,
[0x09] = "multiport0_t/T/fpga_uart" ,
[0x0a] = "multiport0_t/T/gte" ,
[0x0b] = "multiport0_t/T/hsp" ,
[0x0c] = "multiport0_t/T/misc" ,
[0x0d] = "multiport0_t/T/pm" ,
[0x0e] = "multiport0_t/T/tke" ,
[0x0f] = "RESERVED" ,
[0x10] = "multiport1_t/T/hsm" ,
[0x11] = "multiport1_t/T/vic0" ,
[0x12] = "multiport1_t/T/vic1" ,
[0x13] = "ast0_t/T/0" ,
[0x14] = "ast1_t/T/0" ,
[0x15] = "cbb_t/T/0" ,
[0x16] = "cpu_t/T/0" ,
[0x17] = "sce_noc_firewall/T/0" ,
[0x18] = "svc_t/T/0" ,
[0x19] = "RESERVED" ,
[0x1a] = "RESERVED" ,
[0x1b] = "RESERVED" ,
[0x1c] = "RESERVED" ,
[0x1d] = "RESERVED" ,
[0x1e] = "RESERVED" ,
[0x1f] = "RESERVED"
};
/*
* Fields of SCE/RCE NOC lookup table:
* Init flow, Targ flow, Targ subrange, Init mapping, Init localAddress,
* Targ mapping, Targ localAddress
* ----------------------------------------------------------------------------
*/
static const struct tegra194_cbb_aperture tegra194_scenoc_apert_lookup[] = {
{ 0x0, 0x16, 0x0, 0, 0x0b400000, 0, 0x0b400000 },
{ 0x0, 0x16, 0x1, 0, 0x0bc00000, 1, 0x0bc00000 },
{ 0x0, 0x0, 0x0, 0, 0x0b000000, 0, 0x00000000 },
{ 0x0, 0x0, 0x1, 0, 0x0b800000, 1, 0x00000000 },
{ 0x0, 0x1, 0x0, 0, 0x20de0000, 3, 0x000e0000 },
{ 0x0, 0x1, 0x1, 0, 0x210e0000, 7, 0x000e0000 },
{ 0x0, 0x1, 0x2, 0, 0x20dc0000, 2, 0x000c0000 },
{ 0x0, 0x1, 0x3, 0, 0x210c0000, 6, 0x000c0000 },
{ 0x0, 0x1, 0x4, 0, 0x20d80000, 1, 0x00080000 },
{ 0x0, 0x1, 0x5, 0, 0x21080000, 5, 0x00080000 },
{ 0x0, 0x1, 0x6, 0, 0x20d00000, 0, 0x00000000 },
{ 0x0, 0x1, 0x7, 0, 0x21000000, 4, 0x00000000 },
{ 0x0, 0x2, 0x0, 0, 0x0b040000, 0, 0x00000000 },
{ 0x0, 0x2, 0x1, 0, 0x0b840000, 1, 0x00000000 },
{ 0x0, 0x3, 0x0, 0, 0x0b230000, 0, 0x00000000 },
{ 0x0, 0x3, 0x1, 0, 0x0ba30000, 1, 0x00000000 },
{ 0x0, 0x4, 0x0, 0, 0x0b050000, 0, 0x00000000 },
{ 0x0, 0x4, 0x1, 0, 0x0b850000, 1, 0x00000000 },
{ 0x0, 0x5, 0x0, 0, 0x0b060000, 0, 0x00000000 },
{ 0x0, 0x5, 0x1, 0, 0x0b070000, 1, 0x00010000 },
{ 0x0, 0x5, 0x2, 0, 0x0b080000, 2, 0x00020000 },
{ 0x0, 0x5, 0x3, 0, 0x0b090000, 3, 0x00030000 },
{ 0x0, 0x5, 0x4, 0, 0x0b0a0000, 4, 0x00040000 },
{ 0x0, 0x5, 0x5, 0, 0x0b0b0000, 5, 0x00050000 },
{ 0x0, 0x5, 0x6, 0, 0x0b0c0000, 6, 0x00060000 },
{ 0x0, 0x5, 0x7, 0, 0x0b0d0000, 7, 0x00070000 },
{ 0x0, 0x5, 0x8, 0, 0x0b0e0000, 8, 0x00080000 },
{ 0x0, 0x5, 0x9, 0, 0x0b860000, 9, 0x00000000 },
{ 0x0, 0x5, 0xa, 0, 0x0b870000, 10, 0x00010000 },
{ 0x0, 0x5, 0xb, 0, 0x0b880000, 11, 0x00020000 },
{ 0x0, 0x5, 0xc, 0, 0x0b890000, 12, 0x00030000 },
{ 0x0, 0x5, 0xd, 0, 0x0b8a0000, 13, 0x00040000 },
{ 0x0, 0x5, 0xe, 0, 0x0b8b0000, 14, 0x00050000 },
{ 0x0, 0x5, 0xf, 0, 0x0b8c0000, 15, 0x00060000 },
{ 0x0, 0x5, 0x10, 0, 0x0b8d0000, 16, 0x00070000 },
{ 0x0, 0x5, 0x11, 0, 0x0b8e0000, 17, 0x00080000 },
{ 0x0, 0x6, 0x0, 0, 0x0b650000, 0, 0x00000000 },
{ 0x0, 0x6, 0x1, 0, 0x0be50000, 1, 0x00000000 },
{ 0x0, 0x7, 0x0, 0, 0x20df0000, 0, 0x00000000 },
{ 0x0, 0x7, 0x1, 0, 0x210f0000, 1, 0x00000000 },
{ 0x0, 0x8, 0x0, 0, 0x0b3e0000, 0, 0x00000000 },
{ 0x0, 0x8, 0x1, 0, 0x0bbe0000, 1, 0x00000000 },
{ 0x0, 0x9, 0x0, 0, 0x0b3d0000, 0, 0x00000000 },
{ 0x0, 0x9, 0x1, 0, 0x0bbd0000, 1, 0x00000000 },
{ 0x0, 0xa, 0x0, 0, 0x0b1e0000, 0, 0x00000000 },
{ 0x0, 0xa, 0x1, 0, 0x0b9e0000, 1, 0x00000000 },
{ 0x0, 0xb, 0x0, 0, 0x0b150000, 0, 0x00000000 },
{ 0x0, 0xb, 0x1, 0, 0x0b160000, 1, 0x00010000 },
{ 0x0, 0xb, 0x2, 0, 0x0b170000, 2, 0x00020000 },
{ 0x0, 0xb, 0x3, 0, 0x0b180000, 3, 0x00030000 },
{ 0x0, 0xb, 0x4, 0, 0x0b190000, 4, 0x00040000 },
{ 0x0, 0xb, 0x5, 0, 0x0b1a0000, 5, 0x00050000 },
{ 0x0, 0xb, 0x6, 0, 0x0b1b0000, 6, 0x00060000 },
{ 0x0, 0xb, 0x7, 0, 0x0b1c0000, 7, 0x00070000 },
{ 0x0, 0xb, 0x8, 0, 0x0b1d0000, 8, 0x00080000 },
{ 0x0, 0xb, 0x9, 0, 0x0b950000, 9, 0x00000000 },
{ 0x0, 0xb, 0xa, 0, 0x0b960000, 10, 0x00010000 },
{ 0x0, 0xb, 0xb, 0, 0x0b970000, 11, 0x00020000 },
{ 0x0, 0xb, 0xc, 0, 0x0b980000, 12, 0x00030000 },
{ 0x0, 0xb, 0xd, 0, 0x0b990000, 13, 0x00040000 },
{ 0x0, 0xb, 0xe, 0, 0x0b9a0000, 14, 0x00050000 },
{ 0x0, 0xb, 0xf, 0, 0x0b9b0000, 15, 0x00060000 },
{ 0x0, 0xb, 0x10, 0, 0x0b9c0000, 16, 0x00070000 },
{ 0x0, 0xb, 0x11, 0, 0x0b9d0000, 17, 0x00080000 },
{ 0x0, 0xc, 0x0, 0, 0x0b660000, 0, 0x00000000 },
{ 0x0, 0xc, 0x1, 0, 0x0be60000, 1, 0x00000000 },
{ 0x0, 0xd, 0x0, 0, 0x0b1f0000, 0, 0x00000000 },
{ 0x0, 0xd, 0x1, 0, 0x0b200000, 1, 0x00010000 },
{ 0x0, 0xd, 0x2, 0, 0x0b210000, 2, 0x00020000 },
{ 0x0, 0xd, 0x3, 0, 0x0b220000, 3, 0x00030000 },
{ 0x0, 0xd, 0x4, 0, 0x0b9f0000, 4, 0x00000000 },
{ 0x0, 0xd, 0x5, 0, 0x0ba00000, 5, 0x00010000 },
{ 0x0, 0xd, 0x6, 0, 0x0ba10000, 6, 0x00020000 },
{ 0x0, 0xd, 0x7, 0, 0x0ba20000, 7, 0x00030000 },
{ 0x0, 0xe, 0x0, 0, 0x0b0f0000, 0, 0x00000000 },
{ 0x0, 0xe, 0x1, 0, 0x0b100000, 1, 0x00010000 },
{ 0x0, 0xe, 0x2, 0, 0x0b110000, 2, 0x00020000 },
{ 0x0, 0xe, 0x3, 0, 0x0b120000, 3, 0x00030000 },
{ 0x0, 0xe, 0x4, 0, 0x0b130000, 4, 0x00040000 },
{ 0x0, 0xe, 0x5, 0, 0x0b140000, 5, 0x00050000 },
{ 0x0, 0xe, 0x6, 0, 0x0b8f0000, 6, 0x00000000 },
{ 0x0, 0xe, 0x7, 0, 0x0b900000, 7, 0x00010000 },
{ 0x0, 0xe, 0x8, 0, 0x0b910000, 8, 0x00020000 },
{ 0x0, 0xe, 0x9, 0, 0x0b920000, 9, 0x00030000 },
{ 0x0, 0xe, 0xa, 0, 0x0b930000, 10, 0x00040000 },
{ 0x0, 0xe, 0xb, 0, 0x0b940000, 11, 0x00050000 },
{ 0x0, 0x10, 0x0, 0, 0x0b240000, 0, 0x00000000 },
{ 0x0, 0x10, 0x1, 0, 0x0ba40000, 1, 0x00000000 },
{ 0x0, 0x11, 0x0, 0, 0x0b020000, 0, 0x00000000 },
{ 0x0, 0x11, 0x1, 0, 0x0b820000, 1, 0x00000000 },
{ 0x0, 0x12, 0x0, 0, 0x0b030000, 0, 0x00000000 },
{ 0x0, 0x12, 0x1, 0, 0x0b830000, 1, 0x00000000 },
{ 0x0, 0x17, 0x0, 0, 0x0b640000, 0, 0x00000000 },
{ 0x0, 0x17, 0x1, 0, 0x0be40000, 1, 0x00000000 },
{ 0x0, 0x18, 0x0, 0, 0x0b600000, 0, 0x00000000 },
{ 0x0, 0x18, 0x1, 0, 0x0be00000, 1, 0x00000000 },
{ 0x0, 0x18, 0x2, 0, 0x00000000, 0, 0x00000000 },
{ 0x0, 0x18, 0x3, 0, 0x00000000, 0, 0x00000000 },
{ 0x1, 0x13, 0x0, 0, 0x40000000, 0, 0x40000000 },
{ 0x1, 0x13, 0x1, 1, 0x80000000, 1, 0x80000000 },
{ 0x1, 0x13, 0x2, 0, 0x00000000, 0, 0x00000000 },
{ 0x2, 0x15, 0x0, 0, 0x20c00000, 8, 0x20c00000 },
{ 0x2, 0x15, 0x1, 0, 0x21100000, 22, 0x21100000 },
{ 0x2, 0x15, 0x2, 0, 0x20e00000, 9, 0x20e00000 },
{ 0x2, 0x15, 0x3, 0, 0x21200000, 23, 0x21200000 },
{ 0x2, 0x15, 0x4, 0, 0x20800000, 7, 0x20800000 },
{ 0x2, 0x15, 0x5, 0, 0x21400000, 24, 0x21400000 },
{ 0x2, 0x15, 0x6, 0, 0x0b000000, 18, 0x0b000000 },
{ 0x2, 0x15, 0x7, 0, 0x0b800000, 3, 0x0b800000 },
{ 0x2, 0x15, 0x8, 0, 0x20000000, 6, 0x20000000 },
{ 0x2, 0x15, 0x9, 0, 0x21800000, 25, 0x21800000 },
{ 0x2, 0x15, 0xa, 0, 0x0a000000, 2, 0x0a000000 },
{ 0x2, 0x15, 0xb, 0, 0x0a000000, 17, 0x0a000000 },
{ 0x2, 0x15, 0xc, 0, 0x20000000, 21, 0x20000000 },
{ 0x2, 0x15, 0xd, 0, 0x21000000, 10, 0x21000000 },
{ 0x2, 0x15, 0xe, 0, 0x08000000, 1, 0x08000000 },
{ 0x2, 0x15, 0xf, 0, 0x08000000, 16, 0x08000000 },
{ 0x2, 0x15, 0x10, 0, 0x22000000, 11, 0x22000000 },
{ 0x2, 0x15, 0x11, 0, 0x22000000, 26, 0x22000000 },
{ 0x2, 0x15, 0x12, 0, 0x0c000000, 4, 0x0c000000 },
{ 0x2, 0x15, 0x13, 0, 0x0c000000, 19, 0x0c000000 },
{ 0x2, 0x15, 0x14, 0, 0x24000000, 12, 0x24000000 },
{ 0x2, 0x15, 0x15, 0, 0x24000000, 27, 0x24000000 },
{ 0x2, 0x15, 0x16, 0, 0x00000000, 0, 0x00000000 },
{ 0x2, 0x15, 0x17, 0, 0x00000000, 15, 0x00000000 },
{ 0x2, 0x15, 0x18, 0, 0x28000000, 13, 0x28000000 },
{ 0x2, 0x15, 0x19, 0, 0x28000000, 28, 0x28000000 },
{ 0x2, 0x15, 0x1a, 0, 0x10000000, 5, 0x10000000 },
{ 0x2, 0x15, 0x1b, 0, 0x10000000, 20, 0x10000000 },
{ 0x2, 0x15, 0x1c, 0, 0x30000000, 14, 0x30000000 },
{ 0x2, 0x15, 0x1d, 0, 0x30000000, 29, 0x30000000 },
{ 0x2, 0x0, 0x0, 0, 0x0b000000, 0, 0x00000000 },
{ 0x2, 0x0, 0x1, 0, 0x0b800000, 1, 0x00000000 },
{ 0x2, 0x1, 0x0, 0, 0x20de0000, 3, 0x000e0000 },
{ 0x2, 0x1, 0x1, 0, 0x210e0000, 7, 0x000e0000 },
{ 0x2, 0x1, 0x2, 0, 0x20dc0000, 2, 0x000c0000 },
{ 0x2, 0x1, 0x3, 0, 0x210c0000, 6, 0x000c0000 },
{ 0x2, 0x1, 0x4, 0, 0x20d80000, 1, 0x00080000 },
{ 0x2, 0x1, 0x5, 0, 0x21080000, 5, 0x00080000 },
{ 0x2, 0x1, 0x6, 0, 0x20d00000, 0, 0x00000000 },
{ 0x2, 0x1, 0x7, 0, 0x21000000, 4, 0x00000000 },
{ 0x2, 0x2, 0x0, 0, 0x0b040000, 0, 0x00000000 },
{ 0x2, 0x2, 0x1, 0, 0x0b840000, 1, 0x00000000 },
{ 0x2, 0x3, 0x0, 0, 0x0b230000, 0, 0x00000000 },
{ 0x2, 0x3, 0x1, 0, 0x0ba30000, 1, 0x00000000 },
{ 0x2, 0x4, 0x0, 0, 0x0b050000, 0, 0x00000000 },
{ 0x2, 0x4, 0x1, 0, 0x0b850000, 1, 0x00000000 },
{ 0x2, 0x5, 0x0, 0, 0x0b060000, 0, 0x00000000 },
{ 0x2, 0x5, 0x1, 0, 0x0b070000, 1, 0x00010000 },
{ 0x2, 0x5, 0x2, 0, 0x0b080000, 2, 0x00020000 },
{ 0x2, 0x5, 0x3, 0, 0x0b090000, 3, 0x00030000 },
{ 0x2, 0x5, 0x4, 0, 0x0b0a0000, 4, 0x00040000 },
{ 0x2, 0x5, 0x5, 0, 0x0b0b0000, 5, 0x00050000 },
{ 0x2, 0x5, 0x6, 0, 0x0b0c0000, 6, 0x00060000 },
{ 0x2, 0x5, 0x7, 0, 0x0b0d0000, 7, 0x00070000 },
{ 0x2, 0x5, 0x8, 0, 0x0b0e0000, 8, 0x00080000 },
{ 0x2, 0x5, 0x9, 0, 0x0b860000, 9, 0x00000000 },
{ 0x2, 0x5, 0xa, 0, 0x0b870000, 10, 0x00010000 },
{ 0x2, 0x5, 0xb, 0, 0x0b880000, 11, 0x00020000 },
{ 0x2, 0x5, 0xc, 0, 0x0b890000, 12, 0x00030000 },
{ 0x2, 0x5, 0xd, 0, 0x0b8a0000, 13, 0x00040000 },
{ 0x2, 0x5, 0xe, 0, 0x0b8b0000, 14, 0x00050000 },
{ 0x2, 0x5, 0xf, 0, 0x0b8c0000, 15, 0x00060000 },
{ 0x2, 0x5, 0x10, 0, 0x0b8d0000, 16, 0x00070000 },
{ 0x2, 0x5, 0x11, 0, 0x0b8e0000, 17, 0x00080000 },
{ 0x2, 0x6, 0x0, 0, 0x0b650000, 0, 0x00000000 },
{ 0x2, 0x6, 0x1, 0, 0x0be50000, 1, 0x00000000 },
{ 0x2, 0x7, 0x0, 0, 0x20df0000, 0, 0x00000000 },
{ 0x2, 0x7, 0x1, 0, 0x210f0000, 1, 0x00000000 },
{ 0x2, 0x8, 0x0, 0, 0x0b3e0000, 0, 0x00000000 },
{ 0x2, 0x8, 0x1, 0, 0x0bbe0000, 1, 0x00000000 },
{ 0x2, 0x9, 0x0, 0, 0x0b3d0000, 0, 0x00000000 },
{ 0x2, 0x9, 0x1, 0, 0x0bbd0000, 1, 0x00000000 },
{ 0x2, 0xa, 0x0, 0, 0x0b1e0000, 0, 0x00000000 },
{ 0x2, 0xa, 0x1, 0, 0x0b9e0000, 1, 0x00000000 },
{ 0x2, 0xb, 0x0, 0, 0x0b150000, 0, 0x00000000 },
{ 0x2, 0xb, 0x1, 0, 0x0b160000, 1, 0x00010000 },
{ 0x2, 0xb, 0x2, 0, 0x0b170000, 2, 0x00020000 },
{ 0x2, 0xb, 0x3, 0, 0x0b180000, 3, 0x00030000 },
{ 0x2, 0xb, 0x4, 0, 0x0b190000, 4, 0x00040000 },
{ 0x2, 0xb, 0x5, 0, 0x0b1a0000, 5, 0x00050000 },
{ 0x2, 0xb, 0x6, 0, 0x0b1b0000, 6, 0x00060000 },
{ 0x2, 0xb, 0x7, 0, 0x0b1c0000, 7, 0x00070000 },
{ 0x2, 0xb, 0x8, 0, 0x0b1d0000, 8, 0x00080000 },
{ 0x2, 0xb, 0x9, 0, 0x0b950000, 9, 0x00000000 },
{ 0x2, 0xb, 0xa, 0, 0x0b960000, 10, 0x00010000 },
{ 0x2, 0xb, 0xb, 0, 0x0b970000, 11, 0x00020000 },
{ 0x2, 0xb, 0xc, 0, 0x0b980000, 12, 0x00030000 },
{ 0x2, 0xb, 0xd, 0, 0x0b990000, 13, 0x00040000 },
{ 0x2, 0xb, 0xe, 0, 0x0b9a0000, 14, 0x00050000 },
{ 0x2, 0xb, 0xf, 0, 0x0b9b0000, 15, 0x00060000 },
{ 0x2, 0xb, 0x10, 0, 0x0b9c0000, 16, 0x00070000 },
{ 0x2, 0xb, 0x11, 0, 0x0b9d0000, 17, 0x00080000 },
{ 0x2, 0xc, 0x0, 0, 0x0b660000, 0, 0x00000000 },
{ 0x2, 0xc, 0x1, 0, 0x0be60000, 1, 0x00000000 },
{ 0x2, 0xd, 0x0, 0, 0x0b1f0000, 0, 0x00000000 },
{ 0x2, 0xd, 0x1, 0, 0x0b200000, 1, 0x00010000 },
{ 0x2, 0xd, 0x2, 0, 0x0b210000, 2, 0x00020000 },
{ 0x2, 0xd, 0x3, 0, 0x0b220000, 3, 0x00030000 },
{ 0x2, 0xd, 0x4, 0, 0x0b9f0000, 4, 0x00000000 },
{ 0x2, 0xd, 0x5, 0, 0x0ba00000, 5, 0x00010000 },
{ 0x2, 0xd, 0x6, 0, 0x0ba10000, 6, 0x00020000 },
{ 0x2, 0xd, 0x7, 0, 0x0ba20000, 7, 0x00030000 },
{ 0x2, 0xe, 0x0, 0, 0x0b0f0000, 0, 0x00000000 },
--> --------------------
--> maximum size reached
--> --------------------
Messung V0.5 C=99 H=100 G=99