root/drivers/gpu/host1x/hw/hw_host1x01_uclass.h

/* [<][>][^][v][top][bottom][index][help] */

INCLUDED FROM


DEFINITIONS

This source file includes following definitions.
  1. host1x_uclass_incr_syncpt_r
  2. host1x_uclass_incr_syncpt_cond_f
  3. host1x_uclass_incr_syncpt_indx_f
  4. host1x_uclass_wait_syncpt_r
  5. host1x_uclass_wait_syncpt_indx_f
  6. host1x_uclass_wait_syncpt_thresh_f
  7. host1x_uclass_wait_syncpt_base_r
  8. host1x_uclass_wait_syncpt_base_indx_f
  9. host1x_uclass_wait_syncpt_base_base_indx_f
  10. host1x_uclass_wait_syncpt_base_offset_f
  11. host1x_uclass_load_syncpt_base_r
  12. host1x_uclass_load_syncpt_base_base_indx_f
  13. host1x_uclass_load_syncpt_base_value_f
  14. host1x_uclass_incr_syncpt_base_base_indx_f
  15. host1x_uclass_incr_syncpt_base_offset_f
  16. host1x_uclass_indoff_r
  17. host1x_uclass_indoff_indbe_f
  18. host1x_uclass_indoff_autoinc_f
  19. host1x_uclass_indoff_indmodid_f
  20. host1x_uclass_indoff_indroffset_f
  21. host1x_uclass_indoff_rwn_read_v

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

/* [<][>][^][v][top][bottom][index][help] */