|
@@ -2527,28 +2527,31 @@ struct drm_i915_cmd_table {
|
|
|
#define ALL_ENGINES (~0)
|
|
|
|
|
|
#define HAS_ENGINE(dev_priv, id) \
|
|
|
- (!!(INTEL_INFO(dev_priv)->ring_mask & ENGINE_MASK(id)))
|
|
|
+ (!!((dev_priv)->info.ring_mask & ENGINE_MASK(id)))
|
|
|
|
|
|
#define HAS_BSD(dev_priv) HAS_ENGINE(dev_priv, VCS)
|
|
|
#define HAS_BSD2(dev_priv) HAS_ENGINE(dev_priv, VCS2)
|
|
|
#define HAS_BLT(dev_priv) HAS_ENGINE(dev_priv, BCS)
|
|
|
#define HAS_VEBOX(dev_priv) HAS_ENGINE(dev_priv, VECS)
|
|
|
|
|
|
-#define HAS_LLC(dev) (INTEL_INFO(dev)->has_llc)
|
|
|
-#define HAS_SNOOP(dev) (INTEL_INFO(dev)->has_snoop)
|
|
|
-#define HAS_EDRAM(dev) (!!(__I915__(dev)->edram_cap & EDRAM_ENABLED))
|
|
|
+#define HAS_LLC(dev_priv) ((dev_priv)->info.has_llc)
|
|
|
+#define HAS_SNOOP(dev_priv) ((dev_priv)->info.has_snoop)
|
|
|
+#define HAS_EDRAM(dev_priv) (!!((dev_priv)->edram_cap & EDRAM_ENABLED))
|
|
|
#define HAS_WT(dev_priv) ((IS_HASWELL(dev_priv) || \
|
|
|
IS_BROADWELL(dev_priv)) && HAS_EDRAM(dev_priv))
|
|
|
-#define HWS_NEEDS_PHYSICAL(dev) (INTEL_INFO(dev)->hws_needs_physical)
|
|
|
|
|
|
-#define HAS_HW_CONTEXTS(dev) (INTEL_INFO(dev)->has_hw_contexts)
|
|
|
-#define HAS_LOGICAL_RING_CONTEXTS(dev) (INTEL_INFO(dev)->has_logical_ring_contexts)
|
|
|
-#define USES_PPGTT(dev) (i915.enable_ppgtt)
|
|
|
-#define USES_FULL_PPGTT(dev) (i915.enable_ppgtt >= 2)
|
|
|
-#define USES_FULL_48BIT_PPGTT(dev) (i915.enable_ppgtt == 3)
|
|
|
+#define HWS_NEEDS_PHYSICAL(dev_priv) ((dev_priv)->info.hws_needs_physical)
|
|
|
|
|
|
-#define HAS_OVERLAY(dev) (INTEL_INFO(dev)->has_overlay)
|
|
|
-#define OVERLAY_NEEDS_PHYSICAL(dev) (INTEL_INFO(dev)->overlay_needs_physical)
|
|
|
+#define HAS_HW_CONTEXTS(dev_priv) ((dev_priv)->info.has_hw_contexts)
|
|
|
+#define HAS_LOGICAL_RING_CONTEXTS(dev_priv) \
|
|
|
+ ((dev_priv)->info.has_logical_ring_contexts)
|
|
|
+#define USES_PPGTT(dev_priv) (i915.enable_ppgtt)
|
|
|
+#define USES_FULL_PPGTT(dev_priv) (i915.enable_ppgtt >= 2)
|
|
|
+#define USES_FULL_48BIT_PPGTT(dev_priv) (i915.enable_ppgtt == 3)
|
|
|
+
|
|
|
+#define HAS_OVERLAY(dev_priv) ((dev_priv)->info.has_overlay)
|
|
|
+#define OVERLAY_NEEDS_PHYSICAL(dev_priv) \
|
|
|
+ ((dev_priv)->info.overlay_needs_physical)
|
|
|
|
|
|
/* Early gen2 have a totally busted CS tlb and require pinned batches. */
|
|
|
#define HAS_BROKEN_CS_TLB(dev_priv) (IS_I830(dev_priv) || IS_845G(dev_priv))
|
|
@@ -2565,8 +2568,8 @@ struct drm_i915_cmd_table {
|
|
|
* legacy irq no. is shared with another device. The kernel then disables that
|
|
|
* interrupt source and so prevents the other device from working properly.
|
|
|
*/
|
|
|
-#define HAS_AUX_IRQ(dev) (INTEL_INFO(dev)->gen >= 5)
|
|
|
-#define HAS_GMBUS_IRQ(dev) (INTEL_INFO(dev)->has_gmbus_irq)
|
|
|
+#define HAS_AUX_IRQ(dev_priv) ((dev_priv)->info.gen >= 5)
|
|
|
+#define HAS_GMBUS_IRQ(dev_priv) ((dev_priv)->info.has_gmbus_irq)
|
|
|
|
|
|
/* With the 945 and later, Y tiling got adjusted so that it was 32 128-byte
|
|
|
* rows, which changed the alignment requirements and fence programming.
|