Module Name:    src
Committed By:   riastradh
Date:           Sun Dec 19 01:25:14 UTC 2021

Modified Files:
        src/sys/external/bsd/drm2/include/linux: dma-fence.h
        src/sys/external/bsd/drm2/linux: linux_dma_fence.c

Log Message:
dma_fence_set_error


To generate a diff of this commit:
cvs rdiff -u -r1.4 -r1.5 src/sys/external/bsd/drm2/include/linux/dma-fence.h
cvs rdiff -u -r1.4 -r1.5 src/sys/external/bsd/drm2/linux/linux_dma_fence.c

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.

Modified files:

Index: src/sys/external/bsd/drm2/include/linux/dma-fence.h
diff -u src/sys/external/bsd/drm2/include/linux/dma-fence.h:1.4 src/sys/external/bsd/drm2/include/linux/dma-fence.h:1.5
--- src/sys/external/bsd/drm2/include/linux/dma-fence.h:1.4	Sun Dec 19 01:16:05 2021
+++ src/sys/external/bsd/drm2/include/linux/dma-fence.h	Sun Dec 19 01:25:13 2021
@@ -1,4 +1,4 @@
-/*	$NetBSD: dma-fence.h,v 1.4 2021/12/19 01:16:05 riastradh Exp $	*/
+/*	$NetBSD: dma-fence.h,v 1.5 2021/12/19 01:25:13 riastradh Exp $	*/
 
 /*-
  * Copyright (c) 2018 The NetBSD Foundation, Inc.
@@ -50,6 +50,7 @@ struct dma_fence {
 	unsigned			context;
 	unsigned			seqno;
 	const struct dma_fence_ops	*ops;
+	int				error;
 
 	TAILQ_HEAD(, dma_fence_cb)	f_callbacks;
 	kcondvar_t			f_cv;
@@ -91,6 +92,7 @@ struct dma_fence_cb {
 #define	dma_fence_is_signaled_locked	linux_dma_fence_is_signaled_locked
 #define	dma_fence_put			linux_dma_fence_put
 #define	dma_fence_remove_callback	linux_dma_fence_remove_callback
+#define	dma_fence_set_error		linux_dma_fence_set_error
 #define	dma_fence_signal		linux_dma_fence_signal
 #define	dma_fence_signal_locked		linux_dma_fence_signal_locked
 #define	dma_fence_wait			linux_dma_fence_wait
@@ -123,6 +125,7 @@ void	dma_fence_enable_sw_signaling(struc
 
 bool	dma_fence_is_signaled(struct dma_fence *);
 bool	dma_fence_is_signaled_locked(struct dma_fence *);
+void	dma_fence_set_error(struct dma_fence *, int);
 int	dma_fence_signal(struct dma_fence *);
 int	dma_fence_signal_locked(struct dma_fence *);
 long	dma_fence_default_wait(struct dma_fence *, bool, long);

Index: src/sys/external/bsd/drm2/linux/linux_dma_fence.c
diff -u src/sys/external/bsd/drm2/linux/linux_dma_fence.c:1.4 src/sys/external/bsd/drm2/linux/linux_dma_fence.c:1.5
--- src/sys/external/bsd/drm2/linux/linux_dma_fence.c:1.4	Sun Dec 19 01:16:05 2021
+++ src/sys/external/bsd/drm2/linux/linux_dma_fence.c	Sun Dec 19 01:25:13 2021
@@ -1,4 +1,4 @@
-/*	$NetBSD: linux_dma_fence.c,v 1.4 2021/12/19 01:16:05 riastradh Exp $	*/
+/*	$NetBSD: linux_dma_fence.c,v 1.5 2021/12/19 01:25:13 riastradh Exp $	*/
 
 /*-
  * Copyright (c) 2018 The NetBSD Foundation, Inc.
@@ -30,7 +30,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: linux_dma_fence.c,v 1.4 2021/12/19 01:16:05 riastradh Exp $");
+__KERNEL_RCSID(0, "$NetBSD: linux_dma_fence.c,v 1.5 2021/12/19 01:25:13 riastradh Exp $");
 
 #include <sys/atomic.h>
 #include <sys/condvar.h>
@@ -463,6 +463,23 @@ dma_fence_is_signaled_locked(struct dma_
 }
 
 /*
+ * dma_fence_set_error(fence, error)
+ *
+ *	Set an error code prior to dma_fence_signal for use by a
+ *	waiter to learn about success or failure of the fence.
+ */
+void
+dma_fence_set_error(struct dma_fence *fence, int error)
+{
+
+	KASSERT(!(fence->flags & (1u << DMA_FENCE_FLAG_SIGNALED_BIT)));
+	KASSERTMSG(error >= -MAX_ERRNO, "%d", error);
+	KASSERTMSG(error < 0, "%d", error);
+
+	fence->error = error;
+}
+
+/*
  * dma_fence_signal(fence)
  *
  *	Signal the fence.  If it has already been signalled, return

Reply via email to