qos.c 36 KB

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