drm/i915: Implement for_each_sgt_daddr_next
authorjsg <jsg@openbsd.org>
Mon, 12 Aug 2024 23:42:15 +0000 (23:42 +0000)
committerjsg <jsg@openbsd.org>
Mon, 12 Aug 2024 23:42:15 +0000 (23:42 +0000)
From Nirmoy Das
0e514878486053363f8b2a806525fe67ae692827 in mainline linux

sys/dev/pci/drm/i915/gt/intel_gtt.h
sys/dev/pci/drm/i915/i915_scatterlist.h

index 9ace406..b8e5a5f 100644 (file)
@@ -171,6 +171,9 @@ struct intel_gt;
 #define for_each_sgt_daddr(__dp, __iter, __sgt) \
        __for_each_sgt_daddr(__dp, __iter, __sgt, I915_GTT_PAGE_SIZE)
 
+#define for_each_sgt_daddr_next(__dp, __iter) \
+       __for_each_daddr_next(__dp, __iter, I915_GTT_PAGE_SIZE)
+
 struct i915_page_table {
        struct drm_i915_gem_object *base;
        union {
index c552cc2..2331edb 100644 (file)
@@ -91,6 +91,16 @@ static inline struct scatterlist *__sg_next(struct scatterlist *sg)
             ((__dp) = (__iter).dma + (__iter).curr), (__iter).sgp;     \
             (((__iter).curr += (__step)) >= (__iter).max) ?            \
             (__iter) = __sgt_iter(__sg_next((__iter).sgp), true), 0 : 0)
+/**
+ * __for_each_daddr_next - iterates over the device addresses with pre-initialized iterator.
+ * @__dp:      Device address (output)
+ * @__iter:    'struct sgt_iter' (iterator state, external)
+ * @__step:    step size
+ */
+#define __for_each_daddr_next(__dp, __iter, __step)                  \
+       for (; ((__dp) = (__iter).dma + (__iter).curr), (__iter).sgp;   \
+            (((__iter).curr += (__step)) >= (__iter).max) ?            \
+            (__iter) = __sgt_iter(__sg_next((__iter).sgp), true), 0 : 0)
 
 /**
  * for_each_sgt_page - iterate over the pages of the given sg_table