Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 363283
b: refs/heads/master
c: b699a64
h: refs/heads/master
i:
  363281: 952aa4d
  363279: d0bc413
v: v3
  • Loading branch information
Erik Gilling authored and Greg Kroah-Hartman committed Mar 4, 2013
1 parent 4f96088 commit 6fb8cc6
Show file tree
Hide file tree
Showing 3 changed files with 94 additions and 1 deletion.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 135114a566c15dfe44fb8ca31e42dd215d627383
refs/heads/master: b699a644f82110e8e5a0f9b45ee1d3a3cd3e4586
11 changes: 11 additions & 0 deletions trunk/drivers/staging/android/sync.c
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,9 @@

#include "sync.h"

#define CREATE_TRACE_POINTS
#include "trace/sync.h"

static void sync_fence_signal_pt(struct sync_pt *pt);
static int _sync_pt_has_signaled(struct sync_pt *pt);
static void sync_fence_free(struct kref *kref);
Expand Down Expand Up @@ -134,6 +137,8 @@ void sync_timeline_signal(struct sync_timeline *obj)
LIST_HEAD(signaled_pts);
struct list_head *pos, *n;

trace_sync_timeline(obj);

spin_lock_irqsave(&obj->active_list_lock, flags);

list_for_each_safe(pos, n, &obj->active_list_head) {
Expand Down Expand Up @@ -581,6 +586,11 @@ static bool sync_fence_check(struct sync_fence *fence)
int sync_fence_wait(struct sync_fence *fence, long timeout)
{
int err = 0;
struct sync_pt *pt;

trace_sync_wait(fence, 1);
list_for_each_entry(pt, &fence->pt_list_head, pt_list)
trace_sync_pt(pt);

if (timeout > 0) {
timeout = msecs_to_jiffies(timeout);
Expand All @@ -591,6 +601,7 @@ int sync_fence_wait(struct sync_fence *fence, long timeout)
err = wait_event_interruptible(fence->wq,
sync_fence_check(fence));
}
trace_sync_wait(fence, 0);

if (err < 0)
return err;
Expand Down
82 changes: 82 additions & 0 deletions trunk/drivers/staging/android/trace/sync.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,82 @@
#undef TRACE_SYSTEM
#define TRACE_INCLUDE_PATH ../../drivers/staging/android/trace
#define TRACE_SYSTEM sync

#if !defined(_TRACE_SYNC_H) || defined(TRACE_HEADER_MULTI_READ)
#define _TRACE_SYNC_H

#include "../sync.h"
#include <linux/tracepoint.h>

TRACE_EVENT(sync_timeline,
TP_PROTO(struct sync_timeline *timeline),

TP_ARGS(timeline),

TP_STRUCT__entry(
__string(name, timeline->name)
__array(char, value, 32)
),

TP_fast_assign(
__assign_str(name, timeline->name);
if (timeline->ops->timeline_value_str) {
timeline->ops->timeline_value_str(timeline,
__entry->value,
sizeof(__entry->value));
} else {
__entry->value[0] = '\0';
}
),

TP_printk("name=%s value=%s", __get_str(name), __entry->value)
);

TRACE_EVENT(sync_wait,
TP_PROTO(struct sync_fence *fence, int begin),

TP_ARGS(fence, begin),

TP_STRUCT__entry(
__string(name, fence->name)
__field(s32, status)
__field(u32, begin)
),

TP_fast_assign(
__assign_str(name, fence->name);
__entry->status = fence->status;
__entry->begin = begin;
),

TP_printk("%s name=%s state=%d", __entry->begin ? "begin" : "end",
__get_str(name), __entry->status)
);

TRACE_EVENT(sync_pt,
TP_PROTO(struct sync_pt *pt),

TP_ARGS(pt),

TP_STRUCT__entry(
__string(timeline, pt->parent->name)
__array(char, value, 32)
),

TP_fast_assign(
__assign_str(timeline, pt->parent->name);
if (pt->parent->ops->pt_value_str) {
pt->parent->ops->pt_value_str(pt, __entry->value,
sizeof(__entry->value));
} else {
__entry->value[0] = '\0';
}
),

TP_printk("name=%s value=%s", __get_str(timeline), __entry->value)
);

#endif /* if !defined(_TRACE_SYNC_H) || defined(TRACE_HEADER_MULTI_READ) */

/* This part must be outside protection */
#include <trace/define_trace.h>

0 comments on commit 6fb8cc6

Please sign in to comment.