net: axienet: add missing memory barriers
[linux-2.6-microblaze.git] / drivers / dma-buf / dma-resv.c
index 9eb2baa..4deea75 100644 (file)
@@ -38,6 +38,7 @@
 #include <linux/mm.h>
 #include <linux/sched/mm.h>
 #include <linux/mmu_notifier.h>
+#include <linux/seq_file.h>
 
 /**
  * DOC: Reservation Object Overview
@@ -304,8 +305,7 @@ void dma_resv_add_excl_fence(struct dma_resv *obj, struct dma_fence *fence)
        if (old)
                i = old->shared_count;
 
-       if (fence)
-               dma_fence_get(fence);
+       dma_fence_get(fence);
 
        write_seqcount_begin(&obj->seq);
        /* write_seqcount_begin provides the necessary memory barrier */
@@ -666,6 +666,28 @@ bool dma_resv_test_signaled(struct dma_resv *obj, bool test_all)
 }
 EXPORT_SYMBOL_GPL(dma_resv_test_signaled);
 
+/**
+ * dma_resv_describe - Dump description of the resv object into seq_file
+ * @obj: the reservation object
+ * @seq: the seq_file to dump the description into
+ *
+ * Dump a textual description of the fences inside an dma_resv object into the
+ * seq_file.
+ */
+void dma_resv_describe(struct dma_resv *obj, struct seq_file *seq)
+{
+       struct dma_resv_iter cursor;
+       struct dma_fence *fence;
+
+       dma_resv_for_each_fence(&cursor, obj, true, fence) {
+               seq_printf(seq, "\t%s fence:",
+                          dma_resv_iter_is_exclusive(&cursor) ?
+                               "Exclusive" : "Shared");
+               dma_fence_describe(fence, seq);
+       }
+}
+EXPORT_SYMBOL_GPL(dma_resv_describe);
+
 #if IS_ENABLED(CONFIG_LOCKDEP)
 static int __init dma_resv_lockdep(void)
 {