189214fe9SHaiyue Wang /* SPDX-License-Identifier: BSD-3-Clause 27815caa6SQi Zhang * Copyright(c) 2001-2021 Intel Corporation 389214fe9SHaiyue Wang */ 489214fe9SHaiyue Wang 589214fe9SHaiyue Wang #ifndef _IAVF_REGISTER_H_ 689214fe9SHaiyue Wang #define _IAVF_REGISTER_H_ 789214fe9SHaiyue Wang 889214fe9SHaiyue Wang #define IAVF_VF_ARQBAH1 0x00006000 /* Reset: EMPR */ 989214fe9SHaiyue Wang #define IAVF_VF_ARQBAL1 0x00006C00 /* Reset: EMPR */ 1089214fe9SHaiyue Wang #define IAVF_VF_ARQH1 0x00007400 /* Reset: EMPR */ 1189214fe9SHaiyue Wang #define IAVF_VF_ARQH1_ARQH_SHIFT 0 1289214fe9SHaiyue Wang #define IAVF_VF_ARQH1_ARQH_MASK IAVF_MASK(0x3FF, IAVF_VF_ARQH1_ARQH_SHIFT) 1389214fe9SHaiyue Wang #define IAVF_VF_ARQLEN1 0x00008000 /* Reset: EMPR */ 1489214fe9SHaiyue Wang #define IAVF_VF_ARQLEN1_ARQVFE_SHIFT 28 1589214fe9SHaiyue Wang #define IAVF_VF_ARQLEN1_ARQVFE_MASK IAVF_MASK(1UL, IAVF_VF_ARQLEN1_ARQVFE_SHIFT) 1689214fe9SHaiyue Wang #define IAVF_VF_ARQLEN1_ARQOVFL_SHIFT 29 1789214fe9SHaiyue Wang #define IAVF_VF_ARQLEN1_ARQOVFL_MASK IAVF_MASK(1UL, IAVF_VF_ARQLEN1_ARQOVFL_SHIFT) 1889214fe9SHaiyue Wang #define IAVF_VF_ARQLEN1_ARQCRIT_SHIFT 30 1989214fe9SHaiyue Wang #define IAVF_VF_ARQLEN1_ARQCRIT_MASK IAVF_MASK(1UL, IAVF_VF_ARQLEN1_ARQCRIT_SHIFT) 2089214fe9SHaiyue Wang #define IAVF_VF_ARQLEN1_ARQENABLE_SHIFT 31 2189214fe9SHaiyue Wang #define IAVF_VF_ARQLEN1_ARQENABLE_MASK IAVF_MASK(1UL, IAVF_VF_ARQLEN1_ARQENABLE_SHIFT) 2289214fe9SHaiyue Wang #define IAVF_VF_ARQT1 0x00007000 /* Reset: EMPR */ 2389214fe9SHaiyue Wang #define IAVF_VF_ATQBAH1 0x00007800 /* Reset: EMPR */ 2489214fe9SHaiyue Wang #define IAVF_VF_ATQBAL1 0x00007C00 /* Reset: EMPR */ 2589214fe9SHaiyue Wang #define IAVF_VF_ATQH1 0x00006400 /* Reset: EMPR */ 2689214fe9SHaiyue Wang #define IAVF_VF_ATQLEN1 0x00006800 /* Reset: EMPR */ 2789214fe9SHaiyue Wang #define IAVF_VF_ATQLEN1_ATQVFE_SHIFT 28 2889214fe9SHaiyue Wang #define IAVF_VF_ATQLEN1_ATQVFE_MASK IAVF_MASK(1UL, IAVF_VF_ATQLEN1_ATQVFE_SHIFT) 2989214fe9SHaiyue Wang #define IAVF_VF_ATQLEN1_ATQOVFL_SHIFT 29 3089214fe9SHaiyue Wang #define IAVF_VF_ATQLEN1_ATQOVFL_MASK IAVF_MASK(1UL, IAVF_VF_ATQLEN1_ATQOVFL_SHIFT) 3189214fe9SHaiyue Wang #define IAVF_VF_ATQLEN1_ATQCRIT_SHIFT 30 3289214fe9SHaiyue Wang #define IAVF_VF_ATQLEN1_ATQCRIT_MASK IAVF_MASK(1UL, IAVF_VF_ATQLEN1_ATQCRIT_SHIFT) 3389214fe9SHaiyue Wang #define IAVF_VF_ATQLEN1_ATQENABLE_SHIFT 31 3489214fe9SHaiyue Wang #define IAVF_VF_ATQLEN1_ATQENABLE_MASK IAVF_MASK(1UL, IAVF_VF_ATQLEN1_ATQENABLE_SHIFT) 3589214fe9SHaiyue Wang #define IAVF_VF_ATQT1 0x00008400 /* Reset: EMPR */ 3689214fe9SHaiyue Wang #define IAVF_VFGEN_RSTAT 0x00008800 /* Reset: VFR */ 3789214fe9SHaiyue Wang #define IAVF_VFGEN_RSTAT_VFR_STATE_SHIFT 0 3889214fe9SHaiyue Wang #define IAVF_VFGEN_RSTAT_VFR_STATE_MASK IAVF_MASK(0x3, IAVF_VFGEN_RSTAT_VFR_STATE_SHIFT) 3989214fe9SHaiyue Wang #define IAVF_VFINT_DYN_CTL01 0x00005C00 /* Reset: VFR */ 4089214fe9SHaiyue Wang #define IAVF_VFINT_DYN_CTL01_INTENA_SHIFT 0 4189214fe9SHaiyue Wang #define IAVF_VFINT_DYN_CTL01_INTENA_MASK IAVF_MASK(1UL, IAVF_VFINT_DYN_CTL01_INTENA_SHIFT) 4289214fe9SHaiyue Wang #define IAVF_VFINT_DYN_CTL01_CLEARPBA_SHIFT 1 4389214fe9SHaiyue Wang #define IAVF_VFINT_DYN_CTL01_CLEARPBA_MASK IAVF_MASK(1UL, IAVF_VFINT_DYN_CTL01_CLEARPBA_SHIFT) 4489214fe9SHaiyue Wang #define IAVF_VFINT_DYN_CTL01_SWINT_TRIG_SHIFT 2 4589214fe9SHaiyue Wang #define IAVF_VFINT_DYN_CTL01_SWINT_TRIG_MASK IAVF_MASK(1UL, IAVF_VFINT_DYN_CTL01_SWINT_TRIG_SHIFT) 4689214fe9SHaiyue Wang #define IAVF_VFINT_DYN_CTL01_ITR_INDX_SHIFT 3 4789214fe9SHaiyue Wang #define IAVF_VFINT_DYN_CTL01_ITR_INDX_MASK IAVF_MASK(0x3, IAVF_VFINT_DYN_CTL01_ITR_INDX_SHIFT) 4889214fe9SHaiyue Wang #define IAVF_VFINT_DYN_CTL01_INTERVAL_SHIFT 5 4989214fe9SHaiyue Wang #define IAVF_VFINT_DYN_CTL01_INTERVAL_MASK IAVF_MASK(0xFFF, IAVF_VFINT_DYN_CTL01_INTERVAL_SHIFT) 5089214fe9SHaiyue Wang #define IAVF_VFINT_DYN_CTL01_SW_ITR_INDX_ENA_SHIFT 24 5189214fe9SHaiyue Wang #define IAVF_VFINT_DYN_CTL01_SW_ITR_INDX_ENA_MASK IAVF_MASK(1UL, IAVF_VFINT_DYN_CTL01_SW_ITR_INDX_ENA_SHIFT) 5289214fe9SHaiyue Wang #define IAVF_VFINT_DYN_CTL01_SW_ITR_INDX_SHIFT 25 5389214fe9SHaiyue Wang #define IAVF_VFINT_DYN_CTL01_SW_ITR_INDX_MASK IAVF_MASK(0x3, IAVF_VFINT_DYN_CTL01_SW_ITR_INDX_SHIFT) 54*1cc2ffd1SAhmed Zaki #define IAVF_VFINT_DYN_CTLN1_MAX_INDEX 63 55*1cc2ffd1SAhmed Zaki #define IAVF_VFINT_DYN_CTLN1(_INTVF) (0x00003800 + ((_INTVF) * 4)) /* _i=0...63 */ /* Reset: VFR */ 5689214fe9SHaiyue Wang #define IAVF_VFINT_DYN_CTLN1_INTENA_SHIFT 0 5789214fe9SHaiyue Wang #define IAVF_VFINT_DYN_CTLN1_INTENA_MASK IAVF_MASK(1UL, IAVF_VFINT_DYN_CTLN1_INTENA_SHIFT) 5889214fe9SHaiyue Wang #define IAVF_VFINT_DYN_CTLN1_CLEARPBA_SHIFT 1 5989214fe9SHaiyue Wang #define IAVF_VFINT_DYN_CTLN1_CLEARPBA_MASK IAVF_MASK(1UL, IAVF_VFINT_DYN_CTLN1_CLEARPBA_SHIFT) 6089214fe9SHaiyue Wang #define IAVF_VFINT_DYN_CTLN1_SWINT_TRIG_SHIFT 2 6189214fe9SHaiyue Wang #define IAVF_VFINT_DYN_CTLN1_SWINT_TRIG_MASK IAVF_MASK(1UL, IAVF_VFINT_DYN_CTLN1_SWINT_TRIG_SHIFT) 6289214fe9SHaiyue Wang #define IAVF_VFINT_DYN_CTLN1_ITR_INDX_SHIFT 3 6389214fe9SHaiyue Wang #define IAVF_VFINT_DYN_CTLN1_ITR_INDX_MASK IAVF_MASK(0x3, IAVF_VFINT_DYN_CTLN1_ITR_INDX_SHIFT) 6489214fe9SHaiyue Wang #define IAVF_VFINT_DYN_CTLN1_INTERVAL_SHIFT 5 6589214fe9SHaiyue Wang #define IAVF_VFINT_DYN_CTLN1_INTERVAL_MASK IAVF_MASK(0xFFF, IAVF_VFINT_DYN_CTLN1_INTERVAL_SHIFT) 6689214fe9SHaiyue Wang #define IAVF_VFINT_DYN_CTLN1_SW_ITR_INDX_ENA_SHIFT 24 6789214fe9SHaiyue Wang #define IAVF_VFINT_DYN_CTLN1_SW_ITR_INDX_ENA_MASK IAVF_MASK(1UL, IAVF_VFINT_DYN_CTLN1_SW_ITR_INDX_ENA_SHIFT) 6889214fe9SHaiyue Wang #define IAVF_VFINT_DYN_CTLN1_SW_ITR_INDX_SHIFT 25 6989214fe9SHaiyue Wang #define IAVF_VFINT_DYN_CTLN1_SW_ITR_INDX_MASK IAVF_MASK(0x3, IAVF_VFINT_DYN_CTLN1_SW_ITR_INDX_SHIFT) 7089214fe9SHaiyue Wang #define IAVF_VFINT_ICR0_ENA1 0x00005000 /* Reset: CORER */ 7189214fe9SHaiyue Wang #define IAVF_VFINT_ICR0_ENA1_ADMINQ_SHIFT 30 7289214fe9SHaiyue Wang #define IAVF_VFINT_ICR0_ENA1_ADMINQ_MASK IAVF_MASK(1UL, IAVF_VFINT_ICR0_ENA1_ADMINQ_SHIFT) 7389214fe9SHaiyue Wang #define IAVF_VFINT_ICR0_ENA1_RSVD_SHIFT 31 7489214fe9SHaiyue Wang #define IAVF_VFINT_ICR01 0x00004800 /* Reset: CORER */ 7589214fe9SHaiyue Wang #define IAVF_VFINT_ICR01_QUEUE_0_SHIFT 1 7689214fe9SHaiyue Wang #define IAVF_VFINT_ICR01_QUEUE_0_MASK IAVF_MASK(1UL, IAVF_VFINT_ICR01_QUEUE_0_SHIFT) 7789214fe9SHaiyue Wang #define IAVF_VFINT_ICR01_LINK_STAT_CHANGE_SHIFT 25 7889214fe9SHaiyue Wang #define IAVF_VFINT_ICR01_LINK_STAT_CHANGE_MASK IAVF_MASK(1UL, IAVF_VFINT_ICR01_LINK_STAT_CHANGE_SHIFT) 7989214fe9SHaiyue Wang #define IAVF_VFINT_ICR01_ADMINQ_SHIFT 30 8089214fe9SHaiyue Wang #define IAVF_VFINT_ICR01_ADMINQ_MASK IAVF_MASK(1UL, IAVF_VFINT_ICR01_ADMINQ_SHIFT) 8189214fe9SHaiyue Wang #define IAVF_VFINT_ITR01(_i) (0x00004C00 + ((_i) * 4)) /* _i=0...2 */ /* Reset: VFR */ 8289214fe9SHaiyue Wang #define IAVF_VFINT_ITRN1(_i, _INTVF) (0x00002800 + ((_i) * 64 + (_INTVF) * 4)) /* _i=0...2, _INTVF=0...15 */ /* Reset: VFR */ 8389214fe9SHaiyue Wang #define IAVF_VFINT_STAT_CTL01 0x00005400 /* Reset: CORER */ 8489214fe9SHaiyue Wang #define IAVF_QRX_TAIL1(_Q) (0x00002000 + ((_Q) * 4)) /* _i=0...15 */ /* Reset: CORER */ 8589214fe9SHaiyue Wang #define IAVF_QTX_TAIL1(_Q) (0x00000000 + ((_Q) * 4)) /* _i=0...15 */ /* Reset: PFR */ 8689214fe9SHaiyue Wang #define IAVF_VFQF_HENA(_i) (0x0000C400 + ((_i) * 4)) /* _i=0...1 */ /* Reset: CORER */ 8789214fe9SHaiyue Wang #define IAVF_VFQF_HKEY(_i) (0x0000CC00 + ((_i) * 4)) /* _i=0...12 */ /* Reset: CORER */ 8889214fe9SHaiyue Wang #define IAVF_VFQF_HKEY_MAX_INDEX 12 8989214fe9SHaiyue Wang #define IAVF_VFQF_HLUT(_i) (0x0000D000 + ((_i) * 4)) /* _i=0...15 */ /* Reset: CORER */ 9089214fe9SHaiyue Wang #define IAVF_VFQF_HLUT_MAX_INDEX 15 9189214fe9SHaiyue Wang #define IAVF_VFINT_DYN_CTLN1_WB_ON_ITR_SHIFT 30 9289214fe9SHaiyue Wang #define IAVF_VFINT_DYN_CTLN1_WB_ON_ITR_MASK IAVF_MASK(1UL, IAVF_VFINT_DYN_CTLN1_WB_ON_ITR_SHIFT) 9389214fe9SHaiyue Wang 9489214fe9SHaiyue Wang #endif /* _IAVF_REGISTER_H_ */ 95