qos.c 34 KB

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