1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-2.0 */ 2*4882a593Smuzhiyun /* Copyright(c) 2013 - 2018 Intel Corporation. */ 3*4882a593Smuzhiyun 4*4882a593Smuzhiyun #ifndef _IAVF_REGISTER_H_ 5*4882a593Smuzhiyun #define _IAVF_REGISTER_H_ 6*4882a593Smuzhiyun 7*4882a593Smuzhiyun #define IAVF_VF_ARQBAH1 0x00006000 /* Reset: EMPR */ 8*4882a593Smuzhiyun #define IAVF_VF_ARQBAL1 0x00006C00 /* Reset: EMPR */ 9*4882a593Smuzhiyun #define IAVF_VF_ARQH1 0x00007400 /* Reset: EMPR */ 10*4882a593Smuzhiyun #define IAVF_VF_ARQH1_ARQH_SHIFT 0 11*4882a593Smuzhiyun #define IAVF_VF_ARQH1_ARQH_MASK IAVF_MASK(0x3FF, IAVF_VF_ARQH1_ARQH_SHIFT) 12*4882a593Smuzhiyun #define IAVF_VF_ARQLEN1 0x00008000 /* Reset: EMPR */ 13*4882a593Smuzhiyun #define IAVF_VF_ARQLEN1_ARQVFE_SHIFT 28 14*4882a593Smuzhiyun #define IAVF_VF_ARQLEN1_ARQVFE_MASK IAVF_MASK(0x1, IAVF_VF_ARQLEN1_ARQVFE_SHIFT) 15*4882a593Smuzhiyun #define IAVF_VF_ARQLEN1_ARQOVFL_SHIFT 29 16*4882a593Smuzhiyun #define IAVF_VF_ARQLEN1_ARQOVFL_MASK IAVF_MASK(0x1, IAVF_VF_ARQLEN1_ARQOVFL_SHIFT) 17*4882a593Smuzhiyun #define IAVF_VF_ARQLEN1_ARQCRIT_SHIFT 30 18*4882a593Smuzhiyun #define IAVF_VF_ARQLEN1_ARQCRIT_MASK IAVF_MASK(0x1, IAVF_VF_ARQLEN1_ARQCRIT_SHIFT) 19*4882a593Smuzhiyun #define IAVF_VF_ARQLEN1_ARQENABLE_SHIFT 31 20*4882a593Smuzhiyun #define IAVF_VF_ARQLEN1_ARQENABLE_MASK IAVF_MASK(0x1, IAVF_VF_ARQLEN1_ARQENABLE_SHIFT) 21*4882a593Smuzhiyun #define IAVF_VF_ARQT1 0x00007000 /* Reset: EMPR */ 22*4882a593Smuzhiyun #define IAVF_VF_ATQBAH1 0x00007800 /* Reset: EMPR */ 23*4882a593Smuzhiyun #define IAVF_VF_ATQBAL1 0x00007C00 /* Reset: EMPR */ 24*4882a593Smuzhiyun #define IAVF_VF_ATQH1 0x00006400 /* Reset: EMPR */ 25*4882a593Smuzhiyun #define IAVF_VF_ATQLEN1 0x00006800 /* Reset: EMPR */ 26*4882a593Smuzhiyun #define IAVF_VF_ATQLEN1_ATQVFE_SHIFT 28 27*4882a593Smuzhiyun #define IAVF_VF_ATQLEN1_ATQVFE_MASK IAVF_MASK(0x1, IAVF_VF_ATQLEN1_ATQVFE_SHIFT) 28*4882a593Smuzhiyun #define IAVF_VF_ATQLEN1_ATQOVFL_SHIFT 29 29*4882a593Smuzhiyun #define IAVF_VF_ATQLEN1_ATQOVFL_MASK IAVF_MASK(0x1, IAVF_VF_ATQLEN1_ATQOVFL_SHIFT) 30*4882a593Smuzhiyun #define IAVF_VF_ATQLEN1_ATQCRIT_SHIFT 30 31*4882a593Smuzhiyun #define IAVF_VF_ATQLEN1_ATQCRIT_MASK IAVF_MASK(0x1, IAVF_VF_ATQLEN1_ATQCRIT_SHIFT) 32*4882a593Smuzhiyun #define IAVF_VF_ATQLEN1_ATQENABLE_SHIFT 31 33*4882a593Smuzhiyun #define IAVF_VF_ATQLEN1_ATQENABLE_MASK IAVF_MASK(0x1, IAVF_VF_ATQLEN1_ATQENABLE_SHIFT) 34*4882a593Smuzhiyun #define IAVF_VF_ATQT1 0x00008400 /* Reset: EMPR */ 35*4882a593Smuzhiyun #define IAVF_VFGEN_RSTAT 0x00008800 /* Reset: VFR */ 36*4882a593Smuzhiyun #define IAVF_VFGEN_RSTAT_VFR_STATE_SHIFT 0 37*4882a593Smuzhiyun #define IAVF_VFGEN_RSTAT_VFR_STATE_MASK IAVF_MASK(0x3, IAVF_VFGEN_RSTAT_VFR_STATE_SHIFT) 38*4882a593Smuzhiyun #define IAVF_VFINT_DYN_CTL01 0x00005C00 /* Reset: VFR */ 39*4882a593Smuzhiyun #define IAVF_VFINT_DYN_CTL01_INTENA_SHIFT 0 40*4882a593Smuzhiyun #define IAVF_VFINT_DYN_CTL01_INTENA_MASK IAVF_MASK(0x1, IAVF_VFINT_DYN_CTL01_INTENA_SHIFT) 41*4882a593Smuzhiyun #define IAVF_VFINT_DYN_CTL01_ITR_INDX_SHIFT 3 42*4882a593Smuzhiyun #define IAVF_VFINT_DYN_CTL01_ITR_INDX_MASK IAVF_MASK(0x3, IAVF_VFINT_DYN_CTL01_ITR_INDX_SHIFT) 43*4882a593Smuzhiyun #define IAVF_VFINT_DYN_CTLN1(_INTVF) (0x00003800 + ((_INTVF) * 4)) /* _i=0...15 */ /* Reset: VFR */ 44*4882a593Smuzhiyun #define IAVF_VFINT_DYN_CTLN1_INTENA_SHIFT 0 45*4882a593Smuzhiyun #define IAVF_VFINT_DYN_CTLN1_INTENA_MASK IAVF_MASK(0x1, IAVF_VFINT_DYN_CTLN1_INTENA_SHIFT) 46*4882a593Smuzhiyun #define IAVF_VFINT_DYN_CTLN1_SWINT_TRIG_SHIFT 2 47*4882a593Smuzhiyun #define IAVF_VFINT_DYN_CTLN1_SWINT_TRIG_MASK IAVF_MASK(0x1, IAVF_VFINT_DYN_CTLN1_SWINT_TRIG_SHIFT) 48*4882a593Smuzhiyun #define IAVF_VFINT_DYN_CTLN1_ITR_INDX_SHIFT 3 49*4882a593Smuzhiyun #define IAVF_VFINT_DYN_CTLN1_ITR_INDX_MASK IAVF_MASK(0x3, IAVF_VFINT_DYN_CTLN1_ITR_INDX_SHIFT) 50*4882a593Smuzhiyun #define IAVF_VFINT_DYN_CTLN1_INTERVAL_SHIFT 5 51*4882a593Smuzhiyun #define IAVF_VFINT_DYN_CTLN1_SW_ITR_INDX_ENA_SHIFT 24 52*4882a593Smuzhiyun #define IAVF_VFINT_DYN_CTLN1_SW_ITR_INDX_ENA_MASK IAVF_MASK(0x1, IAVF_VFINT_DYN_CTLN1_SW_ITR_INDX_ENA_SHIFT) 53*4882a593Smuzhiyun #define IAVF_VFINT_ICR0_ENA1 0x00005000 /* Reset: CORER */ 54*4882a593Smuzhiyun #define IAVF_VFINT_ICR0_ENA1_ADMINQ_SHIFT 30 55*4882a593Smuzhiyun #define IAVF_VFINT_ICR0_ENA1_ADMINQ_MASK IAVF_MASK(0x1, IAVF_VFINT_ICR0_ENA1_ADMINQ_SHIFT) 56*4882a593Smuzhiyun #define IAVF_VFINT_ICR0_ENA1_RSVD_SHIFT 31 57*4882a593Smuzhiyun #define IAVF_VFINT_ICR01 0x00004800 /* Reset: CORER */ 58*4882a593Smuzhiyun #define IAVF_VFINT_ITRN1(_i, _INTVF) (0x00002800 + ((_i) * 64 + (_INTVF) * 4)) /* _i=0...2, _INTVF=0...15 */ /* Reset: VFR */ 59*4882a593Smuzhiyun #define IAVF_QRX_TAIL1(_Q) (0x00002000 + ((_Q) * 4)) /* _i=0...15 */ /* Reset: CORER */ 60*4882a593Smuzhiyun #define IAVF_QTX_TAIL1(_Q) (0x00000000 + ((_Q) * 4)) /* _i=0...15 */ /* Reset: PFR */ 61*4882a593Smuzhiyun #define IAVF_VFQF_HENA(_i) (0x0000C400 + ((_i) * 4)) /* _i=0...1 */ /* Reset: CORER */ 62*4882a593Smuzhiyun #define IAVF_VFQF_HKEY(_i) (0x0000CC00 + ((_i) * 4)) /* _i=0...12 */ /* Reset: CORER */ 63*4882a593Smuzhiyun #define IAVF_VFQF_HKEY_MAX_INDEX 12 64*4882a593Smuzhiyun #define IAVF_VFQF_HLUT(_i) (0x0000D000 + ((_i) * 4)) /* _i=0...15 */ /* Reset: CORER */ 65*4882a593Smuzhiyun #define IAVF_VFQF_HLUT_MAX_INDEX 15 66*4882a593Smuzhiyun #define IAVF_VFINT_DYN_CTLN1_WB_ON_ITR_SHIFT 30 67*4882a593Smuzhiyun #define IAVF_VFINT_DYN_CTLN1_WB_ON_ITR_MASK IAVF_MASK(0x1, IAVF_VFINT_DYN_CTLN1_WB_ON_ITR_SHIFT) 68*4882a593Smuzhiyun #endif /* _IAVF_REGISTER_H_ */ 69