Branch data Line data Source code
1 : : /*
2 : : * SPDX-License-Identifier: MIT
3 : : *
4 : : * Copyright © 2019 Intel Corporation
5 : : */
6 : :
7 : : #include <linux/sched/clock.h>
8 : :
9 : : #include "i915_drv.h"
10 : : #include "i915_irq.h"
11 : : #include "intel_gt.h"
12 : : #include "intel_gt_irq.h"
13 : : #include "intel_uncore.h"
14 : : #include "intel_rps.h"
15 : :
16 : 0 : static void guc_irq_handler(struct intel_guc *guc, u16 iir)
17 : : {
18 : 0 : if (iir & GUC_INTR_GUC2HOST)
19 : 0 : intel_guc_to_host_event_handler(guc);
20 : : }
21 : :
22 : : static void
23 : 0 : cs_irq_handler(struct intel_engine_cs *engine, u32 iir)
24 : : {
25 : 0 : bool tasklet = false;
26 : :
27 [ # # ]: 0 : if (iir & GT_CONTEXT_SWITCH_INTERRUPT)
28 : 0 : tasklet = true;
29 : :
30 [ # # ]: 0 : if (iir & GT_RENDER_USER_INTERRUPT) {
31 : 0 : intel_engine_signal_breadcrumbs(engine);
32 : 0 : tasklet |= intel_engine_needs_breadcrumb_tasklet(engine);
33 : : }
34 : :
35 [ # # ]: 0 : if (tasklet)
36 : 0 : tasklet_hi_schedule(&engine->execlists.tasklet);
37 : 0 : }
38 : :
39 : : static u32
40 : : gen11_gt_engine_identity(struct intel_gt *gt,
41 : : const unsigned int bank, const unsigned int bit)
42 : : {
43 : : void __iomem * const regs = gt->uncore->regs;
44 : : u32 timeout_ts;
45 : : u32 ident;
46 : :
47 : : lockdep_assert_held(>->irq_lock);
48 : :
49 : : raw_reg_write(regs, GEN11_IIR_REG_SELECTOR(bank), BIT(bit));
50 : :
51 : : /*
52 : : * NB: Specs do not specify how long to spin wait,
53 : : * so we do ~100us as an educated guess.
54 : : */
55 : : timeout_ts = (local_clock() >> 10) + 100;
56 : : do {
57 : : ident = raw_reg_read(regs, GEN11_INTR_IDENTITY_REG(bank));
58 : : } while (!(ident & GEN11_INTR_DATA_VALID) &&
59 : : !time_after32(local_clock() >> 10, timeout_ts));
60 : :
61 : : if (unlikely(!(ident & GEN11_INTR_DATA_VALID))) {
62 : : DRM_ERROR("INTR_IDENTITY_REG%u:%u 0x%08x not valid!\n",
63 : : bank, bit, ident);
64 : : return 0;
65 : : }
66 : :
67 : : raw_reg_write(regs, GEN11_INTR_IDENTITY_REG(bank),
68 : : GEN11_INTR_DATA_VALID);
69 : :
70 : : return ident;
71 : : }
72 : :
73 : : static void
74 : 0 : gen11_other_irq_handler(struct intel_gt *gt, const u8 instance,
75 : : const u16 iir)
76 : : {
77 [ # # ]: 0 : if (instance == OTHER_GUC_INSTANCE)
78 [ # # ]: 0 : return guc_irq_handler(>->uc.guc, iir);
79 : :
80 [ # # ]: 0 : if (instance == OTHER_GTPM_INSTANCE)
81 : 0 : return gen11_rps_irq_handler(>->rps, iir);
82 : :
83 [ # # ]: 0 : WARN_ONCE(1, "unhandled other interrupt instance=0x%x, iir=0x%x\n",
84 : : instance, iir);
85 : : }
86 : :
87 : : static void
88 : 0 : gen11_engine_irq_handler(struct intel_gt *gt, const u8 class,
89 : : const u8 instance, const u16 iir)
90 : : {
91 : 0 : struct intel_engine_cs *engine;
92 : :
93 [ # # ]: 0 : if (instance <= MAX_ENGINE_INSTANCE)
94 : 0 : engine = gt->engine_class[class][instance];
95 : : else
96 : : engine = NULL;
97 : :
98 [ # # ]: 0 : if (likely(engine))
99 : 0 : return cs_irq_handler(engine, iir);
100 : :
101 [ # # ]: 0 : WARN_ONCE(1, "unhandled engine interrupt class=0x%x, instance=0x%x\n",
102 : : class, instance);
103 : : }
104 : :
105 : : static void
106 : 0 : gen11_gt_identity_handler(struct intel_gt *gt, const u32 identity)
107 : : {
108 : 0 : const u8 class = GEN11_INTR_ENGINE_CLASS(identity);
109 : 0 : const u8 instance = GEN11_INTR_ENGINE_INSTANCE(identity);
110 : 0 : const u16 intr = GEN11_INTR_ENGINE_INTR(identity);
111 : :
112 [ # # ]: 0 : if (unlikely(!intr))
113 : : return;
114 : :
115 [ # # ]: 0 : if (class <= COPY_ENGINE_CLASS)
116 : 0 : return gen11_engine_irq_handler(gt, class, instance, intr);
117 : :
118 [ # # ]: 0 : if (class == OTHER_CLASS)
119 : 0 : return gen11_other_irq_handler(gt, instance, intr);
120 : :
121 [ # # ]: 0 : WARN_ONCE(1, "unknown interrupt class=0x%x, instance=0x%x, intr=0x%x\n",
122 : : class, instance, intr);
123 : : }
124 : :
125 : : static void
126 : 0 : gen11_gt_bank_handler(struct intel_gt *gt, const unsigned int bank)
127 : : {
128 : 0 : void __iomem * const regs = gt->uncore->regs;
129 : 0 : unsigned long intr_dw;
130 : 0 : unsigned int bit;
131 : :
132 : 0 : lockdep_assert_held(>->irq_lock);
133 : :
134 : 0 : intr_dw = raw_reg_read(regs, GEN11_GT_INTR_DW(bank));
135 : :
136 [ # # ]: 0 : for_each_set_bit(bit, &intr_dw, 32) {
137 : 0 : const u32 ident = gen11_gt_engine_identity(gt, bank, bit);
138 : :
139 : 0 : gen11_gt_identity_handler(gt, ident);
140 : : }
141 : :
142 : : /* Clear must be after shared has been served for engine */
143 : 0 : raw_reg_write(regs, GEN11_GT_INTR_DW(bank), intr_dw);
144 : 0 : }
145 : :
146 : 0 : void gen11_gt_irq_handler(struct intel_gt *gt, const u32 master_ctl)
147 : : {
148 : 0 : unsigned int bank;
149 : :
150 : 0 : spin_lock(>->irq_lock);
151 : :
152 [ # # ]: 0 : for (bank = 0; bank < 2; bank++) {
153 [ # # ]: 0 : if (master_ctl & GEN11_GT_DW_IRQ(bank))
154 : 0 : gen11_gt_bank_handler(gt, bank);
155 : : }
156 : :
157 : 0 : spin_unlock(>->irq_lock);
158 : 0 : }
159 : :
160 : 0 : bool gen11_gt_reset_one_iir(struct intel_gt *gt,
161 : : const unsigned int bank, const unsigned int bit)
162 : : {
163 : 0 : void __iomem * const regs = gt->uncore->regs;
164 : 0 : u32 dw;
165 : :
166 : 0 : lockdep_assert_held(>->irq_lock);
167 : :
168 : 0 : dw = raw_reg_read(regs, GEN11_GT_INTR_DW(bank));
169 [ # # ]: 0 : if (dw & BIT(bit)) {
170 : : /*
171 : : * According to the BSpec, DW_IIR bits cannot be cleared without
172 : : * first servicing the Selector & Shared IIR registers.
173 : : */
174 : 0 : gen11_gt_engine_identity(gt, bank, bit);
175 : :
176 : : /*
177 : : * We locked GT INT DW by reading it. If we want to (try
178 : : * to) recover from this successfully, we need to clear
179 : : * our bit, otherwise we are locking the register for
180 : : * everybody.
181 : : */
182 : 0 : raw_reg_write(regs, GEN11_GT_INTR_DW(bank), BIT(bit));
183 : :
184 : 0 : return true;
185 : : }
186 : :
187 : : return false;
188 : : }
189 : :
190 : 0 : void gen11_gt_irq_reset(struct intel_gt *gt)
191 : : {
192 : 0 : struct intel_uncore *uncore = gt->uncore;
193 : :
194 : : /* Disable RCS, BCS, VCS and VECS class engines. */
195 : 0 : intel_uncore_write(uncore, GEN11_RENDER_COPY_INTR_ENABLE, 0);
196 : 0 : intel_uncore_write(uncore, GEN11_VCS_VECS_INTR_ENABLE, 0);
197 : :
198 : : /* Restore masks irqs on RCS, BCS, VCS and VECS engines. */
199 : 0 : intel_uncore_write(uncore, GEN11_RCS0_RSVD_INTR_MASK, ~0);
200 : 0 : intel_uncore_write(uncore, GEN11_BCS_RSVD_INTR_MASK, ~0);
201 : 0 : intel_uncore_write(uncore, GEN11_VCS0_VCS1_INTR_MASK, ~0);
202 : 0 : intel_uncore_write(uncore, GEN11_VCS2_VCS3_INTR_MASK, ~0);
203 : 0 : intel_uncore_write(uncore, GEN11_VECS0_VECS1_INTR_MASK, ~0);
204 : :
205 : 0 : intel_uncore_write(uncore, GEN11_GPM_WGBOXPERF_INTR_ENABLE, 0);
206 : 0 : intel_uncore_write(uncore, GEN11_GPM_WGBOXPERF_INTR_MASK, ~0);
207 : 0 : intel_uncore_write(uncore, GEN11_GUC_SG_INTR_ENABLE, 0);
208 : 0 : intel_uncore_write(uncore, GEN11_GUC_SG_INTR_MASK, ~0);
209 : 0 : }
210 : :
211 : 0 : void gen11_gt_irq_postinstall(struct intel_gt *gt)
212 : : {
213 : 0 : const u32 irqs = GT_RENDER_USER_INTERRUPT | GT_CONTEXT_SWITCH_INTERRUPT;
214 : 0 : struct intel_uncore *uncore = gt->uncore;
215 : 0 : const u32 dmask = irqs << 16 | irqs;
216 : 0 : const u32 smask = irqs << 16;
217 : :
218 : 0 : BUILD_BUG_ON(irqs & 0xffff0000);
219 : :
220 : : /* Enable RCS, BCS, VCS and VECS class interrupts. */
221 : 0 : intel_uncore_write(uncore, GEN11_RENDER_COPY_INTR_ENABLE, dmask);
222 : 0 : intel_uncore_write(uncore, GEN11_VCS_VECS_INTR_ENABLE, dmask);
223 : :
224 : : /* Unmask irqs on RCS, BCS, VCS and VECS engines. */
225 : 0 : intel_uncore_write(uncore, GEN11_RCS0_RSVD_INTR_MASK, ~smask);
226 : 0 : intel_uncore_write(uncore, GEN11_BCS_RSVD_INTR_MASK, ~smask);
227 : 0 : intel_uncore_write(uncore, GEN11_VCS0_VCS1_INTR_MASK, ~dmask);
228 : 0 : intel_uncore_write(uncore, GEN11_VCS2_VCS3_INTR_MASK, ~dmask);
229 : 0 : intel_uncore_write(uncore, GEN11_VECS0_VECS1_INTR_MASK, ~dmask);
230 : :
231 : : /*
232 : : * RPS interrupts will get enabled/disabled on demand when RPS itself
233 : : * is enabled/disabled.
234 : : */
235 : 0 : gt->pm_ier = 0x0;
236 : 0 : gt->pm_imr = ~gt->pm_ier;
237 : 0 : intel_uncore_write(uncore, GEN11_GPM_WGBOXPERF_INTR_ENABLE, 0);
238 : 0 : intel_uncore_write(uncore, GEN11_GPM_WGBOXPERF_INTR_MASK, ~0);
239 : :
240 : : /* Same thing for GuC interrupts */
241 : 0 : intel_uncore_write(uncore, GEN11_GUC_SG_INTR_ENABLE, 0);
242 : 0 : intel_uncore_write(uncore, GEN11_GUC_SG_INTR_MASK, ~0);
243 : 0 : }
244 : :
245 : 0 : void gen5_gt_irq_handler(struct intel_gt *gt, u32 gt_iir)
246 : : {
247 [ # # ]: 0 : if (gt_iir & GT_RENDER_USER_INTERRUPT)
248 : 0 : intel_engine_signal_breadcrumbs(gt->engine_class[RENDER_CLASS][0]);
249 [ # # ]: 0 : if (gt_iir & ILK_BSD_USER_INTERRUPT)
250 : 0 : intel_engine_signal_breadcrumbs(gt->engine_class[VIDEO_DECODE_CLASS][0]);
251 : 0 : }
252 : :
253 : 0 : static void gen7_parity_error_irq_handler(struct intel_gt *gt, u32 iir)
254 : : {
255 [ # # ]: 0 : if (!HAS_L3_DPF(gt->i915))
256 : : return;
257 : :
258 : 0 : spin_lock(>->irq_lock);
259 [ # # ]: 0 : gen5_gt_disable_irq(gt, GT_PARITY_ERROR(gt->i915));
260 : 0 : spin_unlock(>->irq_lock);
261 : :
262 [ # # ]: 0 : if (iir & GT_RENDER_L3_PARITY_ERROR_INTERRUPT_S1)
263 : 0 : gt->i915->l3_parity.which_slice |= 1 << 1;
264 : :
265 [ # # ]: 0 : if (iir & GT_RENDER_L3_PARITY_ERROR_INTERRUPT)
266 : 0 : gt->i915->l3_parity.which_slice |= 1 << 0;
267 : :
268 : 0 : schedule_work(>->i915->l3_parity.error_work);
269 : : }
270 : :
271 : 0 : void gen6_gt_irq_handler(struct intel_gt *gt, u32 gt_iir)
272 : : {
273 [ # # ]: 0 : if (gt_iir & GT_RENDER_USER_INTERRUPT)
274 : 0 : intel_engine_signal_breadcrumbs(gt->engine_class[RENDER_CLASS][0]);
275 [ # # ]: 0 : if (gt_iir & GT_BSD_USER_INTERRUPT)
276 : 0 : intel_engine_signal_breadcrumbs(gt->engine_class[VIDEO_DECODE_CLASS][0]);
277 [ # # ]: 0 : if (gt_iir & GT_BLT_USER_INTERRUPT)
278 : 0 : intel_engine_signal_breadcrumbs(gt->engine_class[COPY_ENGINE_CLASS][0]);
279 : :
280 [ # # ]: 0 : if (gt_iir & (GT_BLT_CS_ERROR_INTERRUPT |
281 : : GT_BSD_CS_ERROR_INTERRUPT |
282 : : GT_RENDER_CS_MASTER_ERROR_INTERRUPT))
283 : 0 : DRM_DEBUG("Command parser error, gt_iir 0x%08x\n", gt_iir);
284 : :
285 [ # # # # ]: 0 : if (gt_iir & GT_PARITY_ERROR(gt->i915))
286 : 0 : gen7_parity_error_irq_handler(gt, gt_iir);
287 : 0 : }
288 : :
289 : 0 : void gen8_gt_irq_ack(struct intel_gt *gt, u32 master_ctl, u32 gt_iir[4])
290 : : {
291 : 0 : void __iomem * const regs = gt->uncore->regs;
292 : :
293 [ # # ]: 0 : if (master_ctl & (GEN8_GT_RCS_IRQ | GEN8_GT_BCS_IRQ)) {
294 : 0 : gt_iir[0] = raw_reg_read(regs, GEN8_GT_IIR(0));
295 [ # # ]: 0 : if (likely(gt_iir[0]))
296 : 0 : raw_reg_write(regs, GEN8_GT_IIR(0), gt_iir[0]);
297 : : }
298 : :
299 [ # # ]: 0 : if (master_ctl & (GEN8_GT_VCS0_IRQ | GEN8_GT_VCS1_IRQ)) {
300 : 0 : gt_iir[1] = raw_reg_read(regs, GEN8_GT_IIR(1));
301 [ # # ]: 0 : if (likely(gt_iir[1]))
302 : 0 : raw_reg_write(regs, GEN8_GT_IIR(1), gt_iir[1]);
303 : : }
304 : :
305 [ # # ]: 0 : if (master_ctl & (GEN8_GT_PM_IRQ | GEN8_GT_GUC_IRQ)) {
306 : 0 : gt_iir[2] = raw_reg_read(regs, GEN8_GT_IIR(2));
307 [ # # ]: 0 : if (likely(gt_iir[2]))
308 : 0 : raw_reg_write(regs, GEN8_GT_IIR(2), gt_iir[2]);
309 : : }
310 : :
311 [ # # ]: 0 : if (master_ctl & GEN8_GT_VECS_IRQ) {
312 : 0 : gt_iir[3] = raw_reg_read(regs, GEN8_GT_IIR(3));
313 [ # # ]: 0 : if (likely(gt_iir[3]))
314 : 0 : raw_reg_write(regs, GEN8_GT_IIR(3), gt_iir[3]);
315 : : }
316 : 0 : }
317 : :
318 : 0 : void gen8_gt_irq_handler(struct intel_gt *gt, u32 master_ctl, u32 gt_iir[4])
319 : : {
320 [ # # ]: 0 : if (master_ctl & (GEN8_GT_RCS_IRQ | GEN8_GT_BCS_IRQ)) {
321 : 0 : cs_irq_handler(gt->engine_class[RENDER_CLASS][0],
322 : : gt_iir[0] >> GEN8_RCS_IRQ_SHIFT);
323 : 0 : cs_irq_handler(gt->engine_class[COPY_ENGINE_CLASS][0],
324 : 0 : gt_iir[0] >> GEN8_BCS_IRQ_SHIFT);
325 : : }
326 : :
327 [ # # ]: 0 : if (master_ctl & (GEN8_GT_VCS0_IRQ | GEN8_GT_VCS1_IRQ)) {
328 : 0 : cs_irq_handler(gt->engine_class[VIDEO_DECODE_CLASS][0],
329 : : gt_iir[1] >> GEN8_VCS0_IRQ_SHIFT);
330 : 0 : cs_irq_handler(gt->engine_class[VIDEO_DECODE_CLASS][1],
331 : 0 : gt_iir[1] >> GEN8_VCS1_IRQ_SHIFT);
332 : : }
333 : :
334 [ # # ]: 0 : if (master_ctl & GEN8_GT_VECS_IRQ) {
335 : 0 : cs_irq_handler(gt->engine_class[VIDEO_ENHANCEMENT_CLASS][0],
336 : : gt_iir[3] >> GEN8_VECS_IRQ_SHIFT);
337 : : }
338 : :
339 [ # # ]: 0 : if (master_ctl & (GEN8_GT_PM_IRQ | GEN8_GT_GUC_IRQ)) {
340 : 0 : gen6_rps_irq_handler(>->rps, gt_iir[2]);
341 [ # # ]: 0 : guc_irq_handler(>->uc.guc, gt_iir[2] >> 16);
342 : : }
343 : 0 : }
344 : :
345 : 0 : void gen8_gt_irq_reset(struct intel_gt *gt)
346 : : {
347 : 0 : struct intel_uncore *uncore = gt->uncore;
348 : :
349 : 0 : GEN8_IRQ_RESET_NDX(uncore, GT, 0);
350 : 0 : GEN8_IRQ_RESET_NDX(uncore, GT, 1);
351 : 0 : GEN8_IRQ_RESET_NDX(uncore, GT, 2);
352 : 0 : GEN8_IRQ_RESET_NDX(uncore, GT, 3);
353 : 0 : }
354 : :
355 : 0 : void gen8_gt_irq_postinstall(struct intel_gt *gt)
356 : : {
357 : 0 : struct intel_uncore *uncore = gt->uncore;
358 : :
359 : : /* These are interrupts we'll toggle with the ring mask register */
360 : 0 : u32 gt_interrupts[] = {
361 : : (GT_RENDER_USER_INTERRUPT << GEN8_RCS_IRQ_SHIFT |
362 : : GT_CONTEXT_SWITCH_INTERRUPT << GEN8_RCS_IRQ_SHIFT |
363 : : GT_RENDER_USER_INTERRUPT << GEN8_BCS_IRQ_SHIFT |
364 : : GT_CONTEXT_SWITCH_INTERRUPT << GEN8_BCS_IRQ_SHIFT),
365 : :
366 : : (GT_RENDER_USER_INTERRUPT << GEN8_VCS0_IRQ_SHIFT |
367 : : GT_CONTEXT_SWITCH_INTERRUPT << GEN8_VCS0_IRQ_SHIFT |
368 : : GT_RENDER_USER_INTERRUPT << GEN8_VCS1_IRQ_SHIFT |
369 : : GT_CONTEXT_SWITCH_INTERRUPT << GEN8_VCS1_IRQ_SHIFT),
370 : :
371 : : 0,
372 : :
373 : : (GT_RENDER_USER_INTERRUPT << GEN8_VECS_IRQ_SHIFT |
374 : : GT_CONTEXT_SWITCH_INTERRUPT << GEN8_VECS_IRQ_SHIFT)
375 : : };
376 : :
377 : 0 : gt->pm_ier = 0x0;
378 : 0 : gt->pm_imr = ~gt->pm_ier;
379 : 0 : GEN8_IRQ_INIT_NDX(uncore, GT, 0, ~gt_interrupts[0], gt_interrupts[0]);
380 : 0 : GEN8_IRQ_INIT_NDX(uncore, GT, 1, ~gt_interrupts[1], gt_interrupts[1]);
381 : : /*
382 : : * RPS interrupts will get enabled/disabled on demand when RPS itself
383 : : * is enabled/disabled. Same wil be the case for GuC interrupts.
384 : : */
385 : 0 : GEN8_IRQ_INIT_NDX(uncore, GT, 2, gt->pm_imr, gt->pm_ier);
386 : 0 : GEN8_IRQ_INIT_NDX(uncore, GT, 3, ~gt_interrupts[3], gt_interrupts[3]);
387 : 0 : }
388 : :
389 : 0 : static void gen5_gt_update_irq(struct intel_gt *gt,
390 : : u32 interrupt_mask,
391 : : u32 enabled_irq_mask)
392 : : {
393 : 0 : lockdep_assert_held(>->irq_lock);
394 : :
395 : 0 : GEM_BUG_ON(enabled_irq_mask & ~interrupt_mask);
396 : :
397 : 0 : gt->gt_imr &= ~interrupt_mask;
398 : 0 : gt->gt_imr |= (~enabled_irq_mask & interrupt_mask);
399 : 0 : intel_uncore_write(gt->uncore, GTIMR, gt->gt_imr);
400 : : }
401 : :
402 : 0 : void gen5_gt_enable_irq(struct intel_gt *gt, u32 mask)
403 : : {
404 : 0 : gen5_gt_update_irq(gt, mask, mask);
405 : 0 : intel_uncore_posting_read_fw(gt->uncore, GTIMR);
406 : 0 : }
407 : :
408 : 0 : void gen5_gt_disable_irq(struct intel_gt *gt, u32 mask)
409 : : {
410 : 0 : gen5_gt_update_irq(gt, mask, 0);
411 : 0 : }
412 : :
413 : 0 : void gen5_gt_irq_reset(struct intel_gt *gt)
414 : : {
415 : 0 : struct intel_uncore *uncore = gt->uncore;
416 : :
417 : 0 : GEN3_IRQ_RESET(uncore, GT);
418 [ # # ]: 0 : if (INTEL_GEN(gt->i915) >= 6)
419 : 0 : GEN3_IRQ_RESET(uncore, GEN6_PM);
420 : 0 : }
421 : :
422 : 0 : void gen5_gt_irq_postinstall(struct intel_gt *gt)
423 : : {
424 : 0 : struct intel_uncore *uncore = gt->uncore;
425 : 0 : u32 pm_irqs = 0;
426 : 0 : u32 gt_irqs = 0;
427 : :
428 : 0 : gt->gt_imr = ~0;
429 [ # # ]: 0 : if (HAS_L3_DPF(gt->i915)) {
430 : : /* L3 parity interrupt is always unmasked. */
431 [ # # ]: 0 : gt->gt_imr = ~GT_PARITY_ERROR(gt->i915);
432 [ # # ]: 0 : gt_irqs |= GT_PARITY_ERROR(gt->i915);
433 : : }
434 : :
435 : 0 : gt_irqs |= GT_RENDER_USER_INTERRUPT;
436 [ # # ]: 0 : if (IS_GEN(gt->i915, 5))
437 : 0 : gt_irqs |= ILK_BSD_USER_INTERRUPT;
438 : : else
439 : 0 : gt_irqs |= GT_BLT_USER_INTERRUPT | GT_BSD_USER_INTERRUPT;
440 : :
441 : 0 : GEN3_IRQ_INIT(uncore, GT, gt->gt_imr, gt_irqs);
442 : :
443 [ # # ]: 0 : if (INTEL_GEN(gt->i915) >= 6) {
444 : : /*
445 : : * RPS interrupts will get enabled/disabled on demand when RPS
446 : : * itself is enabled/disabled.
447 : : */
448 [ # # ]: 0 : if (HAS_ENGINE(gt->i915, VECS0)) {
449 : 0 : pm_irqs |= PM_VEBOX_USER_INTERRUPT;
450 : 0 : gt->pm_ier |= PM_VEBOX_USER_INTERRUPT;
451 : : }
452 : :
453 : 0 : gt->pm_imr = 0xffffffff;
454 : 0 : GEN3_IRQ_INIT(uncore, GEN6_PM, gt->pm_imr, pm_irqs);
455 : : }
456 : 0 : }
|