drm/i915: Move for_each_engine* out of i915_drv.h
authorTvrtko Ursulin <tvrtko.ursulin@intel.com>
Thu, 2 Nov 2023 09:32:48 +0000 (09:32 +0000)
committerTvrtko Ursulin <tvrtko.ursulin@intel.com>
Mon, 6 Nov 2023 09:04:52 +0000 (09:04 +0000)
Iterators operate on struct intel_gt so lets move it to intel_gt.h in
order to make i915_drv.h less of a dumping ground for stuff.

Signed-off-by: Tvrtko Ursulin <tvrtko.ursulin@intel.com>
Suggested-by: Jani Nikula <jani.nikula@linux.intel.com>
Reviewed-by: Jani Nikula <jani.nikula@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20231102093248.362659-2-tvrtko.ursulin@linux.intel.com
drivers/gpu/drm/i915/gt/intel_engine_pm.h
drivers/gpu/drm/i915/gt/intel_gt.h
drivers/gpu/drm/i915/gt/intel_gt_engines_debugfs.c
drivers/gpu/drm/i915/i915_drv.h
drivers/gpu/drm/i915/selftests/intel_uncore.c

index d68675925b79e50a6931ed62f622d9be21dc4a01..1d97c435a01528404d6e8840c9ad1dbb792cc628 100644 (file)
@@ -10,6 +10,7 @@
 #include "i915_request.h"
 #include "intel_engine_types.h"
 #include "intel_wakeref.h"
+#include "intel_gt.h"
 #include "intel_gt_pm.h"
 
 static inline bool
index 2cac499d5aa3e57e15ffe7d90727e8a31253916e..df0f656c03626eba076bc7d79a7211694556ff08 100644 (file)
@@ -167,6 +167,20 @@ void intel_gt_release_all(struct drm_i915_private *i915);
             (id__)++) \
                for_each_if(((gt__) = (i915__)->gt[(id__)]))
 
+/* Simple iterator over all initialised engines */
+#define for_each_engine(engine__, gt__, id__) \
+       for ((id__) = 0; \
+            (id__) < I915_NUM_ENGINES; \
+            (id__)++) \
+               for_each_if ((engine__) = (gt__)->engine[(id__)])
+
+/* Iterator over subset of engines selected by mask */
+#define for_each_engine_masked(engine__, gt__, mask__, tmp__) \
+       for ((tmp__) = (mask__) & (gt__)->info.engine_mask; \
+            (tmp__) ? \
+            ((engine__) = (gt__)->engine[__mask_next_bit(tmp__)]), 1 : \
+            0;)
+
 void intel_gt_info_print(const struct intel_gt_info *info,
                         struct drm_printer *p);
 
index 8f9b874fdc9c80efb5896aabbf0cd3657780400c..3aa1d014c14dfe98f5eedcd408240f1b5be8349e 100644 (file)
@@ -6,8 +6,8 @@
 
 #include <drm/drm_print.h>
 
-#include "i915_drv.h" /* for_each_engine! */
 #include "intel_engine.h"
+#include "intel_gt.h"
 #include "intel_gt_debugfs.h"
 #include "intel_gt_engines_debugfs.h"
 
index 4352cdd13c44716217f9df1537f7b5859da34dca..739f43af9b3a72e47cb8c1ae9eefc8e67d7fd078 100644 (file)
@@ -381,20 +381,6 @@ static inline struct intel_gt *to_gt(const struct drm_i915_private *i915)
        return i915->gt[0];
 }
 
-/* Simple iterator over all initialised engines */
-#define for_each_engine(engine__, gt__, id__) \
-       for ((id__) = 0; \
-            (id__) < I915_NUM_ENGINES; \
-            (id__)++) \
-               for_each_if ((engine__) = (gt__)->engine[(id__)])
-
-/* Iterator over subset of engines selected by mask */
-#define for_each_engine_masked(engine__, gt__, mask__, tmp__) \
-       for ((tmp__) = (mask__) & (gt__)->info.engine_mask; \
-            (tmp__) ? \
-            ((engine__) = (gt__)->engine[__mask_next_bit(tmp__)]), 1 : \
-            0;)
-
 #define rb_to_uabi_engine(rb) \
        rb_entry_safe(rb, struct intel_engine_cs, uabi_node)
 
index 03ea75cd84dd5c3784b7bf018296262bff1d4e9c..4f98aa8a861ea7d4c4ae69ebd0386b93b99561b3 100644 (file)
@@ -24,6 +24,8 @@
 
 #include "../i915_selftest.h"
 
+#include "gt/intel_gt.h"
+
 static int intel_fw_table_check(const struct intel_forcewake_range *ranges,
                                unsigned int num_ranges,
                                bool is_watertight)