]> Git Repo - J-linux.git/blob - drivers/gpu/drm/xe/display/ext/i915_irq.c
Merge tag 'vfs-6.13-rc7.fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/vfs/vfs
[J-linux.git] / drivers / gpu / drm / xe / display / ext / i915_irq.c
1 // SPDX-License-Identifier: MIT
2 /*
3  * Copyright © 2023 Intel Corporation
4  */
5
6 #include "i915_irq.h"
7 #include "i915_reg.h"
8 #include "intel_uncore.h"
9
10 void gen2_irq_reset(struct intel_uncore *uncore, struct i915_irq_regs regs)
11 {
12         intel_uncore_write(uncore, regs.imr, 0xffffffff);
13         intel_uncore_posting_read(uncore, regs.imr);
14
15         intel_uncore_write(uncore, regs.ier, 0);
16
17         /* IIR can theoretically queue up two events. Be paranoid. */
18         intel_uncore_write(uncore, regs.iir, 0xffffffff);
19         intel_uncore_posting_read(uncore, regs.iir);
20         intel_uncore_write(uncore, regs.iir, 0xffffffff);
21         intel_uncore_posting_read(uncore, regs.iir);
22 }
23
24 /*
25  * We should clear IMR at preinstall/uninstall, and just check at postinstall.
26  */
27 void gen2_assert_iir_is_zero(struct intel_uncore *uncore, i915_reg_t reg)
28 {
29         struct xe_device *xe = container_of(uncore, struct xe_device, uncore);
30         u32 val = intel_uncore_read(uncore, reg);
31
32         if (val == 0)
33                 return;
34
35         drm_WARN(&xe->drm, 1,
36                  "Interrupt register 0x%x is not zero: 0x%08x\n",
37                  i915_mmio_reg_offset(reg), val);
38         intel_uncore_write(uncore, reg, 0xffffffff);
39         intel_uncore_posting_read(uncore, reg);
40         intel_uncore_write(uncore, reg, 0xffffffff);
41         intel_uncore_posting_read(uncore, reg);
42 }
43
44 void gen2_irq_init(struct intel_uncore *uncore, struct i915_irq_regs regs,
45                    u32 imr_val, u32 ier_val)
46 {
47         gen2_assert_iir_is_zero(uncore, regs.iir);
48
49         intel_uncore_write(uncore, regs.ier, ier_val);
50         intel_uncore_write(uncore, regs.imr, imr_val);
51         intel_uncore_posting_read(uncore, regs.imr);
52 }
53
54 bool intel_irqs_enabled(struct xe_device *xe)
55 {
56         /*
57          * XXX: i915 has a racy handling of the irq.enabled, since it doesn't
58          * lock its transitions. Because of that, the irq.enabled sometimes
59          * is not read with the irq.lock in place.
60          * However, the most critical cases like vblank and page flips are
61          * properly using the locks.
62          * We cannot take the lock in here or run any kind of assert because
63          * of i915 inconsistency.
64          * But at this point the xe irq is better protected against races,
65          * although the full solution would be protecting the i915 side.
66          */
67         return xe->irq.enabled;
68 }
69
70 void intel_synchronize_irq(struct xe_device *xe)
71 {
72         synchronize_irq(to_pci_dev(xe->drm.dev)->irq);
73 }
This page took 0.031735 seconds and 4 git commands to generate.