aboutsummaryrefslogtreecommitdiffstats
path: root/include/linux
diff options
context:
space:
mode:
authorPekka Paalanen <pq@iki.fi>2008-05-12 15:20:57 -0400
committerThomas Gleixner <tglx@linutronix.de>2008-05-24 05:22:24 -0400
commitd61fc44853f46fb002228b18aa5f30db21fcd4ac (patch)
tree14fa9416aeceb7c5d24876c1111f6f2458a1dc7d /include/linux
parent0fd0e3da4557c479b820b9a4a7afa25b4637ddf2 (diff)
x86: mmiotrace, preview 2
Kconfig.debug, Makefile and testmmiotrace.c style fixes. Use real mutex instead of mutex. Fix failure path in register probe func. kmmio: RCU read-locked over single stepping. Generate mapping id's. Make mmio-mod.c built-in and rewrite its locking. Add debugfs file to enable/disable mmiotracing. kmmio: use irqsave spinlocks. Lots of cleanups in mmio-mod.c Marker file moved from /proc into debugfs. Call mmiotrace entrypoints directly from ioremap.c. Signed-off-by: Pekka Paalanen <pq@iki.fi> Signed-off-by: Ingo Molnar <mingo@elte.hu> Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Diffstat (limited to 'include/linux')
-rw-r--r--include/linux/mmiotrace.h18
1 files changed, 17 insertions, 1 deletions
diff --git a/include/linux/mmiotrace.h b/include/linux/mmiotrace.h
index d87a6cd8b686..cb5efd0c7f51 100644
--- a/include/linux/mmiotrace.h
+++ b/include/linux/mmiotrace.h
@@ -16,11 +16,12 @@ typedef void (*kmmio_post_handler_t)(struct kmmio_probe *,
16 unsigned long condition, struct pt_regs *); 16 unsigned long condition, struct pt_regs *);
17 17
18struct kmmio_probe { 18struct kmmio_probe {
19 struct list_head list; 19 struct list_head list; /* kmmio internal list */
20 unsigned long addr; /* start location of the probe point */ 20 unsigned long addr; /* start location of the probe point */
21 unsigned long len; /* length of the probe region */ 21 unsigned long len; /* length of the probe region */
22 kmmio_pre_handler_t pre_handler; /* Called before addr is executed. */ 22 kmmio_pre_handler_t pre_handler; /* Called before addr is executed. */
23 kmmio_post_handler_t post_handler; /* Called after addr is executed */ 23 kmmio_post_handler_t post_handler; /* Called after addr is executed */
24 void *user_data;
24}; 25};
25 26
26/* kmmio is active by some kmmio_probes? */ 27/* kmmio is active by some kmmio_probes? */
@@ -38,6 +39,21 @@ extern void unregister_kmmio_probe(struct kmmio_probe *p);
38/* Called from page fault handler. */ 39/* Called from page fault handler. */
39extern int kmmio_handler(struct pt_regs *regs, unsigned long addr); 40extern int kmmio_handler(struct pt_regs *regs, unsigned long addr);
40 41
42/* Called from ioremap.c */
43#ifdef CONFIG_MMIOTRACE
44extern void
45mmiotrace_ioremap(unsigned long offset, unsigned long size, void __iomem *addr);
46extern void mmiotrace_iounmap(volatile void __iomem *addr);
47#else
48static inline void
49mmiotrace_ioremap(unsigned long offset, unsigned long size, void __iomem *addr)
50{
51}
52static inline void mmiotrace_iounmap(volatile void __iomem *addr)
53{
54}
55#endif /* CONFIG_MMIOTRACE_HOOKS */
56
41#endif /* __KERNEL__ */ 57#endif /* __KERNEL__ */
42 58
43 59