tegrakernel/kernel/nvidia/include/linux/platform/tegra/tegra_cbb.h

171 lines
5.8 KiB
C
Raw Permalink Normal View History

2022-02-16 09:13:02 -06:00
/*
* Copyright (c) 2017-2020, NVIDIA CORPORATION. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms and conditions of the GNU General Public License,
* version 2, as published by the Free Software Foundation.
*
* This program is distributed in the hope it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*/
#define OFF_ERRLOGGER_0_ID_COREID_0 0x00000000
#define OFF_ERRLOGGER_0_ID_REVISIONID_0 0x00000004
#define OFF_ERRLOGGER_0_FAULTEN_0 0x00000008
#define OFF_ERRLOGGER_0_ERRVLD_0 0x0000000c
#define OFF_ERRLOGGER_0_ERRCLR_0 0x00000010
#define OFF_ERRLOGGER_0_ERRLOG0_0 0x00000014
#define OFF_ERRLOGGER_0_ERRLOG1_0 0x00000018
#define OFF_ERRLOGGER_0_RESERVED_00_0 0x0000001c
#define OFF_ERRLOGGER_0_ERRLOG3_0 0x00000020
#define OFF_ERRLOGGER_0_ERRLOG4_0 0x00000024
#define OFF_ERRLOGGER_0_ERRLOG5_0 0x00000028
#define OFF_ERRLOGGER_0_STALLEN_0 0x00000038
#define OFF_ERRLOGGER_1_ID_COREID_0 0x00000080
#define OFF_ERRLOGGER_1_ID_REVISIONID_0 0x00000084
#define OFF_ERRLOGGER_1_FAULTEN_0 0x00000088
#define OFF_ERRLOGGER_1_ERRVLD_0 0x0000008c
#define OFF_ERRLOGGER_1_ERRCLR_0 0x00000090
#define OFF_ERRLOGGER_1_ERRLOG0_0 0x00000094
#define OFF_ERRLOGGER_1_ERRLOG1_0 0x00000098
#define OFF_ERRLOGGER_1_RESERVED_00_0 0x0000009c
#define OFF_ERRLOGGER_1_ERRLOG3_0 0x000000A0
#define OFF_ERRLOGGER_1_ERRLOG4_0 0x000000A4
#define OFF_ERRLOGGER_1_ERRLOG5_0 0x000000A8
#define OFF_ERRLOGGER_1_STALLEN_0 0x000000b8
#define OFF_ERRLOGGER_2_ID_COREID_0 0x00000100
#define OFF_ERRLOGGER_2_ID_REVISIONID_0 0x00000104
#define OFF_ERRLOGGER_2_FAULTEN_0 0x00000108
#define OFF_ERRLOGGER_2_ERRVLD_0 0x0000010c
#define OFF_ERRLOGGER_2_ERRCLR_0 0x00000110
#define OFF_ERRLOGGER_2_ERRLOG0_0 0x00000114
#define OFF_ERRLOGGER_2_ERRLOG1_0 0x00000118
#define OFF_ERRLOGGER_2_RESERVED_00_0 0x0000011c
#define OFF_ERRLOGGER_2_ERRLOG3_0 0x00000120
#define OFF_ERRLOGGER_2_ERRLOG4_0 0x00000124
#define OFF_ERRLOGGER_2_ERRLOG5_0 0x00000128
#define OFF_ERRLOGGER_2_STALLEN_0 0x00000138
#define DMAAPB_X_RAW_INTERRUPT_STATUS 0x2ec
#define CBB_BIT(_bit_) (1ULL << (_bit_))
#define CBB_MASK(_msb_, _lsb_) \
((CBB_BIT(_msb_+1) - 1) & ~(CBB_BIT(_lsb_) - 1))
#define CBB_EXTRACT(_x_, _msb_, _lsb_) \
((_x_ & CBB_MASK(_msb_, _lsb_)) >> _lsb_)
#define get_noc_errlog_subfield(_x_, _msb_, _lsb_) \
CBB_EXTRACT(_x_, _msb_, _lsb_)
struct tegra_noc_errors {
char *errcode;
char *src;
char *type;
};
struct tegra_noc_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 tegra_lookup_noc_aperture {
u8 initflow;
u8 targflow;
u8 targ_subrange;
u8 init_mapping;
u32 init_localaddress;
u8 targ_mapping;
u32 targ_localaddress;
u16 seqid;
};
struct tegra_noc_userbits {
u8 axcache;
u8 non_mod;
u8 axprot;
u8 falconsec;
u8 grpsec;
u8 vqc;
u8 mstr_id;
u8 axi_id;
};
struct tegra_cbb_errlog_record {
struct list_head node;
struct serr_hook *callback;
char *name;
phys_addr_t start;
void __iomem *vaddr;
int noc_secure_irq;
int noc_nonsecure_irq;
u32 errlog0;
u32 errlog1;
u32 errlog2;
u32 errlog3;
u32 errlog4;
u32 errlog5;
u32 errlog6; //RESERVED
u32 errlog7; //RESERVED
u32 errlog8; //RESERVED
unsigned int (*errvld)(void __iomem *addr);
void (*errclr)(void __iomem *addr);
void (*faulten)(void __iomem *addr);
void (*stallen)(void __iomem *addr);
void (*tegra_noc_parse_routeid)
(struct tegra_lookup_noc_aperture *, u64);
void (*tegra_noc_parse_userbits)
(struct tegra_noc_userbits *, u64);
struct tegra_lookup_noc_aperture *noc_aperture;
int max_noc_aperture;
char **tegra_noc_routeid_initflow;
char **tegra_noc_routeid_targflow;
char **tegra_cbb_master_id;
bool is_ax2apb_bridge_connected;
void __iomem **axi2abp_bases;
int apb_bridge_cnt;
bool is_clk_rst;
int (*is_cluster_probed)(void);
int (*is_clk_enabled)(void);
int (*tegra_noc_en_clk_rpm)(void);
int (*tegra_noc_dis_clk_rpm)(void);
int (*tegra_noc_en_clk_no_rpm)(void);
int (*tegra_noc_dis_clk_no_rpm)(void);
};
struct tegra_cbb_noc_data {
char *name;
unsigned int (*errvld)(void __iomem *addr);
void (*errclr)(void __iomem *addr);
void (*faulten)(void __iomem *addr);
void (*stallen)(void __iomem *addr);
void (*tegra_noc_parse_routeid)
(struct tegra_lookup_noc_aperture *, u64);
void (*tegra_noc_parse_userbits)
(struct tegra_noc_userbits *, u64);
struct tegra_lookup_noc_aperture *noc_aperture;
int max_error;
int max_noc_aperture;
char **tegra_noc_routeid_initflow;
char **tegra_noc_routeid_targflow;
char **tegra_cbb_master_id;
bool is_ax2apb_bridge_connected;
bool is_clk_rst;
bool erd_mask_inband_err;
u64 off_erd_err_config;
int (*is_cluster_probed)(void);
int (*is_clk_enabled)(void);
int (*tegra_noc_en_clk_rpm)(void);
int (*tegra_noc_dis_clk_rpm)(void);
int (*tegra_noc_en_clk_no_rpm)(void);
int (*tegra_noc_dis_clk_no_rpm)(void);
};