qos.c 36 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000
  1. /*
  2. * board/renesas/alt/qos.c
  3. *
  4. * Copyright (C) 2014 Renesas Electronics Corporation
  5. *
  6. * SPDX-License-Identifier: GPL-2.0
  7. *
  8. */
  9. #include <common.h>
  10. #include <asm/processor.h>
  11. #include <asm/mach-types.h>
  12. #include <asm/io.h>
  13. #include <asm/arch/rmobile.h>
  14. #if defined(CONFIG_ARCH_RMOBILE_EXTRAM_BOOT)
  15. /* QoS version 0.311 for ES1 and version 0.321 for ES2 */
  16. enum {
  17. DBSC3_00, DBSC3_01, DBSC3_02, DBSC3_03, DBSC3_04,
  18. DBSC3_05, DBSC3_06, DBSC3_07, DBSC3_08, DBSC3_09,
  19. DBSC3_10, DBSC3_11, DBSC3_12, DBSC3_13, DBSC3_14,
  20. DBSC3_15,
  21. DBSC3_NR,
  22. };
  23. static u32 dbsc3_0_r_qos_addr[DBSC3_NR] = {
  24. [DBSC3_00] = DBSC3_0_QOS_R0_BASE,
  25. [DBSC3_01] = DBSC3_0_QOS_R1_BASE,
  26. [DBSC3_02] = DBSC3_0_QOS_R2_BASE,
  27. [DBSC3_03] = DBSC3_0_QOS_R3_BASE,
  28. [DBSC3_04] = DBSC3_0_QOS_R4_BASE,
  29. [DBSC3_05] = DBSC3_0_QOS_R5_BASE,
  30. [DBSC3_06] = DBSC3_0_QOS_R6_BASE,
  31. [DBSC3_07] = DBSC3_0_QOS_R7_BASE,
  32. [DBSC3_08] = DBSC3_0_QOS_R8_BASE,
  33. [DBSC3_09] = DBSC3_0_QOS_R9_BASE,
  34. [DBSC3_10] = DBSC3_0_QOS_R10_BASE,
  35. [DBSC3_11] = DBSC3_0_QOS_R11_BASE,
  36. [DBSC3_12] = DBSC3_0_QOS_R12_BASE,
  37. [DBSC3_13] = DBSC3_0_QOS_R13_BASE,
  38. [DBSC3_14] = DBSC3_0_QOS_R14_BASE,
  39. [DBSC3_15] = DBSC3_0_QOS_R15_BASE,
  40. };
  41. static u32 dbsc3_0_w_qos_addr[DBSC3_NR] = {
  42. [DBSC3_00] = DBSC3_0_QOS_W0_BASE,
  43. [DBSC3_01] = DBSC3_0_QOS_W1_BASE,
  44. [DBSC3_02] = DBSC3_0_QOS_W2_BASE,
  45. [DBSC3_03] = DBSC3_0_QOS_W3_BASE,
  46. [DBSC3_04] = DBSC3_0_QOS_W4_BASE,
  47. [DBSC3_05] = DBSC3_0_QOS_W5_BASE,
  48. [DBSC3_06] = DBSC3_0_QOS_W6_BASE,
  49. [DBSC3_07] = DBSC3_0_QOS_W7_BASE,
  50. [DBSC3_08] = DBSC3_0_QOS_W8_BASE,
  51. [DBSC3_09] = DBSC3_0_QOS_W9_BASE,
  52. [DBSC3_10] = DBSC3_0_QOS_W10_BASE,
  53. [DBSC3_11] = DBSC3_0_QOS_W11_BASE,
  54. [DBSC3_12] = DBSC3_0_QOS_W12_BASE,
  55. [DBSC3_13] = DBSC3_0_QOS_W13_BASE,
  56. [DBSC3_14] = DBSC3_0_QOS_W14_BASE,
  57. [DBSC3_15] = DBSC3_0_QOS_W15_BASE,
  58. };
  59. #if defined(CONFIG_QOS_PRI_MEDIA)
  60. #define is_qos_pri_media() 1
  61. #else
  62. #define is_qos_pri_media() 0
  63. #endif
  64. #if defined(CONFIG_QOS_PRI_NORMAL)
  65. #define is_qos_pri_normal() 1
  66. #else
  67. #define is_qos_pri_normal() 0
  68. #endif
  69. #if defined(CONFIG_QOS_PRI_GFX)
  70. #define is_qos_pri_gfx() 1
  71. #else
  72. #define is_qos_pri_gfx() 0
  73. #endif
  74. void qos_init(void)
  75. {
  76. int i;
  77. struct rcar_s3c *s3c;
  78. struct rcar_s3c_qos *s3c_qos;
  79. struct rcar_dbsc3_qos *qos_addr;
  80. struct rcar_mxi *mxi;
  81. struct rcar_mxi_qos *mxi_qos;
  82. struct rcar_axi_qos *axi_qos;
  83. /* DBSC DBADJ2 */
  84. writel(0x20042004, DBSC3_0_DBADJ2);
  85. /* S3C -QoS */
  86. s3c = (struct rcar_s3c *)S3C_BASE;
  87. if (is_qos_pri_media()) {
  88. writel(0x1F0B0604, &s3c->s3crorr);
  89. writel(0x1F0E0705, &s3c->s3cworr);
  90. } else if (is_qos_pri_normal()) {
  91. writel(0x1F0B0908, &s3c->s3crorr);
  92. writel(0x1F0E0A08, &s3c->s3cworr);
  93. } else if (is_qos_pri_media()) {
  94. writel(0x1F0B0B0B, &s3c->s3crorr);
  95. writel(0x1F0E0C0C, &s3c->s3cworr);
  96. }
  97. /* QoS Control Registers */
  98. s3c_qos = (struct rcar_s3c_qos *)S3C_QOS_CCI0_BASE;
  99. writel(0x00890089, &s3c_qos->s3cqos0);
  100. writel(0x20960010, &s3c_qos->s3cqos1);
  101. writel(0x20302030, &s3c_qos->s3cqos2);
  102. if (is_qos_pri_media())
  103. writel(0x20AA2300, &s3c_qos->s3cqos3);
  104. else if (is_qos_pri_normal())
  105. writel(0x20AA2200, &s3c_qos->s3cqos3);
  106. else if (is_qos_pri_media())
  107. writel(0x20AA2100, &s3c_qos->s3cqos3);
  108. writel(0x00002032, &s3c_qos->s3cqos4);
  109. writel(0x20960010, &s3c_qos->s3cqos5);
  110. writel(0x20302030, &s3c_qos->s3cqos6);
  111. if (is_qos_pri_media())
  112. writel(0x20AA2300, &s3c_qos->s3cqos7);
  113. else if (is_qos_pri_normal())
  114. writel(0x20AA2200, &s3c_qos->s3cqos7);
  115. else if (is_qos_pri_gfx())
  116. writel(0x20AA2100, &s3c_qos->s3cqos7);
  117. writel(0x00002032, &s3c_qos->s3cqos8);
  118. s3c_qos = (struct rcar_s3c_qos *)S3C_QOS_CCI1_BASE;
  119. writel(0x00890089, &s3c_qos->s3cqos0);
  120. writel(0x20960010, &s3c_qos->s3cqos1);
  121. writel(0x20302030, &s3c_qos->s3cqos2);
  122. if (is_qos_pri_media())
  123. writel(0x20AA2300, &s3c_qos->s3cqos3);
  124. else if (is_qos_pri_normal())
  125. writel(0x20AA2200, &s3c_qos->s3cqos3);
  126. else if (is_qos_pri_gfx())
  127. writel(0x20AA2100, &s3c_qos->s3cqos3);
  128. writel(0x00002032, &s3c_qos->s3cqos4);
  129. writel(0x20960010, &s3c_qos->s3cqos5);
  130. writel(0x20302030, &s3c_qos->s3cqos6);
  131. if (is_qos_pri_media())
  132. writel(0x20AA2300, &s3c_qos->s3cqos7);
  133. else if (is_qos_pri_media())
  134. writel(0x20AA2200, &s3c_qos->s3cqos7);
  135. else if (is_qos_pri_media())
  136. writel(0x20AA2100, &s3c_qos->s3cqos7);
  137. writel(0x00002032, &s3c_qos->s3cqos8);
  138. s3c_qos = (struct rcar_s3c_qos *)S3C_QOS_MXI_BASE;
  139. writel(0x80928092, &s3c_qos->s3cqos0);
  140. writel(0x20960020, &s3c_qos->s3cqos1);
  141. writel(0x20302030, &s3c_qos->s3cqos2);
  142. writel(0x20AA20DC, &s3c_qos->s3cqos3);
  143. writel(0x00002032, &s3c_qos->s3cqos4);
  144. writel(0x20960020, &s3c_qos->s3cqos5);
  145. writel(0x20302030, &s3c_qos->s3cqos6);
  146. writel(0x20AA20DC, &s3c_qos->s3cqos7);
  147. writel(0x00002032, &s3c_qos->s3cqos8);
  148. s3c_qos = (struct rcar_s3c_qos *)S3C_QOS_AXI_BASE;
  149. writel(0x00820092, &s3c_qos->s3cqos0);
  150. writel(0x20960020, &s3c_qos->s3cqos1);
  151. writel(0x20302030, &s3c_qos->s3cqos2);
  152. writel(0x20AA20FA, &s3c_qos->s3cqos3);
  153. writel(0x00002032, &s3c_qos->s3cqos4);
  154. writel(0x20960020, &s3c_qos->s3cqos5);
  155. writel(0x20302030, &s3c_qos->s3cqos6);
  156. writel(0x20AA20FA, &s3c_qos->s3cqos7);
  157. writel(0x00002032, &s3c_qos->s3cqos8);
  158. /* DBSC -QoS */
  159. /* DBSC0 - Read */
  160. for (i = DBSC3_00; i < DBSC3_NR; i++) {
  161. qos_addr = (struct rcar_dbsc3_qos *)dbsc3_0_r_qos_addr[i];
  162. writel(0x00000002, &qos_addr->dblgcnt);
  163. writel(0x0000207D, &qos_addr->dbtmval0);
  164. writel(0x00002053, &qos_addr->dbtmval1);
  165. writel(0x0000202A, &qos_addr->dbtmval2);
  166. writel(0x00001FBD, &qos_addr->dbtmval3);
  167. writel(0x00000001, &qos_addr->dbrqctr);
  168. writel(0x00002064, &qos_addr->dbthres0);
  169. writel(0x0000203E, &qos_addr->dbthres1);
  170. writel(0x00002019, &qos_addr->dbthres2);
  171. writel(0x00000001, &qos_addr->dblgqon);
  172. }
  173. /* DBSC0 - Write */
  174. for (i = DBSC3_00; i < DBSC3_NR; i++) {
  175. qos_addr = (struct rcar_dbsc3_qos *)dbsc3_0_w_qos_addr[i];
  176. writel(0x00000002, &qos_addr->dblgcnt);
  177. writel(0x0000207D, &qos_addr->dbtmval0);
  178. writel(0x00002053, &qos_addr->dbtmval1);
  179. writel(0x00002043, &qos_addr->dbtmval2);
  180. writel(0x00002030, &qos_addr->dbtmval3);
  181. writel(0x00000001, &qos_addr->dbrqctr);
  182. writel(0x00002064, &qos_addr->dbthres0);
  183. writel(0x0000203E, &qos_addr->dbthres1);
  184. writel(0x00002031, &qos_addr->dbthres2);
  185. writel(0x00000001, &qos_addr->dblgqon);
  186. }
  187. /* CCI-400 -QoS */
  188. if (IS_R8A7794_ES2()) {
  189. writel(0x20001000, CCI_400_MAXOT_1);
  190. writel(0x20001000, CCI_400_MAXOT_2);
  191. } else {
  192. writel(0x20000800, CCI_400_MAXOT_1);
  193. writel(0x20000800, CCI_400_MAXOT_2);
  194. }
  195. writel(0x0000000C, CCI_400_QOSCNTL_1);
  196. writel(0x0000000C, CCI_400_QOSCNTL_2);
  197. /* MXI -QoS */
  198. /* Transaction Control (MXI) */
  199. mxi = (struct rcar_mxi *)MXI_BASE;
  200. writel(0x00000013, &mxi->mxrtcr);
  201. writel(0x00000016, &mxi->mxwtcr);
  202. writel(0x00780080, &mxi->mxsaar0);
  203. writel(0x02000800, &mxi->mxsaar1);
  204. /* QoS Control (MXI) */
  205. mxi_qos = (struct rcar_mxi_qos *)MXI_QOS_BASE;
  206. writel(0x0000000C, &mxi_qos->vspdu0);
  207. writel(0x0000000E, &mxi_qos->du0);
  208. /* AXI -QoS */
  209. /* Transaction Control (MXI) */
  210. axi_qos = (struct rcar_axi_qos *)SYS_AXI_SYX64TO128_BASE;
  211. writel(0x00000002, &axi_qos->qosconf);
  212. writel(0x00002245, &axi_qos->qosctset0);
  213. writel(0x00002096, &axi_qos->qosctset1);
  214. writel(0x00002030, &axi_qos->qosctset2);
  215. writel(0x00002030, &axi_qos->qosctset3);
  216. writel(0x00000001, &axi_qos->qosreqctr);
  217. writel(0x00002064, &axi_qos->qosthres0);
  218. writel(0x00002004, &axi_qos->qosthres1);
  219. writel(0x00000000, &axi_qos->qosthres2);
  220. writel(0x00000001, &axi_qos->qosqon);
  221. axi_qos = (struct rcar_axi_qos *)SYS_AXI_AVB_BASE;
  222. writel(0x00000000, &axi_qos->qosconf);
  223. writel(0x000020A6, &axi_qos->qosctset0);
  224. writel(0x00000001, &axi_qos->qosreqctr);
  225. writel(0x00002064, &axi_qos->qosthres0);
  226. writel(0x00002004, &axi_qos->qosthres1);
  227. writel(0x00000000, &axi_qos->qosthres2);
  228. writel(0x00000001, &axi_qos->qosqon);
  229. axi_qos = (struct rcar_axi_qos *)SYS_AXI_IMUX0_BASE;
  230. writel(0x00000002, &axi_qos->qosconf);
  231. writel(0x00002245, &axi_qos->qosctset0);
  232. writel(0x00002096, &axi_qos->qosctset1);
  233. writel(0x00002030, &axi_qos->qosctset2);
  234. writel(0x00002030, &axi_qos->qosctset3);
  235. writel(0x00000001, &axi_qos->qosreqctr);
  236. writel(0x00002064, &axi_qos->qosthres0);
  237. writel(0x00002004, &axi_qos->qosthres1);
  238. writel(0x00000000, &axi_qos->qosthres2);
  239. writel(0x00000001, &axi_qos->qosqon);
  240. axi_qos = (struct rcar_axi_qos *)SYS_AXI_IMUX1_BASE;
  241. writel(0x00000002, &axi_qos->qosconf);
  242. writel(0x00002245, &axi_qos->qosctset0);
  243. writel(0x00002096, &axi_qos->qosctset1);
  244. writel(0x00002030, &axi_qos->qosctset2);
  245. writel(0x00002030, &axi_qos->qosctset3);
  246. writel(0x00000001, &axi_qos->qosreqctr);
  247. writel(0x00002064, &axi_qos->qosthres0);
  248. writel(0x00002004, &axi_qos->qosthres1);
  249. writel(0x00000000, &axi_qos->qosthres2);
  250. writel(0x00000001, &axi_qos->qosqon);
  251. axi_qos = (struct rcar_axi_qos *)SYS_AXI_IMUX2_BASE;
  252. writel(0x00000002, &axi_qos->qosconf);
  253. writel(0x00002245, &axi_qos->qosctset0);
  254. writel(0x00002096, &axi_qos->qosctset1);
  255. writel(0x00002030, &axi_qos->qosctset2);
  256. writel(0x00002030, &axi_qos->qosctset3);
  257. writel(0x00000001, &axi_qos->qosreqctr);
  258. writel(0x00002064, &axi_qos->qosthres0);
  259. writel(0x00002004, &axi_qos->qosthres1);
  260. writel(0x00000000, &axi_qos->qosthres2);
  261. writel(0x00000001, &axi_qos->qosqon);
  262. axi_qos = (struct rcar_axi_qos *)SYS_AXI_LBS_BASE;
  263. writel(0x00000000, &axi_qos->qosconf);
  264. writel(0x0000214C, &axi_qos->qosctset0);
  265. writel(0x00000001, &axi_qos->qosreqctr);
  266. writel(0x00002064, &axi_qos->qosthres0);
  267. writel(0x00002004, &axi_qos->qosthres1);
  268. writel(0x00000000, &axi_qos->qosthres2);
  269. writel(0x00000001, &axi_qos->qosqon);
  270. axi_qos = (struct rcar_axi_qos *)SYS_AXI_MMUDS_BASE;
  271. writel(0x00000001, &axi_qos->qosconf);
  272. writel(0x00002004, &axi_qos->qosctset0);
  273. writel(0x00002096, &axi_qos->qosctset1);
  274. writel(0x00002030, &axi_qos->qosctset2);
  275. writel(0x00002030, &axi_qos->qosctset3);
  276. writel(0x00000001, &axi_qos->qosreqctr);
  277. writel(0x00002064, &axi_qos->qosthres0);
  278. writel(0x00002004, &axi_qos->qosthres1);
  279. writel(0x00000000, &axi_qos->qosthres2);
  280. writel(0x00000001, &axi_qos->qosqon);
  281. axi_qos = (struct rcar_axi_qos *)SYS_AXI_MMUM_BASE;
  282. writel(0x00000001, &axi_qos->qosconf);
  283. writel(0x00002004, &axi_qos->qosctset0);
  284. writel(0x00002096, &axi_qos->qosctset1);
  285. writel(0x00002030, &axi_qos->qosctset2);
  286. writel(0x00002030, &axi_qos->qosctset3);
  287. writel(0x00000001, &axi_qos->qosreqctr);
  288. writel(0x00002064, &axi_qos->qosthres0);
  289. writel(0x00002004, &axi_qos->qosthres1);
  290. writel(0x00000000, &axi_qos->qosthres2);
  291. writel(0x00000001, &axi_qos->qosqon);
  292. axi_qos = (struct rcar_axi_qos *)SYS_AXI_MMUS0_BASE;
  293. writel(0x00000001, &axi_qos->qosconf);
  294. writel(0x00002004, &axi_qos->qosctset0);
  295. writel(0x00002096, &axi_qos->qosctset1);
  296. writel(0x00002030, &axi_qos->qosctset2);
  297. writel(0x00002030, &axi_qos->qosctset3);
  298. writel(0x00000001, &axi_qos->qosreqctr);
  299. writel(0x00002064, &axi_qos->qosthres0);
  300. writel(0x00002004, &axi_qos->qosthres1);
  301. writel(0x00000000, &axi_qos->qosthres2);
  302. writel(0x00000001, &axi_qos->qosqon);
  303. axi_qos = (struct rcar_axi_qos *)SYS_AXI_MMUS1_BASE;
  304. writel(0x00000001, &axi_qos->qosconf);
  305. writel(0x00002004, &axi_qos->qosctset0);
  306. writel(0x00002096, &axi_qos->qosctset1);
  307. writel(0x00002030, &axi_qos->qosctset2);
  308. writel(0x00002030, &axi_qos->qosctset3);
  309. writel(0x00000001, &axi_qos->qosreqctr);
  310. writel(0x00002064, &axi_qos->qosthres0);
  311. writel(0x00002004, &axi_qos->qosthres1);
  312. writel(0x00000000, &axi_qos->qosthres2);
  313. writel(0x00000001, &axi_qos->qosqon);
  314. axi_qos = (struct rcar_axi_qos *)SYS_AXI_RTX_BASE;
  315. writel(0x00000002, &axi_qos->qosconf);
  316. writel(0x00002245, &axi_qos->qosctset0);
  317. writel(0x00002096, &axi_qos->qosctset1);
  318. writel(0x00002030, &axi_qos->qosctset2);
  319. writel(0x00002030, &axi_qos->qosctset3);
  320. writel(0x00000001, &axi_qos->qosreqctr);
  321. writel(0x00002064, &axi_qos->qosthres0);
  322. writel(0x00002004, &axi_qos->qosthres1);
  323. writel(0x00000000, &axi_qos->qosthres2);
  324. writel(0x00000001, &axi_qos->qosqon);
  325. axi_qos = (struct rcar_axi_qos *)SYS_AXI_SDS0_BASE;
  326. writel(0x00000000, &axi_qos->qosconf);
  327. writel(0x000020A6, &axi_qos->qosctset0);
  328. writel(0x00000001, &axi_qos->qosreqctr);
  329. writel(0x00002064, &axi_qos->qosthres0);
  330. writel(0x00002004, &axi_qos->qosthres1);
  331. writel(0x00000000, &axi_qos->qosthres2);
  332. writel(0x00000001, &axi_qos->qosqon);
  333. axi_qos = (struct rcar_axi_qos *)SYS_AXI_SDS1_BASE;
  334. writel(0x00000000, &axi_qos->qosconf);
  335. writel(0x000020A6, &axi_qos->qosctset0);
  336. writel(0x00000001, &axi_qos->qosreqctr);
  337. writel(0x00002064, &axi_qos->qosthres0);
  338. writel(0x00002004, &axi_qos->qosthres1);
  339. writel(0x00000000, &axi_qos->qosthres2);
  340. writel(0x00000001, &axi_qos->qosqon);
  341. axi_qos = (struct rcar_axi_qos *)SYS_AXI_USB20_BASE;
  342. writel(0x00000000, &axi_qos->qosconf);
  343. writel(0x00002053, &axi_qos->qosctset0);
  344. writel(0x00000001, &axi_qos->qosreqctr);
  345. writel(0x00002064, &axi_qos->qosthres0);
  346. writel(0x00002004, &axi_qos->qosthres1);
  347. writel(0x00000000, &axi_qos->qosthres2);
  348. writel(0x00000001, &axi_qos->qosqon);
  349. axi_qos = (struct rcar_axi_qos *)SYS_AXI_USB22_BASE;
  350. writel(0x00000000, &axi_qos->qosconf);
  351. writel(0x00002053, &axi_qos->qosctset0);
  352. writel(0x00000001, &axi_qos->qosreqctr);
  353. writel(0x00002064, &axi_qos->qosthres0);
  354. writel(0x00002004, &axi_qos->qosthres1);
  355. writel(0x00000000, &axi_qos->qosthres2);
  356. writel(0x00000001, &axi_qos->qosqon);
  357. axi_qos = (struct rcar_axi_qos *)SYS_AXI_AX2M_BASE;
  358. writel(0x00000002, &axi_qos->qosconf);
  359. writel(0x00002245, &axi_qos->qosctset0);
  360. writel(0x00000001, &axi_qos->qosreqctr);
  361. writel(0x00002064, &axi_qos->qosthres0);
  362. writel(0x00002004, &axi_qos->qosthres1);
  363. writel(0x00000000, &axi_qos->qosthres2);
  364. writel(0x00000001, &axi_qos->qosqon);
  365. axi_qos = (struct rcar_axi_qos *)SYS_AXI_CC50_BASE;
  366. writel(0x00000000, &axi_qos->qosconf);
  367. writel(0x00002029, &axi_qos->qosctset0);
  368. writel(0x00000001, &axi_qos->qosreqctr);
  369. writel(0x00002064, &axi_qos->qosthres0);
  370. writel(0x00002004, &axi_qos->qosthres1);
  371. writel(0x00000000, &axi_qos->qosthres2);
  372. writel(0x00000001, &axi_qos->qosqon);
  373. axi_qos = (struct rcar_axi_qos *)SYS_AXI_CCI_BASE;
  374. writel(0x00000002, &axi_qos->qosconf);
  375. writel(0x00002245, &axi_qos->qosctset0);
  376. writel(0x00000001, &axi_qos->qosreqctr);
  377. writel(0x00002064, &axi_qos->qosthres0);
  378. writel(0x00002004, &axi_qos->qosthres1);
  379. writel(0x00000000, &axi_qos->qosthres2);
  380. writel(0x00000001, &axi_qos->qosqon);
  381. axi_qos = (struct rcar_axi_qos *)SYS_AXI_CS_BASE;
  382. writel(0x00000000, &axi_qos->qosconf);
  383. writel(0x00002053, &axi_qos->qosctset0);
  384. writel(0x00000001, &axi_qos->qosreqctr);
  385. writel(0x00002064, &axi_qos->qosthres0);
  386. writel(0x00002004, &axi_qos->qosthres1);
  387. writel(0x00000000, &axi_qos->qosthres2);
  388. writel(0x00000001, &axi_qos->qosqon);
  389. axi_qos = (struct rcar_axi_qos *)SYS_AXI_DDM_BASE;
  390. writel(0x00000000, &axi_qos->qosconf);
  391. writel(0x000020A6, &axi_qos->qosctset0);
  392. writel(0x00000001, &axi_qos->qosreqctr);
  393. writel(0x00002064, &axi_qos->qosthres0);
  394. writel(0x00002004, &axi_qos->qosthres1);
  395. writel(0x00000000, &axi_qos->qosthres2);
  396. writel(0x00000001, &axi_qos->qosqon);
  397. axi_qos = (struct rcar_axi_qos *)SYS_AXI_ETH_BASE;
  398. writel(0x00000000, &axi_qos->qosconf);
  399. writel(0x00002053, &axi_qos->qosctset0);
  400. writel(0x00000001, &axi_qos->qosreqctr);
  401. writel(0x00002064, &axi_qos->qosthres0);
  402. writel(0x00002004, &axi_qos->qosthres1);
  403. writel(0x00000000, &axi_qos->qosthres2);
  404. writel(0x00000001, &axi_qos->qosqon);
  405. axi_qos = (struct rcar_axi_qos *)SYS_AXI_MPXM_BASE;
  406. writel(0x00000002, &axi_qos->qosconf);
  407. writel(0x00002245, &axi_qos->qosctset0);
  408. writel(0x00000001, &axi_qos->qosreqctr);
  409. writel(0x00002064, &axi_qos->qosthres0);
  410. writel(0x00002004, &axi_qos->qosthres1);
  411. writel(0x00000000, &axi_qos->qosthres2);
  412. writel(0x00000001, &axi_qos->qosqon);
  413. axi_qos = (struct rcar_axi_qos *)SYS_AXI_SDM0_BASE;
  414. writel(0x00000000, &axi_qos->qosconf);
  415. writel(0x0000214C, &axi_qos->qosctset0);
  416. writel(0x00000001, &axi_qos->qosreqctr);
  417. writel(0x00002064, &axi_qos->qosthres0);
  418. writel(0x00002004, &axi_qos->qosthres1);
  419. writel(0x00000000, &axi_qos->qosthres2);
  420. writel(0x00000001, &axi_qos->qosqon);
  421. axi_qos = (struct rcar_axi_qos *)SYS_AXI_SDM1_BASE;
  422. writel(0x00000000, &axi_qos->qosconf);
  423. writel(0x0000214C, &axi_qos->qosctset0);
  424. writel(0x00000001, &axi_qos->qosreqctr);
  425. writel(0x00002064, &axi_qos->qosthres0);
  426. writel(0x00002004, &axi_qos->qosthres1);
  427. writel(0x00000000, &axi_qos->qosthres2);
  428. writel(0x00000001, &axi_qos->qosqon);
  429. axi_qos = (struct rcar_axi_qos *)SYS_AXI_TRAB_BASE;
  430. writel(0x00000000, &axi_qos->qosconf);
  431. writel(0x000020A6, &axi_qos->qosctset0);
  432. writel(0x00000001, &axi_qos->qosreqctr);
  433. writel(0x00002064, &axi_qos->qosthres0);
  434. writel(0x00002004, &axi_qos->qosthres1);
  435. writel(0x00000000, &axi_qos->qosthres2);
  436. writel(0x00000001, &axi_qos->qosqon);
  437. axi_qos = (struct rcar_axi_qos *)SYS_AXI_UDM0_BASE;
  438. writel(0x00000000, &axi_qos->qosconf);
  439. writel(0x00002053, &axi_qos->qosctset0);
  440. writel(0x00000001, &axi_qos->qosreqctr);
  441. writel(0x00002064, &axi_qos->qosthres0);
  442. writel(0x00002004, &axi_qos->qosthres1);
  443. writel(0x00000000, &axi_qos->qosthres2);
  444. writel(0x00000001, &axi_qos->qosqon);
  445. axi_qos = (struct rcar_axi_qos *)SYS_AXI_UDM1_BASE;
  446. writel(0x00000000, &axi_qos->qosconf);
  447. writel(0x00002053, &axi_qos->qosctset0);
  448. writel(0x00000001, &axi_qos->qosreqctr);
  449. writel(0x00002064, &axi_qos->qosthres0);
  450. writel(0x00002004, &axi_qos->qosthres1);
  451. writel(0x00000000, &axi_qos->qosthres2);
  452. writel(0x00000001, &axi_qos->qosqon);
  453. /* QoS Register (RT-AXI) */
  454. axi_qos = (struct rcar_axi_qos *)RT_AXI_SHX_BASE;
  455. writel(0x00000001, &axi_qos->qosconf);
  456. writel(0x00002053, &axi_qos->qosctset0);
  457. writel(0x00002096, &axi_qos->qosctset1);
  458. writel(0x00002030, &axi_qos->qosctset2);
  459. writel(0x00002030, &axi_qos->qosctset3);
  460. writel(0x00000001, &axi_qos->qosreqctr);
  461. writel(0x00002064, &axi_qos->qosthres0);
  462. writel(0x00002004, &axi_qos->qosthres1);
  463. writel(0x00000000, &axi_qos->qosthres2);
  464. writel(0x00000001, &axi_qos->qosqon);
  465. axi_qos = (struct rcar_axi_qos *)RT_AXI_DBG_BASE;
  466. writel(0x00000000, &axi_qos->qosconf);
  467. writel(0x00002053, &axi_qos->qosctset0);
  468. writel(0x00002096, &axi_qos->qosctset1);
  469. writel(0x00002030, &axi_qos->qosctset2);
  470. writel(0x00002030, &axi_qos->qosctset3);
  471. writel(0x00000001, &axi_qos->qosreqctr);
  472. writel(0x00002064, &axi_qos->qosthres0);
  473. writel(0x00002004, &axi_qos->qosthres1);
  474. writel(0x00000000, &axi_qos->qosthres2);
  475. writel(0x00000001, &axi_qos->qosqon);
  476. axi_qos = (struct rcar_axi_qos *)RT_AXI_RTX64TO128_BASE;
  477. writel(0x00000002, &axi_qos->qosconf);
  478. writel(0x00002245, &axi_qos->qosctset0);
  479. writel(0x00002096, &axi_qos->qosctset1);
  480. writel(0x00002030, &axi_qos->qosctset2);
  481. writel(0x00002030, &axi_qos->qosctset3);
  482. writel(0x00000001, &axi_qos->qosreqctr);
  483. writel(0x00002064, &axi_qos->qosthres0);
  484. writel(0x00002004, &axi_qos->qosthres1);
  485. writel(0x00000000, &axi_qos->qosthres2);
  486. writel(0x00000001, &axi_qos->qosqon);
  487. axi_qos = (struct rcar_axi_qos *)RT_AXI_SY2RT_BASE;
  488. writel(0x00000002, &axi_qos->qosconf);
  489. writel(0x00002245, &axi_qos->qosctset0);
  490. writel(0x00000001, &axi_qos->qosreqctr);
  491. writel(0x00002064, &axi_qos->qosthres0);
  492. writel(0x00002004, &axi_qos->qosthres1);
  493. writel(0x00000000, &axi_qos->qosthres2);
  494. writel(0x00000001, &axi_qos->qosqon);
  495. /* QoS Register (MP-AXI) */
  496. axi_qos = (struct rcar_axi_qos *)MP_AXI_ADSP_BASE;
  497. writel(0x00000000, &axi_qos->qosconf);
  498. writel(0x00002037, &axi_qos->qosctset0);
  499. writel(0x00000001, &axi_qos->qosreqctr);
  500. writel(0x00002064, &axi_qos->qosthres0);
  501. writel(0x00002004, &axi_qos->qosthres1);
  502. writel(0x00000000, &axi_qos->qosthres2);
  503. writel(0x00000001, &axi_qos->qosqon);
  504. axi_qos = (struct rcar_axi_qos *)MP_AXI_ASDS0_BASE;
  505. writel(0x00000001, &axi_qos->qosconf);
  506. writel(0x00002014, &axi_qos->qosctset0);
  507. writel(0x00000040, &axi_qos->qosreqctr);
  508. writel(0x00002064, &axi_qos->qosthres0);
  509. writel(0x00002004, &axi_qos->qosthres1);
  510. writel(0x00000000, &axi_qos->qosthres2);
  511. writel(0x00000001, &axi_qos->qosqon);
  512. axi_qos = (struct rcar_axi_qos *)MP_AXI_ASDS1_BASE;
  513. writel(0x00000001, &axi_qos->qosconf);
  514. writel(0x00002014, &axi_qos->qosctset0);
  515. writel(0x00000040, &axi_qos->qosreqctr);
  516. writel(0x00002064, &axi_qos->qosthres0);
  517. writel(0x00002004, &axi_qos->qosthres1);
  518. writel(0x00000000, &axi_qos->qosthres2);
  519. writel(0x00000001, &axi_qos->qosqon);
  520. axi_qos = (struct rcar_axi_qos *)MP_AXI_MLP_BASE;
  521. writel(0x00000001, &axi_qos->qosconf);
  522. writel(0x00001FF0, &axi_qos->qosctset0);
  523. writel(0x00000020, &axi_qos->qosreqctr);
  524. writel(0x00002064, &axi_qos->qosthres0);
  525. writel(0x00002004, &axi_qos->qosthres1);
  526. writel(0x00002001, &axi_qos->qosthres2);
  527. writel(0x00000001, &axi_qos->qosqon);
  528. axi_qos = (struct rcar_axi_qos *)MP_AXI_MMUMP_BASE;
  529. writel(0x00000001, &axi_qos->qosconf);
  530. writel(0x00002004, &axi_qos->qosctset0);
  531. writel(0x00002096, &axi_qos->qosctset1);
  532. writel(0x00002030, &axi_qos->qosctset2);
  533. writel(0x00002030, &axi_qos->qosctset3);
  534. writel(0x00000001, &axi_qos->qosreqctr);
  535. writel(0x00002064, &axi_qos->qosthres0);
  536. writel(0x00002004, &axi_qos->qosthres1);
  537. writel(0x00000000, &axi_qos->qosthres2);
  538. writel(0x00000001, &axi_qos->qosqon);
  539. axi_qos = (struct rcar_axi_qos *)MP_AXI_SPU_BASE;
  540. writel(0x00000000, &axi_qos->qosconf);
  541. writel(0x00002053, &axi_qos->qosctset0);
  542. writel(0x00000001, &axi_qos->qosreqctr);
  543. writel(0x00002064, &axi_qos->qosthres0);
  544. writel(0x00002004, &axi_qos->qosthres1);
  545. writel(0x00000000, &axi_qos->qosthres2);
  546. writel(0x00000001, &axi_qos->qosqon);
  547. axi_qos = (struct rcar_axi_qos *)MP_AXI_SPUC_BASE;
  548. writel(0x00000000, &axi_qos->qosconf);
  549. writel(0x0000206E, &axi_qos->qosctset0);
  550. writel(0x00000001, &axi_qos->qosreqctr);
  551. writel(0x00002064, &axi_qos->qosthres0);
  552. writel(0x00002004, &axi_qos->qosthres1);
  553. writel(0x00000000, &axi_qos->qosthres2);
  554. writel(0x00000001, &axi_qos->qosqon);
  555. /* QoS Register (SYS-AXI256) */
  556. axi_qos = (struct rcar_axi_qos *)SYS_AXI256_AXI128TO256_BASE;
  557. writel(0x00000002, &axi_qos->qosconf);
  558. writel(0x000020EB, &axi_qos->qosctset0);
  559. writel(0x00002096, &axi_qos->qosctset1);
  560. writel(0x00002030, &axi_qos->qosctset2);
  561. writel(0x00002030, &axi_qos->qosctset3);
  562. writel(0x00000001, &axi_qos->qosreqctr);
  563. writel(0x00002064, &axi_qos->qosthres0);
  564. writel(0x00002004, &axi_qos->qosthres1);
  565. writel(0x00000000, &axi_qos->qosthres2);
  566. writel(0x00000001, &axi_qos->qosqon);
  567. axi_qos = (struct rcar_axi_qos *)SYS_AXI256_SYX_BASE;
  568. writel(0x00000002, &axi_qos->qosconf);
  569. writel(0x000020EB, &axi_qos->qosctset0);
  570. writel(0x00002096, &axi_qos->qosctset1);
  571. writel(0x00002030, &axi_qos->qosctset2);
  572. writel(0x00002030, &axi_qos->qosctset3);
  573. writel(0x00000001, &axi_qos->qosreqctr);
  574. writel(0x00002064, &axi_qos->qosthres0);
  575. writel(0x00002004, &axi_qos->qosthres1);
  576. writel(0x00000000, &axi_qos->qosthres2);
  577. writel(0x00000001, &axi_qos->qosqon);
  578. axi_qos = (struct rcar_axi_qos *)SYS_AXI256_MPX_BASE;
  579. writel(0x00000002, &axi_qos->qosconf);
  580. writel(0x000020EB, &axi_qos->qosctset0);
  581. writel(0x00002096, &axi_qos->qosctset1);
  582. writel(0x00002030, &axi_qos->qosctset2);
  583. writel(0x00002030, &axi_qos->qosctset3);
  584. writel(0x00000001, &axi_qos->qosreqctr);
  585. writel(0x00002064, &axi_qos->qosthres0);
  586. writel(0x00002004, &axi_qos->qosthres1);
  587. writel(0x00000000, &axi_qos->qosthres2);
  588. writel(0x00000001, &axi_qos->qosqon);
  589. axi_qos = (struct rcar_axi_qos *)SYS_AXI256_MXI_BASE;
  590. writel(0x00000002, &axi_qos->qosconf);
  591. writel(0x000020EB, &axi_qos->qosctset0);
  592. writel(0x00002096, &axi_qos->qosctset1);
  593. writel(0x00002030, &axi_qos->qosctset2);
  594. writel(0x00002030, &axi_qos->qosctset3);
  595. writel(0x00000001, &axi_qos->qosreqctr);
  596. writel(0x00002064, &axi_qos->qosthres0);
  597. writel(0x00002004, &axi_qos->qosthres1);
  598. writel(0x00000000, &axi_qos->qosthres2);
  599. writel(0x00000001, &axi_qos->qosqon);
  600. /* QoS Register (CCI-AXI) */
  601. axi_qos = (struct rcar_axi_qos *)CCI_AXI_MMUS0_BASE;
  602. writel(0x00000001, &axi_qos->qosconf);
  603. writel(0x00002004, &axi_qos->qosctset0);
  604. writel(0x00002096, &axi_qos->qosctset1);
  605. writel(0x00002030, &axi_qos->qosctset2);
  606. writel(0x00002030, &axi_qos->qosctset3);
  607. writel(0x00000001, &axi_qos->qosreqctr);
  608. writel(0x00002064, &axi_qos->qosthres0);
  609. writel(0x00002004, &axi_qos->qosthres1);
  610. writel(0x00000000, &axi_qos->qosthres2);
  611. writel(0x00000001, &axi_qos->qosqon);
  612. axi_qos = (struct rcar_axi_qos *)CCI_AXI_SYX2_BASE;
  613. writel(0x00000002, &axi_qos->qosconf);
  614. writel(0x00002245, &axi_qos->qosctset0);
  615. writel(0x00002096, &axi_qos->qosctset1);
  616. writel(0x00002030, &axi_qos->qosctset2);
  617. writel(0x00002030, &axi_qos->qosctset3);
  618. writel(0x00000001, &axi_qos->qosreqctr);
  619. writel(0x00002064, &axi_qos->qosthres0);
  620. writel(0x00002004, &axi_qos->qosthres1);
  621. writel(0x00000000, &axi_qos->qosthres2);
  622. writel(0x00000001, &axi_qos->qosqon);
  623. axi_qos = (struct rcar_axi_qos *)CCI_AXI_MMUR_BASE;
  624. writel(0x00000001, &axi_qos->qosconf);
  625. writel(0x00002004, &axi_qos->qosctset0);
  626. writel(0x00002096, &axi_qos->qosctset1);
  627. writel(0x00002030, &axi_qos->qosctset2);
  628. writel(0x00002030, &axi_qos->qosctset3);
  629. writel(0x00000001, &axi_qos->qosreqctr);
  630. writel(0x00002064, &axi_qos->qosthres0);
  631. writel(0x00002004, &axi_qos->qosthres1);
  632. writel(0x00000000, &axi_qos->qosthres2);
  633. writel(0x00000001, &axi_qos->qosqon);
  634. axi_qos = (struct rcar_axi_qos *)CCI_AXI_MMUDS_BASE;
  635. writel(0x00000001, &axi_qos->qosconf);
  636. writel(0x00002004, &axi_qos->qosctset0);
  637. writel(0x00002096, &axi_qos->qosctset1);
  638. writel(0x00002030, &axi_qos->qosctset2);
  639. writel(0x00002030, &axi_qos->qosctset3);
  640. writel(0x00000001, &axi_qos->qosreqctr);
  641. writel(0x00002064, &axi_qos->qosthres0);
  642. writel(0x00002004, &axi_qos->qosthres1);
  643. writel(0x00000000, &axi_qos->qosthres2);
  644. writel(0x00000001, &axi_qos->qosqon);
  645. axi_qos = (struct rcar_axi_qos *)CCI_AXI_MMUM_BASE;
  646. writel(0x00000001, &axi_qos->qosconf);
  647. writel(0x00002004, &axi_qos->qosctset0);
  648. writel(0x00002096, &axi_qos->qosctset1);
  649. writel(0x00002030, &axi_qos->qosctset2);
  650. writel(0x00002030, &axi_qos->qosctset3);
  651. writel(0x00000001, &axi_qos->qosreqctr);
  652. writel(0x00002064, &axi_qos->qosthres0);
  653. writel(0x00002004, &axi_qos->qosthres1);
  654. writel(0x00000000, &axi_qos->qosthres2);
  655. writel(0x00000001, &axi_qos->qosqon);
  656. axi_qos = (struct rcar_axi_qos *)CCI_AXI_MXI_BASE;
  657. writel(0x00000002, &axi_qos->qosconf);
  658. writel(0x00002245, &axi_qos->qosctset0);
  659. writel(0x00002096, &axi_qos->qosctset1);
  660. writel(0x00002030, &axi_qos->qosctset2);
  661. writel(0x00002030, &axi_qos->qosctset3);
  662. writel(0x00000001, &axi_qos->qosreqctr);
  663. writel(0x00002064, &axi_qos->qosthres0);
  664. writel(0x00002004, &axi_qos->qosthres1);
  665. writel(0x00000000, &axi_qos->qosthres2);
  666. writel(0x00000001, &axi_qos->qosqon);
  667. axi_qos = (struct rcar_axi_qos *)CCI_AXI_MMUS1_BASE;
  668. writel(0x00000001, &axi_qos->qosconf);
  669. writel(0x00002004, &axi_qos->qosctset0);
  670. writel(0x00002096, &axi_qos->qosctset1);
  671. writel(0x00002030, &axi_qos->qosctset2);
  672. writel(0x00002030, &axi_qos->qosctset3);
  673. writel(0x00000001, &axi_qos->qosreqctr);
  674. writel(0x00002064, &axi_qos->qosthres0);
  675. writel(0x00002004, &axi_qos->qosthres1);
  676. writel(0x00000000, &axi_qos->qosthres2);
  677. writel(0x00000001, &axi_qos->qosqon);
  678. axi_qos = (struct rcar_axi_qos *)CCI_AXI_MMUMP_BASE;
  679. writel(0x00000001, &axi_qos->qosconf);
  680. writel(0x00002004, &axi_qos->qosctset0);
  681. writel(0x00002096, &axi_qos->qosctset1);
  682. writel(0x00002030, &axi_qos->qosctset2);
  683. writel(0x00002030, &axi_qos->qosctset3);
  684. writel(0x00000001, &axi_qos->qosreqctr);
  685. writel(0x00002064, &axi_qos->qosthres0);
  686. writel(0x00002004, &axi_qos->qosthres1);
  687. writel(0x00000000, &axi_qos->qosthres2);
  688. writel(0x00000001, &axi_qos->qosqon);
  689. /* QoS Register (Media-AXI) */
  690. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_MXR_BASE;
  691. writel(0x00000002, &axi_qos->qosconf);
  692. writel(0x000020DC, &axi_qos->qosctset0);
  693. writel(0x00002096, &axi_qos->qosctset1);
  694. writel(0x00002030, &axi_qos->qosctset2);
  695. writel(0x00002030, &axi_qos->qosctset3);
  696. writel(0x00000020, &axi_qos->qosreqctr);
  697. writel(0x000020AA, &axi_qos->qosthres0);
  698. writel(0x00002032, &axi_qos->qosthres1);
  699. writel(0x00000001, &axi_qos->qosthres2);
  700. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_MXW_BASE;
  701. writel(0x00000002, &axi_qos->qosconf);
  702. writel(0x000020DC, &axi_qos->qosctset0);
  703. writel(0x00002096, &axi_qos->qosctset1);
  704. writel(0x00002030, &axi_qos->qosctset2);
  705. writel(0x00002030, &axi_qos->qosctset3);
  706. writel(0x00000020, &axi_qos->qosreqctr);
  707. writel(0x000020AA, &axi_qos->qosthres0);
  708. writel(0x00002032, &axi_qos->qosthres1);
  709. writel(0x00000001, &axi_qos->qosthres2);
  710. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_TDMR_BASE;
  711. writel(0x00000001, &axi_qos->qosconf);
  712. writel(0x00002190, &axi_qos->qosctset0);
  713. writel(0x00000020, &axi_qos->qosreqctr);
  714. writel(0x00002064, &axi_qos->qosthres0);
  715. writel(0x00002004, &axi_qos->qosthres1);
  716. writel(0x00000001, &axi_qos->qosthres2);
  717. writel(0x00000001, &axi_qos->qosqon);
  718. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_TDMW_BASE;
  719. writel(0x00000001, &axi_qos->qosconf);
  720. writel(0x00002190, &axi_qos->qosctset0);
  721. writel(0x00000020, &axi_qos->qosreqctr);
  722. writel(0x00000001, &axi_qos->qosthres0);
  723. writel(0x00000001, &axi_qos->qosthres1);
  724. writel(0x00000001, &axi_qos->qosthres2);
  725. writel(0x00000001, &axi_qos->qosqon);
  726. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_VSP1CR_BASE;
  727. writel(0x00000001, &axi_qos->qosconf);
  728. writel(0x00002190, &axi_qos->qosctset0);
  729. writel(0x00000020, &axi_qos->qosreqctr);
  730. writel(0x00002064, &axi_qos->qosthres0);
  731. writel(0x00002004, &axi_qos->qosthres1);
  732. writel(0x00000001, &axi_qos->qosthres2);
  733. writel(0x00000001, &axi_qos->qosqon);
  734. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_VSP1CW_BASE;
  735. writel(0x00000001, &axi_qos->qosconf);
  736. writel(0x00002190, &axi_qos->qosctset0);
  737. writel(0x00000020, &axi_qos->qosreqctr);
  738. writel(0x00000001, &axi_qos->qosthres0);
  739. writel(0x00000001, &axi_qos->qosthres1);
  740. writel(0x00000001, &axi_qos->qosthres2);
  741. writel(0x00000001, &axi_qos->qosqon);
  742. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_VSPDU0CR_BASE;
  743. writel(0x00000001, &axi_qos->qosconf);
  744. writel(0x00002190, &axi_qos->qosctset0);
  745. writel(0x00000020, &axi_qos->qosreqctr);
  746. writel(0x00002064, &axi_qos->qosthres0);
  747. writel(0x00002004, &axi_qos->qosthres1);
  748. writel(0x00000001, &axi_qos->qosthres2);
  749. writel(0x00000001, &axi_qos->qosqon);
  750. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_VSPDU0CW_BASE;
  751. writel(0x00000001, &axi_qos->qosconf);
  752. writel(0x00002190, &axi_qos->qosctset0);
  753. writel(0x00000020, &axi_qos->qosreqctr);
  754. writel(0x00000001, &axi_qos->qosthres0);
  755. writel(0x00000001, &axi_qos->qosthres1);
  756. writel(0x00000001, &axi_qos->qosthres2);
  757. writel(0x00000001, &axi_qos->qosqon);
  758. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_VIN0W_BASE;
  759. writel(0x00000001, &axi_qos->qosconf);
  760. writel(0x00001FF0, &axi_qos->qosctset0);
  761. writel(0x00000020, &axi_qos->qosreqctr);
  762. writel(0x00002064, &axi_qos->qosthres0);
  763. writel(0x00002004, &axi_qos->qosthres1);
  764. writel(0x00002001, &axi_qos->qosthres2);
  765. writel(0x00000001, &axi_qos->qosqon);
  766. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_FDP0R_BASE;
  767. writel(0x00000001, &axi_qos->qosconf);
  768. writel(0x000020C8, &axi_qos->qosctset0);
  769. writel(0x00000020, &axi_qos->qosreqctr);
  770. writel(0x00002064, &axi_qos->qosthres0);
  771. writel(0x00002004, &axi_qos->qosthres1);
  772. writel(0x00000001, &axi_qos->qosthres2);
  773. writel(0x00000001, &axi_qos->qosqon);
  774. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_FDP0W_BASE;
  775. writel(0x00000001, &axi_qos->qosconf);
  776. writel(0x000020C8, &axi_qos->qosctset0);
  777. writel(0x00000020, &axi_qos->qosreqctr);
  778. writel(0x00000001, &axi_qos->qosthres0);
  779. writel(0x00000001, &axi_qos->qosthres1);
  780. writel(0x00000001, &axi_qos->qosthres2);
  781. writel(0x00000001, &axi_qos->qosqon);
  782. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_IMSR_BASE;
  783. writel(0x00000001, &axi_qos->qosconf);
  784. writel(0x000020C8, &axi_qos->qosctset0);
  785. writel(0x00000020, &axi_qos->qosreqctr);
  786. writel(0x00002064, &axi_qos->qosthres0);
  787. writel(0x00002004, &axi_qos->qosthres1);
  788. writel(0x00000001, &axi_qos->qosthres2);
  789. writel(0x00000001, &axi_qos->qosqon);
  790. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_IMSW_BASE;
  791. writel(0x00000001, &axi_qos->qosconf);
  792. writel(0x000020C8, &axi_qos->qosctset0);
  793. writel(0x00000020, &axi_qos->qosreqctr);
  794. writel(0x00002064, &axi_qos->qosthres0);
  795. writel(0x00002004, &axi_qos->qosthres1);
  796. writel(0x00000001, &axi_qos->qosthres2);
  797. writel(0x00000001, &axi_qos->qosqon);
  798. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_VSP1R_BASE;
  799. writel(0x00000001, &axi_qos->qosconf);
  800. writel(0x000020C8, &axi_qos->qosctset0);
  801. writel(0x00000020, &axi_qos->qosreqctr);
  802. writel(0x00002064, &axi_qos->qosthres0);
  803. writel(0x00002004, &axi_qos->qosthres1);
  804. writel(0x00000001, &axi_qos->qosthres2);
  805. writel(0x00000001, &axi_qos->qosqon);
  806. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_VSP1W_BASE;
  807. writel(0x00000001, &axi_qos->qosconf);
  808. writel(0x000020C8, &axi_qos->qosctset0);
  809. writel(0x00000020, &axi_qos->qosreqctr);
  810. writel(0x00000001, &axi_qos->qosthres0);
  811. writel(0x00000001, &axi_qos->qosthres1);
  812. writel(0x00000001, &axi_qos->qosthres2);
  813. writel(0x00000001, &axi_qos->qosqon);
  814. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_IMRR_BASE;
  815. writel(0x00000001, &axi_qos->qosconf);
  816. writel(0x000020C8, &axi_qos->qosctset0);
  817. writel(0x00000020, &axi_qos->qosreqctr);
  818. writel(0x00002064, &axi_qos->qosthres0);
  819. writel(0x00002004, &axi_qos->qosthres1);
  820. writel(0x00000001, &axi_qos->qosthres2);
  821. writel(0x00000001, &axi_qos->qosqon);
  822. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_IMRW_BASE;
  823. writel(0x00000001, &axi_qos->qosconf);
  824. writel(0x000020C8, &axi_qos->qosctset0);
  825. writel(0x00000020, &axi_qos->qosreqctr);
  826. writel(0x00002064, &axi_qos->qosthres0);
  827. writel(0x00002004, &axi_qos->qosthres1);
  828. writel(0x00000001, &axi_qos->qosthres2);
  829. writel(0x00000001, &axi_qos->qosqon);
  830. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_VSPD0R_BASE;
  831. writel(0x00000003, &axi_qos->qosconf);
  832. writel(0x000020C8, &axi_qos->qosctset0);
  833. writel(0x00002064, &axi_qos->qosthres0);
  834. writel(0x00002004, &axi_qos->qosthres1);
  835. writel(0x00000001, &axi_qos->qosthres2);
  836. writel(0x00000001, &axi_qos->qosqon);
  837. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_VSPD0W_BASE;
  838. writel(0x00000003, &axi_qos->qosconf);
  839. writel(0x000020C8, &axi_qos->qosctset0);
  840. writel(0x00002064, &axi_qos->qosthres0);
  841. writel(0x00002004, &axi_qos->qosthres1);
  842. writel(0x00000001, &axi_qos->qosthres2);
  843. writel(0x00000001, &axi_qos->qosqon);
  844. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_DU0R_BASE;
  845. writel(0x00000003, &axi_qos->qosconf);
  846. writel(0x00002063, &axi_qos->qosctset0);
  847. writel(0x00000001, &axi_qos->qosreqctr);
  848. writel(0x00002064, &axi_qos->qosthres0);
  849. writel(0x00002004, &axi_qos->qosthres1);
  850. writel(0x00000001, &axi_qos->qosthres2);
  851. writel(0x00000001, &axi_qos->qosqon);
  852. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_DU0W_BASE;
  853. writel(0x00000003, &axi_qos->qosconf);
  854. writel(0x00002063, &axi_qos->qosctset0);
  855. writel(0x00000001, &axi_qos->qosreqctr);
  856. writel(0x00002064, &axi_qos->qosthres0);
  857. writel(0x00002004, &axi_qos->qosthres1);
  858. writel(0x00000001, &axi_qos->qosthres2);
  859. writel(0x00000001, &axi_qos->qosqon);
  860. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_VCP0CR_BASE;
  861. writel(0x00000001, &axi_qos->qosconf);
  862. writel(0x00002073, &axi_qos->qosctset0);
  863. writel(0x00000020, &axi_qos->qosreqctr);
  864. writel(0x00002064, &axi_qos->qosthres0);
  865. writel(0x00002004, &axi_qos->qosthres1);
  866. writel(0x00000001, &axi_qos->qosthres2);
  867. writel(0x00000001, &axi_qos->qosqon);
  868. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_VCP0CW_BASE;
  869. writel(0x00000001, &axi_qos->qosconf);
  870. writel(0x00002073, &axi_qos->qosctset0);
  871. writel(0x00000020, &axi_qos->qosreqctr);
  872. writel(0x00000001, &axi_qos->qosthres0);
  873. writel(0x00000001, &axi_qos->qosthres1);
  874. writel(0x00000001, &axi_qos->qosthres2);
  875. writel(0x00000001, &axi_qos->qosqon);
  876. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_VCP0VR_BASE;
  877. writel(0x00000001, &axi_qos->qosconf);
  878. writel(0x00002073, &axi_qos->qosctset0);
  879. writel(0x00000020, &axi_qos->qosreqctr);
  880. writel(0x00002064, &axi_qos->qosthres0);
  881. writel(0x00002004, &axi_qos->qosthres1);
  882. writel(0x00000001, &axi_qos->qosthres2);
  883. writel(0x00000001, &axi_qos->qosqon);
  884. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_VCP0VW_BASE;
  885. writel(0x00000001, &axi_qos->qosconf);
  886. writel(0x00002073, &axi_qos->qosctset0);
  887. writel(0x00000020, &axi_qos->qosreqctr);
  888. writel(0x00000001, &axi_qos->qosthres0);
  889. writel(0x00000001, &axi_qos->qosthres1);
  890. writel(0x00000001, &axi_qos->qosthres2);
  891. writel(0x00000001, &axi_qos->qosqon);
  892. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_VPC0R_BASE;
  893. writel(0x00000001, &axi_qos->qosconf);
  894. writel(0x00002073, &axi_qos->qosctset0);
  895. writel(0x00000020, &axi_qos->qosreqctr);
  896. writel(0x00002064, &axi_qos->qosthres0);
  897. writel(0x00002004, &axi_qos->qosthres1);
  898. writel(0x00000001, &axi_qos->qosthres2);
  899. writel(0x00000001, &axi_qos->qosqon);
  900. }
  901. #else /* CONFIG_ARCH_RMOBILE_EXTRAM_BOOT */
  902. void qos_init(void)
  903. {
  904. }
  905. #endif /* CONFIG_ARCH_RMOBILE_EXTRAM_BOOT */