Am 14.11.2013 16:37, schrieb Alex Deucher: > Added the series to my queue for 3.13.
Please drop [PATCH 3/3] drm/radeon: disable CIK CP semaphores for now. With the recent discovery that's an alignment issue that doesn't seems to be necessary any more. Christian. > > Thanks, > > Alex > > On Tue, Nov 12, 2013 at 6:58 AM, Christian K?nig > <deathsimple at vodafone.de> wrote: >> From: Christian K?nig <christian.koenig at amd.com> >> >> Signed-off-by: Christian K?nig <christian.koenig at amd.com> >> --- >> drivers/gpu/drm/radeon/radeon_semaphore.c | 6 +++++- >> drivers/gpu/drm/radeon/radeon_trace.h | 36 >> +++++++++++++++++++++++++++++++ >> 2 files changed, 41 insertions(+), 1 deletion(-) >> >> diff --git a/drivers/gpu/drm/radeon/radeon_semaphore.c >> b/drivers/gpu/drm/radeon/radeon_semaphore.c >> index 8dcc20f..97d73bf 100644 >> --- a/drivers/gpu/drm/radeon/radeon_semaphore.c >> +++ b/drivers/gpu/drm/radeon/radeon_semaphore.c >> @@ -29,7 +29,7 @@ >> */ >> #include <drm/drmP.h> >> #include "radeon.h" >> - >> +#include "radeon_trace.h" >> >> int radeon_semaphore_create(struct radeon_device *rdev, >> struct radeon_semaphore **semaphore) >> @@ -56,6 +56,8 @@ int radeon_semaphore_create(struct radeon_device *rdev, >> void radeon_semaphore_emit_signal(struct radeon_device *rdev, int ring, >> struct radeon_semaphore *semaphore) >> { >> + trace_radeon_semaphore_signale(ring, semaphore); >> + >> --semaphore->waiters; >> radeon_semaphore_ring_emit(rdev, ring, &rdev->ring[ring], >> semaphore, false); >> } >> @@ -63,6 +65,8 @@ void radeon_semaphore_emit_signal(struct radeon_device >> *rdev, int ring, >> void radeon_semaphore_emit_wait(struct radeon_device *rdev, int ring, >> struct radeon_semaphore *semaphore) >> { >> + trace_radeon_semaphore_wait(ring, semaphore); >> + >> ++semaphore->waiters; >> radeon_semaphore_ring_emit(rdev, ring, &rdev->ring[ring], >> semaphore, true); >> } >> diff --git a/drivers/gpu/drm/radeon/radeon_trace.h >> b/drivers/gpu/drm/radeon/radeon_trace.h >> index 811bca6..9f0e181 100644 >> --- a/drivers/gpu/drm/radeon/radeon_trace.h >> +++ b/drivers/gpu/drm/radeon/radeon_trace.h >> @@ -111,6 +111,42 @@ DEFINE_EVENT(radeon_fence_request, >> radeon_fence_wait_end, >> TP_ARGS(dev, seqno) >> ); >> >> +DECLARE_EVENT_CLASS(radeon_semaphore_request, >> + >> + TP_PROTO(int ring, struct radeon_semaphore *sem), >> + >> + TP_ARGS(ring, sem), >> + >> + TP_STRUCT__entry( >> + __field(int, ring) >> + __field(signed, waiters) >> + __field(uint64_t, gpu_addr) >> + ), >> + >> + TP_fast_assign( >> + __entry->ring = ring; >> + __entry->waiters = sem->waiters; >> + __entry->gpu_addr = sem->gpu_addr; >> + ), >> + >> + TP_printk("ring=%u, waiters=%d, addr=%010Lx", __entry->ring, >> + __entry->waiters, __entry->gpu_addr) >> +); >> + >> +DEFINE_EVENT(radeon_semaphore_request, radeon_semaphore_signale, >> + >> + TP_PROTO(int ring, struct radeon_semaphore *sem), >> + >> + TP_ARGS(ring, sem) >> +); >> + >> +DEFINE_EVENT(radeon_semaphore_request, radeon_semaphore_wait, >> + >> + TP_PROTO(int ring, struct radeon_semaphore *sem), >> + >> + TP_ARGS(ring, sem) >> +); >> + >> #endif >> >> /* This part must be outside protection */ >> -- >> 1.8.1.2 >>