1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-2.0-only */ 2*4882a593Smuzhiyun /* 3*4882a593Smuzhiyun * Copyright (c) 2012-2013, NVIDIA Corporation. 4*4882a593Smuzhiyun */ 5*4882a593Smuzhiyun 6*4882a593Smuzhiyun /* 7*4882a593Smuzhiyun * Function naming determines intended use: 8*4882a593Smuzhiyun * 9*4882a593Smuzhiyun * <x>_r(void) : Returns the offset for register <x>. 10*4882a593Smuzhiyun * 11*4882a593Smuzhiyun * <x>_w(void) : Returns the word offset for word (4 byte) element <x>. 12*4882a593Smuzhiyun * 13*4882a593Smuzhiyun * <x>_<y>_s(void) : Returns size of field <y> of register <x> in bits. 14*4882a593Smuzhiyun * 15*4882a593Smuzhiyun * <x>_<y>_f(u32 v) : Returns a value based on 'v' which has been shifted 16*4882a593Smuzhiyun * and masked to place it at field <y> of register <x>. This value 17*4882a593Smuzhiyun * can be |'d with others to produce a full register value for 18*4882a593Smuzhiyun * register <x>. 19*4882a593Smuzhiyun * 20*4882a593Smuzhiyun * <x>_<y>_m(void) : Returns a mask for field <y> of register <x>. This 21*4882a593Smuzhiyun * value can be ~'d and then &'d to clear the value of field <y> for 22*4882a593Smuzhiyun * register <x>. 23*4882a593Smuzhiyun * 24*4882a593Smuzhiyun * <x>_<y>_<z>_f(void) : Returns the constant value <z> after being shifted 25*4882a593Smuzhiyun * to place it at field <y> of register <x>. This value can be |'d 26*4882a593Smuzhiyun * with others to produce a full register value for <x>. 27*4882a593Smuzhiyun * 28*4882a593Smuzhiyun * <x>_<y>_v(u32 r) : Returns the value of field <y> from a full register 29*4882a593Smuzhiyun * <x> value 'r' after being shifted to place its LSB at bit 0. 30*4882a593Smuzhiyun * This value is suitable for direct comparison with other unshifted 31*4882a593Smuzhiyun * values appropriate for use in field <y> of register <x>. 32*4882a593Smuzhiyun * 33*4882a593Smuzhiyun * <x>_<y>_<z>_v(void) : Returns the constant value for <z> defined for 34*4882a593Smuzhiyun * field <y> of register <x>. This value is suitable for direct 35*4882a593Smuzhiyun * comparison with unshifted values appropriate for use in field <y> 36*4882a593Smuzhiyun * of register <x>. 37*4882a593Smuzhiyun */ 38*4882a593Smuzhiyun 39*4882a593Smuzhiyun #ifndef __hw_host1x_uclass_host1x_h__ 40*4882a593Smuzhiyun #define __hw_host1x_uclass_host1x_h__ 41*4882a593Smuzhiyun host1x_uclass_incr_syncpt_r(void)42*4882a593Smuzhiyunstatic inline u32 host1x_uclass_incr_syncpt_r(void) 43*4882a593Smuzhiyun { 44*4882a593Smuzhiyun return 0x0; 45*4882a593Smuzhiyun } 46*4882a593Smuzhiyun #define HOST1X_UCLASS_INCR_SYNCPT \ 47*4882a593Smuzhiyun host1x_uclass_incr_syncpt_r() host1x_uclass_incr_syncpt_cond_f(u32 v)48*4882a593Smuzhiyunstatic inline u32 host1x_uclass_incr_syncpt_cond_f(u32 v) 49*4882a593Smuzhiyun { 50*4882a593Smuzhiyun return (v & 0xff) << 8; 51*4882a593Smuzhiyun } 52*4882a593Smuzhiyun #define HOST1X_UCLASS_INCR_SYNCPT_COND_F(v) \ 53*4882a593Smuzhiyun host1x_uclass_incr_syncpt_cond_f(v) host1x_uclass_incr_syncpt_indx_f(u32 v)54*4882a593Smuzhiyunstatic inline u32 host1x_uclass_incr_syncpt_indx_f(u32 v) 55*4882a593Smuzhiyun { 56*4882a593Smuzhiyun return (v & 0xff) << 0; 57*4882a593Smuzhiyun } 58*4882a593Smuzhiyun #define HOST1X_UCLASS_INCR_SYNCPT_INDX_F(v) \ 59*4882a593Smuzhiyun host1x_uclass_incr_syncpt_indx_f(v) host1x_uclass_wait_syncpt_r(void)60*4882a593Smuzhiyunstatic inline u32 host1x_uclass_wait_syncpt_r(void) 61*4882a593Smuzhiyun { 62*4882a593Smuzhiyun return 0x8; 63*4882a593Smuzhiyun } 64*4882a593Smuzhiyun #define HOST1X_UCLASS_WAIT_SYNCPT \ 65*4882a593Smuzhiyun host1x_uclass_wait_syncpt_r() host1x_uclass_wait_syncpt_indx_f(u32 v)66*4882a593Smuzhiyunstatic inline u32 host1x_uclass_wait_syncpt_indx_f(u32 v) 67*4882a593Smuzhiyun { 68*4882a593Smuzhiyun return (v & 0xff) << 24; 69*4882a593Smuzhiyun } 70*4882a593Smuzhiyun #define HOST1X_UCLASS_WAIT_SYNCPT_INDX_F(v) \ 71*4882a593Smuzhiyun host1x_uclass_wait_syncpt_indx_f(v) host1x_uclass_wait_syncpt_thresh_f(u32 v)72*4882a593Smuzhiyunstatic inline u32 host1x_uclass_wait_syncpt_thresh_f(u32 v) 73*4882a593Smuzhiyun { 74*4882a593Smuzhiyun return (v & 0xffffff) << 0; 75*4882a593Smuzhiyun } 76*4882a593Smuzhiyun #define HOST1X_UCLASS_WAIT_SYNCPT_THRESH_F(v) \ 77*4882a593Smuzhiyun host1x_uclass_wait_syncpt_thresh_f(v) host1x_uclass_wait_syncpt_base_r(void)78*4882a593Smuzhiyunstatic inline u32 host1x_uclass_wait_syncpt_base_r(void) 79*4882a593Smuzhiyun { 80*4882a593Smuzhiyun return 0x9; 81*4882a593Smuzhiyun } 82*4882a593Smuzhiyun #define HOST1X_UCLASS_WAIT_SYNCPT_BASE \ 83*4882a593Smuzhiyun host1x_uclass_wait_syncpt_base_r() host1x_uclass_wait_syncpt_base_indx_f(u32 v)84*4882a593Smuzhiyunstatic inline u32 host1x_uclass_wait_syncpt_base_indx_f(u32 v) 85*4882a593Smuzhiyun { 86*4882a593Smuzhiyun return (v & 0xff) << 24; 87*4882a593Smuzhiyun } 88*4882a593Smuzhiyun #define HOST1X_UCLASS_WAIT_SYNCPT_BASE_INDX_F(v) \ 89*4882a593Smuzhiyun host1x_uclass_wait_syncpt_base_indx_f(v) host1x_uclass_wait_syncpt_base_base_indx_f(u32 v)90*4882a593Smuzhiyunstatic inline u32 host1x_uclass_wait_syncpt_base_base_indx_f(u32 v) 91*4882a593Smuzhiyun { 92*4882a593Smuzhiyun return (v & 0xff) << 16; 93*4882a593Smuzhiyun } 94*4882a593Smuzhiyun #define HOST1X_UCLASS_WAIT_SYNCPT_BASE_BASE_INDX_F(v) \ 95*4882a593Smuzhiyun host1x_uclass_wait_syncpt_base_base_indx_f(v) host1x_uclass_wait_syncpt_base_offset_f(u32 v)96*4882a593Smuzhiyunstatic inline u32 host1x_uclass_wait_syncpt_base_offset_f(u32 v) 97*4882a593Smuzhiyun { 98*4882a593Smuzhiyun return (v & 0xffff) << 0; 99*4882a593Smuzhiyun } 100*4882a593Smuzhiyun #define HOST1X_UCLASS_WAIT_SYNCPT_BASE_OFFSET_F(v) \ 101*4882a593Smuzhiyun host1x_uclass_wait_syncpt_base_offset_f(v) host1x_uclass_load_syncpt_base_r(void)102*4882a593Smuzhiyunstatic inline u32 host1x_uclass_load_syncpt_base_r(void) 103*4882a593Smuzhiyun { 104*4882a593Smuzhiyun return 0xb; 105*4882a593Smuzhiyun } 106*4882a593Smuzhiyun #define HOST1X_UCLASS_LOAD_SYNCPT_BASE \ 107*4882a593Smuzhiyun host1x_uclass_load_syncpt_base_r() host1x_uclass_load_syncpt_base_base_indx_f(u32 v)108*4882a593Smuzhiyunstatic inline u32 host1x_uclass_load_syncpt_base_base_indx_f(u32 v) 109*4882a593Smuzhiyun { 110*4882a593Smuzhiyun return (v & 0xff) << 24; 111*4882a593Smuzhiyun } 112*4882a593Smuzhiyun #define HOST1X_UCLASS_LOAD_SYNCPT_BASE_BASE_INDX_F(v) \ 113*4882a593Smuzhiyun host1x_uclass_load_syncpt_base_base_indx_f(v) host1x_uclass_load_syncpt_base_value_f(u32 v)114*4882a593Smuzhiyunstatic inline u32 host1x_uclass_load_syncpt_base_value_f(u32 v) 115*4882a593Smuzhiyun { 116*4882a593Smuzhiyun return (v & 0xffffff) << 0; 117*4882a593Smuzhiyun } 118*4882a593Smuzhiyun #define HOST1X_UCLASS_LOAD_SYNCPT_BASE_VALUE_F(v) \ 119*4882a593Smuzhiyun host1x_uclass_load_syncpt_base_value_f(v) host1x_uclass_incr_syncpt_base_base_indx_f(u32 v)120*4882a593Smuzhiyunstatic inline u32 host1x_uclass_incr_syncpt_base_base_indx_f(u32 v) 121*4882a593Smuzhiyun { 122*4882a593Smuzhiyun return (v & 0xff) << 24; 123*4882a593Smuzhiyun } 124*4882a593Smuzhiyun #define HOST1X_UCLASS_INCR_SYNCPT_BASE_BASE_INDX_F(v) \ 125*4882a593Smuzhiyun host1x_uclass_incr_syncpt_base_base_indx_f(v) host1x_uclass_incr_syncpt_base_offset_f(u32 v)126*4882a593Smuzhiyunstatic inline u32 host1x_uclass_incr_syncpt_base_offset_f(u32 v) 127*4882a593Smuzhiyun { 128*4882a593Smuzhiyun return (v & 0xffffff) << 0; 129*4882a593Smuzhiyun } 130*4882a593Smuzhiyun #define HOST1X_UCLASS_INCR_SYNCPT_BASE_OFFSET_F(v) \ 131*4882a593Smuzhiyun host1x_uclass_incr_syncpt_base_offset_f(v) host1x_uclass_indoff_r(void)132*4882a593Smuzhiyunstatic inline u32 host1x_uclass_indoff_r(void) 133*4882a593Smuzhiyun { 134*4882a593Smuzhiyun return 0x2d; 135*4882a593Smuzhiyun } 136*4882a593Smuzhiyun #define HOST1X_UCLASS_INDOFF \ 137*4882a593Smuzhiyun host1x_uclass_indoff_r() host1x_uclass_indoff_indbe_f(u32 v)138*4882a593Smuzhiyunstatic inline u32 host1x_uclass_indoff_indbe_f(u32 v) 139*4882a593Smuzhiyun { 140*4882a593Smuzhiyun return (v & 0xf) << 28; 141*4882a593Smuzhiyun } 142*4882a593Smuzhiyun #define HOST1X_UCLASS_INDOFF_INDBE_F(v) \ 143*4882a593Smuzhiyun host1x_uclass_indoff_indbe_f(v) host1x_uclass_indoff_autoinc_f(u32 v)144*4882a593Smuzhiyunstatic inline u32 host1x_uclass_indoff_autoinc_f(u32 v) 145*4882a593Smuzhiyun { 146*4882a593Smuzhiyun return (v & 0x1) << 27; 147*4882a593Smuzhiyun } 148*4882a593Smuzhiyun #define HOST1X_UCLASS_INDOFF_AUTOINC_F(v) \ 149*4882a593Smuzhiyun host1x_uclass_indoff_autoinc_f(v) host1x_uclass_indoff_indmodid_f(u32 v)150*4882a593Smuzhiyunstatic inline u32 host1x_uclass_indoff_indmodid_f(u32 v) 151*4882a593Smuzhiyun { 152*4882a593Smuzhiyun return (v & 0xff) << 18; 153*4882a593Smuzhiyun } 154*4882a593Smuzhiyun #define HOST1X_UCLASS_INDOFF_INDMODID_F(v) \ 155*4882a593Smuzhiyun host1x_uclass_indoff_indmodid_f(v) host1x_uclass_indoff_indroffset_f(u32 v)156*4882a593Smuzhiyunstatic inline u32 host1x_uclass_indoff_indroffset_f(u32 v) 157*4882a593Smuzhiyun { 158*4882a593Smuzhiyun return (v & 0xffff) << 2; 159*4882a593Smuzhiyun } 160*4882a593Smuzhiyun #define HOST1X_UCLASS_INDOFF_INDROFFSET_F(v) \ 161*4882a593Smuzhiyun host1x_uclass_indoff_indroffset_f(v) host1x_uclass_indoff_rwn_read_v(void)162*4882a593Smuzhiyunstatic inline u32 host1x_uclass_indoff_rwn_read_v(void) 163*4882a593Smuzhiyun { 164*4882a593Smuzhiyun return 1; 165*4882a593Smuzhiyun } 166*4882a593Smuzhiyun #define HOST1X_UCLASS_INDOFF_INDROFFSET_F(v) \ 167*4882a593Smuzhiyun host1x_uclass_indoff_indroffset_f(v) 168*4882a593Smuzhiyun #endif 169