mdp4.xml.h 49 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173
  1. #ifndef MDP4_XML
  2. #define MDP4_XML
  3. /* Autogenerated file, DO NOT EDIT manually!
  4. This file was generated by the rules-ng-ng headergen tool in this git repository:
  5. http://github.com/freedreno/envytools/
  6. git clone https://github.com/freedreno/envytools.git
  7. The rules-ng-ng source files this header was generated from are:
  8. - /home/robclark/src/freedreno/envytools/rnndb/msm.xml ( 676 bytes, from 2015-05-20 20:03:14)
  9. - /home/robclark/src/freedreno/envytools/rnndb/freedreno_copyright.xml ( 1453 bytes, from 2015-05-20 20:03:07)
  10. - /home/robclark/src/freedreno/envytools/rnndb/mdp/mdp4.xml ( 20915 bytes, from 2015-05-20 20:03:14)
  11. - /home/robclark/src/freedreno/envytools/rnndb/mdp/mdp_common.xml ( 2849 bytes, from 2015-09-18 12:07:28)
  12. - /home/robclark/src/freedreno/envytools/rnndb/mdp/mdp5.xml ( 37194 bytes, from 2015-09-18 12:07:28)
  13. - /home/robclark/src/freedreno/envytools/rnndb/dsi/dsi.xml ( 27887 bytes, from 2015-10-22 16:34:52)
  14. - /home/robclark/src/freedreno/envytools/rnndb/dsi/sfpb.xml ( 602 bytes, from 2015-10-22 16:35:02)
  15. - /home/robclark/src/freedreno/envytools/rnndb/dsi/mmss_cc.xml ( 1686 bytes, from 2015-05-20 20:03:14)
  16. - /home/robclark/src/freedreno/envytools/rnndb/hdmi/qfprom.xml ( 600 bytes, from 2015-05-20 20:03:07)
  17. - /home/robclark/src/freedreno/envytools/rnndb/hdmi/hdmi.xml ( 29154 bytes, from 2015-08-10 21:25:43)
  18. - /home/robclark/src/freedreno/envytools/rnndb/edp/edp.xml ( 10416 bytes, from 2015-05-20 20:03:14)
  19. Copyright (C) 2013-2015 by the following authors:
  20. - Rob Clark <robdclark@gmail.com> (robclark)
  21. Permission is hereby granted, free of charge, to any person obtaining
  22. a copy of this software and associated documentation files (the
  23. "Software"), to deal in the Software without restriction, including
  24. without limitation the rights to use, copy, modify, merge, publish,
  25. distribute, sublicense, and/or sell copies of the Software, and to
  26. permit persons to whom the Software is furnished to do so, subject to
  27. the following conditions:
  28. The above copyright notice and this permission notice (including the
  29. next paragraph) shall be included in all copies or substantial
  30. portions of the Software.
  31. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
  32. EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
  33. MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
  34. IN NO EVENT SHALL THE COPYRIGHT OWNER(S) AND/OR ITS SUPPLIERS BE
  35. LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
  36. OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
  37. WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
  38. */
  39. enum mdp4_pipe {
  40. VG1 = 0,
  41. VG2 = 1,
  42. RGB1 = 2,
  43. RGB2 = 3,
  44. RGB3 = 4,
  45. VG3 = 5,
  46. VG4 = 6,
  47. };
  48. enum mdp4_mixer {
  49. MIXER0 = 0,
  50. MIXER1 = 1,
  51. MIXER2 = 2,
  52. };
  53. enum mdp4_intf {
  54. INTF_LCDC_DTV = 0,
  55. INTF_DSI_VIDEO = 1,
  56. INTF_DSI_CMD = 2,
  57. INTF_EBI2_TV = 3,
  58. };
  59. enum mdp4_cursor_format {
  60. CURSOR_ARGB = 1,
  61. CURSOR_XRGB = 2,
  62. };
  63. enum mdp4_frame_format {
  64. FRAME_LINEAR = 0,
  65. FRAME_TILE_ARGB_4X4 = 1,
  66. FRAME_TILE_YCBCR_420 = 2,
  67. };
  68. enum mdp4_scale_unit {
  69. SCALE_FIR = 0,
  70. SCALE_MN_PHASE = 1,
  71. SCALE_PIXEL_RPT = 2,
  72. };
  73. enum mdp4_dma {
  74. DMA_P = 0,
  75. DMA_S = 1,
  76. DMA_E = 2,
  77. };
  78. #define MDP4_IRQ_OVERLAY0_DONE 0x00000001
  79. #define MDP4_IRQ_OVERLAY1_DONE 0x00000002
  80. #define MDP4_IRQ_DMA_S_DONE 0x00000004
  81. #define MDP4_IRQ_DMA_E_DONE 0x00000008
  82. #define MDP4_IRQ_DMA_P_DONE 0x00000010
  83. #define MDP4_IRQ_VG1_HISTOGRAM 0x00000020
  84. #define MDP4_IRQ_VG2_HISTOGRAM 0x00000040
  85. #define MDP4_IRQ_PRIMARY_VSYNC 0x00000080
  86. #define MDP4_IRQ_PRIMARY_INTF_UDERRUN 0x00000100
  87. #define MDP4_IRQ_EXTERNAL_VSYNC 0x00000200
  88. #define MDP4_IRQ_EXTERNAL_INTF_UDERRUN 0x00000400
  89. #define MDP4_IRQ_PRIMARY_RDPTR 0x00000800
  90. #define MDP4_IRQ_DMA_P_HISTOGRAM 0x00020000
  91. #define MDP4_IRQ_DMA_S_HISTOGRAM 0x04000000
  92. #define MDP4_IRQ_OVERLAY2_DONE 0x40000000
  93. #define REG_MDP4_VERSION 0x00000000
  94. #define MDP4_VERSION_MINOR__MASK 0x00ff0000
  95. #define MDP4_VERSION_MINOR__SHIFT 16
  96. static inline uint32_t MDP4_VERSION_MINOR(uint32_t val)
  97. {
  98. return ((val) << MDP4_VERSION_MINOR__SHIFT) & MDP4_VERSION_MINOR__MASK;
  99. }
  100. #define MDP4_VERSION_MAJOR__MASK 0xff000000
  101. #define MDP4_VERSION_MAJOR__SHIFT 24
  102. static inline uint32_t MDP4_VERSION_MAJOR(uint32_t val)
  103. {
  104. return ((val) << MDP4_VERSION_MAJOR__SHIFT) & MDP4_VERSION_MAJOR__MASK;
  105. }
  106. #define REG_MDP4_OVLP0_KICK 0x00000004
  107. #define REG_MDP4_OVLP1_KICK 0x00000008
  108. #define REG_MDP4_OVLP2_KICK 0x000000d0
  109. #define REG_MDP4_DMA_P_KICK 0x0000000c
  110. #define REG_MDP4_DMA_S_KICK 0x00000010
  111. #define REG_MDP4_DMA_E_KICK 0x00000014
  112. #define REG_MDP4_DISP_STATUS 0x00000018
  113. #define REG_MDP4_DISP_INTF_SEL 0x00000038
  114. #define MDP4_DISP_INTF_SEL_PRIM__MASK 0x00000003
  115. #define MDP4_DISP_INTF_SEL_PRIM__SHIFT 0
  116. static inline uint32_t MDP4_DISP_INTF_SEL_PRIM(enum mdp4_intf val)
  117. {
  118. return ((val) << MDP4_DISP_INTF_SEL_PRIM__SHIFT) & MDP4_DISP_INTF_SEL_PRIM__MASK;
  119. }
  120. #define MDP4_DISP_INTF_SEL_SEC__MASK 0x0000000c
  121. #define MDP4_DISP_INTF_SEL_SEC__SHIFT 2
  122. static inline uint32_t MDP4_DISP_INTF_SEL_SEC(enum mdp4_intf val)
  123. {
  124. return ((val) << MDP4_DISP_INTF_SEL_SEC__SHIFT) & MDP4_DISP_INTF_SEL_SEC__MASK;
  125. }
  126. #define MDP4_DISP_INTF_SEL_EXT__MASK 0x00000030
  127. #define MDP4_DISP_INTF_SEL_EXT__SHIFT 4
  128. static inline uint32_t MDP4_DISP_INTF_SEL_EXT(enum mdp4_intf val)
  129. {
  130. return ((val) << MDP4_DISP_INTF_SEL_EXT__SHIFT) & MDP4_DISP_INTF_SEL_EXT__MASK;
  131. }
  132. #define MDP4_DISP_INTF_SEL_DSI_VIDEO 0x00000040
  133. #define MDP4_DISP_INTF_SEL_DSI_CMD 0x00000080
  134. #define REG_MDP4_RESET_STATUS 0x0000003c
  135. #define REG_MDP4_READ_CNFG 0x0000004c
  136. #define REG_MDP4_INTR_ENABLE 0x00000050
  137. #define REG_MDP4_INTR_STATUS 0x00000054
  138. #define REG_MDP4_INTR_CLEAR 0x00000058
  139. #define REG_MDP4_EBI2_LCD0 0x00000060
  140. #define REG_MDP4_EBI2_LCD1 0x00000064
  141. #define REG_MDP4_PORTMAP_MODE 0x00000070
  142. #define REG_MDP4_CS_CONTROLLER0 0x000000c0
  143. #define REG_MDP4_CS_CONTROLLER1 0x000000c4
  144. #define REG_MDP4_LAYERMIXER2_IN_CFG 0x000100f0
  145. #define MDP4_LAYERMIXER2_IN_CFG_PIPE0__MASK 0x00000007
  146. #define MDP4_LAYERMIXER2_IN_CFG_PIPE0__SHIFT 0
  147. static inline uint32_t MDP4_LAYERMIXER2_IN_CFG_PIPE0(enum mdp_mixer_stage_id val)
  148. {
  149. return ((val) << MDP4_LAYERMIXER2_IN_CFG_PIPE0__SHIFT) & MDP4_LAYERMIXER2_IN_CFG_PIPE0__MASK;
  150. }
  151. #define MDP4_LAYERMIXER2_IN_CFG_PIPE0_MIXER1 0x00000008
  152. #define MDP4_LAYERMIXER2_IN_CFG_PIPE1__MASK 0x00000070
  153. #define MDP4_LAYERMIXER2_IN_CFG_PIPE1__SHIFT 4
  154. static inline uint32_t MDP4_LAYERMIXER2_IN_CFG_PIPE1(enum mdp_mixer_stage_id val)
  155. {
  156. return ((val) << MDP4_LAYERMIXER2_IN_CFG_PIPE1__SHIFT) & MDP4_LAYERMIXER2_IN_CFG_PIPE1__MASK;
  157. }
  158. #define MDP4_LAYERMIXER2_IN_CFG_PIPE1_MIXER1 0x00000080
  159. #define MDP4_LAYERMIXER2_IN_CFG_PIPE2__MASK 0x00000700
  160. #define MDP4_LAYERMIXER2_IN_CFG_PIPE2__SHIFT 8
  161. static inline uint32_t MDP4_LAYERMIXER2_IN_CFG_PIPE2(enum mdp_mixer_stage_id val)
  162. {
  163. return ((val) << MDP4_LAYERMIXER2_IN_CFG_PIPE2__SHIFT) & MDP4_LAYERMIXER2_IN_CFG_PIPE2__MASK;
  164. }
  165. #define MDP4_LAYERMIXER2_IN_CFG_PIPE2_MIXER1 0x00000800
  166. #define MDP4_LAYERMIXER2_IN_CFG_PIPE3__MASK 0x00007000
  167. #define MDP4_LAYERMIXER2_IN_CFG_PIPE3__SHIFT 12
  168. static inline uint32_t MDP4_LAYERMIXER2_IN_CFG_PIPE3(enum mdp_mixer_stage_id val)
  169. {
  170. return ((val) << MDP4_LAYERMIXER2_IN_CFG_PIPE3__SHIFT) & MDP4_LAYERMIXER2_IN_CFG_PIPE3__MASK;
  171. }
  172. #define MDP4_LAYERMIXER2_IN_CFG_PIPE3_MIXER1 0x00008000
  173. #define MDP4_LAYERMIXER2_IN_CFG_PIPE4__MASK 0x00070000
  174. #define MDP4_LAYERMIXER2_IN_CFG_PIPE4__SHIFT 16
  175. static inline uint32_t MDP4_LAYERMIXER2_IN_CFG_PIPE4(enum mdp_mixer_stage_id val)
  176. {
  177. return ((val) << MDP4_LAYERMIXER2_IN_CFG_PIPE4__SHIFT) & MDP4_LAYERMIXER2_IN_CFG_PIPE4__MASK;
  178. }
  179. #define MDP4_LAYERMIXER2_IN_CFG_PIPE4_MIXER1 0x00080000
  180. #define MDP4_LAYERMIXER2_IN_CFG_PIPE5__MASK 0x00700000
  181. #define MDP4_LAYERMIXER2_IN_CFG_PIPE5__SHIFT 20
  182. static inline uint32_t MDP4_LAYERMIXER2_IN_CFG_PIPE5(enum mdp_mixer_stage_id val)
  183. {
  184. return ((val) << MDP4_LAYERMIXER2_IN_CFG_PIPE5__SHIFT) & MDP4_LAYERMIXER2_IN_CFG_PIPE5__MASK;
  185. }
  186. #define MDP4_LAYERMIXER2_IN_CFG_PIPE5_MIXER1 0x00800000
  187. #define MDP4_LAYERMIXER2_IN_CFG_PIPE6__MASK 0x07000000
  188. #define MDP4_LAYERMIXER2_IN_CFG_PIPE6__SHIFT 24
  189. static inline uint32_t MDP4_LAYERMIXER2_IN_CFG_PIPE6(enum mdp_mixer_stage_id val)
  190. {
  191. return ((val) << MDP4_LAYERMIXER2_IN_CFG_PIPE6__SHIFT) & MDP4_LAYERMIXER2_IN_CFG_PIPE6__MASK;
  192. }
  193. #define MDP4_LAYERMIXER2_IN_CFG_PIPE6_MIXER1 0x08000000
  194. #define MDP4_LAYERMIXER2_IN_CFG_PIPE7__MASK 0x70000000
  195. #define MDP4_LAYERMIXER2_IN_CFG_PIPE7__SHIFT 28
  196. static inline uint32_t MDP4_LAYERMIXER2_IN_CFG_PIPE7(enum mdp_mixer_stage_id val)
  197. {
  198. return ((val) << MDP4_LAYERMIXER2_IN_CFG_PIPE7__SHIFT) & MDP4_LAYERMIXER2_IN_CFG_PIPE7__MASK;
  199. }
  200. #define MDP4_LAYERMIXER2_IN_CFG_PIPE7_MIXER1 0x80000000
  201. #define REG_MDP4_LAYERMIXER_IN_CFG_UPDATE_METHOD 0x000100fc
  202. #define REG_MDP4_LAYERMIXER_IN_CFG 0x00010100
  203. #define MDP4_LAYERMIXER_IN_CFG_PIPE0__MASK 0x00000007
  204. #define MDP4_LAYERMIXER_IN_CFG_PIPE0__SHIFT 0
  205. static inline uint32_t MDP4_LAYERMIXER_IN_CFG_PIPE0(enum mdp_mixer_stage_id val)
  206. {
  207. return ((val) << MDP4_LAYERMIXER_IN_CFG_PIPE0__SHIFT) & MDP4_LAYERMIXER_IN_CFG_PIPE0__MASK;
  208. }
  209. #define MDP4_LAYERMIXER_IN_CFG_PIPE0_MIXER1 0x00000008
  210. #define MDP4_LAYERMIXER_IN_CFG_PIPE1__MASK 0x00000070
  211. #define MDP4_LAYERMIXER_IN_CFG_PIPE1__SHIFT 4
  212. static inline uint32_t MDP4_LAYERMIXER_IN_CFG_PIPE1(enum mdp_mixer_stage_id val)
  213. {
  214. return ((val) << MDP4_LAYERMIXER_IN_CFG_PIPE1__SHIFT) & MDP4_LAYERMIXER_IN_CFG_PIPE1__MASK;
  215. }
  216. #define MDP4_LAYERMIXER_IN_CFG_PIPE1_MIXER1 0x00000080
  217. #define MDP4_LAYERMIXER_IN_CFG_PIPE2__MASK 0x00000700
  218. #define MDP4_LAYERMIXER_IN_CFG_PIPE2__SHIFT 8
  219. static inline uint32_t MDP4_LAYERMIXER_IN_CFG_PIPE2(enum mdp_mixer_stage_id val)
  220. {
  221. return ((val) << MDP4_LAYERMIXER_IN_CFG_PIPE2__SHIFT) & MDP4_LAYERMIXER_IN_CFG_PIPE2__MASK;
  222. }
  223. #define MDP4_LAYERMIXER_IN_CFG_PIPE2_MIXER1 0x00000800
  224. #define MDP4_LAYERMIXER_IN_CFG_PIPE3__MASK 0x00007000
  225. #define MDP4_LAYERMIXER_IN_CFG_PIPE3__SHIFT 12
  226. static inline uint32_t MDP4_LAYERMIXER_IN_CFG_PIPE3(enum mdp_mixer_stage_id val)
  227. {
  228. return ((val) << MDP4_LAYERMIXER_IN_CFG_PIPE3__SHIFT) & MDP4_LAYERMIXER_IN_CFG_PIPE3__MASK;
  229. }
  230. #define MDP4_LAYERMIXER_IN_CFG_PIPE3_MIXER1 0x00008000
  231. #define MDP4_LAYERMIXER_IN_CFG_PIPE4__MASK 0x00070000
  232. #define MDP4_LAYERMIXER_IN_CFG_PIPE4__SHIFT 16
  233. static inline uint32_t MDP4_LAYERMIXER_IN_CFG_PIPE4(enum mdp_mixer_stage_id val)
  234. {
  235. return ((val) << MDP4_LAYERMIXER_IN_CFG_PIPE4__SHIFT) & MDP4_LAYERMIXER_IN_CFG_PIPE4__MASK;
  236. }
  237. #define MDP4_LAYERMIXER_IN_CFG_PIPE4_MIXER1 0x00080000
  238. #define MDP4_LAYERMIXER_IN_CFG_PIPE5__MASK 0x00700000
  239. #define MDP4_LAYERMIXER_IN_CFG_PIPE5__SHIFT 20
  240. static inline uint32_t MDP4_LAYERMIXER_IN_CFG_PIPE5(enum mdp_mixer_stage_id val)
  241. {
  242. return ((val) << MDP4_LAYERMIXER_IN_CFG_PIPE5__SHIFT) & MDP4_LAYERMIXER_IN_CFG_PIPE5__MASK;
  243. }
  244. #define MDP4_LAYERMIXER_IN_CFG_PIPE5_MIXER1 0x00800000
  245. #define MDP4_LAYERMIXER_IN_CFG_PIPE6__MASK 0x07000000
  246. #define MDP4_LAYERMIXER_IN_CFG_PIPE6__SHIFT 24
  247. static inline uint32_t MDP4_LAYERMIXER_IN_CFG_PIPE6(enum mdp_mixer_stage_id val)
  248. {
  249. return ((val) << MDP4_LAYERMIXER_IN_CFG_PIPE6__SHIFT) & MDP4_LAYERMIXER_IN_CFG_PIPE6__MASK;
  250. }
  251. #define MDP4_LAYERMIXER_IN_CFG_PIPE6_MIXER1 0x08000000
  252. #define MDP4_LAYERMIXER_IN_CFG_PIPE7__MASK 0x70000000
  253. #define MDP4_LAYERMIXER_IN_CFG_PIPE7__SHIFT 28
  254. static inline uint32_t MDP4_LAYERMIXER_IN_CFG_PIPE7(enum mdp_mixer_stage_id val)
  255. {
  256. return ((val) << MDP4_LAYERMIXER_IN_CFG_PIPE7__SHIFT) & MDP4_LAYERMIXER_IN_CFG_PIPE7__MASK;
  257. }
  258. #define MDP4_LAYERMIXER_IN_CFG_PIPE7_MIXER1 0x80000000
  259. #define REG_MDP4_VG2_SRC_FORMAT 0x00030050
  260. #define REG_MDP4_VG2_CONST_COLOR 0x00031008
  261. #define REG_MDP4_OVERLAY_FLUSH 0x00018000
  262. #define MDP4_OVERLAY_FLUSH_OVLP0 0x00000001
  263. #define MDP4_OVERLAY_FLUSH_OVLP1 0x00000002
  264. #define MDP4_OVERLAY_FLUSH_VG1 0x00000004
  265. #define MDP4_OVERLAY_FLUSH_VG2 0x00000008
  266. #define MDP4_OVERLAY_FLUSH_RGB1 0x00000010
  267. #define MDP4_OVERLAY_FLUSH_RGB2 0x00000020
  268. static inline uint32_t __offset_OVLP(uint32_t idx)
  269. {
  270. switch (idx) {
  271. case 0: return 0x00010000;
  272. case 1: return 0x00018000;
  273. case 2: return 0x00088000;
  274. default: return INVALID_IDX(idx);
  275. }
  276. }
  277. static inline uint32_t REG_MDP4_OVLP(uint32_t i0) { return 0x00000000 + __offset_OVLP(i0); }
  278. static inline uint32_t REG_MDP4_OVLP_CFG(uint32_t i0) { return 0x00000004 + __offset_OVLP(i0); }
  279. static inline uint32_t REG_MDP4_OVLP_SIZE(uint32_t i0) { return 0x00000008 + __offset_OVLP(i0); }
  280. #define MDP4_OVLP_SIZE_HEIGHT__MASK 0xffff0000
  281. #define MDP4_OVLP_SIZE_HEIGHT__SHIFT 16
  282. static inline uint32_t MDP4_OVLP_SIZE_HEIGHT(uint32_t val)
  283. {
  284. return ((val) << MDP4_OVLP_SIZE_HEIGHT__SHIFT) & MDP4_OVLP_SIZE_HEIGHT__MASK;
  285. }
  286. #define MDP4_OVLP_SIZE_WIDTH__MASK 0x0000ffff
  287. #define MDP4_OVLP_SIZE_WIDTH__SHIFT 0
  288. static inline uint32_t MDP4_OVLP_SIZE_WIDTH(uint32_t val)
  289. {
  290. return ((val) << MDP4_OVLP_SIZE_WIDTH__SHIFT) & MDP4_OVLP_SIZE_WIDTH__MASK;
  291. }
  292. static inline uint32_t REG_MDP4_OVLP_BASE(uint32_t i0) { return 0x0000000c + __offset_OVLP(i0); }
  293. static inline uint32_t REG_MDP4_OVLP_STRIDE(uint32_t i0) { return 0x00000010 + __offset_OVLP(i0); }
  294. static inline uint32_t REG_MDP4_OVLP_OPMODE(uint32_t i0) { return 0x00000014 + __offset_OVLP(i0); }
  295. static inline uint32_t __offset_STAGE(uint32_t idx)
  296. {
  297. switch (idx) {
  298. case 0: return 0x00000104;
  299. case 1: return 0x00000124;
  300. case 2: return 0x00000144;
  301. case 3: return 0x00000160;
  302. default: return INVALID_IDX(idx);
  303. }
  304. }
  305. static inline uint32_t REG_MDP4_OVLP_STAGE(uint32_t i0, uint32_t i1) { return 0x00000000 + __offset_OVLP(i0) + __offset_STAGE(i1); }
  306. static inline uint32_t REG_MDP4_OVLP_STAGE_OP(uint32_t i0, uint32_t i1) { return 0x00000000 + __offset_OVLP(i0) + __offset_STAGE(i1); }
  307. #define MDP4_OVLP_STAGE_OP_FG_ALPHA__MASK 0x00000003
  308. #define MDP4_OVLP_STAGE_OP_FG_ALPHA__SHIFT 0
  309. static inline uint32_t MDP4_OVLP_STAGE_OP_FG_ALPHA(enum mdp_alpha_type val)
  310. {
  311. return ((val) << MDP4_OVLP_STAGE_OP_FG_ALPHA__SHIFT) & MDP4_OVLP_STAGE_OP_FG_ALPHA__MASK;
  312. }
  313. #define MDP4_OVLP_STAGE_OP_FG_INV_ALPHA 0x00000004
  314. #define MDP4_OVLP_STAGE_OP_FG_MOD_ALPHA 0x00000008
  315. #define MDP4_OVLP_STAGE_OP_BG_ALPHA__MASK 0x00000030
  316. #define MDP4_OVLP_STAGE_OP_BG_ALPHA__SHIFT 4
  317. static inline uint32_t MDP4_OVLP_STAGE_OP_BG_ALPHA(enum mdp_alpha_type val)
  318. {
  319. return ((val) << MDP4_OVLP_STAGE_OP_BG_ALPHA__SHIFT) & MDP4_OVLP_STAGE_OP_BG_ALPHA__MASK;
  320. }
  321. #define MDP4_OVLP_STAGE_OP_BG_INV_ALPHA 0x00000040
  322. #define MDP4_OVLP_STAGE_OP_BG_MOD_ALPHA 0x00000080
  323. #define MDP4_OVLP_STAGE_OP_FG_TRANSP 0x00000100
  324. #define MDP4_OVLP_STAGE_OP_BG_TRANSP 0x00000200
  325. static inline uint32_t REG_MDP4_OVLP_STAGE_FG_ALPHA(uint32_t i0, uint32_t i1) { return 0x00000004 + __offset_OVLP(i0) + __offset_STAGE(i1); }
  326. static inline uint32_t REG_MDP4_OVLP_STAGE_BG_ALPHA(uint32_t i0, uint32_t i1) { return 0x00000008 + __offset_OVLP(i0) + __offset_STAGE(i1); }
  327. static inline uint32_t REG_MDP4_OVLP_STAGE_TRANSP_LOW0(uint32_t i0, uint32_t i1) { return 0x0000000c + __offset_OVLP(i0) + __offset_STAGE(i1); }
  328. static inline uint32_t REG_MDP4_OVLP_STAGE_TRANSP_LOW1(uint32_t i0, uint32_t i1) { return 0x00000010 + __offset_OVLP(i0) + __offset_STAGE(i1); }
  329. static inline uint32_t REG_MDP4_OVLP_STAGE_TRANSP_HIGH0(uint32_t i0, uint32_t i1) { return 0x00000014 + __offset_OVLP(i0) + __offset_STAGE(i1); }
  330. static inline uint32_t REG_MDP4_OVLP_STAGE_TRANSP_HIGH1(uint32_t i0, uint32_t i1) { return 0x00000018 + __offset_OVLP(i0) + __offset_STAGE(i1); }
  331. static inline uint32_t __offset_STAGE_CO3(uint32_t idx)
  332. {
  333. switch (idx) {
  334. case 0: return 0x00001004;
  335. case 1: return 0x00001404;
  336. case 2: return 0x00001804;
  337. case 3: return 0x00001b84;
  338. default: return INVALID_IDX(idx);
  339. }
  340. }
  341. static inline uint32_t REG_MDP4_OVLP_STAGE_CO3(uint32_t i0, uint32_t i1) { return 0x00000000 + __offset_OVLP(i0) + __offset_STAGE_CO3(i1); }
  342. static inline uint32_t REG_MDP4_OVLP_STAGE_CO3_SEL(uint32_t i0, uint32_t i1) { return 0x00000000 + __offset_OVLP(i0) + __offset_STAGE_CO3(i1); }
  343. #define MDP4_OVLP_STAGE_CO3_SEL_FG_ALPHA 0x00000001
  344. static inline uint32_t REG_MDP4_OVLP_TRANSP_LOW0(uint32_t i0) { return 0x00000180 + __offset_OVLP(i0); }
  345. static inline uint32_t REG_MDP4_OVLP_TRANSP_LOW1(uint32_t i0) { return 0x00000184 + __offset_OVLP(i0); }
  346. static inline uint32_t REG_MDP4_OVLP_TRANSP_HIGH0(uint32_t i0) { return 0x00000188 + __offset_OVLP(i0); }
  347. static inline uint32_t REG_MDP4_OVLP_TRANSP_HIGH1(uint32_t i0) { return 0x0000018c + __offset_OVLP(i0); }
  348. static inline uint32_t REG_MDP4_OVLP_CSC_CONFIG(uint32_t i0) { return 0x00000200 + __offset_OVLP(i0); }
  349. static inline uint32_t REG_MDP4_OVLP_CSC(uint32_t i0) { return 0x00002000 + __offset_OVLP(i0); }
  350. static inline uint32_t REG_MDP4_OVLP_CSC_MV(uint32_t i0, uint32_t i1) { return 0x00002400 + __offset_OVLP(i0) + 0x4*i1; }
  351. static inline uint32_t REG_MDP4_OVLP_CSC_MV_VAL(uint32_t i0, uint32_t i1) { return 0x00002400 + __offset_OVLP(i0) + 0x4*i1; }
  352. static inline uint32_t REG_MDP4_OVLP_CSC_PRE_BV(uint32_t i0, uint32_t i1) { return 0x00002500 + __offset_OVLP(i0) + 0x4*i1; }
  353. static inline uint32_t REG_MDP4_OVLP_CSC_PRE_BV_VAL(uint32_t i0, uint32_t i1) { return 0x00002500 + __offset_OVLP(i0) + 0x4*i1; }
  354. static inline uint32_t REG_MDP4_OVLP_CSC_POST_BV(uint32_t i0, uint32_t i1) { return 0x00002580 + __offset_OVLP(i0) + 0x4*i1; }
  355. static inline uint32_t REG_MDP4_OVLP_CSC_POST_BV_VAL(uint32_t i0, uint32_t i1) { return 0x00002580 + __offset_OVLP(i0) + 0x4*i1; }
  356. static inline uint32_t REG_MDP4_OVLP_CSC_PRE_LV(uint32_t i0, uint32_t i1) { return 0x00002600 + __offset_OVLP(i0) + 0x4*i1; }
  357. static inline uint32_t REG_MDP4_OVLP_CSC_PRE_LV_VAL(uint32_t i0, uint32_t i1) { return 0x00002600 + __offset_OVLP(i0) + 0x4*i1; }
  358. static inline uint32_t REG_MDP4_OVLP_CSC_POST_LV(uint32_t i0, uint32_t i1) { return 0x00002680 + __offset_OVLP(i0) + 0x4*i1; }
  359. static inline uint32_t REG_MDP4_OVLP_CSC_POST_LV_VAL(uint32_t i0, uint32_t i1) { return 0x00002680 + __offset_OVLP(i0) + 0x4*i1; }
  360. #define REG_MDP4_DMA_P_OP_MODE 0x00090070
  361. static inline uint32_t REG_MDP4_LUTN(uint32_t i0) { return 0x00094800 + 0x400*i0; }
  362. static inline uint32_t REG_MDP4_LUTN_LUT(uint32_t i0, uint32_t i1) { return 0x00094800 + 0x400*i0 + 0x4*i1; }
  363. static inline uint32_t REG_MDP4_LUTN_LUT_VAL(uint32_t i0, uint32_t i1) { return 0x00094800 + 0x400*i0 + 0x4*i1; }
  364. #define REG_MDP4_DMA_S_OP_MODE 0x000a0028
  365. static inline uint32_t REG_MDP4_DMA_E_QUANT(uint32_t i0) { return 0x000b0070 + 0x4*i0; }
  366. static inline uint32_t __offset_DMA(enum mdp4_dma idx)
  367. {
  368. switch (idx) {
  369. case DMA_P: return 0x00090000;
  370. case DMA_S: return 0x000a0000;
  371. case DMA_E: return 0x000b0000;
  372. default: return INVALID_IDX(idx);
  373. }
  374. }
  375. static inline uint32_t REG_MDP4_DMA(enum mdp4_dma i0) { return 0x00000000 + __offset_DMA(i0); }
  376. static inline uint32_t REG_MDP4_DMA_CONFIG(enum mdp4_dma i0) { return 0x00000000 + __offset_DMA(i0); }
  377. #define MDP4_DMA_CONFIG_G_BPC__MASK 0x00000003
  378. #define MDP4_DMA_CONFIG_G_BPC__SHIFT 0
  379. static inline uint32_t MDP4_DMA_CONFIG_G_BPC(enum mdp_bpc val)
  380. {
  381. return ((val) << MDP4_DMA_CONFIG_G_BPC__SHIFT) & MDP4_DMA_CONFIG_G_BPC__MASK;
  382. }
  383. #define MDP4_DMA_CONFIG_B_BPC__MASK 0x0000000c
  384. #define MDP4_DMA_CONFIG_B_BPC__SHIFT 2
  385. static inline uint32_t MDP4_DMA_CONFIG_B_BPC(enum mdp_bpc val)
  386. {
  387. return ((val) << MDP4_DMA_CONFIG_B_BPC__SHIFT) & MDP4_DMA_CONFIG_B_BPC__MASK;
  388. }
  389. #define MDP4_DMA_CONFIG_R_BPC__MASK 0x00000030
  390. #define MDP4_DMA_CONFIG_R_BPC__SHIFT 4
  391. static inline uint32_t MDP4_DMA_CONFIG_R_BPC(enum mdp_bpc val)
  392. {
  393. return ((val) << MDP4_DMA_CONFIG_R_BPC__SHIFT) & MDP4_DMA_CONFIG_R_BPC__MASK;
  394. }
  395. #define MDP4_DMA_CONFIG_PACK_ALIGN_MSB 0x00000080
  396. #define MDP4_DMA_CONFIG_PACK__MASK 0x0000ff00
  397. #define MDP4_DMA_CONFIG_PACK__SHIFT 8
  398. static inline uint32_t MDP4_DMA_CONFIG_PACK(uint32_t val)
  399. {
  400. return ((val) << MDP4_DMA_CONFIG_PACK__SHIFT) & MDP4_DMA_CONFIG_PACK__MASK;
  401. }
  402. #define MDP4_DMA_CONFIG_DEFLKR_EN 0x01000000
  403. #define MDP4_DMA_CONFIG_DITHER_EN 0x01000000
  404. static inline uint32_t REG_MDP4_DMA_SRC_SIZE(enum mdp4_dma i0) { return 0x00000004 + __offset_DMA(i0); }
  405. #define MDP4_DMA_SRC_SIZE_HEIGHT__MASK 0xffff0000
  406. #define MDP4_DMA_SRC_SIZE_HEIGHT__SHIFT 16
  407. static inline uint32_t MDP4_DMA_SRC_SIZE_HEIGHT(uint32_t val)
  408. {
  409. return ((val) << MDP4_DMA_SRC_SIZE_HEIGHT__SHIFT) & MDP4_DMA_SRC_SIZE_HEIGHT__MASK;
  410. }
  411. #define MDP4_DMA_SRC_SIZE_WIDTH__MASK 0x0000ffff
  412. #define MDP4_DMA_SRC_SIZE_WIDTH__SHIFT 0
  413. static inline uint32_t MDP4_DMA_SRC_SIZE_WIDTH(uint32_t val)
  414. {
  415. return ((val) << MDP4_DMA_SRC_SIZE_WIDTH__SHIFT) & MDP4_DMA_SRC_SIZE_WIDTH__MASK;
  416. }
  417. static inline uint32_t REG_MDP4_DMA_SRC_BASE(enum mdp4_dma i0) { return 0x00000008 + __offset_DMA(i0); }
  418. static inline uint32_t REG_MDP4_DMA_SRC_STRIDE(enum mdp4_dma i0) { return 0x0000000c + __offset_DMA(i0); }
  419. static inline uint32_t REG_MDP4_DMA_DST_SIZE(enum mdp4_dma i0) { return 0x00000010 + __offset_DMA(i0); }
  420. #define MDP4_DMA_DST_SIZE_HEIGHT__MASK 0xffff0000
  421. #define MDP4_DMA_DST_SIZE_HEIGHT__SHIFT 16
  422. static inline uint32_t MDP4_DMA_DST_SIZE_HEIGHT(uint32_t val)
  423. {
  424. return ((val) << MDP4_DMA_DST_SIZE_HEIGHT__SHIFT) & MDP4_DMA_DST_SIZE_HEIGHT__MASK;
  425. }
  426. #define MDP4_DMA_DST_SIZE_WIDTH__MASK 0x0000ffff
  427. #define MDP4_DMA_DST_SIZE_WIDTH__SHIFT 0
  428. static inline uint32_t MDP4_DMA_DST_SIZE_WIDTH(uint32_t val)
  429. {
  430. return ((val) << MDP4_DMA_DST_SIZE_WIDTH__SHIFT) & MDP4_DMA_DST_SIZE_WIDTH__MASK;
  431. }
  432. static inline uint32_t REG_MDP4_DMA_CURSOR_SIZE(enum mdp4_dma i0) { return 0x00000044 + __offset_DMA(i0); }
  433. #define MDP4_DMA_CURSOR_SIZE_WIDTH__MASK 0x0000007f
  434. #define MDP4_DMA_CURSOR_SIZE_WIDTH__SHIFT 0
  435. static inline uint32_t MDP4_DMA_CURSOR_SIZE_WIDTH(uint32_t val)
  436. {
  437. return ((val) << MDP4_DMA_CURSOR_SIZE_WIDTH__SHIFT) & MDP4_DMA_CURSOR_SIZE_WIDTH__MASK;
  438. }
  439. #define MDP4_DMA_CURSOR_SIZE_HEIGHT__MASK 0x007f0000
  440. #define MDP4_DMA_CURSOR_SIZE_HEIGHT__SHIFT 16
  441. static inline uint32_t MDP4_DMA_CURSOR_SIZE_HEIGHT(uint32_t val)
  442. {
  443. return ((val) << MDP4_DMA_CURSOR_SIZE_HEIGHT__SHIFT) & MDP4_DMA_CURSOR_SIZE_HEIGHT__MASK;
  444. }
  445. static inline uint32_t REG_MDP4_DMA_CURSOR_BASE(enum mdp4_dma i0) { return 0x00000048 + __offset_DMA(i0); }
  446. static inline uint32_t REG_MDP4_DMA_CURSOR_POS(enum mdp4_dma i0) { return 0x0000004c + __offset_DMA(i0); }
  447. #define MDP4_DMA_CURSOR_POS_X__MASK 0x0000ffff
  448. #define MDP4_DMA_CURSOR_POS_X__SHIFT 0
  449. static inline uint32_t MDP4_DMA_CURSOR_POS_X(uint32_t val)
  450. {
  451. return ((val) << MDP4_DMA_CURSOR_POS_X__SHIFT) & MDP4_DMA_CURSOR_POS_X__MASK;
  452. }
  453. #define MDP4_DMA_CURSOR_POS_Y__MASK 0xffff0000
  454. #define MDP4_DMA_CURSOR_POS_Y__SHIFT 16
  455. static inline uint32_t MDP4_DMA_CURSOR_POS_Y(uint32_t val)
  456. {
  457. return ((val) << MDP4_DMA_CURSOR_POS_Y__SHIFT) & MDP4_DMA_CURSOR_POS_Y__MASK;
  458. }
  459. static inline uint32_t REG_MDP4_DMA_CURSOR_BLEND_CONFIG(enum mdp4_dma i0) { return 0x00000060 + __offset_DMA(i0); }
  460. #define MDP4_DMA_CURSOR_BLEND_CONFIG_CURSOR_EN 0x00000001
  461. #define MDP4_DMA_CURSOR_BLEND_CONFIG_FORMAT__MASK 0x00000006
  462. #define MDP4_DMA_CURSOR_BLEND_CONFIG_FORMAT__SHIFT 1
  463. static inline uint32_t MDP4_DMA_CURSOR_BLEND_CONFIG_FORMAT(enum mdp4_cursor_format val)
  464. {
  465. return ((val) << MDP4_DMA_CURSOR_BLEND_CONFIG_FORMAT__SHIFT) & MDP4_DMA_CURSOR_BLEND_CONFIG_FORMAT__MASK;
  466. }
  467. #define MDP4_DMA_CURSOR_BLEND_CONFIG_TRANSP_EN 0x00000008
  468. static inline uint32_t REG_MDP4_DMA_CURSOR_BLEND_PARAM(enum mdp4_dma i0) { return 0x00000064 + __offset_DMA(i0); }
  469. static inline uint32_t REG_MDP4_DMA_BLEND_TRANS_LOW(enum mdp4_dma i0) { return 0x00000068 + __offset_DMA(i0); }
  470. static inline uint32_t REG_MDP4_DMA_BLEND_TRANS_HIGH(enum mdp4_dma i0) { return 0x0000006c + __offset_DMA(i0); }
  471. static inline uint32_t REG_MDP4_DMA_FETCH_CONFIG(enum mdp4_dma i0) { return 0x00001004 + __offset_DMA(i0); }
  472. static inline uint32_t REG_MDP4_DMA_CSC(enum mdp4_dma i0) { return 0x00003000 + __offset_DMA(i0); }
  473. static inline uint32_t REG_MDP4_DMA_CSC_MV(enum mdp4_dma i0, uint32_t i1) { return 0x00003400 + __offset_DMA(i0) + 0x4*i1; }
  474. static inline uint32_t REG_MDP4_DMA_CSC_MV_VAL(enum mdp4_dma i0, uint32_t i1) { return 0x00003400 + __offset_DMA(i0) + 0x4*i1; }
  475. static inline uint32_t REG_MDP4_DMA_CSC_PRE_BV(enum mdp4_dma i0, uint32_t i1) { return 0x00003500 + __offset_DMA(i0) + 0x4*i1; }
  476. static inline uint32_t REG_MDP4_DMA_CSC_PRE_BV_VAL(enum mdp4_dma i0, uint32_t i1) { return 0x00003500 + __offset_DMA(i0) + 0x4*i1; }
  477. static inline uint32_t REG_MDP4_DMA_CSC_POST_BV(enum mdp4_dma i0, uint32_t i1) { return 0x00003580 + __offset_DMA(i0) + 0x4*i1; }
  478. static inline uint32_t REG_MDP4_DMA_CSC_POST_BV_VAL(enum mdp4_dma i0, uint32_t i1) { return 0x00003580 + __offset_DMA(i0) + 0x4*i1; }
  479. static inline uint32_t REG_MDP4_DMA_CSC_PRE_LV(enum mdp4_dma i0, uint32_t i1) { return 0x00003600 + __offset_DMA(i0) + 0x4*i1; }
  480. static inline uint32_t REG_MDP4_DMA_CSC_PRE_LV_VAL(enum mdp4_dma i0, uint32_t i1) { return 0x00003600 + __offset_DMA(i0) + 0x4*i1; }
  481. static inline uint32_t REG_MDP4_DMA_CSC_POST_LV(enum mdp4_dma i0, uint32_t i1) { return 0x00003680 + __offset_DMA(i0) + 0x4*i1; }
  482. static inline uint32_t REG_MDP4_DMA_CSC_POST_LV_VAL(enum mdp4_dma i0, uint32_t i1) { return 0x00003680 + __offset_DMA(i0) + 0x4*i1; }
  483. static inline uint32_t REG_MDP4_PIPE(enum mdp4_pipe i0) { return 0x00020000 + 0x10000*i0; }
  484. static inline uint32_t REG_MDP4_PIPE_SRC_SIZE(enum mdp4_pipe i0) { return 0x00020000 + 0x10000*i0; }
  485. #define MDP4_PIPE_SRC_SIZE_HEIGHT__MASK 0xffff0000
  486. #define MDP4_PIPE_SRC_SIZE_HEIGHT__SHIFT 16
  487. static inline uint32_t MDP4_PIPE_SRC_SIZE_HEIGHT(uint32_t val)
  488. {
  489. return ((val) << MDP4_PIPE_SRC_SIZE_HEIGHT__SHIFT) & MDP4_PIPE_SRC_SIZE_HEIGHT__MASK;
  490. }
  491. #define MDP4_PIPE_SRC_SIZE_WIDTH__MASK 0x0000ffff
  492. #define MDP4_PIPE_SRC_SIZE_WIDTH__SHIFT 0
  493. static inline uint32_t MDP4_PIPE_SRC_SIZE_WIDTH(uint32_t val)
  494. {
  495. return ((val) << MDP4_PIPE_SRC_SIZE_WIDTH__SHIFT) & MDP4_PIPE_SRC_SIZE_WIDTH__MASK;
  496. }
  497. static inline uint32_t REG_MDP4_PIPE_SRC_XY(enum mdp4_pipe i0) { return 0x00020004 + 0x10000*i0; }
  498. #define MDP4_PIPE_SRC_XY_Y__MASK 0xffff0000
  499. #define MDP4_PIPE_SRC_XY_Y__SHIFT 16
  500. static inline uint32_t MDP4_PIPE_SRC_XY_Y(uint32_t val)
  501. {
  502. return ((val) << MDP4_PIPE_SRC_XY_Y__SHIFT) & MDP4_PIPE_SRC_XY_Y__MASK;
  503. }
  504. #define MDP4_PIPE_SRC_XY_X__MASK 0x0000ffff
  505. #define MDP4_PIPE_SRC_XY_X__SHIFT 0
  506. static inline uint32_t MDP4_PIPE_SRC_XY_X(uint32_t val)
  507. {
  508. return ((val) << MDP4_PIPE_SRC_XY_X__SHIFT) & MDP4_PIPE_SRC_XY_X__MASK;
  509. }
  510. static inline uint32_t REG_MDP4_PIPE_DST_SIZE(enum mdp4_pipe i0) { return 0x00020008 + 0x10000*i0; }
  511. #define MDP4_PIPE_DST_SIZE_HEIGHT__MASK 0xffff0000
  512. #define MDP4_PIPE_DST_SIZE_HEIGHT__SHIFT 16
  513. static inline uint32_t MDP4_PIPE_DST_SIZE_HEIGHT(uint32_t val)
  514. {
  515. return ((val) << MDP4_PIPE_DST_SIZE_HEIGHT__SHIFT) & MDP4_PIPE_DST_SIZE_HEIGHT__MASK;
  516. }
  517. #define MDP4_PIPE_DST_SIZE_WIDTH__MASK 0x0000ffff
  518. #define MDP4_PIPE_DST_SIZE_WIDTH__SHIFT 0
  519. static inline uint32_t MDP4_PIPE_DST_SIZE_WIDTH(uint32_t val)
  520. {
  521. return ((val) << MDP4_PIPE_DST_SIZE_WIDTH__SHIFT) & MDP4_PIPE_DST_SIZE_WIDTH__MASK;
  522. }
  523. static inline uint32_t REG_MDP4_PIPE_DST_XY(enum mdp4_pipe i0) { return 0x0002000c + 0x10000*i0; }
  524. #define MDP4_PIPE_DST_XY_Y__MASK 0xffff0000
  525. #define MDP4_PIPE_DST_XY_Y__SHIFT 16
  526. static inline uint32_t MDP4_PIPE_DST_XY_Y(uint32_t val)
  527. {
  528. return ((val) << MDP4_PIPE_DST_XY_Y__SHIFT) & MDP4_PIPE_DST_XY_Y__MASK;
  529. }
  530. #define MDP4_PIPE_DST_XY_X__MASK 0x0000ffff
  531. #define MDP4_PIPE_DST_XY_X__SHIFT 0
  532. static inline uint32_t MDP4_PIPE_DST_XY_X(uint32_t val)
  533. {
  534. return ((val) << MDP4_PIPE_DST_XY_X__SHIFT) & MDP4_PIPE_DST_XY_X__MASK;
  535. }
  536. static inline uint32_t REG_MDP4_PIPE_SRCP0_BASE(enum mdp4_pipe i0) { return 0x00020010 + 0x10000*i0; }
  537. static inline uint32_t REG_MDP4_PIPE_SRCP1_BASE(enum mdp4_pipe i0) { return 0x00020014 + 0x10000*i0; }
  538. static inline uint32_t REG_MDP4_PIPE_SRCP2_BASE(enum mdp4_pipe i0) { return 0x00020018 + 0x10000*i0; }
  539. static inline uint32_t REG_MDP4_PIPE_SRCP3_BASE(enum mdp4_pipe i0) { return 0x0002001c + 0x10000*i0; }
  540. static inline uint32_t REG_MDP4_PIPE_SRC_STRIDE_A(enum mdp4_pipe i0) { return 0x00020040 + 0x10000*i0; }
  541. #define MDP4_PIPE_SRC_STRIDE_A_P0__MASK 0x0000ffff
  542. #define MDP4_PIPE_SRC_STRIDE_A_P0__SHIFT 0
  543. static inline uint32_t MDP4_PIPE_SRC_STRIDE_A_P0(uint32_t val)
  544. {
  545. return ((val) << MDP4_PIPE_SRC_STRIDE_A_P0__SHIFT) & MDP4_PIPE_SRC_STRIDE_A_P0__MASK;
  546. }
  547. #define MDP4_PIPE_SRC_STRIDE_A_P1__MASK 0xffff0000
  548. #define MDP4_PIPE_SRC_STRIDE_A_P1__SHIFT 16
  549. static inline uint32_t MDP4_PIPE_SRC_STRIDE_A_P1(uint32_t val)
  550. {
  551. return ((val) << MDP4_PIPE_SRC_STRIDE_A_P1__SHIFT) & MDP4_PIPE_SRC_STRIDE_A_P1__MASK;
  552. }
  553. static inline uint32_t REG_MDP4_PIPE_SRC_STRIDE_B(enum mdp4_pipe i0) { return 0x00020044 + 0x10000*i0; }
  554. #define MDP4_PIPE_SRC_STRIDE_B_P2__MASK 0x0000ffff
  555. #define MDP4_PIPE_SRC_STRIDE_B_P2__SHIFT 0
  556. static inline uint32_t MDP4_PIPE_SRC_STRIDE_B_P2(uint32_t val)
  557. {
  558. return ((val) << MDP4_PIPE_SRC_STRIDE_B_P2__SHIFT) & MDP4_PIPE_SRC_STRIDE_B_P2__MASK;
  559. }
  560. #define MDP4_PIPE_SRC_STRIDE_B_P3__MASK 0xffff0000
  561. #define MDP4_PIPE_SRC_STRIDE_B_P3__SHIFT 16
  562. static inline uint32_t MDP4_PIPE_SRC_STRIDE_B_P3(uint32_t val)
  563. {
  564. return ((val) << MDP4_PIPE_SRC_STRIDE_B_P3__SHIFT) & MDP4_PIPE_SRC_STRIDE_B_P3__MASK;
  565. }
  566. static inline uint32_t REG_MDP4_PIPE_SSTILE_FRAME_SIZE(enum mdp4_pipe i0) { return 0x00020048 + 0x10000*i0; }
  567. #define MDP4_PIPE_SSTILE_FRAME_SIZE_HEIGHT__MASK 0xffff0000
  568. #define MDP4_PIPE_SSTILE_FRAME_SIZE_HEIGHT__SHIFT 16
  569. static inline uint32_t MDP4_PIPE_SSTILE_FRAME_SIZE_HEIGHT(uint32_t val)
  570. {
  571. return ((val) << MDP4_PIPE_SSTILE_FRAME_SIZE_HEIGHT__SHIFT) & MDP4_PIPE_SSTILE_FRAME_SIZE_HEIGHT__MASK;
  572. }
  573. #define MDP4_PIPE_SSTILE_FRAME_SIZE_WIDTH__MASK 0x0000ffff
  574. #define MDP4_PIPE_SSTILE_FRAME_SIZE_WIDTH__SHIFT 0
  575. static inline uint32_t MDP4_PIPE_SSTILE_FRAME_SIZE_WIDTH(uint32_t val)
  576. {
  577. return ((val) << MDP4_PIPE_SSTILE_FRAME_SIZE_WIDTH__SHIFT) & MDP4_PIPE_SSTILE_FRAME_SIZE_WIDTH__MASK;
  578. }
  579. static inline uint32_t REG_MDP4_PIPE_SRC_FORMAT(enum mdp4_pipe i0) { return 0x00020050 + 0x10000*i0; }
  580. #define MDP4_PIPE_SRC_FORMAT_G_BPC__MASK 0x00000003
  581. #define MDP4_PIPE_SRC_FORMAT_G_BPC__SHIFT 0
  582. static inline uint32_t MDP4_PIPE_SRC_FORMAT_G_BPC(enum mdp_bpc val)
  583. {
  584. return ((val) << MDP4_PIPE_SRC_FORMAT_G_BPC__SHIFT) & MDP4_PIPE_SRC_FORMAT_G_BPC__MASK;
  585. }
  586. #define MDP4_PIPE_SRC_FORMAT_B_BPC__MASK 0x0000000c
  587. #define MDP4_PIPE_SRC_FORMAT_B_BPC__SHIFT 2
  588. static inline uint32_t MDP4_PIPE_SRC_FORMAT_B_BPC(enum mdp_bpc val)
  589. {
  590. return ((val) << MDP4_PIPE_SRC_FORMAT_B_BPC__SHIFT) & MDP4_PIPE_SRC_FORMAT_B_BPC__MASK;
  591. }
  592. #define MDP4_PIPE_SRC_FORMAT_R_BPC__MASK 0x00000030
  593. #define MDP4_PIPE_SRC_FORMAT_R_BPC__SHIFT 4
  594. static inline uint32_t MDP4_PIPE_SRC_FORMAT_R_BPC(enum mdp_bpc val)
  595. {
  596. return ((val) << MDP4_PIPE_SRC_FORMAT_R_BPC__SHIFT) & MDP4_PIPE_SRC_FORMAT_R_BPC__MASK;
  597. }
  598. #define MDP4_PIPE_SRC_FORMAT_A_BPC__MASK 0x000000c0
  599. #define MDP4_PIPE_SRC_FORMAT_A_BPC__SHIFT 6
  600. static inline uint32_t MDP4_PIPE_SRC_FORMAT_A_BPC(enum mdp_bpc_alpha val)
  601. {
  602. return ((val) << MDP4_PIPE_SRC_FORMAT_A_BPC__SHIFT) & MDP4_PIPE_SRC_FORMAT_A_BPC__MASK;
  603. }
  604. #define MDP4_PIPE_SRC_FORMAT_ALPHA_ENABLE 0x00000100
  605. #define MDP4_PIPE_SRC_FORMAT_CPP__MASK 0x00000600
  606. #define MDP4_PIPE_SRC_FORMAT_CPP__SHIFT 9
  607. static inline uint32_t MDP4_PIPE_SRC_FORMAT_CPP(uint32_t val)
  608. {
  609. return ((val) << MDP4_PIPE_SRC_FORMAT_CPP__SHIFT) & MDP4_PIPE_SRC_FORMAT_CPP__MASK;
  610. }
  611. #define MDP4_PIPE_SRC_FORMAT_ROTATED_90 0x00001000
  612. #define MDP4_PIPE_SRC_FORMAT_UNPACK_COUNT__MASK 0x00006000
  613. #define MDP4_PIPE_SRC_FORMAT_UNPACK_COUNT__SHIFT 13
  614. static inline uint32_t MDP4_PIPE_SRC_FORMAT_UNPACK_COUNT(uint32_t val)
  615. {
  616. return ((val) << MDP4_PIPE_SRC_FORMAT_UNPACK_COUNT__SHIFT) & MDP4_PIPE_SRC_FORMAT_UNPACK_COUNT__MASK;
  617. }
  618. #define MDP4_PIPE_SRC_FORMAT_UNPACK_TIGHT 0x00020000
  619. #define MDP4_PIPE_SRC_FORMAT_UNPACK_ALIGN_MSB 0x00040000
  620. #define MDP4_PIPE_SRC_FORMAT_FETCH_PLANES__MASK 0x00180000
  621. #define MDP4_PIPE_SRC_FORMAT_FETCH_PLANES__SHIFT 19
  622. static inline uint32_t MDP4_PIPE_SRC_FORMAT_FETCH_PLANES(uint32_t val)
  623. {
  624. return ((val) << MDP4_PIPE_SRC_FORMAT_FETCH_PLANES__SHIFT) & MDP4_PIPE_SRC_FORMAT_FETCH_PLANES__MASK;
  625. }
  626. #define MDP4_PIPE_SRC_FORMAT_SOLID_FILL 0x00400000
  627. #define MDP4_PIPE_SRC_FORMAT_CHROMA_SAMP__MASK 0x0c000000
  628. #define MDP4_PIPE_SRC_FORMAT_CHROMA_SAMP__SHIFT 26
  629. static inline uint32_t MDP4_PIPE_SRC_FORMAT_CHROMA_SAMP(enum mdp_chroma_samp_type val)
  630. {
  631. return ((val) << MDP4_PIPE_SRC_FORMAT_CHROMA_SAMP__SHIFT) & MDP4_PIPE_SRC_FORMAT_CHROMA_SAMP__MASK;
  632. }
  633. #define MDP4_PIPE_SRC_FORMAT_FRAME_FORMAT__MASK 0x60000000
  634. #define MDP4_PIPE_SRC_FORMAT_FRAME_FORMAT__SHIFT 29
  635. static inline uint32_t MDP4_PIPE_SRC_FORMAT_FRAME_FORMAT(enum mdp4_frame_format val)
  636. {
  637. return ((val) << MDP4_PIPE_SRC_FORMAT_FRAME_FORMAT__SHIFT) & MDP4_PIPE_SRC_FORMAT_FRAME_FORMAT__MASK;
  638. }
  639. static inline uint32_t REG_MDP4_PIPE_SRC_UNPACK(enum mdp4_pipe i0) { return 0x00020054 + 0x10000*i0; }
  640. #define MDP4_PIPE_SRC_UNPACK_ELEM0__MASK 0x000000ff
  641. #define MDP4_PIPE_SRC_UNPACK_ELEM0__SHIFT 0
  642. static inline uint32_t MDP4_PIPE_SRC_UNPACK_ELEM0(uint32_t val)
  643. {
  644. return ((val) << MDP4_PIPE_SRC_UNPACK_ELEM0__SHIFT) & MDP4_PIPE_SRC_UNPACK_ELEM0__MASK;
  645. }
  646. #define MDP4_PIPE_SRC_UNPACK_ELEM1__MASK 0x0000ff00
  647. #define MDP4_PIPE_SRC_UNPACK_ELEM1__SHIFT 8
  648. static inline uint32_t MDP4_PIPE_SRC_UNPACK_ELEM1(uint32_t val)
  649. {
  650. return ((val) << MDP4_PIPE_SRC_UNPACK_ELEM1__SHIFT) & MDP4_PIPE_SRC_UNPACK_ELEM1__MASK;
  651. }
  652. #define MDP4_PIPE_SRC_UNPACK_ELEM2__MASK 0x00ff0000
  653. #define MDP4_PIPE_SRC_UNPACK_ELEM2__SHIFT 16
  654. static inline uint32_t MDP4_PIPE_SRC_UNPACK_ELEM2(uint32_t val)
  655. {
  656. return ((val) << MDP4_PIPE_SRC_UNPACK_ELEM2__SHIFT) & MDP4_PIPE_SRC_UNPACK_ELEM2__MASK;
  657. }
  658. #define MDP4_PIPE_SRC_UNPACK_ELEM3__MASK 0xff000000
  659. #define MDP4_PIPE_SRC_UNPACK_ELEM3__SHIFT 24
  660. static inline uint32_t MDP4_PIPE_SRC_UNPACK_ELEM3(uint32_t val)
  661. {
  662. return ((val) << MDP4_PIPE_SRC_UNPACK_ELEM3__SHIFT) & MDP4_PIPE_SRC_UNPACK_ELEM3__MASK;
  663. }
  664. static inline uint32_t REG_MDP4_PIPE_OP_MODE(enum mdp4_pipe i0) { return 0x00020058 + 0x10000*i0; }
  665. #define MDP4_PIPE_OP_MODE_SCALEX_EN 0x00000001
  666. #define MDP4_PIPE_OP_MODE_SCALEY_EN 0x00000002
  667. #define MDP4_PIPE_OP_MODE_SCALEX_UNIT_SEL__MASK 0x0000000c
  668. #define MDP4_PIPE_OP_MODE_SCALEX_UNIT_SEL__SHIFT 2
  669. static inline uint32_t MDP4_PIPE_OP_MODE_SCALEX_UNIT_SEL(enum mdp4_scale_unit val)
  670. {
  671. return ((val) << MDP4_PIPE_OP_MODE_SCALEX_UNIT_SEL__SHIFT) & MDP4_PIPE_OP_MODE_SCALEX_UNIT_SEL__MASK;
  672. }
  673. #define MDP4_PIPE_OP_MODE_SCALEY_UNIT_SEL__MASK 0x00000030
  674. #define MDP4_PIPE_OP_MODE_SCALEY_UNIT_SEL__SHIFT 4
  675. static inline uint32_t MDP4_PIPE_OP_MODE_SCALEY_UNIT_SEL(enum mdp4_scale_unit val)
  676. {
  677. return ((val) << MDP4_PIPE_OP_MODE_SCALEY_UNIT_SEL__SHIFT) & MDP4_PIPE_OP_MODE_SCALEY_UNIT_SEL__MASK;
  678. }
  679. #define MDP4_PIPE_OP_MODE_SRC_YCBCR 0x00000200
  680. #define MDP4_PIPE_OP_MODE_DST_YCBCR 0x00000400
  681. #define MDP4_PIPE_OP_MODE_CSC_EN 0x00000800
  682. #define MDP4_PIPE_OP_MODE_FLIP_LR 0x00002000
  683. #define MDP4_PIPE_OP_MODE_FLIP_UD 0x00004000
  684. #define MDP4_PIPE_OP_MODE_DITHER_EN 0x00008000
  685. #define MDP4_PIPE_OP_MODE_IGC_LUT_EN 0x00010000
  686. #define MDP4_PIPE_OP_MODE_DEINT_EN 0x00040000
  687. #define MDP4_PIPE_OP_MODE_DEINT_ODD_REF 0x00080000
  688. static inline uint32_t REG_MDP4_PIPE_PHASEX_STEP(enum mdp4_pipe i0) { return 0x0002005c + 0x10000*i0; }
  689. static inline uint32_t REG_MDP4_PIPE_PHASEY_STEP(enum mdp4_pipe i0) { return 0x00020060 + 0x10000*i0; }
  690. static inline uint32_t REG_MDP4_PIPE_FETCH_CONFIG(enum mdp4_pipe i0) { return 0x00021004 + 0x10000*i0; }
  691. static inline uint32_t REG_MDP4_PIPE_SOLID_COLOR(enum mdp4_pipe i0) { return 0x00021008 + 0x10000*i0; }
  692. static inline uint32_t REG_MDP4_PIPE_CSC(enum mdp4_pipe i0) { return 0x00024000 + 0x10000*i0; }
  693. static inline uint32_t REG_MDP4_PIPE_CSC_MV(enum mdp4_pipe i0, uint32_t i1) { return 0x00024400 + 0x10000*i0 + 0x4*i1; }
  694. static inline uint32_t REG_MDP4_PIPE_CSC_MV_VAL(enum mdp4_pipe i0, uint32_t i1) { return 0x00024400 + 0x10000*i0 + 0x4*i1; }
  695. static inline uint32_t REG_MDP4_PIPE_CSC_PRE_BV(enum mdp4_pipe i0, uint32_t i1) { return 0x00024500 + 0x10000*i0 + 0x4*i1; }
  696. static inline uint32_t REG_MDP4_PIPE_CSC_PRE_BV_VAL(enum mdp4_pipe i0, uint32_t i1) { return 0x00024500 + 0x10000*i0 + 0x4*i1; }
  697. static inline uint32_t REG_MDP4_PIPE_CSC_POST_BV(enum mdp4_pipe i0, uint32_t i1) { return 0x00024580 + 0x10000*i0 + 0x4*i1; }
  698. static inline uint32_t REG_MDP4_PIPE_CSC_POST_BV_VAL(enum mdp4_pipe i0, uint32_t i1) { return 0x00024580 + 0x10000*i0 + 0x4*i1; }
  699. static inline uint32_t REG_MDP4_PIPE_CSC_PRE_LV(enum mdp4_pipe i0, uint32_t i1) { return 0x00024600 + 0x10000*i0 + 0x4*i1; }
  700. static inline uint32_t REG_MDP4_PIPE_CSC_PRE_LV_VAL(enum mdp4_pipe i0, uint32_t i1) { return 0x00024600 + 0x10000*i0 + 0x4*i1; }
  701. static inline uint32_t REG_MDP4_PIPE_CSC_POST_LV(enum mdp4_pipe i0, uint32_t i1) { return 0x00024680 + 0x10000*i0 + 0x4*i1; }
  702. static inline uint32_t REG_MDP4_PIPE_CSC_POST_LV_VAL(enum mdp4_pipe i0, uint32_t i1) { return 0x00024680 + 0x10000*i0 + 0x4*i1; }
  703. #define REG_MDP4_LCDC 0x000c0000
  704. #define REG_MDP4_LCDC_ENABLE 0x000c0000
  705. #define REG_MDP4_LCDC_HSYNC_CTRL 0x000c0004
  706. #define MDP4_LCDC_HSYNC_CTRL_PULSEW__MASK 0x0000ffff
  707. #define MDP4_LCDC_HSYNC_CTRL_PULSEW__SHIFT 0
  708. static inline uint32_t MDP4_LCDC_HSYNC_CTRL_PULSEW(uint32_t val)
  709. {
  710. return ((val) << MDP4_LCDC_HSYNC_CTRL_PULSEW__SHIFT) & MDP4_LCDC_HSYNC_CTRL_PULSEW__MASK;
  711. }
  712. #define MDP4_LCDC_HSYNC_CTRL_PERIOD__MASK 0xffff0000
  713. #define MDP4_LCDC_HSYNC_CTRL_PERIOD__SHIFT 16
  714. static inline uint32_t MDP4_LCDC_HSYNC_CTRL_PERIOD(uint32_t val)
  715. {
  716. return ((val) << MDP4_LCDC_HSYNC_CTRL_PERIOD__SHIFT) & MDP4_LCDC_HSYNC_CTRL_PERIOD__MASK;
  717. }
  718. #define REG_MDP4_LCDC_VSYNC_PERIOD 0x000c0008
  719. #define REG_MDP4_LCDC_VSYNC_LEN 0x000c000c
  720. #define REG_MDP4_LCDC_DISPLAY_HCTRL 0x000c0010
  721. #define MDP4_LCDC_DISPLAY_HCTRL_START__MASK 0x0000ffff
  722. #define MDP4_LCDC_DISPLAY_HCTRL_START__SHIFT 0
  723. static inline uint32_t MDP4_LCDC_DISPLAY_HCTRL_START(uint32_t val)
  724. {
  725. return ((val) << MDP4_LCDC_DISPLAY_HCTRL_START__SHIFT) & MDP4_LCDC_DISPLAY_HCTRL_START__MASK;
  726. }
  727. #define MDP4_LCDC_DISPLAY_HCTRL_END__MASK 0xffff0000
  728. #define MDP4_LCDC_DISPLAY_HCTRL_END__SHIFT 16
  729. static inline uint32_t MDP4_LCDC_DISPLAY_HCTRL_END(uint32_t val)
  730. {
  731. return ((val) << MDP4_LCDC_DISPLAY_HCTRL_END__SHIFT) & MDP4_LCDC_DISPLAY_HCTRL_END__MASK;
  732. }
  733. #define REG_MDP4_LCDC_DISPLAY_VSTART 0x000c0014
  734. #define REG_MDP4_LCDC_DISPLAY_VEND 0x000c0018
  735. #define REG_MDP4_LCDC_ACTIVE_HCTL 0x000c001c
  736. #define MDP4_LCDC_ACTIVE_HCTL_START__MASK 0x00007fff
  737. #define MDP4_LCDC_ACTIVE_HCTL_START__SHIFT 0
  738. static inline uint32_t MDP4_LCDC_ACTIVE_HCTL_START(uint32_t val)
  739. {
  740. return ((val) << MDP4_LCDC_ACTIVE_HCTL_START__SHIFT) & MDP4_LCDC_ACTIVE_HCTL_START__MASK;
  741. }
  742. #define MDP4_LCDC_ACTIVE_HCTL_END__MASK 0x7fff0000
  743. #define MDP4_LCDC_ACTIVE_HCTL_END__SHIFT 16
  744. static inline uint32_t MDP4_LCDC_ACTIVE_HCTL_END(uint32_t val)
  745. {
  746. return ((val) << MDP4_LCDC_ACTIVE_HCTL_END__SHIFT) & MDP4_LCDC_ACTIVE_HCTL_END__MASK;
  747. }
  748. #define MDP4_LCDC_ACTIVE_HCTL_ACTIVE_START_X 0x80000000
  749. #define REG_MDP4_LCDC_ACTIVE_VSTART 0x000c0020
  750. #define REG_MDP4_LCDC_ACTIVE_VEND 0x000c0024
  751. #define REG_MDP4_LCDC_BORDER_CLR 0x000c0028
  752. #define REG_MDP4_LCDC_UNDERFLOW_CLR 0x000c002c
  753. #define MDP4_LCDC_UNDERFLOW_CLR_COLOR__MASK 0x00ffffff
  754. #define MDP4_LCDC_UNDERFLOW_CLR_COLOR__SHIFT 0
  755. static inline uint32_t MDP4_LCDC_UNDERFLOW_CLR_COLOR(uint32_t val)
  756. {
  757. return ((val) << MDP4_LCDC_UNDERFLOW_CLR_COLOR__SHIFT) & MDP4_LCDC_UNDERFLOW_CLR_COLOR__MASK;
  758. }
  759. #define MDP4_LCDC_UNDERFLOW_CLR_ENABLE_RECOVERY 0x80000000
  760. #define REG_MDP4_LCDC_HSYNC_SKEW 0x000c0030
  761. #define REG_MDP4_LCDC_TEST_CNTL 0x000c0034
  762. #define REG_MDP4_LCDC_CTRL_POLARITY 0x000c0038
  763. #define MDP4_LCDC_CTRL_POLARITY_HSYNC_LOW 0x00000001
  764. #define MDP4_LCDC_CTRL_POLARITY_VSYNC_LOW 0x00000002
  765. #define MDP4_LCDC_CTRL_POLARITY_DATA_EN_LOW 0x00000004
  766. #define REG_MDP4_LCDC_LVDS_INTF_CTL 0x000c2000
  767. #define MDP4_LCDC_LVDS_INTF_CTL_MODE_SEL 0x00000004
  768. #define MDP4_LCDC_LVDS_INTF_CTL_RGB_OUT 0x00000008
  769. #define MDP4_LCDC_LVDS_INTF_CTL_CH_SWAP 0x00000010
  770. #define MDP4_LCDC_LVDS_INTF_CTL_CH1_RES_BIT 0x00000020
  771. #define MDP4_LCDC_LVDS_INTF_CTL_CH2_RES_BIT 0x00000040
  772. #define MDP4_LCDC_LVDS_INTF_CTL_ENABLE 0x00000080
  773. #define MDP4_LCDC_LVDS_INTF_CTL_CH1_DATA_LANE0_EN 0x00000100
  774. #define MDP4_LCDC_LVDS_INTF_CTL_CH1_DATA_LANE1_EN 0x00000200
  775. #define MDP4_LCDC_LVDS_INTF_CTL_CH1_DATA_LANE2_EN 0x00000400
  776. #define MDP4_LCDC_LVDS_INTF_CTL_CH1_DATA_LANE3_EN 0x00000800
  777. #define MDP4_LCDC_LVDS_INTF_CTL_CH2_DATA_LANE0_EN 0x00001000
  778. #define MDP4_LCDC_LVDS_INTF_CTL_CH2_DATA_LANE1_EN 0x00002000
  779. #define MDP4_LCDC_LVDS_INTF_CTL_CH2_DATA_LANE2_EN 0x00004000
  780. #define MDP4_LCDC_LVDS_INTF_CTL_CH2_DATA_LANE3_EN 0x00008000
  781. #define MDP4_LCDC_LVDS_INTF_CTL_CH1_CLK_LANE_EN 0x00010000
  782. #define MDP4_LCDC_LVDS_INTF_CTL_CH2_CLK_LANE_EN 0x00020000
  783. static inline uint32_t REG_MDP4_LCDC_LVDS_MUX_CTL(uint32_t i0) { return 0x000c2014 + 0x8*i0; }
  784. static inline uint32_t REG_MDP4_LCDC_LVDS_MUX_CTL_3_TO_0(uint32_t i0) { return 0x000c2014 + 0x8*i0; }
  785. #define MDP4_LCDC_LVDS_MUX_CTL_3_TO_0_BIT0__MASK 0x000000ff
  786. #define MDP4_LCDC_LVDS_MUX_CTL_3_TO_0_BIT0__SHIFT 0
  787. static inline uint32_t MDP4_LCDC_LVDS_MUX_CTL_3_TO_0_BIT0(uint32_t val)
  788. {
  789. return ((val) << MDP4_LCDC_LVDS_MUX_CTL_3_TO_0_BIT0__SHIFT) & MDP4_LCDC_LVDS_MUX_CTL_3_TO_0_BIT0__MASK;
  790. }
  791. #define MDP4_LCDC_LVDS_MUX_CTL_3_TO_0_BIT1__MASK 0x0000ff00
  792. #define MDP4_LCDC_LVDS_MUX_CTL_3_TO_0_BIT1__SHIFT 8
  793. static inline uint32_t MDP4_LCDC_LVDS_MUX_CTL_3_TO_0_BIT1(uint32_t val)
  794. {
  795. return ((val) << MDP4_LCDC_LVDS_MUX_CTL_3_TO_0_BIT1__SHIFT) & MDP4_LCDC_LVDS_MUX_CTL_3_TO_0_BIT1__MASK;
  796. }
  797. #define MDP4_LCDC_LVDS_MUX_CTL_3_TO_0_BIT2__MASK 0x00ff0000
  798. #define MDP4_LCDC_LVDS_MUX_CTL_3_TO_0_BIT2__SHIFT 16
  799. static inline uint32_t MDP4_LCDC_LVDS_MUX_CTL_3_TO_0_BIT2(uint32_t val)
  800. {
  801. return ((val) << MDP4_LCDC_LVDS_MUX_CTL_3_TO_0_BIT2__SHIFT) & MDP4_LCDC_LVDS_MUX_CTL_3_TO_0_BIT2__MASK;
  802. }
  803. #define MDP4_LCDC_LVDS_MUX_CTL_3_TO_0_BIT3__MASK 0xff000000
  804. #define MDP4_LCDC_LVDS_MUX_CTL_3_TO_0_BIT3__SHIFT 24
  805. static inline uint32_t MDP4_LCDC_LVDS_MUX_CTL_3_TO_0_BIT3(uint32_t val)
  806. {
  807. return ((val) << MDP4_LCDC_LVDS_MUX_CTL_3_TO_0_BIT3__SHIFT) & MDP4_LCDC_LVDS_MUX_CTL_3_TO_0_BIT3__MASK;
  808. }
  809. static inline uint32_t REG_MDP4_LCDC_LVDS_MUX_CTL_6_TO_4(uint32_t i0) { return 0x000c2018 + 0x8*i0; }
  810. #define MDP4_LCDC_LVDS_MUX_CTL_6_TO_4_BIT4__MASK 0x000000ff
  811. #define MDP4_LCDC_LVDS_MUX_CTL_6_TO_4_BIT4__SHIFT 0
  812. static inline uint32_t MDP4_LCDC_LVDS_MUX_CTL_6_TO_4_BIT4(uint32_t val)
  813. {
  814. return ((val) << MDP4_LCDC_LVDS_MUX_CTL_6_TO_4_BIT4__SHIFT) & MDP4_LCDC_LVDS_MUX_CTL_6_TO_4_BIT4__MASK;
  815. }
  816. #define MDP4_LCDC_LVDS_MUX_CTL_6_TO_4_BIT5__MASK 0x0000ff00
  817. #define MDP4_LCDC_LVDS_MUX_CTL_6_TO_4_BIT5__SHIFT 8
  818. static inline uint32_t MDP4_LCDC_LVDS_MUX_CTL_6_TO_4_BIT5(uint32_t val)
  819. {
  820. return ((val) << MDP4_LCDC_LVDS_MUX_CTL_6_TO_4_BIT5__SHIFT) & MDP4_LCDC_LVDS_MUX_CTL_6_TO_4_BIT5__MASK;
  821. }
  822. #define MDP4_LCDC_LVDS_MUX_CTL_6_TO_4_BIT6__MASK 0x00ff0000
  823. #define MDP4_LCDC_LVDS_MUX_CTL_6_TO_4_BIT6__SHIFT 16
  824. static inline uint32_t MDP4_LCDC_LVDS_MUX_CTL_6_TO_4_BIT6(uint32_t val)
  825. {
  826. return ((val) << MDP4_LCDC_LVDS_MUX_CTL_6_TO_4_BIT6__SHIFT) & MDP4_LCDC_LVDS_MUX_CTL_6_TO_4_BIT6__MASK;
  827. }
  828. #define REG_MDP4_LCDC_LVDS_PHY_RESET 0x000c2034
  829. #define REG_MDP4_LVDS_PHY_PLL_CTRL_0 0x000c3000
  830. #define REG_MDP4_LVDS_PHY_PLL_CTRL_1 0x000c3004
  831. #define REG_MDP4_LVDS_PHY_PLL_CTRL_2 0x000c3008
  832. #define REG_MDP4_LVDS_PHY_PLL_CTRL_3 0x000c300c
  833. #define REG_MDP4_LVDS_PHY_PLL_CTRL_5 0x000c3014
  834. #define REG_MDP4_LVDS_PHY_PLL_CTRL_6 0x000c3018
  835. #define REG_MDP4_LVDS_PHY_PLL_CTRL_7 0x000c301c
  836. #define REG_MDP4_LVDS_PHY_PLL_CTRL_8 0x000c3020
  837. #define REG_MDP4_LVDS_PHY_PLL_CTRL_9 0x000c3024
  838. #define REG_MDP4_LVDS_PHY_PLL_LOCKED 0x000c3080
  839. #define REG_MDP4_LVDS_PHY_CFG2 0x000c3108
  840. #define REG_MDP4_LVDS_PHY_CFG0 0x000c3100
  841. #define MDP4_LVDS_PHY_CFG0_SERIALIZATION_ENBLE 0x00000010
  842. #define MDP4_LVDS_PHY_CFG0_CHANNEL0 0x00000040
  843. #define MDP4_LVDS_PHY_CFG0_CHANNEL1 0x00000080
  844. #define REG_MDP4_DTV 0x000d0000
  845. #define REG_MDP4_DTV_ENABLE 0x000d0000
  846. #define REG_MDP4_DTV_HSYNC_CTRL 0x000d0004
  847. #define MDP4_DTV_HSYNC_CTRL_PULSEW__MASK 0x0000ffff
  848. #define MDP4_DTV_HSYNC_CTRL_PULSEW__SHIFT 0
  849. static inline uint32_t MDP4_DTV_HSYNC_CTRL_PULSEW(uint32_t val)
  850. {
  851. return ((val) << MDP4_DTV_HSYNC_CTRL_PULSEW__SHIFT) & MDP4_DTV_HSYNC_CTRL_PULSEW__MASK;
  852. }
  853. #define MDP4_DTV_HSYNC_CTRL_PERIOD__MASK 0xffff0000
  854. #define MDP4_DTV_HSYNC_CTRL_PERIOD__SHIFT 16
  855. static inline uint32_t MDP4_DTV_HSYNC_CTRL_PERIOD(uint32_t val)
  856. {
  857. return ((val) << MDP4_DTV_HSYNC_CTRL_PERIOD__SHIFT) & MDP4_DTV_HSYNC_CTRL_PERIOD__MASK;
  858. }
  859. #define REG_MDP4_DTV_VSYNC_PERIOD 0x000d0008
  860. #define REG_MDP4_DTV_VSYNC_LEN 0x000d000c
  861. #define REG_MDP4_DTV_DISPLAY_HCTRL 0x000d0018
  862. #define MDP4_DTV_DISPLAY_HCTRL_START__MASK 0x0000ffff
  863. #define MDP4_DTV_DISPLAY_HCTRL_START__SHIFT 0
  864. static inline uint32_t MDP4_DTV_DISPLAY_HCTRL_START(uint32_t val)
  865. {
  866. return ((val) << MDP4_DTV_DISPLAY_HCTRL_START__SHIFT) & MDP4_DTV_DISPLAY_HCTRL_START__MASK;
  867. }
  868. #define MDP4_DTV_DISPLAY_HCTRL_END__MASK 0xffff0000
  869. #define MDP4_DTV_DISPLAY_HCTRL_END__SHIFT 16
  870. static inline uint32_t MDP4_DTV_DISPLAY_HCTRL_END(uint32_t val)
  871. {
  872. return ((val) << MDP4_DTV_DISPLAY_HCTRL_END__SHIFT) & MDP4_DTV_DISPLAY_HCTRL_END__MASK;
  873. }
  874. #define REG_MDP4_DTV_DISPLAY_VSTART 0x000d001c
  875. #define REG_MDP4_DTV_DISPLAY_VEND 0x000d0020
  876. #define REG_MDP4_DTV_ACTIVE_HCTL 0x000d002c
  877. #define MDP4_DTV_ACTIVE_HCTL_START__MASK 0x00007fff
  878. #define MDP4_DTV_ACTIVE_HCTL_START__SHIFT 0
  879. static inline uint32_t MDP4_DTV_ACTIVE_HCTL_START(uint32_t val)
  880. {
  881. return ((val) << MDP4_DTV_ACTIVE_HCTL_START__SHIFT) & MDP4_DTV_ACTIVE_HCTL_START__MASK;
  882. }
  883. #define MDP4_DTV_ACTIVE_HCTL_END__MASK 0x7fff0000
  884. #define MDP4_DTV_ACTIVE_HCTL_END__SHIFT 16
  885. static inline uint32_t MDP4_DTV_ACTIVE_HCTL_END(uint32_t val)
  886. {
  887. return ((val) << MDP4_DTV_ACTIVE_HCTL_END__SHIFT) & MDP4_DTV_ACTIVE_HCTL_END__MASK;
  888. }
  889. #define MDP4_DTV_ACTIVE_HCTL_ACTIVE_START_X 0x80000000
  890. #define REG_MDP4_DTV_ACTIVE_VSTART 0x000d0030
  891. #define REG_MDP4_DTV_ACTIVE_VEND 0x000d0038
  892. #define REG_MDP4_DTV_BORDER_CLR 0x000d0040
  893. #define REG_MDP4_DTV_UNDERFLOW_CLR 0x000d0044
  894. #define MDP4_DTV_UNDERFLOW_CLR_COLOR__MASK 0x00ffffff
  895. #define MDP4_DTV_UNDERFLOW_CLR_COLOR__SHIFT 0
  896. static inline uint32_t MDP4_DTV_UNDERFLOW_CLR_COLOR(uint32_t val)
  897. {
  898. return ((val) << MDP4_DTV_UNDERFLOW_CLR_COLOR__SHIFT) & MDP4_DTV_UNDERFLOW_CLR_COLOR__MASK;
  899. }
  900. #define MDP4_DTV_UNDERFLOW_CLR_ENABLE_RECOVERY 0x80000000
  901. #define REG_MDP4_DTV_HSYNC_SKEW 0x000d0048
  902. #define REG_MDP4_DTV_TEST_CNTL 0x000d004c
  903. #define REG_MDP4_DTV_CTRL_POLARITY 0x000d0050
  904. #define MDP4_DTV_CTRL_POLARITY_HSYNC_LOW 0x00000001
  905. #define MDP4_DTV_CTRL_POLARITY_VSYNC_LOW 0x00000002
  906. #define MDP4_DTV_CTRL_POLARITY_DATA_EN_LOW 0x00000004
  907. #define REG_MDP4_DSI 0x000e0000
  908. #define REG_MDP4_DSI_ENABLE 0x000e0000
  909. #define REG_MDP4_DSI_HSYNC_CTRL 0x000e0004
  910. #define MDP4_DSI_HSYNC_CTRL_PULSEW__MASK 0x0000ffff
  911. #define MDP4_DSI_HSYNC_CTRL_PULSEW__SHIFT 0
  912. static inline uint32_t MDP4_DSI_HSYNC_CTRL_PULSEW(uint32_t val)
  913. {
  914. return ((val) << MDP4_DSI_HSYNC_CTRL_PULSEW__SHIFT) & MDP4_DSI_HSYNC_CTRL_PULSEW__MASK;
  915. }
  916. #define MDP4_DSI_HSYNC_CTRL_PERIOD__MASK 0xffff0000
  917. #define MDP4_DSI_HSYNC_CTRL_PERIOD__SHIFT 16
  918. static inline uint32_t MDP4_DSI_HSYNC_CTRL_PERIOD(uint32_t val)
  919. {
  920. return ((val) << MDP4_DSI_HSYNC_CTRL_PERIOD__SHIFT) & MDP4_DSI_HSYNC_CTRL_PERIOD__MASK;
  921. }
  922. #define REG_MDP4_DSI_VSYNC_PERIOD 0x000e0008
  923. #define REG_MDP4_DSI_VSYNC_LEN 0x000e000c
  924. #define REG_MDP4_DSI_DISPLAY_HCTRL 0x000e0010
  925. #define MDP4_DSI_DISPLAY_HCTRL_START__MASK 0x0000ffff
  926. #define MDP4_DSI_DISPLAY_HCTRL_START__SHIFT 0
  927. static inline uint32_t MDP4_DSI_DISPLAY_HCTRL_START(uint32_t val)
  928. {
  929. return ((val) << MDP4_DSI_DISPLAY_HCTRL_START__SHIFT) & MDP4_DSI_DISPLAY_HCTRL_START__MASK;
  930. }
  931. #define MDP4_DSI_DISPLAY_HCTRL_END__MASK 0xffff0000
  932. #define MDP4_DSI_DISPLAY_HCTRL_END__SHIFT 16
  933. static inline uint32_t MDP4_DSI_DISPLAY_HCTRL_END(uint32_t val)
  934. {
  935. return ((val) << MDP4_DSI_DISPLAY_HCTRL_END__SHIFT) & MDP4_DSI_DISPLAY_HCTRL_END__MASK;
  936. }
  937. #define REG_MDP4_DSI_DISPLAY_VSTART 0x000e0014
  938. #define REG_MDP4_DSI_DISPLAY_VEND 0x000e0018
  939. #define REG_MDP4_DSI_ACTIVE_HCTL 0x000e001c
  940. #define MDP4_DSI_ACTIVE_HCTL_START__MASK 0x00007fff
  941. #define MDP4_DSI_ACTIVE_HCTL_START__SHIFT 0
  942. static inline uint32_t MDP4_DSI_ACTIVE_HCTL_START(uint32_t val)
  943. {
  944. return ((val) << MDP4_DSI_ACTIVE_HCTL_START__SHIFT) & MDP4_DSI_ACTIVE_HCTL_START__MASK;
  945. }
  946. #define MDP4_DSI_ACTIVE_HCTL_END__MASK 0x7fff0000
  947. #define MDP4_DSI_ACTIVE_HCTL_END__SHIFT 16
  948. static inline uint32_t MDP4_DSI_ACTIVE_HCTL_END(uint32_t val)
  949. {
  950. return ((val) << MDP4_DSI_ACTIVE_HCTL_END__SHIFT) & MDP4_DSI_ACTIVE_HCTL_END__MASK;
  951. }
  952. #define MDP4_DSI_ACTIVE_HCTL_ACTIVE_START_X 0x80000000
  953. #define REG_MDP4_DSI_ACTIVE_VSTART 0x000e0020
  954. #define REG_MDP4_DSI_ACTIVE_VEND 0x000e0024
  955. #define REG_MDP4_DSI_BORDER_CLR 0x000e0028
  956. #define REG_MDP4_DSI_UNDERFLOW_CLR 0x000e002c
  957. #define MDP4_DSI_UNDERFLOW_CLR_COLOR__MASK 0x00ffffff
  958. #define MDP4_DSI_UNDERFLOW_CLR_COLOR__SHIFT 0
  959. static inline uint32_t MDP4_DSI_UNDERFLOW_CLR_COLOR(uint32_t val)
  960. {
  961. return ((val) << MDP4_DSI_UNDERFLOW_CLR_COLOR__SHIFT) & MDP4_DSI_UNDERFLOW_CLR_COLOR__MASK;
  962. }
  963. #define MDP4_DSI_UNDERFLOW_CLR_ENABLE_RECOVERY 0x80000000
  964. #define REG_MDP4_DSI_HSYNC_SKEW 0x000e0030
  965. #define REG_MDP4_DSI_TEST_CNTL 0x000e0034
  966. #define REG_MDP4_DSI_CTRL_POLARITY 0x000e0038
  967. #define MDP4_DSI_CTRL_POLARITY_HSYNC_LOW 0x00000001
  968. #define MDP4_DSI_CTRL_POLARITY_VSYNC_LOW 0x00000002
  969. #define MDP4_DSI_CTRL_POLARITY_DATA_EN_LOW 0x00000004
  970. #endif /* MDP4_XML */