Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/external/bsd/drm2/dist/drm/radeon Fix bad merge of radeo...
details: https://anonhg.NetBSD.org/src/rev/cbb52ea764b7
branches: trunk
changeset: 366096:cbb52ea764b7
user: riastradh <riastradh%NetBSD.org@localhost>
date: Mon Aug 27 07:49:25 2018 +0000
description:
Fix bad merge of radeon fence wakeup.
diffstat:
sys/external/bsd/drm2/dist/drm/radeon/radeon_fence.c | 24 +++++++++----------
1 files changed, 11 insertions(+), 13 deletions(-)
diffs (98 lines):
diff -r b78944cc745a -r cbb52ea764b7 sys/external/bsd/drm2/dist/drm/radeon/radeon_fence.c
--- a/sys/external/bsd/drm2/dist/drm/radeon/radeon_fence.c Mon Aug 27 07:49:14 2018 +0000
+++ b/sys/external/bsd/drm2/dist/drm/radeon/radeon_fence.c Mon Aug 27 07:49:25 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: radeon_fence.c,v 1.11 2018/08/27 07:49:14 riastradh Exp $ */
+/* $NetBSD: radeon_fence.c,v 1.12 2018/08/27 07:49:25 riastradh Exp $ */
/*
* Copyright 2009 Jerome Glisse.
@@ -31,7 +31,7 @@
* Dave Airlie
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: radeon_fence.c,v 1.11 2018/08/27 07:49:14 riastradh Exp $");
+__KERNEL_RCSID(0, "$NetBSD: radeon_fence.c,v 1.12 2018/08/27 07:49:25 riastradh Exp $");
#include <linux/seq_file.h>
#include <linux/atomic.h>
@@ -192,7 +192,7 @@
radeon_irq_kms_sw_irq_put(fence->rdev, fence->ring);
#ifdef __NetBSD__
- TAILQ_REMOVE(fence, fence_check);
+ TAILQ_REMOVE(&fence->rdev->fence_check, fence, fence_check);
#else
__remove_wait_queue(&fence->rdev->fence_queue, &fence->fence_wake);
#endif
@@ -330,7 +330,7 @@
if (radeon_fence_activity(rdev, ring))
#ifdef __NetBSD__
- radeon_wakeup(rdev);
+ radeon_fence_wakeup_locked(rdev);
#else
wake_up_all(&rdev->fence_queue);
#endif
@@ -346,7 +346,7 @@
/* remember that we need an reset */
rdev->needs_reset = true;
#ifdef __NetBSD__
- radeon_wakeup(rdev);
+ radeon_fence_wakeup_locked(rdev);
#else
wake_up_all(&rdev->fence_queue);
#endif
@@ -370,7 +370,7 @@
{
if (radeon_fence_activity(rdev, ring))
#ifdef __NetBSD__
- radeon_wakeup(&rdev);
+ radeon_fence_wakeup_locked(rdev);
#else
wake_up_all(&rdev->fence_queue);
#endif
@@ -460,7 +460,7 @@
if (radeon_fence_activity(rdev, fence->ring))
#ifdef __NetBSD__
- radeon_wakeup(rdev);
+ radeon_fence_wakeup_locked(rdev);
#else
wake_up_all_locked(&rdev->fence_queue);
#endif
@@ -585,14 +585,12 @@
if (intr)
DRM_SPIN_TIMED_WAIT_UNTIL(r, &rdev->fence_queue,
&rdev->fence_lock, timeout,
- ((signaled = radeon_fence_any_seq_signaled(rdev,
- target_seq))
+ (radeon_fence_any_seq_signaled(rdev, target_seq)
|| rdev->needs_reset));
else
DRM_SPIN_TIMED_WAIT_NOINTR_UNTIL(r, &rdev->fence_queue,
&rdev->fence_lock, timeout,
- ((signaled = radeon_fence_any_seq_signaled(rdev,
- target_seq))
+ (radeon_fence_any_seq_signaled(rdev, target_seq)
|| rdev->needs_reset));
#else
if (intr) {
@@ -993,7 +991,7 @@
#ifdef __NetBSD__
spin_lock_init(&rdev->fence_lock);
DRM_INIT_WAITQUEUE(&rdev->fence_queue, "radfence");
- TALIQ_INIT(&rdev->fence_queue);
+ TAILQ_INIT(&rdev->fence_check);
#else
init_waitqueue_head(&rdev->fence_queue);
#endif
@@ -1030,7 +1028,7 @@
cancel_delayed_work_sync(&rdev->fence_drv[ring].lockup_work);
#ifdef __NetBSD__
spin_lock(&rdev->fence_lock);
- radeon_wakeup(rdev);
+ radeon_fence_wakeup_locked(rdev);
spin_unlock(&rdev->fence_lock);
#else
wake_up_all(&rdev->fence_queue);
Home |
Main Index |
Thread Index |
Old Index