diff options
author | Jesse Barnes <jbarnes@virtuousgeek.org> | 2010-07-01 19:47:31 -0400 |
---|---|---|
committer | Dave Airlie <airlied@redhat.com> | 2010-07-02 00:02:44 -0400 |
commit | ac2874b980e05ed7a4ea8fed7b0a92428b51ce58 (patch) | |
tree | 71c0c8e4abe395a46ca21d2bdc3493cce19719e7 /drivers | |
parent | 97e0214044d9f279a3d6286c9f859696ef0b7ebe (diff) |
drm: add vblank event trace point
Emit a trace point for vblank events. This can be helpful for mapping
drawing activity against the vblank frequency and period.
Signed-off-by: Jesse Barnes <jbarnes@virtuousgeek.org>
Signed-off-by: Dave Airlie <airlied@redhat.com>
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/gpu/drm/Makefile | 5 | ||||
-rw-r--r-- | drivers/gpu/drm/drm_irq.c | 3 | ||||
-rw-r--r-- | drivers/gpu/drm/drm_trace.h | 37 | ||||
-rw-r--r-- | drivers/gpu/drm/drm_trace_points.c | 4 |
4 files changed, 48 insertions, 1 deletions
diff --git a/drivers/gpu/drm/Makefile b/drivers/gpu/drm/Makefile index abe3f446ca48..3b02e04ec2c4 100644 --- a/drivers/gpu/drm/Makefile +++ b/drivers/gpu/drm/Makefile | |||
@@ -11,7 +11,8 @@ drm-y := drm_auth.o drm_buffer.o drm_bufs.o drm_cache.o \ | |||
11 | drm_agpsupport.o drm_scatter.o ati_pcigart.o drm_pci.o \ | 11 | drm_agpsupport.o drm_scatter.o ati_pcigart.o drm_pci.o \ |
12 | drm_sysfs.o drm_hashtab.o drm_sman.o drm_mm.o \ | 12 | drm_sysfs.o drm_hashtab.o drm_sman.o drm_mm.o \ |
13 | drm_crtc.o drm_modes.o drm_edid.o \ | 13 | drm_crtc.o drm_modes.o drm_edid.o \ |
14 | drm_info.o drm_debugfs.o drm_encoder_slave.o | 14 | drm_info.o drm_debugfs.o drm_encoder_slave.o \ |
15 | drm_trace_points.o | ||
15 | 16 | ||
16 | drm-$(CONFIG_COMPAT) += drm_ioc32.o | 17 | drm-$(CONFIG_COMPAT) += drm_ioc32.o |
17 | 18 | ||
@@ -19,6 +20,8 @@ drm_kms_helper-y := drm_fb_helper.o drm_crtc_helper.o drm_dp_i2c_helper.o | |||
19 | 20 | ||
20 | obj-$(CONFIG_DRM_KMS_HELPER) += drm_kms_helper.o | 21 | obj-$(CONFIG_DRM_KMS_HELPER) += drm_kms_helper.o |
21 | 22 | ||
23 | CFLAGS_drm_trace_points.o := -I$(src) | ||
24 | |||
22 | obj-$(CONFIG_DRM) += drm.o | 25 | obj-$(CONFIG_DRM) += drm.o |
23 | obj-$(CONFIG_DRM_TTM) += ttm/ | 26 | obj-$(CONFIG_DRM_TTM) += ttm/ |
24 | obj-$(CONFIG_DRM_TDFX) += tdfx/ | 27 | obj-$(CONFIG_DRM_TDFX) += tdfx/ |
diff --git a/drivers/gpu/drm/drm_irq.c b/drivers/gpu/drm/drm_irq.c index a263b7070fc6..6d201a89441c 100644 --- a/drivers/gpu/drm/drm_irq.c +++ b/drivers/gpu/drm/drm_irq.c | |||
@@ -34,6 +34,7 @@ | |||
34 | */ | 34 | */ |
35 | 35 | ||
36 | #include "drmP.h" | 36 | #include "drmP.h" |
37 | #include "drm_trace.h" | ||
37 | 38 | ||
38 | #include <linux/interrupt.h> /* For task queue support */ | 39 | #include <linux/interrupt.h> /* For task queue support */ |
39 | #include <linux/slab.h> | 40 | #include <linux/slab.h> |
@@ -754,6 +755,8 @@ void drm_handle_vblank_events(struct drm_device *dev, int crtc) | |||
754 | } | 755 | } |
755 | 756 | ||
756 | spin_unlock_irqrestore(&dev->event_lock, flags); | 757 | spin_unlock_irqrestore(&dev->event_lock, flags); |
758 | |||
759 | trace_drm_vblank_event(crtc, seq); | ||
757 | } | 760 | } |
758 | 761 | ||
759 | /** | 762 | /** |
diff --git a/drivers/gpu/drm/drm_trace.h b/drivers/gpu/drm/drm_trace.h new file mode 100644 index 000000000000..8a92683f14ec --- /dev/null +++ b/drivers/gpu/drm/drm_trace.h | |||
@@ -0,0 +1,37 @@ | |||
1 | #if !defined(_DRM_TRACE_H_) || defined(TRACE_HEADER_MULTI_READ) | ||
2 | #define _DRM_TRACE_H_ | ||
3 | |||
4 | #include <linux/stringify.h> | ||
5 | #include <linux/types.h> | ||
6 | #include <linux/tracepoint.h> | ||
7 | |||
8 | #undef TRACE_SYSTEM | ||
9 | #define TRACE_SYSTEM drm | ||
10 | #define TRACE_SYSTEM_STRING __stringify(TRACE_SYSTEM) | ||
11 | #define TRACE_INCLUDE_FILE drm_trace | ||
12 | |||
13 | TRACE_EVENT(drm_vblank_event, | ||
14 | |||
15 | TP_PROTO(int crtc, unsigned int seq), | ||
16 | |||
17 | TP_ARGS(crtc, seq), | ||
18 | |||
19 | TP_STRUCT__entry( | ||
20 | __field(int, crtc) | ||
21 | __field(unsigned int, seq) | ||
22 | ), | ||
23 | |||
24 | TP_fast_assign( | ||
25 | __entry->crtc = crtc; | ||
26 | __entry->seq = seq; | ||
27 | ), | ||
28 | |||
29 | TP_printk("crtc=%d, seq=%d", __entry->crtc, __entry->seq) | ||
30 | ); | ||
31 | |||
32 | #endif /* _DRM_TRACE_H_ */ | ||
33 | |||
34 | /* This part must be outside protection */ | ||
35 | #undef TRACE_INCLUDE_PATH | ||
36 | #define TRACE_INCLUDE_PATH . | ||
37 | #include <trace/define_trace.h> | ||
diff --git a/drivers/gpu/drm/drm_trace_points.c b/drivers/gpu/drm/drm_trace_points.c new file mode 100644 index 000000000000..0d0eb90864ae --- /dev/null +++ b/drivers/gpu/drm/drm_trace_points.c | |||
@@ -0,0 +1,4 @@ | |||
1 | #include "drmP.h" | ||
2 | |||
3 | #define CREATE_TRACE_POINTS | ||
4 | #include "drm_trace.h" | ||