diff options
author | Felipe Balbi <balbi@ti.com> | 2014-04-30 18:45:10 -0400 |
---|---|---|
committer | Felipe Balbi <balbi@ti.com> | 2014-09-05 10:55:51 -0400 |
commit | 2c4cbe6e5a9c71408b496e00a78ea9284e98af16 (patch) | |
tree | c90423ae169751bf43925c9a37734762199ec803 /drivers/usb/dwc3/debug.c | |
parent | 3ece0ec474bf3cea9eefa7f92e3d4b6c3f9f71fd (diff) |
usb: dwc3: add tracepoints to aid debugging
When we're debugging hard-to-reproduce and time-sensitive
use cases, printk() poses too much overhead. That's when
the kernel's tracing infrastructure comes into play.
This patch implements a few initial tracepoints for the
dwc3 driver. More traces can be added as necessary in order
to ease the task of debugging dwc3.
Reviewed-by: Paul Zimmerman <paulz@synopsys.com>
Signed-off-by: Felipe Balbi <balbi@ti.com>
Diffstat (limited to 'drivers/usb/dwc3/debug.c')
-rw-r--r-- | drivers/usb/dwc3/debug.c | 32 |
1 files changed, 32 insertions, 0 deletions
diff --git a/drivers/usb/dwc3/debug.c b/drivers/usb/dwc3/debug.c new file mode 100644 index 000000000000..0be6885bc370 --- /dev/null +++ b/drivers/usb/dwc3/debug.c | |||
@@ -0,0 +1,32 @@ | |||
1 | /** | ||
2 | * debug.c - DesignWare USB3 DRD Controller Debug/Trace Support | ||
3 | * | ||
4 | * Copyright (C) 2014 Texas Instruments Incorporated - http://www.ti.com | ||
5 | * | ||
6 | * Author: Felipe Balbi <balbi@ti.com> | ||
7 | * | ||
8 | * This program is free software: you can redistribute it and/or modify | ||
9 | * it under the terms of the GNU General Public License version 2 of | ||
10 | * the License as published by the Free Software Foundation. | ||
11 | * | ||
12 | * This program is distributed in the hope that it will be useful, | ||
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
15 | * GNU General Public License for more details. | ||
16 | */ | ||
17 | |||
18 | #include "debug.h" | ||
19 | |||
20 | void dwc3_trace(void (*trace)(struct va_format *), const char *fmt, ...) | ||
21 | { | ||
22 | struct va_format vaf; | ||
23 | va_list args; | ||
24 | |||
25 | va_start(args, fmt); | ||
26 | vaf.fmt = fmt; | ||
27 | vaf.va = &args; | ||
28 | |||
29 | trace(&vaf); | ||
30 | |||
31 | va_end(args); | ||
32 | } | ||