qos.c 34 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950
  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_RMOBILE_EXTRAM_BOOT)
  15. /* QoS version 0.11 */
  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. void qos_init(void)
  60. {
  61. int i;
  62. struct rcar_s3c *s3c;
  63. struct rcar_s3c_qos *s3c_qos;
  64. struct rcar_dbsc3_qos *qos_addr;
  65. struct rcar_mxi *mxi;
  66. struct rcar_mxi_qos *mxi_qos;
  67. struct rcar_axi_qos *axi_qos;
  68. /* DBSC DBADJ2 */
  69. writel(0x20042004, DBSC3_0_DBADJ2);
  70. /* S3C -QoS */
  71. s3c = (struct rcar_s3c *)S3C_BASE;
  72. writel(0x1F0D0B0A, &s3c->s3crorr);
  73. writel(0x1F0D0B09, &s3c->s3cworr);
  74. /* QoS Control Registers */
  75. s3c_qos = (struct rcar_s3c_qos *)S3C_QOS_CCI0_BASE;
  76. writel(0x00890089, &s3c_qos->s3cqos0);
  77. writel(0x20960010, &s3c_qos->s3cqos1);
  78. writel(0x20302030, &s3c_qos->s3cqos2);
  79. writel(0x20AA2200, &s3c_qos->s3cqos3);
  80. writel(0x00002032, &s3c_qos->s3cqos4);
  81. writel(0x20960010, &s3c_qos->s3cqos5);
  82. writel(0x20302030, &s3c_qos->s3cqos6);
  83. writel(0x20AA2200, &s3c_qos->s3cqos7);
  84. writel(0x00002032, &s3c_qos->s3cqos8);
  85. s3c_qos = (struct rcar_s3c_qos *)S3C_QOS_CCI1_BASE;
  86. writel(0x00890089, &s3c_qos->s3cqos0);
  87. writel(0x20960010, &s3c_qos->s3cqos1);
  88. writel(0x20302030, &s3c_qos->s3cqos2);
  89. writel(0x20AA2200, &s3c_qos->s3cqos3);
  90. writel(0x00002032, &s3c_qos->s3cqos4);
  91. writel(0x20960010, &s3c_qos->s3cqos5);
  92. writel(0x20302030, &s3c_qos->s3cqos6);
  93. writel(0x20AA2200, &s3c_qos->s3cqos7);
  94. writel(0x00002032, &s3c_qos->s3cqos8);
  95. s3c_qos = (struct rcar_s3c_qos *)S3C_QOS_MXI_BASE;
  96. writel(0x80928092, &s3c_qos->s3cqos0);
  97. writel(0x20960020, &s3c_qos->s3cqos1);
  98. writel(0x20302030, &s3c_qos->s3cqos2);
  99. writel(0x20AA20DC, &s3c_qos->s3cqos3);
  100. writel(0x00002032, &s3c_qos->s3cqos4);
  101. writel(0x20960020, &s3c_qos->s3cqos5);
  102. writel(0x20302030, &s3c_qos->s3cqos6);
  103. writel(0x20AA20DC, &s3c_qos->s3cqos7);
  104. writel(0x00002032, &s3c_qos->s3cqos8);
  105. s3c_qos = (struct rcar_s3c_qos *)S3C_QOS_AXI_BASE;
  106. writel(0x00820082, &s3c_qos->s3cqos0);
  107. writel(0x20960020, &s3c_qos->s3cqos1);
  108. writel(0x20302030, &s3c_qos->s3cqos2);
  109. writel(0x20AA20FA, &s3c_qos->s3cqos3);
  110. writel(0x00002032, &s3c_qos->s3cqos4);
  111. writel(0x20960020, &s3c_qos->s3cqos5);
  112. writel(0x20302030, &s3c_qos->s3cqos6);
  113. writel(0x20AA20FA, &s3c_qos->s3cqos7);
  114. writel(0x00002032, &s3c_qos->s3cqos8);
  115. /* DBSC -QoS */
  116. /* DBSC0 - Read */
  117. for (i = DBSC3_00; i < DBSC3_NR; i++) {
  118. qos_addr = (struct rcar_dbsc3_qos *)dbsc3_0_r_qos_addr[i];
  119. writel(0x00000002, &qos_addr->dblgcnt);
  120. writel(0x0000207D, &qos_addr->dbtmval0);
  121. writel(0x00002053, &qos_addr->dbtmval1);
  122. writel(0x0000202A, &qos_addr->dbtmval2);
  123. writel(0x00001FBD, &qos_addr->dbtmval3);
  124. writel(0x00000001, &qos_addr->dbrqctr);
  125. writel(0x00002064, &qos_addr->dbthres0);
  126. writel(0x0000203E, &qos_addr->dbthres1);
  127. writel(0x00002019, &qos_addr->dbthres2);
  128. writel(0x00000001, &qos_addr->dblgqon);
  129. }
  130. /* DBSC0 - Write */
  131. for (i = DBSC3_00; i < DBSC3_NR; i++) {
  132. qos_addr = (struct rcar_dbsc3_qos *)dbsc3_0_w_qos_addr[i];
  133. writel(0x00000002, &qos_addr->dblgcnt);
  134. writel(0x0000207D, &qos_addr->dbtmval0);
  135. writel(0x00002053, &qos_addr->dbtmval1);
  136. writel(0x00002043, &qos_addr->dbtmval2);
  137. writel(0x00002030, &qos_addr->dbtmval3);
  138. writel(0x00000001, &qos_addr->dbrqctr);
  139. writel(0x00002064, &qos_addr->dbthres0);
  140. writel(0x0000203E, &qos_addr->dbthres1);
  141. writel(0x00002031, &qos_addr->dbthres2);
  142. writel(0x00000001, &qos_addr->dblgqon);
  143. }
  144. /* CCI-400 -QoS */
  145. writel(0x20000800, CCI_400_MAXOT_1);
  146. writel(0x20000800, CCI_400_MAXOT_2);
  147. writel(0x0000000C, CCI_400_QOSCNTL_1);
  148. writel(0x0000000C, CCI_400_QOSCNTL_2);
  149. /* MXI -QoS */
  150. /* Transaction Control (MXI) */
  151. mxi = (struct rcar_mxi *)MXI_BASE;
  152. writel(0x00000013, &mxi->mxrtcr);
  153. writel(0x00000013, &mxi->mxwtcr);
  154. writel(0x00780080, &mxi->mxsaar0);
  155. writel(0x02000800, &mxi->mxsaar1);
  156. /* QoS Control (MXI) */
  157. mxi_qos = (struct rcar_mxi_qos *)MXI_QOS_BASE;
  158. writel(0x0000000C, &mxi_qos->vspdu0);
  159. writel(0x0000000E, &mxi_qos->du0);
  160. /* AXI -QoS */
  161. /* Transaction Control (MXI) */
  162. axi_qos = (struct rcar_axi_qos *)SYS_AXI_SYX64TO128_BASE;
  163. writel(0x00000002, &axi_qos->qosconf);
  164. writel(0x00002245, &axi_qos->qosctset0);
  165. writel(0x00002096, &axi_qos->qosctset1);
  166. writel(0x00002030, &axi_qos->qosctset2);
  167. writel(0x00002030, &axi_qos->qosctset3);
  168. writel(0x00000001, &axi_qos->qosreqctr);
  169. writel(0x00002064, &axi_qos->qosthres0);
  170. writel(0x00002004, &axi_qos->qosthres1);
  171. writel(0x00000000, &axi_qos->qosthres2);
  172. writel(0x00000001, &axi_qos->qosqon);
  173. axi_qos = (struct rcar_axi_qos *)SYS_AXI_AVB_BASE;
  174. writel(0x00000000, &axi_qos->qosconf);
  175. writel(0x000020A6, &axi_qos->qosctset0);
  176. writel(0x00000001, &axi_qos->qosreqctr);
  177. writel(0x00002064, &axi_qos->qosthres0);
  178. writel(0x00002004, &axi_qos->qosthres1);
  179. writel(0x00000000, &axi_qos->qosthres2);
  180. writel(0x00000001, &axi_qos->qosqon);
  181. axi_qos = (struct rcar_axi_qos *)SYS_AXI_IMUX0_BASE;
  182. writel(0x00000002, &axi_qos->qosconf);
  183. writel(0x00002245, &axi_qos->qosctset0);
  184. writel(0x00002096, &axi_qos->qosctset1);
  185. writel(0x00002030, &axi_qos->qosctset2);
  186. writel(0x00002030, &axi_qos->qosctset3);
  187. writel(0x00000001, &axi_qos->qosreqctr);
  188. writel(0x00002064, &axi_qos->qosthres0);
  189. writel(0x00002004, &axi_qos->qosthres1);
  190. writel(0x00000000, &axi_qos->qosthres2);
  191. writel(0x00000001, &axi_qos->qosqon);
  192. axi_qos = (struct rcar_axi_qos *)SYS_AXI_IMUX1_BASE;
  193. writel(0x00000002, &axi_qos->qosconf);
  194. writel(0x00002245, &axi_qos->qosctset0);
  195. writel(0x00002096, &axi_qos->qosctset1);
  196. writel(0x00002030, &axi_qos->qosctset2);
  197. writel(0x00002030, &axi_qos->qosctset3);
  198. writel(0x00000001, &axi_qos->qosreqctr);
  199. writel(0x00002064, &axi_qos->qosthres0);
  200. writel(0x00002004, &axi_qos->qosthres1);
  201. writel(0x00000000, &axi_qos->qosthres2);
  202. writel(0x00000001, &axi_qos->qosqon);
  203. axi_qos = (struct rcar_axi_qos *)SYS_AXI_IMUX2_BASE;
  204. writel(0x00000002, &axi_qos->qosconf);
  205. writel(0x00002245, &axi_qos->qosctset0);
  206. writel(0x00002096, &axi_qos->qosctset1);
  207. writel(0x00002030, &axi_qos->qosctset2);
  208. writel(0x00002030, &axi_qos->qosctset3);
  209. writel(0x00000001, &axi_qos->qosreqctr);
  210. writel(0x00002064, &axi_qos->qosthres0);
  211. writel(0x00002004, &axi_qos->qosthres1);
  212. writel(0x00000000, &axi_qos->qosthres2);
  213. writel(0x00000001, &axi_qos->qosqon);
  214. axi_qos = (struct rcar_axi_qos *)SYS_AXI_LBS_BASE;
  215. writel(0x00000000, &axi_qos->qosconf);
  216. writel(0x0000214C, &axi_qos->qosctset0);
  217. writel(0x00000001, &axi_qos->qosreqctr);
  218. writel(0x00002064, &axi_qos->qosthres0);
  219. writel(0x00002004, &axi_qos->qosthres1);
  220. writel(0x00000000, &axi_qos->qosthres2);
  221. writel(0x00000001, &axi_qos->qosqon);
  222. axi_qos = (struct rcar_axi_qos *)SYS_AXI_MMUDS_BASE;
  223. writel(0x00000001, &axi_qos->qosconf);
  224. writel(0x00002004, &axi_qos->qosctset0);
  225. writel(0x00002096, &axi_qos->qosctset1);
  226. writel(0x00002030, &axi_qos->qosctset2);
  227. writel(0x00002030, &axi_qos->qosctset3);
  228. writel(0x00000001, &axi_qos->qosreqctr);
  229. writel(0x00002064, &axi_qos->qosthres0);
  230. writel(0x00002004, &axi_qos->qosthres1);
  231. writel(0x00000000, &axi_qos->qosthres2);
  232. writel(0x00000001, &axi_qos->qosqon);
  233. axi_qos = (struct rcar_axi_qos *)SYS_AXI_MMUM_BASE;
  234. writel(0x00000001, &axi_qos->qosconf);
  235. writel(0x00002004, &axi_qos->qosctset0);
  236. writel(0x00002096, &axi_qos->qosctset1);
  237. writel(0x00002030, &axi_qos->qosctset2);
  238. writel(0x00002030, &axi_qos->qosctset3);
  239. writel(0x00000001, &axi_qos->qosreqctr);
  240. writel(0x00002064, &axi_qos->qosthres0);
  241. writel(0x00002004, &axi_qos->qosthres1);
  242. writel(0x00000000, &axi_qos->qosthres2);
  243. writel(0x00000001, &axi_qos->qosqon);
  244. axi_qos = (struct rcar_axi_qos *)SYS_AXI_MMUS0_BASE;
  245. writel(0x00000001, &axi_qos->qosconf);
  246. writel(0x00002004, &axi_qos->qosctset0);
  247. writel(0x00002096, &axi_qos->qosctset1);
  248. writel(0x00002030, &axi_qos->qosctset2);
  249. writel(0x00002030, &axi_qos->qosctset3);
  250. writel(0x00000001, &axi_qos->qosreqctr);
  251. writel(0x00002064, &axi_qos->qosthres0);
  252. writel(0x00002004, &axi_qos->qosthres1);
  253. writel(0x00000000, &axi_qos->qosthres2);
  254. writel(0x00000001, &axi_qos->qosqon);
  255. axi_qos = (struct rcar_axi_qos *)SYS_AXI_MMUS1_BASE;
  256. writel(0x00000001, &axi_qos->qosconf);
  257. writel(0x00002004, &axi_qos->qosctset0);
  258. writel(0x00002096, &axi_qos->qosctset1);
  259. writel(0x00002030, &axi_qos->qosctset2);
  260. writel(0x00002030, &axi_qos->qosctset3);
  261. writel(0x00000001, &axi_qos->qosreqctr);
  262. writel(0x00002064, &axi_qos->qosthres0);
  263. writel(0x00002004, &axi_qos->qosthres1);
  264. writel(0x00000000, &axi_qos->qosthres2);
  265. writel(0x00000001, &axi_qos->qosqon);
  266. axi_qos = (struct rcar_axi_qos *)SYS_AXI_RTX_BASE;
  267. writel(0x00000002, &axi_qos->qosconf);
  268. writel(0x00002245, &axi_qos->qosctset0);
  269. writel(0x00002096, &axi_qos->qosctset1);
  270. writel(0x00002030, &axi_qos->qosctset2);
  271. writel(0x00002030, &axi_qos->qosctset3);
  272. writel(0x00000001, &axi_qos->qosreqctr);
  273. writel(0x00002064, &axi_qos->qosthres0);
  274. writel(0x00002004, &axi_qos->qosthres1);
  275. writel(0x00000000, &axi_qos->qosthres2);
  276. writel(0x00000001, &axi_qos->qosqon);
  277. axi_qos = (struct rcar_axi_qos *)SYS_AXI_SDS0_BASE;
  278. writel(0x00000000, &axi_qos->qosconf);
  279. writel(0x000020A6, &axi_qos->qosctset0);
  280. writel(0x00000001, &axi_qos->qosreqctr);
  281. writel(0x00002064, &axi_qos->qosthres0);
  282. writel(0x00002004, &axi_qos->qosthres1);
  283. writel(0x00000000, &axi_qos->qosthres2);
  284. writel(0x00000001, &axi_qos->qosqon);
  285. axi_qos = (struct rcar_axi_qos *)SYS_AXI_SDS1_BASE;
  286. writel(0x00000000, &axi_qos->qosconf);
  287. writel(0x000020A6, &axi_qos->qosctset0);
  288. writel(0x00000001, &axi_qos->qosreqctr);
  289. writel(0x00002064, &axi_qos->qosthres0);
  290. writel(0x00002004, &axi_qos->qosthres1);
  291. writel(0x00000000, &axi_qos->qosthres2);
  292. writel(0x00000001, &axi_qos->qosqon);
  293. axi_qos = (struct rcar_axi_qos *)SYS_AXI_USB20_BASE;
  294. writel(0x00000000, &axi_qos->qosconf);
  295. writel(0x00002053, &axi_qos->qosctset0);
  296. writel(0x00000001, &axi_qos->qosreqctr);
  297. writel(0x00002064, &axi_qos->qosthres0);
  298. writel(0x00002004, &axi_qos->qosthres1);
  299. writel(0x00000000, &axi_qos->qosthres2);
  300. writel(0x00000001, &axi_qos->qosqon);
  301. axi_qos = (struct rcar_axi_qos *)SYS_AXI_USB22_BASE;
  302. writel(0x00000000, &axi_qos->qosconf);
  303. writel(0x00002053, &axi_qos->qosctset0);
  304. writel(0x00000001, &axi_qos->qosreqctr);
  305. writel(0x00002064, &axi_qos->qosthres0);
  306. writel(0x00002004, &axi_qos->qosthres1);
  307. writel(0x00000000, &axi_qos->qosthres2);
  308. writel(0x00000001, &axi_qos->qosqon);
  309. axi_qos = (struct rcar_axi_qos *)SYS_AXI_AX2M_BASE;
  310. writel(0x00000002, &axi_qos->qosconf);
  311. writel(0x00002245, &axi_qos->qosctset0);
  312. writel(0x00000001, &axi_qos->qosreqctr);
  313. writel(0x00002064, &axi_qos->qosthres0);
  314. writel(0x00002004, &axi_qos->qosthres1);
  315. writel(0x00000000, &axi_qos->qosthres2);
  316. writel(0x00000001, &axi_qos->qosqon);
  317. axi_qos = (struct rcar_axi_qos *)SYS_AXI_CC50_BASE;
  318. writel(0x00000000, &axi_qos->qosconf);
  319. writel(0x00002029, &axi_qos->qosctset0);
  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_CCI_BASE;
  326. writel(0x00000002, &axi_qos->qosconf);
  327. writel(0x00002245, &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_CS_BASE;
  334. writel(0x00000000, &axi_qos->qosconf);
  335. writel(0x00002053, &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_DDM_BASE;
  342. writel(0x00000000, &axi_qos->qosconf);
  343. writel(0x000020A6, &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_ETH_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_MPXM_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_SDM0_BASE;
  366. writel(0x00000000, &axi_qos->qosconf);
  367. writel(0x0000214C, &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_SDM1_BASE;
  374. writel(0x00000000, &axi_qos->qosconf);
  375. writel(0x0000214C, &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_TRAB_BASE;
  382. writel(0x00000000, &axi_qos->qosconf);
  383. writel(0x000020A6, &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_UDM0_BASE;
  390. writel(0x00000000, &axi_qos->qosconf);
  391. writel(0x00002053, &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_UDM1_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. /* QoS Register (RT-AXI) */
  406. axi_qos = (struct rcar_axi_qos *)RT_AXI_SHX_BASE;
  407. writel(0x00000000, &axi_qos->qosconf);
  408. writel(0x00002053, &axi_qos->qosctset0);
  409. writel(0x00002096, &axi_qos->qosctset1);
  410. writel(0x00002030, &axi_qos->qosctset2);
  411. writel(0x00002030, &axi_qos->qosctset3);
  412. writel(0x00000001, &axi_qos->qosreqctr);
  413. writel(0x00002064, &axi_qos->qosthres0);
  414. writel(0x00002004, &axi_qos->qosthres1);
  415. writel(0x00000000, &axi_qos->qosthres2);
  416. writel(0x00000001, &axi_qos->qosqon);
  417. axi_qos = (struct rcar_axi_qos *)RT_AXI_DBG_BASE;
  418. writel(0x00000000, &axi_qos->qosconf);
  419. writel(0x00002053, &axi_qos->qosctset0);
  420. writel(0x00002096, &axi_qos->qosctset1);
  421. writel(0x00002030, &axi_qos->qosctset2);
  422. writel(0x00002030, &axi_qos->qosctset3);
  423. writel(0x00000001, &axi_qos->qosreqctr);
  424. writel(0x00002064, &axi_qos->qosthres0);
  425. writel(0x00002004, &axi_qos->qosthres1);
  426. writel(0x00000000, &axi_qos->qosthres2);
  427. writel(0x00000001, &axi_qos->qosqon);
  428. axi_qos = (struct rcar_axi_qos *)RT_AXI_RTX64TO128_BASE;
  429. writel(0x00000002, &axi_qos->qosconf);
  430. writel(0x00002245, &axi_qos->qosctset0);
  431. writel(0x00002096, &axi_qos->qosctset1);
  432. writel(0x00002030, &axi_qos->qosctset2);
  433. writel(0x00002030, &axi_qos->qosctset3);
  434. writel(0x00000001, &axi_qos->qosreqctr);
  435. writel(0x00002064, &axi_qos->qosthres0);
  436. writel(0x00002004, &axi_qos->qosthres1);
  437. writel(0x00000000, &axi_qos->qosthres2);
  438. writel(0x00000001, &axi_qos->qosqon);
  439. axi_qos = (struct rcar_axi_qos *)RT_AXI_SY2RT_BASE;
  440. writel(0x00000002, &axi_qos->qosconf);
  441. writel(0x00002245, &axi_qos->qosctset0);
  442. writel(0x00000001, &axi_qos->qosreqctr);
  443. writel(0x00002064, &axi_qos->qosthres0);
  444. writel(0x00002004, &axi_qos->qosthres1);
  445. writel(0x00000000, &axi_qos->qosthres2);
  446. writel(0x00000001, &axi_qos->qosqon);
  447. /* QoS Register (MP-AXI) */
  448. axi_qos = (struct rcar_axi_qos *)MP_AXI_ADSP_BASE;
  449. writel(0x00000000, &axi_qos->qosconf);
  450. writel(0x00002037, &axi_qos->qosctset0);
  451. writel(0x00000001, &axi_qos->qosreqctr);
  452. writel(0x00002064, &axi_qos->qosthres0);
  453. writel(0x00002004, &axi_qos->qosthres1);
  454. writel(0x00000000, &axi_qos->qosthres2);
  455. writel(0x00000001, &axi_qos->qosqon);
  456. axi_qos = (struct rcar_axi_qos *)MP_AXI_ASDS0_BASE;
  457. writel(0x00000001, &axi_qos->qosconf);
  458. writel(0x00002014, &axi_qos->qosctset0);
  459. writel(0x00000040, &axi_qos->qosreqctr);
  460. writel(0x00002064, &axi_qos->qosthres0);
  461. writel(0x00002004, &axi_qos->qosthres1);
  462. writel(0x00000000, &axi_qos->qosthres2);
  463. writel(0x00000001, &axi_qos->qosqon);
  464. axi_qos = (struct rcar_axi_qos *)MP_AXI_ASDS1_BASE;
  465. writel(0x00000001, &axi_qos->qosconf);
  466. writel(0x00002014, &axi_qos->qosctset0);
  467. writel(0x00000040, &axi_qos->qosreqctr);
  468. writel(0x00002064, &axi_qos->qosthres0);
  469. writel(0x00002004, &axi_qos->qosthres1);
  470. writel(0x00000000, &axi_qos->qosthres2);
  471. writel(0x00000001, &axi_qos->qosqon);
  472. axi_qos = (struct rcar_axi_qos *)MP_AXI_MLP_BASE;
  473. writel(0x00000001, &axi_qos->qosconf);
  474. writel(0x00001FF0, &axi_qos->qosctset0);
  475. writel(0x00000020, &axi_qos->qosreqctr);
  476. writel(0x00002064, &axi_qos->qosthres0);
  477. writel(0x00002004, &axi_qos->qosthres1);
  478. writel(0x00002001, &axi_qos->qosthres2);
  479. writel(0x00000001, &axi_qos->qosqon);
  480. axi_qos = (struct rcar_axi_qos *)MP_AXI_MMUMP_BASE;
  481. writel(0x00000001, &axi_qos->qosconf);
  482. writel(0x00002004, &axi_qos->qosctset0);
  483. writel(0x00002096, &axi_qos->qosctset1);
  484. writel(0x00002030, &axi_qos->qosctset2);
  485. writel(0x00002030, &axi_qos->qosctset3);
  486. writel(0x00000001, &axi_qos->qosreqctr);
  487. writel(0x00002064, &axi_qos->qosthres0);
  488. writel(0x00002004, &axi_qos->qosthres1);
  489. writel(0x00000000, &axi_qos->qosthres2);
  490. writel(0x00000001, &axi_qos->qosqon);
  491. axi_qos = (struct rcar_axi_qos *)MP_AXI_SPU_BASE;
  492. writel(0x00000000, &axi_qos->qosconf);
  493. writel(0x00002053, &axi_qos->qosctset0);
  494. writel(0x00000001, &axi_qos->qosreqctr);
  495. writel(0x00002064, &axi_qos->qosthres0);
  496. writel(0x00002004, &axi_qos->qosthres1);
  497. writel(0x00000000, &axi_qos->qosthres2);
  498. writel(0x00000001, &axi_qos->qosqon);
  499. axi_qos = (struct rcar_axi_qos *)MP_AXI_SPUC_BASE;
  500. writel(0x00000000, &axi_qos->qosconf);
  501. writel(0x0000206E, &axi_qos->qosctset0);
  502. writel(0x00000001, &axi_qos->qosreqctr);
  503. writel(0x00002064, &axi_qos->qosthres0);
  504. writel(0x00002004, &axi_qos->qosthres1);
  505. writel(0x00000000, &axi_qos->qosthres2);
  506. writel(0x00000001, &axi_qos->qosqon);
  507. /* QoS Register (SYS-AXI256) */
  508. axi_qos = (struct rcar_axi_qos *)SYS_AXI256_AXI128TO256_BASE;
  509. writel(0x00000002, &axi_qos->qosconf);
  510. writel(0x000020EB, &axi_qos->qosctset0);
  511. writel(0x00002096, &axi_qos->qosctset1);
  512. writel(0x00002030, &axi_qos->qosctset2);
  513. writel(0x00002030, &axi_qos->qosctset3);
  514. writel(0x00000001, &axi_qos->qosreqctr);
  515. writel(0x00002064, &axi_qos->qosthres0);
  516. writel(0x00002004, &axi_qos->qosthres1);
  517. writel(0x00000000, &axi_qos->qosthres2);
  518. writel(0x00000001, &axi_qos->qosqon);
  519. axi_qos = (struct rcar_axi_qos *)SYS_AXI256_SYX_BASE;
  520. writel(0x00000002, &axi_qos->qosconf);
  521. writel(0x000020EB, &axi_qos->qosctset0);
  522. writel(0x00002096, &axi_qos->qosctset1);
  523. writel(0x00002030, &axi_qos->qosctset2);
  524. writel(0x00002030, &axi_qos->qosctset3);
  525. writel(0x00000001, &axi_qos->qosreqctr);
  526. writel(0x00002064, &axi_qos->qosthres0);
  527. writel(0x00002004, &axi_qos->qosthres1);
  528. writel(0x00000000, &axi_qos->qosthres2);
  529. writel(0x00000001, &axi_qos->qosqon);
  530. axi_qos = (struct rcar_axi_qos *)SYS_AXI256_MPX_BASE;
  531. writel(0x00000002, &axi_qos->qosconf);
  532. writel(0x000020EB, &axi_qos->qosctset0);
  533. writel(0x00002096, &axi_qos->qosctset1);
  534. writel(0x00002030, &axi_qos->qosctset2);
  535. writel(0x00002030, &axi_qos->qosctset3);
  536. writel(0x00000001, &axi_qos->qosreqctr);
  537. writel(0x00002064, &axi_qos->qosthres0);
  538. writel(0x00002004, &axi_qos->qosthres1);
  539. writel(0x00000000, &axi_qos->qosthres2);
  540. writel(0x00000001, &axi_qos->qosqon);
  541. axi_qos = (struct rcar_axi_qos *)SYS_AXI256_MXI_BASE;
  542. writel(0x00000002, &axi_qos->qosconf);
  543. writel(0x000020EB, &axi_qos->qosctset0);
  544. writel(0x00002096, &axi_qos->qosctset1);
  545. writel(0x00002030, &axi_qos->qosctset2);
  546. writel(0x00002030, &axi_qos->qosctset3);
  547. writel(0x00000001, &axi_qos->qosreqctr);
  548. writel(0x00002064, &axi_qos->qosthres0);
  549. writel(0x00002004, &axi_qos->qosthres1);
  550. writel(0x00000000, &axi_qos->qosthres2);
  551. writel(0x00000001, &axi_qos->qosqon);
  552. /* QoS Register (CCI-AXI) */
  553. axi_qos = (struct rcar_axi_qos *)CCI_AXI_MMUS0_BASE;
  554. writel(0x00000001, &axi_qos->qosconf);
  555. writel(0x00002004, &axi_qos->qosctset0);
  556. writel(0x00002096, &axi_qos->qosctset1);
  557. writel(0x00002030, &axi_qos->qosctset2);
  558. writel(0x00002030, &axi_qos->qosctset3);
  559. writel(0x00000001, &axi_qos->qosreqctr);
  560. writel(0x00002064, &axi_qos->qosthres0);
  561. writel(0x00002004, &axi_qos->qosthres1);
  562. writel(0x00000000, &axi_qos->qosthres2);
  563. writel(0x00000001, &axi_qos->qosqon);
  564. axi_qos = (struct rcar_axi_qos *)CCI_AXI_SYX2_BASE;
  565. writel(0x00000002, &axi_qos->qosconf);
  566. writel(0x00002245, &axi_qos->qosctset0);
  567. writel(0x00002096, &axi_qos->qosctset1);
  568. writel(0x00002030, &axi_qos->qosctset2);
  569. writel(0x00002030, &axi_qos->qosctset3);
  570. writel(0x00000001, &axi_qos->qosreqctr);
  571. writel(0x00002064, &axi_qos->qosthres0);
  572. writel(0x00002004, &axi_qos->qosthres1);
  573. writel(0x00000000, &axi_qos->qosthres2);
  574. writel(0x00000001, &axi_qos->qosqon);
  575. axi_qos = (struct rcar_axi_qos *)CCI_AXI_MMUR_BASE;
  576. writel(0x00000001, &axi_qos->qosconf);
  577. writel(0x00002004, &axi_qos->qosctset0);
  578. writel(0x00002096, &axi_qos->qosctset1);
  579. writel(0x00002030, &axi_qos->qosctset2);
  580. writel(0x00002030, &axi_qos->qosctset3);
  581. writel(0x00000001, &axi_qos->qosreqctr);
  582. writel(0x00002064, &axi_qos->qosthres0);
  583. writel(0x00002004, &axi_qos->qosthres1);
  584. writel(0x00000000, &axi_qos->qosthres2);
  585. writel(0x00000001, &axi_qos->qosqon);
  586. axi_qos = (struct rcar_axi_qos *)CCI_AXI_MMUDS_BASE;
  587. writel(0x00000001, &axi_qos->qosconf);
  588. writel(0x00002004, &axi_qos->qosctset0);
  589. writel(0x00002096, &axi_qos->qosctset1);
  590. writel(0x00002030, &axi_qos->qosctset2);
  591. writel(0x00002030, &axi_qos->qosctset3);
  592. writel(0x00000001, &axi_qos->qosreqctr);
  593. writel(0x00002064, &axi_qos->qosthres0);
  594. writel(0x00002004, &axi_qos->qosthres1);
  595. writel(0x00000000, &axi_qos->qosthres2);
  596. writel(0x00000001, &axi_qos->qosqon);
  597. axi_qos = (struct rcar_axi_qos *)CCI_AXI_MMUM_BASE;
  598. writel(0x00000001, &axi_qos->qosconf);
  599. writel(0x00002004, &axi_qos->qosctset0);
  600. writel(0x00002096, &axi_qos->qosctset1);
  601. writel(0x00002030, &axi_qos->qosctset2);
  602. writel(0x00002030, &axi_qos->qosctset3);
  603. writel(0x00000001, &axi_qos->qosreqctr);
  604. writel(0x00002064, &axi_qos->qosthres0);
  605. writel(0x00002004, &axi_qos->qosthres1);
  606. writel(0x00000000, &axi_qos->qosthres2);
  607. writel(0x00000001, &axi_qos->qosqon);
  608. axi_qos = (struct rcar_axi_qos *)CCI_AXI_MXI_BASE;
  609. writel(0x00000002, &axi_qos->qosconf);
  610. writel(0x00002245, &axi_qos->qosctset0);
  611. writel(0x00002096, &axi_qos->qosctset1);
  612. writel(0x00002030, &axi_qos->qosctset2);
  613. writel(0x00002030, &axi_qos->qosctset3);
  614. writel(0x00000001, &axi_qos->qosreqctr);
  615. writel(0x00002064, &axi_qos->qosthres0);
  616. writel(0x00002004, &axi_qos->qosthres1);
  617. writel(0x00000000, &axi_qos->qosthres2);
  618. writel(0x00000001, &axi_qos->qosqon);
  619. axi_qos = (struct rcar_axi_qos *)CCI_AXI_MMUS1_BASE;
  620. writel(0x00000001, &axi_qos->qosconf);
  621. writel(0x00002004, &axi_qos->qosctset0);
  622. writel(0x00002096, &axi_qos->qosctset1);
  623. writel(0x00002030, &axi_qos->qosctset2);
  624. writel(0x00002030, &axi_qos->qosctset3);
  625. writel(0x00000001, &axi_qos->qosreqctr);
  626. writel(0x00002064, &axi_qos->qosthres0);
  627. writel(0x00002004, &axi_qos->qosthres1);
  628. writel(0x00000000, &axi_qos->qosthres2);
  629. writel(0x00000001, &axi_qos->qosqon);
  630. axi_qos = (struct rcar_axi_qos *)CCI_AXI_MMUMP_BASE;
  631. writel(0x00000001, &axi_qos->qosconf);
  632. writel(0x00002004, &axi_qos->qosctset0);
  633. writel(0x00002096, &axi_qos->qosctset1);
  634. writel(0x00002030, &axi_qos->qosctset2);
  635. writel(0x00002030, &axi_qos->qosctset3);
  636. writel(0x00000001, &axi_qos->qosreqctr);
  637. writel(0x00002064, &axi_qos->qosthres0);
  638. writel(0x00002004, &axi_qos->qosthres1);
  639. writel(0x00000000, &axi_qos->qosthres2);
  640. writel(0x00000001, &axi_qos->qosqon);
  641. /* QoS Register (Media-AXI) */
  642. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_MXR_BASE;
  643. writel(0x00000002, &axi_qos->qosconf);
  644. writel(0x000020DC, &axi_qos->qosctset0);
  645. writel(0x00002096, &axi_qos->qosctset1);
  646. writel(0x00002030, &axi_qos->qosctset2);
  647. writel(0x00002030, &axi_qos->qosctset3);
  648. writel(0x00000020, &axi_qos->qosreqctr);
  649. writel(0x000020AA, &axi_qos->qosthres0);
  650. writel(0x00002032, &axi_qos->qosthres1);
  651. writel(0x00000001, &axi_qos->qosthres2);
  652. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_MXW_BASE;
  653. writel(0x00000002, &axi_qos->qosconf);
  654. writel(0x000020DC, &axi_qos->qosctset0);
  655. writel(0x00002096, &axi_qos->qosctset1);
  656. writel(0x00002030, &axi_qos->qosctset2);
  657. writel(0x00002030, &axi_qos->qosctset3);
  658. writel(0x00000020, &axi_qos->qosreqctr);
  659. writel(0x000020AA, &axi_qos->qosthres0);
  660. writel(0x00002032, &axi_qos->qosthres1);
  661. writel(0x00000001, &axi_qos->qosthres2);
  662. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_TDMR_BASE;
  663. writel(0x00000001, &axi_qos->qosconf);
  664. writel(0x00002190, &axi_qos->qosctset0);
  665. writel(0x00000020, &axi_qos->qosreqctr);
  666. writel(0x00002064, &axi_qos->qosthres0);
  667. writel(0x00002004, &axi_qos->qosthres1);
  668. writel(0x00000001, &axi_qos->qosthres2);
  669. writel(0x00000001, &axi_qos->qosqon);
  670. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_TDMW_BASE;
  671. writel(0x00000001, &axi_qos->qosconf);
  672. writel(0x00002190, &axi_qos->qosctset0);
  673. writel(0x00000020, &axi_qos->qosreqctr);
  674. writel(0x00000001, &axi_qos->qosthres0);
  675. writel(0x00000001, &axi_qos->qosthres1);
  676. writel(0x00000001, &axi_qos->qosthres2);
  677. writel(0x00000001, &axi_qos->qosqon);
  678. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_VSP1CR_BASE;
  679. writel(0x00000001, &axi_qos->qosconf);
  680. writel(0x00002190, &axi_qos->qosctset0);
  681. writel(0x00000020, &axi_qos->qosreqctr);
  682. writel(0x00002064, &axi_qos->qosthres0);
  683. writel(0x00002004, &axi_qos->qosthres1);
  684. writel(0x00000001, &axi_qos->qosthres2);
  685. writel(0x00000001, &axi_qos->qosqon);
  686. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_VSP1CW_BASE;
  687. writel(0x00000001, &axi_qos->qosconf);
  688. writel(0x00002190, &axi_qos->qosctset0);
  689. writel(0x00000020, &axi_qos->qosreqctr);
  690. writel(0x00000001, &axi_qos->qosthres0);
  691. writel(0x00000001, &axi_qos->qosthres1);
  692. writel(0x00000001, &axi_qos->qosthres2);
  693. writel(0x00000001, &axi_qos->qosqon);
  694. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_VSPDU0CR_BASE;
  695. writel(0x00000001, &axi_qos->qosconf);
  696. writel(0x00002190, &axi_qos->qosctset0);
  697. writel(0x00000020, &axi_qos->qosreqctr);
  698. writel(0x00002064, &axi_qos->qosthres0);
  699. writel(0x00002004, &axi_qos->qosthres1);
  700. writel(0x00000001, &axi_qos->qosthres2);
  701. writel(0x00000001, &axi_qos->qosqon);
  702. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_VSPDU0CW_BASE;
  703. writel(0x00000001, &axi_qos->qosconf);
  704. writel(0x00002190, &axi_qos->qosctset0);
  705. writel(0x00000020, &axi_qos->qosreqctr);
  706. writel(0x00000001, &axi_qos->qosthres0);
  707. writel(0x00000001, &axi_qos->qosthres1);
  708. writel(0x00000001, &axi_qos->qosthres2);
  709. writel(0x00000001, &axi_qos->qosqon);
  710. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_VIN0W_BASE;
  711. writel(0x00000001, &axi_qos->qosconf);
  712. writel(0x00001FF0, &axi_qos->qosctset0);
  713. writel(0x00000020, &axi_qos->qosreqctr);
  714. writel(0x00002064, &axi_qos->qosthres0);
  715. writel(0x00002004, &axi_qos->qosthres1);
  716. writel(0x00002001, &axi_qos->qosthres2);
  717. writel(0x00000001, &axi_qos->qosqon);
  718. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_FDP0R_BASE;
  719. writel(0x00000001, &axi_qos->qosconf);
  720. writel(0x000020C8, &axi_qos->qosctset0);
  721. writel(0x00000020, &axi_qos->qosreqctr);
  722. writel(0x00002064, &axi_qos->qosthres0);
  723. writel(0x00002004, &axi_qos->qosthres1);
  724. writel(0x00000001, &axi_qos->qosthres2);
  725. writel(0x00000001, &axi_qos->qosqon);
  726. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_FDP0W_BASE;
  727. writel(0x00000001, &axi_qos->qosconf);
  728. writel(0x000020C8, &axi_qos->qosctset0);
  729. writel(0x00000020, &axi_qos->qosreqctr);
  730. writel(0x00000001, &axi_qos->qosthres0);
  731. writel(0x00000001, &axi_qos->qosthres1);
  732. writel(0x00000001, &axi_qos->qosthres2);
  733. writel(0x00000001, &axi_qos->qosqon);
  734. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_IMSR_BASE;
  735. writel(0x00000001, &axi_qos->qosconf);
  736. writel(0x000020C8, &axi_qos->qosctset0);
  737. writel(0x00000020, &axi_qos->qosreqctr);
  738. writel(0x00002064, &axi_qos->qosthres0);
  739. writel(0x00002004, &axi_qos->qosthres1);
  740. writel(0x00000001, &axi_qos->qosthres2);
  741. writel(0x00000001, &axi_qos->qosqon);
  742. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_IMSW_BASE;
  743. writel(0x00000001, &axi_qos->qosconf);
  744. writel(0x000020C8, &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_VSP1R_BASE;
  751. writel(0x00000001, &axi_qos->qosconf);
  752. writel(0x000020C8, &axi_qos->qosctset0);
  753. writel(0x00000020, &axi_qos->qosreqctr);
  754. writel(0x00002064, &axi_qos->qosthres0);
  755. writel(0x00002004, &axi_qos->qosthres1);
  756. writel(0x00000001, &axi_qos->qosthres2);
  757. writel(0x00000001, &axi_qos->qosqon);
  758. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_VSP1W_BASE;
  759. writel(0x00000001, &axi_qos->qosconf);
  760. writel(0x000020C8, &axi_qos->qosctset0);
  761. writel(0x00000020, &axi_qos->qosreqctr);
  762. writel(0x00000001, &axi_qos->qosthres0);
  763. writel(0x00000001, &axi_qos->qosthres1);
  764. writel(0x00000001, &axi_qos->qosthres2);
  765. writel(0x00000001, &axi_qos->qosqon);
  766. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_IMRR_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_IMRW_BASE;
  775. writel(0x00000001, &axi_qos->qosconf);
  776. writel(0x000020C8, &axi_qos->qosctset0);
  777. writel(0x00000020, &axi_qos->qosreqctr);
  778. writel(0x00002064, &axi_qos->qosthres0);
  779. writel(0x00002004, &axi_qos->qosthres1);
  780. writel(0x00000001, &axi_qos->qosthres2);
  781. writel(0x00000001, &axi_qos->qosqon);
  782. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_VSPD0R_BASE;
  783. writel(0x00000003, &axi_qos->qosconf);
  784. writel(0x000020C8, &axi_qos->qosctset0);
  785. writel(0x00002064, &axi_qos->qosthres0);
  786. writel(0x00002004, &axi_qos->qosthres1);
  787. writel(0x00000001, &axi_qos->qosthres2);
  788. writel(0x00000001, &axi_qos->qosqon);
  789. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_VSPD0W_BASE;
  790. writel(0x00000003, &axi_qos->qosconf);
  791. writel(0x000020C8, &axi_qos->qosctset0);
  792. writel(0x00002064, &axi_qos->qosthres0);
  793. writel(0x00002004, &axi_qos->qosthres1);
  794. writel(0x00000001, &axi_qos->qosthres2);
  795. writel(0x00000001, &axi_qos->qosqon);
  796. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_DU0R_BASE;
  797. writel(0x00000003, &axi_qos->qosconf);
  798. writel(0x00002063, &axi_qos->qosctset0);
  799. writel(0x00000001, &axi_qos->qosreqctr);
  800. writel(0x00002064, &axi_qos->qosthres0);
  801. writel(0x00002004, &axi_qos->qosthres1);
  802. writel(0x00000001, &axi_qos->qosthres2);
  803. writel(0x00000001, &axi_qos->qosqon);
  804. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_DU0W_BASE;
  805. writel(0x00000003, &axi_qos->qosconf);
  806. writel(0x00002063, &axi_qos->qosctset0);
  807. writel(0x00000001, &axi_qos->qosreqctr);
  808. writel(0x00002064, &axi_qos->qosthres0);
  809. writel(0x00002004, &axi_qos->qosthres1);
  810. writel(0x00000001, &axi_qos->qosthres2);
  811. writel(0x00000001, &axi_qos->qosqon);
  812. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_VCP0CR_BASE;
  813. writel(0x00000001, &axi_qos->qosconf);
  814. writel(0x00002073, &axi_qos->qosctset0);
  815. writel(0x00000020, &axi_qos->qosreqctr);
  816. writel(0x00002064, &axi_qos->qosthres0);
  817. writel(0x00002004, &axi_qos->qosthres1);
  818. writel(0x00000001, &axi_qos->qosthres2);
  819. writel(0x00000001, &axi_qos->qosqon);
  820. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_VCP0CW_BASE;
  821. writel(0x00000001, &axi_qos->qosconf);
  822. writel(0x00002073, &axi_qos->qosctset0);
  823. writel(0x00000020, &axi_qos->qosreqctr);
  824. writel(0x00000001, &axi_qos->qosthres0);
  825. writel(0x00000001, &axi_qos->qosthres1);
  826. writel(0x00000001, &axi_qos->qosthres2);
  827. writel(0x00000001, &axi_qos->qosqon);
  828. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_VCP0VR_BASE;
  829. writel(0x00000001, &axi_qos->qosconf);
  830. writel(0x00002073, &axi_qos->qosctset0);
  831. writel(0x00000020, &axi_qos->qosreqctr);
  832. writel(0x00002064, &axi_qos->qosthres0);
  833. writel(0x00002004, &axi_qos->qosthres1);
  834. writel(0x00000001, &axi_qos->qosthres2);
  835. writel(0x00000001, &axi_qos->qosqon);
  836. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_VCP0VW_BASE;
  837. writel(0x00000001, &axi_qos->qosconf);
  838. writel(0x00002073, &axi_qos->qosctset0);
  839. writel(0x00000020, &axi_qos->qosreqctr);
  840. writel(0x00000001, &axi_qos->qosthres0);
  841. writel(0x00000001, &axi_qos->qosthres1);
  842. writel(0x00000001, &axi_qos->qosthres2);
  843. writel(0x00000001, &axi_qos->qosqon);
  844. axi_qos = (struct rcar_axi_qos *)MEDIA_AXI_VPC0R_BASE;
  845. writel(0x00000001, &axi_qos->qosconf);
  846. writel(0x00002073, &axi_qos->qosctset0);
  847. writel(0x00000020, &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. }
  853. #else /* CONFIG_RMOBILE_EXTRAM_BOOT */
  854. void qos_init(void)
  855. {
  856. }
  857. #endif /* CONFIG_RMOBILE_EXTRAM_BOOT */