intel_uncore.c 44 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641
  1. /*
  2. * Copyright © 2013 Intel Corporation
  3. *
  4. * Permission is hereby granted, free of charge, to any person obtaining a
  5. * copy of this software and associated documentation files (the "Software"),
  6. * to deal in the Software without restriction, including without limitation
  7. * the rights to use, copy, modify, merge, publish, distribute, sublicense,
  8. * and/or sell copies of the Software, and to permit persons to whom the
  9. * Software is furnished to do so, subject to the following conditions:
  10. *
  11. * The above copyright notice and this permission notice (including the next
  12. * paragraph) shall be included in all copies or substantial portions of the
  13. * Software.
  14. *
  15. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  16. * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  17. * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
  18. * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  19. * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
  20. * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
  21. * IN THE SOFTWARE.
  22. */
  23. #include "i915_drv.h"
  24. #include "intel_drv.h"
  25. #include "i915_vgpu.h"
  26. #include <linux/pm_runtime.h>
  27. #define FORCEWAKE_ACK_TIMEOUT_MS 50
  28. #define __raw_posting_read(dev_priv__, reg__) (void)__raw_i915_read32((dev_priv__), (reg__))
  29. static const char * const forcewake_domain_names[] = {
  30. "render",
  31. "blitter",
  32. "media",
  33. };
  34. const char *
  35. intel_uncore_forcewake_domain_to_str(const enum forcewake_domain_id id)
  36. {
  37. BUILD_BUG_ON(ARRAY_SIZE(forcewake_domain_names) != FW_DOMAIN_ID_COUNT);
  38. if (id >= 0 && id < FW_DOMAIN_ID_COUNT)
  39. return forcewake_domain_names[id];
  40. WARN_ON(id);
  41. return "unknown";
  42. }
  43. static inline void
  44. fw_domain_reset(const struct intel_uncore_forcewake_domain *d)
  45. {
  46. WARN_ON(!i915_mmio_reg_valid(d->reg_set));
  47. __raw_i915_write32(d->i915, d->reg_set, d->val_reset);
  48. }
  49. static inline void
  50. fw_domain_arm_timer(struct intel_uncore_forcewake_domain *d)
  51. {
  52. mod_timer_pinned(&d->timer, jiffies + 1);
  53. }
  54. static inline void
  55. fw_domain_wait_ack_clear(const struct intel_uncore_forcewake_domain *d)
  56. {
  57. if (wait_for_atomic((__raw_i915_read32(d->i915, d->reg_ack) &
  58. FORCEWAKE_KERNEL) == 0,
  59. FORCEWAKE_ACK_TIMEOUT_MS))
  60. DRM_ERROR("%s: timed out waiting for forcewake ack to clear.\n",
  61. intel_uncore_forcewake_domain_to_str(d->id));
  62. }
  63. static inline void
  64. fw_domain_get(const struct intel_uncore_forcewake_domain *d)
  65. {
  66. __raw_i915_write32(d->i915, d->reg_set, d->val_set);
  67. }
  68. static inline void
  69. fw_domain_wait_ack(const struct intel_uncore_forcewake_domain *d)
  70. {
  71. if (wait_for_atomic((__raw_i915_read32(d->i915, d->reg_ack) &
  72. FORCEWAKE_KERNEL),
  73. FORCEWAKE_ACK_TIMEOUT_MS))
  74. DRM_ERROR("%s: timed out waiting for forcewake ack request.\n",
  75. intel_uncore_forcewake_domain_to_str(d->id));
  76. }
  77. static inline void
  78. fw_domain_put(const struct intel_uncore_forcewake_domain *d)
  79. {
  80. __raw_i915_write32(d->i915, d->reg_set, d->val_clear);
  81. }
  82. static inline void
  83. fw_domain_posting_read(const struct intel_uncore_forcewake_domain *d)
  84. {
  85. /* something from same cacheline, but not from the set register */
  86. if (i915_mmio_reg_valid(d->reg_post))
  87. __raw_posting_read(d->i915, d->reg_post);
  88. }
  89. static void
  90. fw_domains_get(struct drm_i915_private *dev_priv, enum forcewake_domains fw_domains)
  91. {
  92. struct intel_uncore_forcewake_domain *d;
  93. enum forcewake_domain_id id;
  94. for_each_fw_domain_mask(d, fw_domains, dev_priv, id) {
  95. fw_domain_wait_ack_clear(d);
  96. fw_domain_get(d);
  97. fw_domain_wait_ack(d);
  98. }
  99. }
  100. static void
  101. fw_domains_put(struct drm_i915_private *dev_priv, enum forcewake_domains fw_domains)
  102. {
  103. struct intel_uncore_forcewake_domain *d;
  104. enum forcewake_domain_id id;
  105. for_each_fw_domain_mask(d, fw_domains, dev_priv, id) {
  106. fw_domain_put(d);
  107. fw_domain_posting_read(d);
  108. }
  109. }
  110. static void
  111. fw_domains_posting_read(struct drm_i915_private *dev_priv)
  112. {
  113. struct intel_uncore_forcewake_domain *d;
  114. enum forcewake_domain_id id;
  115. /* No need to do for all, just do for first found */
  116. for_each_fw_domain(d, dev_priv, id) {
  117. fw_domain_posting_read(d);
  118. break;
  119. }
  120. }
  121. static void
  122. fw_domains_reset(struct drm_i915_private *dev_priv, enum forcewake_domains fw_domains)
  123. {
  124. struct intel_uncore_forcewake_domain *d;
  125. enum forcewake_domain_id id;
  126. if (dev_priv->uncore.fw_domains == 0)
  127. return;
  128. for_each_fw_domain_mask(d, fw_domains, dev_priv, id)
  129. fw_domain_reset(d);
  130. fw_domains_posting_read(dev_priv);
  131. }
  132. static void __gen6_gt_wait_for_thread_c0(struct drm_i915_private *dev_priv)
  133. {
  134. /* w/a for a sporadic read returning 0 by waiting for the GT
  135. * thread to wake up.
  136. */
  137. if (wait_for_atomic_us((__raw_i915_read32(dev_priv, GEN6_GT_THREAD_STATUS_REG) &
  138. GEN6_GT_THREAD_STATUS_CORE_MASK) == 0, 500))
  139. DRM_ERROR("GT thread status wait timed out\n");
  140. }
  141. static void fw_domains_get_with_thread_status(struct drm_i915_private *dev_priv,
  142. enum forcewake_domains fw_domains)
  143. {
  144. fw_domains_get(dev_priv, fw_domains);
  145. /* WaRsForcewakeWaitTC0:snb,ivb,hsw,bdw,vlv */
  146. __gen6_gt_wait_for_thread_c0(dev_priv);
  147. }
  148. static void gen6_gt_check_fifodbg(struct drm_i915_private *dev_priv)
  149. {
  150. u32 gtfifodbg;
  151. gtfifodbg = __raw_i915_read32(dev_priv, GTFIFODBG);
  152. if (WARN(gtfifodbg, "GT wake FIFO error 0x%x\n", gtfifodbg))
  153. __raw_i915_write32(dev_priv, GTFIFODBG, gtfifodbg);
  154. }
  155. static void fw_domains_put_with_fifo(struct drm_i915_private *dev_priv,
  156. enum forcewake_domains fw_domains)
  157. {
  158. fw_domains_put(dev_priv, fw_domains);
  159. gen6_gt_check_fifodbg(dev_priv);
  160. }
  161. static inline u32 fifo_free_entries(struct drm_i915_private *dev_priv)
  162. {
  163. u32 count = __raw_i915_read32(dev_priv, GTFIFOCTL);
  164. return count & GT_FIFO_FREE_ENTRIES_MASK;
  165. }
  166. static int __gen6_gt_wait_for_fifo(struct drm_i915_private *dev_priv)
  167. {
  168. int ret = 0;
  169. /* On VLV, FIFO will be shared by both SW and HW.
  170. * So, we need to read the FREE_ENTRIES everytime */
  171. if (IS_VALLEYVIEW(dev_priv->dev))
  172. dev_priv->uncore.fifo_count = fifo_free_entries(dev_priv);
  173. if (dev_priv->uncore.fifo_count < GT_FIFO_NUM_RESERVED_ENTRIES) {
  174. int loop = 500;
  175. u32 fifo = fifo_free_entries(dev_priv);
  176. while (fifo <= GT_FIFO_NUM_RESERVED_ENTRIES && loop--) {
  177. udelay(10);
  178. fifo = fifo_free_entries(dev_priv);
  179. }
  180. if (WARN_ON(loop < 0 && fifo <= GT_FIFO_NUM_RESERVED_ENTRIES))
  181. ++ret;
  182. dev_priv->uncore.fifo_count = fifo;
  183. }
  184. dev_priv->uncore.fifo_count--;
  185. return ret;
  186. }
  187. static void intel_uncore_fw_release_timer(unsigned long arg)
  188. {
  189. struct intel_uncore_forcewake_domain *domain = (void *)arg;
  190. unsigned long irqflags;
  191. assert_rpm_device_not_suspended(domain->i915);
  192. spin_lock_irqsave(&domain->i915->uncore.lock, irqflags);
  193. if (WARN_ON(domain->wake_count == 0))
  194. domain->wake_count++;
  195. if (--domain->wake_count == 0)
  196. domain->i915->uncore.funcs.force_wake_put(domain->i915,
  197. 1 << domain->id);
  198. spin_unlock_irqrestore(&domain->i915->uncore.lock, irqflags);
  199. }
  200. void intel_uncore_forcewake_reset(struct drm_device *dev, bool restore)
  201. {
  202. struct drm_i915_private *dev_priv = dev->dev_private;
  203. unsigned long irqflags;
  204. struct intel_uncore_forcewake_domain *domain;
  205. int retry_count = 100;
  206. enum forcewake_domain_id id;
  207. enum forcewake_domains fw = 0, active_domains;
  208. /* Hold uncore.lock across reset to prevent any register access
  209. * with forcewake not set correctly. Wait until all pending
  210. * timers are run before holding.
  211. */
  212. while (1) {
  213. active_domains = 0;
  214. for_each_fw_domain(domain, dev_priv, id) {
  215. if (del_timer_sync(&domain->timer) == 0)
  216. continue;
  217. intel_uncore_fw_release_timer((unsigned long)domain);
  218. }
  219. spin_lock_irqsave(&dev_priv->uncore.lock, irqflags);
  220. for_each_fw_domain(domain, dev_priv, id) {
  221. if (timer_pending(&domain->timer))
  222. active_domains |= (1 << id);
  223. }
  224. if (active_domains == 0)
  225. break;
  226. if (--retry_count == 0) {
  227. DRM_ERROR("Timed out waiting for forcewake timers to finish\n");
  228. break;
  229. }
  230. spin_unlock_irqrestore(&dev_priv->uncore.lock, irqflags);
  231. cond_resched();
  232. }
  233. WARN_ON(active_domains);
  234. for_each_fw_domain(domain, dev_priv, id)
  235. if (domain->wake_count)
  236. fw |= 1 << id;
  237. if (fw)
  238. dev_priv->uncore.funcs.force_wake_put(dev_priv, fw);
  239. fw_domains_reset(dev_priv, FORCEWAKE_ALL);
  240. if (restore) { /* If reset with a user forcewake, try to restore */
  241. if (fw)
  242. dev_priv->uncore.funcs.force_wake_get(dev_priv, fw);
  243. if (IS_GEN6(dev) || IS_GEN7(dev))
  244. dev_priv->uncore.fifo_count =
  245. fifo_free_entries(dev_priv);
  246. }
  247. if (!restore)
  248. assert_forcewakes_inactive(dev_priv);
  249. spin_unlock_irqrestore(&dev_priv->uncore.lock, irqflags);
  250. }
  251. static void intel_uncore_ellc_detect(struct drm_device *dev)
  252. {
  253. struct drm_i915_private *dev_priv = dev->dev_private;
  254. if ((IS_HASWELL(dev) || IS_BROADWELL(dev) ||
  255. INTEL_INFO(dev)->gen >= 9) &&
  256. (__raw_i915_read32(dev_priv, HSW_EDRAM_PRESENT) & EDRAM_ENABLED)) {
  257. /* The docs do not explain exactly how the calculation can be
  258. * made. It is somewhat guessable, but for now, it's always
  259. * 128MB.
  260. * NB: We can't write IDICR yet because we do not have gt funcs
  261. * set up */
  262. dev_priv->ellc_size = 128;
  263. DRM_INFO("Found %zuMB of eLLC\n", dev_priv->ellc_size);
  264. }
  265. }
  266. static bool
  267. fpga_check_for_unclaimed_mmio(struct drm_i915_private *dev_priv)
  268. {
  269. u32 dbg;
  270. dbg = __raw_i915_read32(dev_priv, FPGA_DBG);
  271. if (likely(!(dbg & FPGA_DBG_RM_NOCLAIM)))
  272. return false;
  273. __raw_i915_write32(dev_priv, FPGA_DBG, FPGA_DBG_RM_NOCLAIM);
  274. return true;
  275. }
  276. static bool
  277. vlv_check_for_unclaimed_mmio(struct drm_i915_private *dev_priv)
  278. {
  279. u32 cer;
  280. cer = __raw_i915_read32(dev_priv, CLAIM_ER);
  281. if (likely(!(cer & (CLAIM_ER_OVERFLOW | CLAIM_ER_CTR_MASK))))
  282. return false;
  283. __raw_i915_write32(dev_priv, CLAIM_ER, CLAIM_ER_CLR);
  284. return true;
  285. }
  286. static bool
  287. check_for_unclaimed_mmio(struct drm_i915_private *dev_priv)
  288. {
  289. if (HAS_FPGA_DBG_UNCLAIMED(dev_priv))
  290. return fpga_check_for_unclaimed_mmio(dev_priv);
  291. if (IS_VALLEYVIEW(dev_priv) || IS_CHERRYVIEW(dev_priv))
  292. return vlv_check_for_unclaimed_mmio(dev_priv);
  293. return false;
  294. }
  295. static void __intel_uncore_early_sanitize(struct drm_device *dev,
  296. bool restore_forcewake)
  297. {
  298. struct drm_i915_private *dev_priv = dev->dev_private;
  299. /* clear out unclaimed reg detection bit */
  300. if (check_for_unclaimed_mmio(dev_priv))
  301. DRM_DEBUG("unclaimed mmio detected on uncore init, clearing\n");
  302. /* clear out old GT FIFO errors */
  303. if (IS_GEN6(dev) || IS_GEN7(dev))
  304. __raw_i915_write32(dev_priv, GTFIFODBG,
  305. __raw_i915_read32(dev_priv, GTFIFODBG));
  306. /* WaDisableShadowRegForCpd:chv */
  307. if (IS_CHERRYVIEW(dev)) {
  308. __raw_i915_write32(dev_priv, GTFIFOCTL,
  309. __raw_i915_read32(dev_priv, GTFIFOCTL) |
  310. GT_FIFO_CTL_BLOCK_ALL_POLICY_STALL |
  311. GT_FIFO_CTL_RC6_POLICY_STALL);
  312. }
  313. intel_uncore_forcewake_reset(dev, restore_forcewake);
  314. }
  315. void intel_uncore_early_sanitize(struct drm_device *dev, bool restore_forcewake)
  316. {
  317. __intel_uncore_early_sanitize(dev, restore_forcewake);
  318. i915_check_and_clear_faults(dev);
  319. }
  320. void intel_uncore_sanitize(struct drm_device *dev)
  321. {
  322. i915.enable_rc6 = sanitize_rc6_option(dev, i915.enable_rc6);
  323. /* BIOS often leaves RC6 enabled, but disable it for hw init */
  324. intel_disable_gt_powersave(dev);
  325. }
  326. static void __intel_uncore_forcewake_get(struct drm_i915_private *dev_priv,
  327. enum forcewake_domains fw_domains)
  328. {
  329. struct intel_uncore_forcewake_domain *domain;
  330. enum forcewake_domain_id id;
  331. if (!dev_priv->uncore.funcs.force_wake_get)
  332. return;
  333. fw_domains &= dev_priv->uncore.fw_domains;
  334. for_each_fw_domain_mask(domain, fw_domains, dev_priv, id) {
  335. if (domain->wake_count++)
  336. fw_domains &= ~(1 << id);
  337. }
  338. if (fw_domains)
  339. dev_priv->uncore.funcs.force_wake_get(dev_priv, fw_domains);
  340. }
  341. /**
  342. * intel_uncore_forcewake_get - grab forcewake domain references
  343. * @dev_priv: i915 device instance
  344. * @fw_domains: forcewake domains to get reference on
  345. *
  346. * This function can be used get GT's forcewake domain references.
  347. * Normal register access will handle the forcewake domains automatically.
  348. * However if some sequence requires the GT to not power down a particular
  349. * forcewake domains this function should be called at the beginning of the
  350. * sequence. And subsequently the reference should be dropped by symmetric
  351. * call to intel_unforce_forcewake_put(). Usually caller wants all the domains
  352. * to be kept awake so the @fw_domains would be then FORCEWAKE_ALL.
  353. */
  354. void intel_uncore_forcewake_get(struct drm_i915_private *dev_priv,
  355. enum forcewake_domains fw_domains)
  356. {
  357. unsigned long irqflags;
  358. if (!dev_priv->uncore.funcs.force_wake_get)
  359. return;
  360. assert_rpm_wakelock_held(dev_priv);
  361. spin_lock_irqsave(&dev_priv->uncore.lock, irqflags);
  362. __intel_uncore_forcewake_get(dev_priv, fw_domains);
  363. spin_unlock_irqrestore(&dev_priv->uncore.lock, irqflags);
  364. }
  365. /**
  366. * intel_uncore_forcewake_get__locked - grab forcewake domain references
  367. * @dev_priv: i915 device instance
  368. * @fw_domains: forcewake domains to get reference on
  369. *
  370. * See intel_uncore_forcewake_get(). This variant places the onus
  371. * on the caller to explicitly handle the dev_priv->uncore.lock spinlock.
  372. */
  373. void intel_uncore_forcewake_get__locked(struct drm_i915_private *dev_priv,
  374. enum forcewake_domains fw_domains)
  375. {
  376. assert_spin_locked(&dev_priv->uncore.lock);
  377. if (!dev_priv->uncore.funcs.force_wake_get)
  378. return;
  379. __intel_uncore_forcewake_get(dev_priv, fw_domains);
  380. }
  381. static void __intel_uncore_forcewake_put(struct drm_i915_private *dev_priv,
  382. enum forcewake_domains fw_domains)
  383. {
  384. struct intel_uncore_forcewake_domain *domain;
  385. enum forcewake_domain_id id;
  386. if (!dev_priv->uncore.funcs.force_wake_put)
  387. return;
  388. fw_domains &= dev_priv->uncore.fw_domains;
  389. for_each_fw_domain_mask(domain, fw_domains, dev_priv, id) {
  390. if (WARN_ON(domain->wake_count == 0))
  391. continue;
  392. if (--domain->wake_count)
  393. continue;
  394. domain->wake_count++;
  395. fw_domain_arm_timer(domain);
  396. }
  397. }
  398. /**
  399. * intel_uncore_forcewake_put - release a forcewake domain reference
  400. * @dev_priv: i915 device instance
  401. * @fw_domains: forcewake domains to put references
  402. *
  403. * This function drops the device-level forcewakes for specified
  404. * domains obtained by intel_uncore_forcewake_get().
  405. */
  406. void intel_uncore_forcewake_put(struct drm_i915_private *dev_priv,
  407. enum forcewake_domains fw_domains)
  408. {
  409. unsigned long irqflags;
  410. if (!dev_priv->uncore.funcs.force_wake_put)
  411. return;
  412. spin_lock_irqsave(&dev_priv->uncore.lock, irqflags);
  413. __intel_uncore_forcewake_put(dev_priv, fw_domains);
  414. spin_unlock_irqrestore(&dev_priv->uncore.lock, irqflags);
  415. }
  416. /**
  417. * intel_uncore_forcewake_put__locked - grab forcewake domain references
  418. * @dev_priv: i915 device instance
  419. * @fw_domains: forcewake domains to get reference on
  420. *
  421. * See intel_uncore_forcewake_put(). This variant places the onus
  422. * on the caller to explicitly handle the dev_priv->uncore.lock spinlock.
  423. */
  424. void intel_uncore_forcewake_put__locked(struct drm_i915_private *dev_priv,
  425. enum forcewake_domains fw_domains)
  426. {
  427. assert_spin_locked(&dev_priv->uncore.lock);
  428. if (!dev_priv->uncore.funcs.force_wake_put)
  429. return;
  430. __intel_uncore_forcewake_put(dev_priv, fw_domains);
  431. }
  432. void assert_forcewakes_inactive(struct drm_i915_private *dev_priv)
  433. {
  434. struct intel_uncore_forcewake_domain *domain;
  435. enum forcewake_domain_id id;
  436. if (!dev_priv->uncore.funcs.force_wake_get)
  437. return;
  438. for_each_fw_domain(domain, dev_priv, id)
  439. WARN_ON(domain->wake_count);
  440. }
  441. /* We give fast paths for the really cool registers */
  442. #define NEEDS_FORCE_WAKE(reg) ((reg) < 0x40000)
  443. #define REG_RANGE(reg, start, end) ((reg) >= (start) && (reg) < (end))
  444. #define FORCEWAKE_VLV_RENDER_RANGE_OFFSET(reg) \
  445. (REG_RANGE((reg), 0x2000, 0x4000) || \
  446. REG_RANGE((reg), 0x5000, 0x8000) || \
  447. REG_RANGE((reg), 0xB000, 0x12000) || \
  448. REG_RANGE((reg), 0x2E000, 0x30000))
  449. #define FORCEWAKE_VLV_MEDIA_RANGE_OFFSET(reg) \
  450. (REG_RANGE((reg), 0x12000, 0x14000) || \
  451. REG_RANGE((reg), 0x22000, 0x24000) || \
  452. REG_RANGE((reg), 0x30000, 0x40000))
  453. #define FORCEWAKE_CHV_RENDER_RANGE_OFFSET(reg) \
  454. (REG_RANGE((reg), 0x2000, 0x4000) || \
  455. REG_RANGE((reg), 0x5200, 0x8000) || \
  456. REG_RANGE((reg), 0x8300, 0x8500) || \
  457. REG_RANGE((reg), 0xB000, 0xB480) || \
  458. REG_RANGE((reg), 0xE000, 0xE800))
  459. #define FORCEWAKE_CHV_MEDIA_RANGE_OFFSET(reg) \
  460. (REG_RANGE((reg), 0x8800, 0x8900) || \
  461. REG_RANGE((reg), 0xD000, 0xD800) || \
  462. REG_RANGE((reg), 0x12000, 0x14000) || \
  463. REG_RANGE((reg), 0x1A000, 0x1C000) || \
  464. REG_RANGE((reg), 0x1E800, 0x1EA00) || \
  465. REG_RANGE((reg), 0x30000, 0x38000))
  466. #define FORCEWAKE_CHV_COMMON_RANGE_OFFSET(reg) \
  467. (REG_RANGE((reg), 0x4000, 0x5000) || \
  468. REG_RANGE((reg), 0x8000, 0x8300) || \
  469. REG_RANGE((reg), 0x8500, 0x8600) || \
  470. REG_RANGE((reg), 0x9000, 0xB000) || \
  471. REG_RANGE((reg), 0xF000, 0x10000))
  472. #define FORCEWAKE_GEN9_UNCORE_RANGE_OFFSET(reg) \
  473. REG_RANGE((reg), 0xB00, 0x2000)
  474. #define FORCEWAKE_GEN9_RENDER_RANGE_OFFSET(reg) \
  475. (REG_RANGE((reg), 0x2000, 0x2700) || \
  476. REG_RANGE((reg), 0x3000, 0x4000) || \
  477. REG_RANGE((reg), 0x5200, 0x8000) || \
  478. REG_RANGE((reg), 0x8140, 0x8160) || \
  479. REG_RANGE((reg), 0x8300, 0x8500) || \
  480. REG_RANGE((reg), 0x8C00, 0x8D00) || \
  481. REG_RANGE((reg), 0xB000, 0xB480) || \
  482. REG_RANGE((reg), 0xE000, 0xE900) || \
  483. REG_RANGE((reg), 0x24400, 0x24800))
  484. #define FORCEWAKE_GEN9_MEDIA_RANGE_OFFSET(reg) \
  485. (REG_RANGE((reg), 0x8130, 0x8140) || \
  486. REG_RANGE((reg), 0x8800, 0x8A00) || \
  487. REG_RANGE((reg), 0xD000, 0xD800) || \
  488. REG_RANGE((reg), 0x12000, 0x14000) || \
  489. REG_RANGE((reg), 0x1A000, 0x1EA00) || \
  490. REG_RANGE((reg), 0x30000, 0x40000))
  491. #define FORCEWAKE_GEN9_COMMON_RANGE_OFFSET(reg) \
  492. REG_RANGE((reg), 0x9400, 0x9800)
  493. #define FORCEWAKE_GEN9_BLITTER_RANGE_OFFSET(reg) \
  494. ((reg) < 0x40000 && \
  495. !FORCEWAKE_GEN9_UNCORE_RANGE_OFFSET(reg) && \
  496. !FORCEWAKE_GEN9_RENDER_RANGE_OFFSET(reg) && \
  497. !FORCEWAKE_GEN9_MEDIA_RANGE_OFFSET(reg) && \
  498. !FORCEWAKE_GEN9_COMMON_RANGE_OFFSET(reg))
  499. static void
  500. ilk_dummy_write(struct drm_i915_private *dev_priv)
  501. {
  502. /* WaIssueDummyWriteToWakeupFromRC6:ilk Issue a dummy write to wake up
  503. * the chip from rc6 before touching it for real. MI_MODE is masked,
  504. * hence harmless to write 0 into. */
  505. __raw_i915_write32(dev_priv, MI_MODE, 0);
  506. }
  507. static void
  508. __unclaimed_reg_debug(struct drm_i915_private *dev_priv,
  509. const i915_reg_t reg,
  510. const bool read,
  511. const bool before)
  512. {
  513. /* XXX. We limit the auto arming traces for mmio
  514. * debugs on these platforms. There are just too many
  515. * revealed by these and CI/Bat suffers from the noise.
  516. * Please fix and then re-enable the automatic traces.
  517. */
  518. if (i915.mmio_debug < 2 &&
  519. (IS_VALLEYVIEW(dev_priv) || IS_CHERRYVIEW(dev_priv)))
  520. return;
  521. if (WARN(check_for_unclaimed_mmio(dev_priv),
  522. "Unclaimed register detected %s %s register 0x%x\n",
  523. before ? "before" : "after",
  524. read ? "reading" : "writing to",
  525. i915_mmio_reg_offset(reg)))
  526. i915.mmio_debug--; /* Only report the first N failures */
  527. }
  528. static inline void
  529. unclaimed_reg_debug(struct drm_i915_private *dev_priv,
  530. const i915_reg_t reg,
  531. const bool read,
  532. const bool before)
  533. {
  534. if (likely(!i915.mmio_debug))
  535. return;
  536. __unclaimed_reg_debug(dev_priv, reg, read, before);
  537. }
  538. #define GEN2_READ_HEADER(x) \
  539. u##x val = 0; \
  540. assert_rpm_wakelock_held(dev_priv);
  541. #define GEN2_READ_FOOTER \
  542. trace_i915_reg_rw(false, reg, val, sizeof(val), trace); \
  543. return val
  544. #define __gen2_read(x) \
  545. static u##x \
  546. gen2_read##x(struct drm_i915_private *dev_priv, i915_reg_t reg, bool trace) { \
  547. GEN2_READ_HEADER(x); \
  548. val = __raw_i915_read##x(dev_priv, reg); \
  549. GEN2_READ_FOOTER; \
  550. }
  551. #define __gen5_read(x) \
  552. static u##x \
  553. gen5_read##x(struct drm_i915_private *dev_priv, i915_reg_t reg, bool trace) { \
  554. GEN2_READ_HEADER(x); \
  555. ilk_dummy_write(dev_priv); \
  556. val = __raw_i915_read##x(dev_priv, reg); \
  557. GEN2_READ_FOOTER; \
  558. }
  559. __gen5_read(8)
  560. __gen5_read(16)
  561. __gen5_read(32)
  562. __gen5_read(64)
  563. __gen2_read(8)
  564. __gen2_read(16)
  565. __gen2_read(32)
  566. __gen2_read(64)
  567. #undef __gen5_read
  568. #undef __gen2_read
  569. #undef GEN2_READ_FOOTER
  570. #undef GEN2_READ_HEADER
  571. #define GEN6_READ_HEADER(x) \
  572. u32 offset = i915_mmio_reg_offset(reg); \
  573. unsigned long irqflags; \
  574. u##x val = 0; \
  575. assert_rpm_wakelock_held(dev_priv); \
  576. spin_lock_irqsave(&dev_priv->uncore.lock, irqflags); \
  577. unclaimed_reg_debug(dev_priv, reg, true, true)
  578. #define GEN6_READ_FOOTER \
  579. unclaimed_reg_debug(dev_priv, reg, true, false); \
  580. spin_unlock_irqrestore(&dev_priv->uncore.lock, irqflags); \
  581. trace_i915_reg_rw(false, reg, val, sizeof(val), trace); \
  582. return val
  583. static inline void __force_wake_get(struct drm_i915_private *dev_priv,
  584. enum forcewake_domains fw_domains)
  585. {
  586. struct intel_uncore_forcewake_domain *domain;
  587. enum forcewake_domain_id id;
  588. if (WARN_ON(!fw_domains))
  589. return;
  590. /* Ideally GCC would be constant-fold and eliminate this loop */
  591. for_each_fw_domain_mask(domain, fw_domains, dev_priv, id) {
  592. if (domain->wake_count) {
  593. fw_domains &= ~(1 << id);
  594. continue;
  595. }
  596. domain->wake_count++;
  597. fw_domain_arm_timer(domain);
  598. }
  599. if (fw_domains)
  600. dev_priv->uncore.funcs.force_wake_get(dev_priv, fw_domains);
  601. }
  602. #define __gen6_read(x) \
  603. static u##x \
  604. gen6_read##x(struct drm_i915_private *dev_priv, i915_reg_t reg, bool trace) { \
  605. GEN6_READ_HEADER(x); \
  606. if (NEEDS_FORCE_WAKE(offset)) \
  607. __force_wake_get(dev_priv, FORCEWAKE_RENDER); \
  608. val = __raw_i915_read##x(dev_priv, reg); \
  609. GEN6_READ_FOOTER; \
  610. }
  611. #define __vlv_read(x) \
  612. static u##x \
  613. vlv_read##x(struct drm_i915_private *dev_priv, i915_reg_t reg, bool trace) { \
  614. enum forcewake_domains fw_engine = 0; \
  615. GEN6_READ_HEADER(x); \
  616. if (!NEEDS_FORCE_WAKE(offset)) \
  617. fw_engine = 0; \
  618. else if (FORCEWAKE_VLV_RENDER_RANGE_OFFSET(offset)) \
  619. fw_engine = FORCEWAKE_RENDER; \
  620. else if (FORCEWAKE_VLV_MEDIA_RANGE_OFFSET(offset)) \
  621. fw_engine = FORCEWAKE_MEDIA; \
  622. if (fw_engine) \
  623. __force_wake_get(dev_priv, fw_engine); \
  624. val = __raw_i915_read##x(dev_priv, reg); \
  625. GEN6_READ_FOOTER; \
  626. }
  627. #define __chv_read(x) \
  628. static u##x \
  629. chv_read##x(struct drm_i915_private *dev_priv, i915_reg_t reg, bool trace) { \
  630. enum forcewake_domains fw_engine = 0; \
  631. GEN6_READ_HEADER(x); \
  632. if (!NEEDS_FORCE_WAKE(offset)) \
  633. fw_engine = 0; \
  634. else if (FORCEWAKE_CHV_RENDER_RANGE_OFFSET(offset)) \
  635. fw_engine = FORCEWAKE_RENDER; \
  636. else if (FORCEWAKE_CHV_MEDIA_RANGE_OFFSET(offset)) \
  637. fw_engine = FORCEWAKE_MEDIA; \
  638. else if (FORCEWAKE_CHV_COMMON_RANGE_OFFSET(offset)) \
  639. fw_engine = FORCEWAKE_RENDER | FORCEWAKE_MEDIA; \
  640. if (fw_engine) \
  641. __force_wake_get(dev_priv, fw_engine); \
  642. val = __raw_i915_read##x(dev_priv, reg); \
  643. GEN6_READ_FOOTER; \
  644. }
  645. #define SKL_NEEDS_FORCE_WAKE(reg) \
  646. ((reg) < 0x40000 && !FORCEWAKE_GEN9_UNCORE_RANGE_OFFSET(reg))
  647. #define __gen9_read(x) \
  648. static u##x \
  649. gen9_read##x(struct drm_i915_private *dev_priv, i915_reg_t reg, bool trace) { \
  650. enum forcewake_domains fw_engine; \
  651. GEN6_READ_HEADER(x); \
  652. if (!SKL_NEEDS_FORCE_WAKE(offset)) \
  653. fw_engine = 0; \
  654. else if (FORCEWAKE_GEN9_RENDER_RANGE_OFFSET(offset)) \
  655. fw_engine = FORCEWAKE_RENDER; \
  656. else if (FORCEWAKE_GEN9_MEDIA_RANGE_OFFSET(offset)) \
  657. fw_engine = FORCEWAKE_MEDIA; \
  658. else if (FORCEWAKE_GEN9_COMMON_RANGE_OFFSET(offset)) \
  659. fw_engine = FORCEWAKE_RENDER | FORCEWAKE_MEDIA; \
  660. else \
  661. fw_engine = FORCEWAKE_BLITTER; \
  662. if (fw_engine) \
  663. __force_wake_get(dev_priv, fw_engine); \
  664. val = __raw_i915_read##x(dev_priv, reg); \
  665. GEN6_READ_FOOTER; \
  666. }
  667. __gen9_read(8)
  668. __gen9_read(16)
  669. __gen9_read(32)
  670. __gen9_read(64)
  671. __chv_read(8)
  672. __chv_read(16)
  673. __chv_read(32)
  674. __chv_read(64)
  675. __vlv_read(8)
  676. __vlv_read(16)
  677. __vlv_read(32)
  678. __vlv_read(64)
  679. __gen6_read(8)
  680. __gen6_read(16)
  681. __gen6_read(32)
  682. __gen6_read(64)
  683. #undef __gen9_read
  684. #undef __chv_read
  685. #undef __vlv_read
  686. #undef __gen6_read
  687. #undef GEN6_READ_FOOTER
  688. #undef GEN6_READ_HEADER
  689. #define VGPU_READ_HEADER(x) \
  690. unsigned long irqflags; \
  691. u##x val = 0; \
  692. assert_rpm_device_not_suspended(dev_priv); \
  693. spin_lock_irqsave(&dev_priv->uncore.lock, irqflags)
  694. #define VGPU_READ_FOOTER \
  695. spin_unlock_irqrestore(&dev_priv->uncore.lock, irqflags); \
  696. trace_i915_reg_rw(false, reg, val, sizeof(val), trace); \
  697. return val
  698. #define __vgpu_read(x) \
  699. static u##x \
  700. vgpu_read##x(struct drm_i915_private *dev_priv, i915_reg_t reg, bool trace) { \
  701. VGPU_READ_HEADER(x); \
  702. val = __raw_i915_read##x(dev_priv, reg); \
  703. VGPU_READ_FOOTER; \
  704. }
  705. __vgpu_read(8)
  706. __vgpu_read(16)
  707. __vgpu_read(32)
  708. __vgpu_read(64)
  709. #undef __vgpu_read
  710. #undef VGPU_READ_FOOTER
  711. #undef VGPU_READ_HEADER
  712. #define GEN2_WRITE_HEADER \
  713. trace_i915_reg_rw(true, reg, val, sizeof(val), trace); \
  714. assert_rpm_wakelock_held(dev_priv); \
  715. #define GEN2_WRITE_FOOTER
  716. #define __gen2_write(x) \
  717. static void \
  718. gen2_write##x(struct drm_i915_private *dev_priv, i915_reg_t reg, u##x val, bool trace) { \
  719. GEN2_WRITE_HEADER; \
  720. __raw_i915_write##x(dev_priv, reg, val); \
  721. GEN2_WRITE_FOOTER; \
  722. }
  723. #define __gen5_write(x) \
  724. static void \
  725. gen5_write##x(struct drm_i915_private *dev_priv, i915_reg_t reg, u##x val, bool trace) { \
  726. GEN2_WRITE_HEADER; \
  727. ilk_dummy_write(dev_priv); \
  728. __raw_i915_write##x(dev_priv, reg, val); \
  729. GEN2_WRITE_FOOTER; \
  730. }
  731. __gen5_write(8)
  732. __gen5_write(16)
  733. __gen5_write(32)
  734. __gen5_write(64)
  735. __gen2_write(8)
  736. __gen2_write(16)
  737. __gen2_write(32)
  738. __gen2_write(64)
  739. #undef __gen5_write
  740. #undef __gen2_write
  741. #undef GEN2_WRITE_FOOTER
  742. #undef GEN2_WRITE_HEADER
  743. #define GEN6_WRITE_HEADER \
  744. u32 offset = i915_mmio_reg_offset(reg); \
  745. unsigned long irqflags; \
  746. trace_i915_reg_rw(true, reg, val, sizeof(val), trace); \
  747. assert_rpm_wakelock_held(dev_priv); \
  748. spin_lock_irqsave(&dev_priv->uncore.lock, irqflags); \
  749. unclaimed_reg_debug(dev_priv, reg, false, true)
  750. #define GEN6_WRITE_FOOTER \
  751. unclaimed_reg_debug(dev_priv, reg, false, false); \
  752. spin_unlock_irqrestore(&dev_priv->uncore.lock, irqflags)
  753. #define __gen6_write(x) \
  754. static void \
  755. gen6_write##x(struct drm_i915_private *dev_priv, i915_reg_t reg, u##x val, bool trace) { \
  756. u32 __fifo_ret = 0; \
  757. GEN6_WRITE_HEADER; \
  758. if (NEEDS_FORCE_WAKE(offset)) { \
  759. __fifo_ret = __gen6_gt_wait_for_fifo(dev_priv); \
  760. } \
  761. __raw_i915_write##x(dev_priv, reg, val); \
  762. if (unlikely(__fifo_ret)) { \
  763. gen6_gt_check_fifodbg(dev_priv); \
  764. } \
  765. GEN6_WRITE_FOOTER; \
  766. }
  767. #define __hsw_write(x) \
  768. static void \
  769. hsw_write##x(struct drm_i915_private *dev_priv, i915_reg_t reg, u##x val, bool trace) { \
  770. u32 __fifo_ret = 0; \
  771. GEN6_WRITE_HEADER; \
  772. if (NEEDS_FORCE_WAKE(offset)) { \
  773. __fifo_ret = __gen6_gt_wait_for_fifo(dev_priv); \
  774. } \
  775. __raw_i915_write##x(dev_priv, reg, val); \
  776. if (unlikely(__fifo_ret)) { \
  777. gen6_gt_check_fifodbg(dev_priv); \
  778. } \
  779. GEN6_WRITE_FOOTER; \
  780. }
  781. static const i915_reg_t gen8_shadowed_regs[] = {
  782. FORCEWAKE_MT,
  783. GEN6_RPNSWREQ,
  784. GEN6_RC_VIDEO_FREQ,
  785. RING_TAIL(RENDER_RING_BASE),
  786. RING_TAIL(GEN6_BSD_RING_BASE),
  787. RING_TAIL(VEBOX_RING_BASE),
  788. RING_TAIL(BLT_RING_BASE),
  789. /* TODO: Other registers are not yet used */
  790. };
  791. static bool is_gen8_shadowed(struct drm_i915_private *dev_priv,
  792. i915_reg_t reg)
  793. {
  794. int i;
  795. for (i = 0; i < ARRAY_SIZE(gen8_shadowed_regs); i++)
  796. if (i915_mmio_reg_equal(reg, gen8_shadowed_regs[i]))
  797. return true;
  798. return false;
  799. }
  800. #define __gen8_write(x) \
  801. static void \
  802. gen8_write##x(struct drm_i915_private *dev_priv, i915_reg_t reg, u##x val, bool trace) { \
  803. GEN6_WRITE_HEADER; \
  804. if (NEEDS_FORCE_WAKE(offset) && !is_gen8_shadowed(dev_priv, reg)) \
  805. __force_wake_get(dev_priv, FORCEWAKE_RENDER); \
  806. __raw_i915_write##x(dev_priv, reg, val); \
  807. GEN6_WRITE_FOOTER; \
  808. }
  809. #define __chv_write(x) \
  810. static void \
  811. chv_write##x(struct drm_i915_private *dev_priv, i915_reg_t reg, u##x val, bool trace) { \
  812. enum forcewake_domains fw_engine = 0; \
  813. GEN6_WRITE_HEADER; \
  814. if (!NEEDS_FORCE_WAKE(offset) || \
  815. is_gen8_shadowed(dev_priv, reg)) \
  816. fw_engine = 0; \
  817. else if (FORCEWAKE_CHV_RENDER_RANGE_OFFSET(offset)) \
  818. fw_engine = FORCEWAKE_RENDER; \
  819. else if (FORCEWAKE_CHV_MEDIA_RANGE_OFFSET(offset)) \
  820. fw_engine = FORCEWAKE_MEDIA; \
  821. else if (FORCEWAKE_CHV_COMMON_RANGE_OFFSET(offset)) \
  822. fw_engine = FORCEWAKE_RENDER | FORCEWAKE_MEDIA; \
  823. if (fw_engine) \
  824. __force_wake_get(dev_priv, fw_engine); \
  825. __raw_i915_write##x(dev_priv, reg, val); \
  826. GEN6_WRITE_FOOTER; \
  827. }
  828. static const i915_reg_t gen9_shadowed_regs[] = {
  829. RING_TAIL(RENDER_RING_BASE),
  830. RING_TAIL(GEN6_BSD_RING_BASE),
  831. RING_TAIL(VEBOX_RING_BASE),
  832. RING_TAIL(BLT_RING_BASE),
  833. FORCEWAKE_BLITTER_GEN9,
  834. FORCEWAKE_RENDER_GEN9,
  835. FORCEWAKE_MEDIA_GEN9,
  836. GEN6_RPNSWREQ,
  837. GEN6_RC_VIDEO_FREQ,
  838. /* TODO: Other registers are not yet used */
  839. };
  840. static bool is_gen9_shadowed(struct drm_i915_private *dev_priv,
  841. i915_reg_t reg)
  842. {
  843. int i;
  844. for (i = 0; i < ARRAY_SIZE(gen9_shadowed_regs); i++)
  845. if (i915_mmio_reg_equal(reg, gen9_shadowed_regs[i]))
  846. return true;
  847. return false;
  848. }
  849. #define __gen9_write(x) \
  850. static void \
  851. gen9_write##x(struct drm_i915_private *dev_priv, i915_reg_t reg, u##x val, \
  852. bool trace) { \
  853. enum forcewake_domains fw_engine; \
  854. GEN6_WRITE_HEADER; \
  855. if (!SKL_NEEDS_FORCE_WAKE(offset) || \
  856. is_gen9_shadowed(dev_priv, reg)) \
  857. fw_engine = 0; \
  858. else if (FORCEWAKE_GEN9_RENDER_RANGE_OFFSET(offset)) \
  859. fw_engine = FORCEWAKE_RENDER; \
  860. else if (FORCEWAKE_GEN9_MEDIA_RANGE_OFFSET(offset)) \
  861. fw_engine = FORCEWAKE_MEDIA; \
  862. else if (FORCEWAKE_GEN9_COMMON_RANGE_OFFSET(offset)) \
  863. fw_engine = FORCEWAKE_RENDER | FORCEWAKE_MEDIA; \
  864. else \
  865. fw_engine = FORCEWAKE_BLITTER; \
  866. if (fw_engine) \
  867. __force_wake_get(dev_priv, fw_engine); \
  868. __raw_i915_write##x(dev_priv, reg, val); \
  869. GEN6_WRITE_FOOTER; \
  870. }
  871. __gen9_write(8)
  872. __gen9_write(16)
  873. __gen9_write(32)
  874. __gen9_write(64)
  875. __chv_write(8)
  876. __chv_write(16)
  877. __chv_write(32)
  878. __chv_write(64)
  879. __gen8_write(8)
  880. __gen8_write(16)
  881. __gen8_write(32)
  882. __gen8_write(64)
  883. __hsw_write(8)
  884. __hsw_write(16)
  885. __hsw_write(32)
  886. __hsw_write(64)
  887. __gen6_write(8)
  888. __gen6_write(16)
  889. __gen6_write(32)
  890. __gen6_write(64)
  891. #undef __gen9_write
  892. #undef __chv_write
  893. #undef __gen8_write
  894. #undef __hsw_write
  895. #undef __gen6_write
  896. #undef GEN6_WRITE_FOOTER
  897. #undef GEN6_WRITE_HEADER
  898. #define VGPU_WRITE_HEADER \
  899. unsigned long irqflags; \
  900. trace_i915_reg_rw(true, reg, val, sizeof(val), trace); \
  901. assert_rpm_device_not_suspended(dev_priv); \
  902. spin_lock_irqsave(&dev_priv->uncore.lock, irqflags)
  903. #define VGPU_WRITE_FOOTER \
  904. spin_unlock_irqrestore(&dev_priv->uncore.lock, irqflags)
  905. #define __vgpu_write(x) \
  906. static void vgpu_write##x(struct drm_i915_private *dev_priv, \
  907. i915_reg_t reg, u##x val, bool trace) { \
  908. VGPU_WRITE_HEADER; \
  909. __raw_i915_write##x(dev_priv, reg, val); \
  910. VGPU_WRITE_FOOTER; \
  911. }
  912. __vgpu_write(8)
  913. __vgpu_write(16)
  914. __vgpu_write(32)
  915. __vgpu_write(64)
  916. #undef __vgpu_write
  917. #undef VGPU_WRITE_FOOTER
  918. #undef VGPU_WRITE_HEADER
  919. #define ASSIGN_WRITE_MMIO_VFUNCS(x) \
  920. do { \
  921. dev_priv->uncore.funcs.mmio_writeb = x##_write8; \
  922. dev_priv->uncore.funcs.mmio_writew = x##_write16; \
  923. dev_priv->uncore.funcs.mmio_writel = x##_write32; \
  924. dev_priv->uncore.funcs.mmio_writeq = x##_write64; \
  925. } while (0)
  926. #define ASSIGN_READ_MMIO_VFUNCS(x) \
  927. do { \
  928. dev_priv->uncore.funcs.mmio_readb = x##_read8; \
  929. dev_priv->uncore.funcs.mmio_readw = x##_read16; \
  930. dev_priv->uncore.funcs.mmio_readl = x##_read32; \
  931. dev_priv->uncore.funcs.mmio_readq = x##_read64; \
  932. } while (0)
  933. static void fw_domain_init(struct drm_i915_private *dev_priv,
  934. enum forcewake_domain_id domain_id,
  935. i915_reg_t reg_set,
  936. i915_reg_t reg_ack)
  937. {
  938. struct intel_uncore_forcewake_domain *d;
  939. if (WARN_ON(domain_id >= FW_DOMAIN_ID_COUNT))
  940. return;
  941. d = &dev_priv->uncore.fw_domain[domain_id];
  942. WARN_ON(d->wake_count);
  943. d->wake_count = 0;
  944. d->reg_set = reg_set;
  945. d->reg_ack = reg_ack;
  946. if (IS_GEN6(dev_priv)) {
  947. d->val_reset = 0;
  948. d->val_set = FORCEWAKE_KERNEL;
  949. d->val_clear = 0;
  950. } else {
  951. /* WaRsClearFWBitsAtReset:bdw,skl */
  952. d->val_reset = _MASKED_BIT_DISABLE(0xffff);
  953. d->val_set = _MASKED_BIT_ENABLE(FORCEWAKE_KERNEL);
  954. d->val_clear = _MASKED_BIT_DISABLE(FORCEWAKE_KERNEL);
  955. }
  956. if (IS_VALLEYVIEW(dev_priv) || IS_CHERRYVIEW(dev_priv))
  957. d->reg_post = FORCEWAKE_ACK_VLV;
  958. else if (IS_GEN6(dev_priv) || IS_GEN7(dev_priv) || IS_GEN8(dev_priv))
  959. d->reg_post = ECOBUS;
  960. d->i915 = dev_priv;
  961. d->id = domain_id;
  962. setup_timer(&d->timer, intel_uncore_fw_release_timer, (unsigned long)d);
  963. dev_priv->uncore.fw_domains |= (1 << domain_id);
  964. fw_domain_reset(d);
  965. }
  966. static void intel_uncore_fw_domains_init(struct drm_device *dev)
  967. {
  968. struct drm_i915_private *dev_priv = dev->dev_private;
  969. if (INTEL_INFO(dev_priv->dev)->gen <= 5)
  970. return;
  971. if (IS_GEN9(dev)) {
  972. dev_priv->uncore.funcs.force_wake_get = fw_domains_get;
  973. dev_priv->uncore.funcs.force_wake_put = fw_domains_put;
  974. fw_domain_init(dev_priv, FW_DOMAIN_ID_RENDER,
  975. FORCEWAKE_RENDER_GEN9,
  976. FORCEWAKE_ACK_RENDER_GEN9);
  977. fw_domain_init(dev_priv, FW_DOMAIN_ID_BLITTER,
  978. FORCEWAKE_BLITTER_GEN9,
  979. FORCEWAKE_ACK_BLITTER_GEN9);
  980. fw_domain_init(dev_priv, FW_DOMAIN_ID_MEDIA,
  981. FORCEWAKE_MEDIA_GEN9, FORCEWAKE_ACK_MEDIA_GEN9);
  982. } else if (IS_VALLEYVIEW(dev) || IS_CHERRYVIEW(dev)) {
  983. dev_priv->uncore.funcs.force_wake_get = fw_domains_get;
  984. if (!IS_CHERRYVIEW(dev))
  985. dev_priv->uncore.funcs.force_wake_put =
  986. fw_domains_put_with_fifo;
  987. else
  988. dev_priv->uncore.funcs.force_wake_put = fw_domains_put;
  989. fw_domain_init(dev_priv, FW_DOMAIN_ID_RENDER,
  990. FORCEWAKE_VLV, FORCEWAKE_ACK_VLV);
  991. fw_domain_init(dev_priv, FW_DOMAIN_ID_MEDIA,
  992. FORCEWAKE_MEDIA_VLV, FORCEWAKE_ACK_MEDIA_VLV);
  993. } else if (IS_HASWELL(dev) || IS_BROADWELL(dev)) {
  994. dev_priv->uncore.funcs.force_wake_get =
  995. fw_domains_get_with_thread_status;
  996. dev_priv->uncore.funcs.force_wake_put = fw_domains_put;
  997. fw_domain_init(dev_priv, FW_DOMAIN_ID_RENDER,
  998. FORCEWAKE_MT, FORCEWAKE_ACK_HSW);
  999. } else if (IS_IVYBRIDGE(dev)) {
  1000. u32 ecobus;
  1001. /* IVB configs may use multi-threaded forcewake */
  1002. /* A small trick here - if the bios hasn't configured
  1003. * MT forcewake, and if the device is in RC6, then
  1004. * force_wake_mt_get will not wake the device and the
  1005. * ECOBUS read will return zero. Which will be
  1006. * (correctly) interpreted by the test below as MT
  1007. * forcewake being disabled.
  1008. */
  1009. dev_priv->uncore.funcs.force_wake_get =
  1010. fw_domains_get_with_thread_status;
  1011. dev_priv->uncore.funcs.force_wake_put =
  1012. fw_domains_put_with_fifo;
  1013. /* We need to init first for ECOBUS access and then
  1014. * determine later if we want to reinit, in case of MT access is
  1015. * not working. In this stage we don't know which flavour this
  1016. * ivb is, so it is better to reset also the gen6 fw registers
  1017. * before the ecobus check.
  1018. */
  1019. __raw_i915_write32(dev_priv, FORCEWAKE, 0);
  1020. __raw_posting_read(dev_priv, ECOBUS);
  1021. fw_domain_init(dev_priv, FW_DOMAIN_ID_RENDER,
  1022. FORCEWAKE_MT, FORCEWAKE_MT_ACK);
  1023. mutex_lock(&dev->struct_mutex);
  1024. fw_domains_get_with_thread_status(dev_priv, FORCEWAKE_ALL);
  1025. ecobus = __raw_i915_read32(dev_priv, ECOBUS);
  1026. fw_domains_put_with_fifo(dev_priv, FORCEWAKE_ALL);
  1027. mutex_unlock(&dev->struct_mutex);
  1028. if (!(ecobus & FORCEWAKE_MT_ENABLE)) {
  1029. DRM_INFO("No MT forcewake available on Ivybridge, this can result in issues\n");
  1030. DRM_INFO("when using vblank-synced partial screen updates.\n");
  1031. fw_domain_init(dev_priv, FW_DOMAIN_ID_RENDER,
  1032. FORCEWAKE, FORCEWAKE_ACK);
  1033. }
  1034. } else if (IS_GEN6(dev)) {
  1035. dev_priv->uncore.funcs.force_wake_get =
  1036. fw_domains_get_with_thread_status;
  1037. dev_priv->uncore.funcs.force_wake_put =
  1038. fw_domains_put_with_fifo;
  1039. fw_domain_init(dev_priv, FW_DOMAIN_ID_RENDER,
  1040. FORCEWAKE, FORCEWAKE_ACK);
  1041. }
  1042. /* All future platforms are expected to require complex power gating */
  1043. WARN_ON(dev_priv->uncore.fw_domains == 0);
  1044. }
  1045. void intel_uncore_init(struct drm_device *dev)
  1046. {
  1047. struct drm_i915_private *dev_priv = dev->dev_private;
  1048. i915_check_vgpu(dev);
  1049. intel_uncore_ellc_detect(dev);
  1050. intel_uncore_fw_domains_init(dev);
  1051. __intel_uncore_early_sanitize(dev, false);
  1052. dev_priv->uncore.unclaimed_mmio_check = 1;
  1053. switch (INTEL_INFO(dev)->gen) {
  1054. default:
  1055. case 9:
  1056. ASSIGN_WRITE_MMIO_VFUNCS(gen9);
  1057. ASSIGN_READ_MMIO_VFUNCS(gen9);
  1058. break;
  1059. case 8:
  1060. if (IS_CHERRYVIEW(dev)) {
  1061. ASSIGN_WRITE_MMIO_VFUNCS(chv);
  1062. ASSIGN_READ_MMIO_VFUNCS(chv);
  1063. } else {
  1064. ASSIGN_WRITE_MMIO_VFUNCS(gen8);
  1065. ASSIGN_READ_MMIO_VFUNCS(gen6);
  1066. }
  1067. break;
  1068. case 7:
  1069. case 6:
  1070. if (IS_HASWELL(dev)) {
  1071. ASSIGN_WRITE_MMIO_VFUNCS(hsw);
  1072. } else {
  1073. ASSIGN_WRITE_MMIO_VFUNCS(gen6);
  1074. }
  1075. if (IS_VALLEYVIEW(dev)) {
  1076. ASSIGN_READ_MMIO_VFUNCS(vlv);
  1077. } else {
  1078. ASSIGN_READ_MMIO_VFUNCS(gen6);
  1079. }
  1080. break;
  1081. case 5:
  1082. ASSIGN_WRITE_MMIO_VFUNCS(gen5);
  1083. ASSIGN_READ_MMIO_VFUNCS(gen5);
  1084. break;
  1085. case 4:
  1086. case 3:
  1087. case 2:
  1088. ASSIGN_WRITE_MMIO_VFUNCS(gen2);
  1089. ASSIGN_READ_MMIO_VFUNCS(gen2);
  1090. break;
  1091. }
  1092. if (intel_vgpu_active(dev)) {
  1093. ASSIGN_WRITE_MMIO_VFUNCS(vgpu);
  1094. ASSIGN_READ_MMIO_VFUNCS(vgpu);
  1095. }
  1096. i915_check_and_clear_faults(dev);
  1097. }
  1098. #undef ASSIGN_WRITE_MMIO_VFUNCS
  1099. #undef ASSIGN_READ_MMIO_VFUNCS
  1100. void intel_uncore_fini(struct drm_device *dev)
  1101. {
  1102. /* Paranoia: make sure we have disabled everything before we exit. */
  1103. intel_uncore_sanitize(dev);
  1104. intel_uncore_forcewake_reset(dev, false);
  1105. }
  1106. #define GEN_RANGE(l, h) GENMASK(h, l)
  1107. static const struct register_whitelist {
  1108. i915_reg_t offset_ldw, offset_udw;
  1109. uint32_t size;
  1110. /* supported gens, 0x10 for 4, 0x30 for 4 and 5, etc. */
  1111. uint32_t gen_bitmask;
  1112. } whitelist[] = {
  1113. { .offset_ldw = RING_TIMESTAMP(RENDER_RING_BASE),
  1114. .offset_udw = RING_TIMESTAMP_UDW(RENDER_RING_BASE),
  1115. .size = 8, .gen_bitmask = GEN_RANGE(4, 9) },
  1116. };
  1117. int i915_reg_read_ioctl(struct drm_device *dev,
  1118. void *data, struct drm_file *file)
  1119. {
  1120. struct drm_i915_private *dev_priv = dev->dev_private;
  1121. struct drm_i915_reg_read *reg = data;
  1122. struct register_whitelist const *entry = whitelist;
  1123. unsigned size;
  1124. i915_reg_t offset_ldw, offset_udw;
  1125. int i, ret = 0;
  1126. for (i = 0; i < ARRAY_SIZE(whitelist); i++, entry++) {
  1127. if (i915_mmio_reg_offset(entry->offset_ldw) == (reg->offset & -entry->size) &&
  1128. (1 << INTEL_INFO(dev)->gen & entry->gen_bitmask))
  1129. break;
  1130. }
  1131. if (i == ARRAY_SIZE(whitelist))
  1132. return -EINVAL;
  1133. /* We use the low bits to encode extra flags as the register should
  1134. * be naturally aligned (and those that are not so aligned merely
  1135. * limit the available flags for that register).
  1136. */
  1137. offset_ldw = entry->offset_ldw;
  1138. offset_udw = entry->offset_udw;
  1139. size = entry->size;
  1140. size |= reg->offset ^ i915_mmio_reg_offset(offset_ldw);
  1141. intel_runtime_pm_get(dev_priv);
  1142. switch (size) {
  1143. case 8 | 1:
  1144. reg->val = I915_READ64_2x32(offset_ldw, offset_udw);
  1145. break;
  1146. case 8:
  1147. reg->val = I915_READ64(offset_ldw);
  1148. break;
  1149. case 4:
  1150. reg->val = I915_READ(offset_ldw);
  1151. break;
  1152. case 2:
  1153. reg->val = I915_READ16(offset_ldw);
  1154. break;
  1155. case 1:
  1156. reg->val = I915_READ8(offset_ldw);
  1157. break;
  1158. default:
  1159. ret = -EINVAL;
  1160. goto out;
  1161. }
  1162. out:
  1163. intel_runtime_pm_put(dev_priv);
  1164. return ret;
  1165. }
  1166. int i915_get_reset_stats_ioctl(struct drm_device *dev,
  1167. void *data, struct drm_file *file)
  1168. {
  1169. struct drm_i915_private *dev_priv = dev->dev_private;
  1170. struct drm_i915_reset_stats *args = data;
  1171. struct i915_ctx_hang_stats *hs;
  1172. struct intel_context *ctx;
  1173. int ret;
  1174. if (args->flags || args->pad)
  1175. return -EINVAL;
  1176. if (args->ctx_id == DEFAULT_CONTEXT_HANDLE && !capable(CAP_SYS_ADMIN))
  1177. return -EPERM;
  1178. ret = mutex_lock_interruptible(&dev->struct_mutex);
  1179. if (ret)
  1180. return ret;
  1181. ctx = i915_gem_context_get(file->driver_priv, args->ctx_id);
  1182. if (IS_ERR(ctx)) {
  1183. mutex_unlock(&dev->struct_mutex);
  1184. return PTR_ERR(ctx);
  1185. }
  1186. hs = &ctx->hang_stats;
  1187. if (capable(CAP_SYS_ADMIN))
  1188. args->reset_count = i915_reset_count(&dev_priv->gpu_error);
  1189. else
  1190. args->reset_count = 0;
  1191. args->batch_active = hs->batch_active;
  1192. args->batch_pending = hs->batch_pending;
  1193. mutex_unlock(&dev->struct_mutex);
  1194. return 0;
  1195. }
  1196. static int i915_reset_complete(struct drm_device *dev)
  1197. {
  1198. u8 gdrst;
  1199. pci_read_config_byte(dev->pdev, I915_GDRST, &gdrst);
  1200. return (gdrst & GRDOM_RESET_STATUS) == 0;
  1201. }
  1202. static int i915_do_reset(struct drm_device *dev)
  1203. {
  1204. /* assert reset for at least 20 usec */
  1205. pci_write_config_byte(dev->pdev, I915_GDRST, GRDOM_RESET_ENABLE);
  1206. udelay(20);
  1207. pci_write_config_byte(dev->pdev, I915_GDRST, 0);
  1208. return wait_for(i915_reset_complete(dev), 500);
  1209. }
  1210. static int g4x_reset_complete(struct drm_device *dev)
  1211. {
  1212. u8 gdrst;
  1213. pci_read_config_byte(dev->pdev, I915_GDRST, &gdrst);
  1214. return (gdrst & GRDOM_RESET_ENABLE) == 0;
  1215. }
  1216. static int g33_do_reset(struct drm_device *dev)
  1217. {
  1218. pci_write_config_byte(dev->pdev, I915_GDRST, GRDOM_RESET_ENABLE);
  1219. return wait_for(g4x_reset_complete(dev), 500);
  1220. }
  1221. static int g4x_do_reset(struct drm_device *dev)
  1222. {
  1223. struct drm_i915_private *dev_priv = dev->dev_private;
  1224. int ret;
  1225. pci_write_config_byte(dev->pdev, I915_GDRST,
  1226. GRDOM_RENDER | GRDOM_RESET_ENABLE);
  1227. ret = wait_for(g4x_reset_complete(dev), 500);
  1228. if (ret)
  1229. return ret;
  1230. /* WaVcpClkGateDisableForMediaReset:ctg,elk */
  1231. I915_WRITE(VDECCLK_GATE_D, I915_READ(VDECCLK_GATE_D) | VCP_UNIT_CLOCK_GATE_DISABLE);
  1232. POSTING_READ(VDECCLK_GATE_D);
  1233. pci_write_config_byte(dev->pdev, I915_GDRST,
  1234. GRDOM_MEDIA | GRDOM_RESET_ENABLE);
  1235. ret = wait_for(g4x_reset_complete(dev), 500);
  1236. if (ret)
  1237. return ret;
  1238. /* WaVcpClkGateDisableForMediaReset:ctg,elk */
  1239. I915_WRITE(VDECCLK_GATE_D, I915_READ(VDECCLK_GATE_D) & ~VCP_UNIT_CLOCK_GATE_DISABLE);
  1240. POSTING_READ(VDECCLK_GATE_D);
  1241. pci_write_config_byte(dev->pdev, I915_GDRST, 0);
  1242. return 0;
  1243. }
  1244. static int ironlake_do_reset(struct drm_device *dev)
  1245. {
  1246. struct drm_i915_private *dev_priv = dev->dev_private;
  1247. int ret;
  1248. I915_WRITE(ILK_GDSR,
  1249. ILK_GRDOM_RENDER | ILK_GRDOM_RESET_ENABLE);
  1250. ret = wait_for((I915_READ(ILK_GDSR) &
  1251. ILK_GRDOM_RESET_ENABLE) == 0, 500);
  1252. if (ret)
  1253. return ret;
  1254. I915_WRITE(ILK_GDSR,
  1255. ILK_GRDOM_MEDIA | ILK_GRDOM_RESET_ENABLE);
  1256. ret = wait_for((I915_READ(ILK_GDSR) &
  1257. ILK_GRDOM_RESET_ENABLE) == 0, 500);
  1258. if (ret)
  1259. return ret;
  1260. I915_WRITE(ILK_GDSR, 0);
  1261. return 0;
  1262. }
  1263. static int gen6_do_reset(struct drm_device *dev)
  1264. {
  1265. struct drm_i915_private *dev_priv = dev->dev_private;
  1266. int ret;
  1267. /* Reset the chip */
  1268. /* GEN6_GDRST is not in the gt power well, no need to check
  1269. * for fifo space for the write or forcewake the chip for
  1270. * the read
  1271. */
  1272. __raw_i915_write32(dev_priv, GEN6_GDRST, GEN6_GRDOM_FULL);
  1273. /* Spin waiting for the device to ack the reset request */
  1274. ret = wait_for((__raw_i915_read32(dev_priv, GEN6_GDRST) & GEN6_GRDOM_FULL) == 0, 500);
  1275. intel_uncore_forcewake_reset(dev, true);
  1276. return ret;
  1277. }
  1278. static int wait_for_register(struct drm_i915_private *dev_priv,
  1279. i915_reg_t reg,
  1280. const u32 mask,
  1281. const u32 value,
  1282. const unsigned long timeout_ms)
  1283. {
  1284. return wait_for((I915_READ(reg) & mask) == value, timeout_ms);
  1285. }
  1286. static int gen8_do_reset(struct drm_device *dev)
  1287. {
  1288. struct drm_i915_private *dev_priv = dev->dev_private;
  1289. struct intel_engine_cs *engine;
  1290. int i;
  1291. for_each_ring(engine, dev_priv, i) {
  1292. I915_WRITE(RING_RESET_CTL(engine->mmio_base),
  1293. _MASKED_BIT_ENABLE(RESET_CTL_REQUEST_RESET));
  1294. if (wait_for_register(dev_priv,
  1295. RING_RESET_CTL(engine->mmio_base),
  1296. RESET_CTL_READY_TO_RESET,
  1297. RESET_CTL_READY_TO_RESET,
  1298. 700)) {
  1299. DRM_ERROR("%s: reset request timeout\n", engine->name);
  1300. goto not_ready;
  1301. }
  1302. }
  1303. return gen6_do_reset(dev);
  1304. not_ready:
  1305. for_each_ring(engine, dev_priv, i)
  1306. I915_WRITE(RING_RESET_CTL(engine->mmio_base),
  1307. _MASKED_BIT_DISABLE(RESET_CTL_REQUEST_RESET));
  1308. return -EIO;
  1309. }
  1310. static int (*intel_get_gpu_reset(struct drm_device *dev))(struct drm_device *)
  1311. {
  1312. if (!i915.reset)
  1313. return NULL;
  1314. if (INTEL_INFO(dev)->gen >= 8)
  1315. return gen8_do_reset;
  1316. else if (INTEL_INFO(dev)->gen >= 6)
  1317. return gen6_do_reset;
  1318. else if (IS_GEN5(dev))
  1319. return ironlake_do_reset;
  1320. else if (IS_G4X(dev))
  1321. return g4x_do_reset;
  1322. else if (IS_G33(dev))
  1323. return g33_do_reset;
  1324. else if (INTEL_INFO(dev)->gen >= 3)
  1325. return i915_do_reset;
  1326. else
  1327. return NULL;
  1328. }
  1329. int intel_gpu_reset(struct drm_device *dev)
  1330. {
  1331. struct drm_i915_private *dev_priv = to_i915(dev);
  1332. int (*reset)(struct drm_device *);
  1333. int ret;
  1334. reset = intel_get_gpu_reset(dev);
  1335. if (reset == NULL)
  1336. return -ENODEV;
  1337. /* If the power well sleeps during the reset, the reset
  1338. * request may be dropped and never completes (causing -EIO).
  1339. */
  1340. intel_uncore_forcewake_get(dev_priv, FORCEWAKE_ALL);
  1341. ret = reset(dev);
  1342. intel_uncore_forcewake_put(dev_priv, FORCEWAKE_ALL);
  1343. return ret;
  1344. }
  1345. bool intel_has_gpu_reset(struct drm_device *dev)
  1346. {
  1347. return intel_get_gpu_reset(dev) != NULL;
  1348. }
  1349. bool intel_uncore_unclaimed_mmio(struct drm_i915_private *dev_priv)
  1350. {
  1351. return check_for_unclaimed_mmio(dev_priv);
  1352. }
  1353. bool
  1354. intel_uncore_arm_unclaimed_mmio_detection(struct drm_i915_private *dev_priv)
  1355. {
  1356. if (unlikely(i915.mmio_debug ||
  1357. dev_priv->uncore.unclaimed_mmio_check <= 0))
  1358. return false;
  1359. if (unlikely(intel_uncore_unclaimed_mmio(dev_priv))) {
  1360. DRM_DEBUG("Unclaimed register detected, "
  1361. "enabling oneshot unclaimed register reporting. "
  1362. "Please use i915.mmio_debug=N for more information.\n");
  1363. i915.mmio_debug++;
  1364. dev_priv->uncore.unclaimed_mmio_check--;
  1365. return true;
  1366. }
  1367. return false;
  1368. }