提交 74fc4a75 编写于 作者: D Douglas Anderson 提交者: Felipe Balbi

usb: dwc2: host: Add scheduler tracing

In preparation for future changes to the scheduler let's add some
tracing that makes it easy for us to see what's happening.  By default
this tracing will be off.

By changing "core.h" you can easily trace to ftrace, the console, or
nowhere.
Acked-by: NJohn Youn <johnyoun@synopsys.com>
Signed-off-by: NDouglas Anderson <dianders@chromium.org>
Reviewed-by: NKever Yang <kever.yang@rock-chips.com>
Tested-by: NHeiko Stuebner <heiko@sntech.de>
Tested-by: NStefan Wahren <stefan.wahren@i2se.com>
Signed-off-by: NFelipe Balbi <balbi@kernel.org>
上级 c9c8ac01
...@@ -44,6 +44,26 @@ ...@@ -44,6 +44,26 @@
#include <linux/usb/phy.h> #include <linux/usb/phy.h>
#include "hw.h" #include "hw.h"
/*
* Suggested defines for tracers:
* - no_printk: Disable tracing
* - pr_info: Print this info to the console
* - trace_printk: Print this info to trace buffer (good for verbose logging)
*/
#define DWC2_TRACE_SCHEDULER no_printk
#define DWC2_TRACE_SCHEDULER_VB no_printk
/* Detailed scheduler tracing, but won't overwhelm console */
#define dwc2_sch_dbg(hsotg, fmt, ...) \
DWC2_TRACE_SCHEDULER(pr_fmt("%s: SCH: " fmt), \
dev_name(hsotg->dev), ##__VA_ARGS__)
/* Verbose scheduler tracing */
#define dwc2_sch_vdbg(hsotg, fmt, ...) \
DWC2_TRACE_SCHEDULER_VB(pr_fmt("%s: SCH: " fmt), \
dev_name(hsotg->dev), ##__VA_ARGS__)
static inline u32 dwc2_readl(const void __iomem *addr) static inline u32 dwc2_readl(const void __iomem *addr)
{ {
u32 value = __raw_readl(addr); u32 value = __raw_readl(addr);
......
...@@ -563,6 +563,11 @@ static inline u16 dwc2_frame_num_inc(u16 frame, u16 inc) ...@@ -563,6 +563,11 @@ static inline u16 dwc2_frame_num_inc(u16 frame, u16 inc)
return (frame + inc) & HFNUM_MAX_FRNUM; return (frame + inc) & HFNUM_MAX_FRNUM;
} }
static inline u16 dwc2_frame_num_dec(u16 frame, u16 dec)
{
return (frame + HFNUM_MAX_FRNUM + 1 - dec) & HFNUM_MAX_FRNUM;
}
static inline u16 dwc2_full_frame_num(u16 frame) static inline u16 dwc2_full_frame_num(u16 frame)
{ {
return (frame & HFNUM_MAX_FRNUM) >> 3; return (frame & HFNUM_MAX_FRNUM) >> 3;
......
...@@ -138,7 +138,10 @@ static void dwc2_sof_intr(struct dwc2_hsotg *hsotg) ...@@ -138,7 +138,10 @@ static void dwc2_sof_intr(struct dwc2_hsotg *hsotg)
while (qh_entry != &hsotg->periodic_sched_inactive) { while (qh_entry != &hsotg->periodic_sched_inactive) {
qh = list_entry(qh_entry, struct dwc2_qh, qh_list_entry); qh = list_entry(qh_entry, struct dwc2_qh, qh_list_entry);
qh_entry = qh_entry->next; qh_entry = qh_entry->next;
if (dwc2_frame_num_le(qh->sched_frame, hsotg->frame_number)) if (dwc2_frame_num_le(qh->sched_frame, hsotg->frame_number)) {
dwc2_sch_vdbg(hsotg, "QH=%p ready fn=%04x, sch=%04x\n",
qh, hsotg->frame_number, qh->sched_frame);
/* /*
* Move QH to the ready list to be executed next * Move QH to the ready list to be executed next
* (micro)frame * (micro)frame
...@@ -146,6 +149,7 @@ static void dwc2_sof_intr(struct dwc2_hsotg *hsotg) ...@@ -146,6 +149,7 @@ static void dwc2_sof_intr(struct dwc2_hsotg *hsotg)
list_move_tail(&qh->qh_list_entry, list_move_tail(&qh->qh_list_entry,
&hsotg->periodic_sched_ready); &hsotg->periodic_sched_ready);
} }
}
tr_type = dwc2_hcd_select_transactions(hsotg); tr_type = dwc2_hcd_select_transactions(hsotg);
if (tr_type != DWC2_TRANSACTION_NONE) if (tr_type != DWC2_TRANSACTION_NONE)
dwc2_hcd_queue_transactions(hsotg, tr_type); dwc2_hcd_queue_transactions(hsotg, tr_type);
......
...@@ -113,6 +113,9 @@ static void dwc2_qh_init(struct dwc2_hsotg *hsotg, struct dwc2_qh *qh, ...@@ -113,6 +113,9 @@ static void dwc2_qh_init(struct dwc2_hsotg *hsotg, struct dwc2_qh *qh,
qh->sched_frame = dwc2_frame_num_inc(hsotg->frame_number, qh->sched_frame = dwc2_frame_num_inc(hsotg->frame_number,
SCHEDULE_SLOP); SCHEDULE_SLOP);
qh->interval = urb->interval; qh->interval = urb->interval;
dwc2_sch_dbg(hsotg, "QH=%p init sch=%04x, fn=%04x, int=%#x\n",
qh, qh->sched_frame, hsotg->frame_number,
qh->interval);
#if 0 #if 0
/* Increase interrupt polling rate for debugging */ /* Increase interrupt polling rate for debugging */
if (qh->ep_type == USB_ENDPOINT_XFER_INT) if (qh->ep_type == USB_ENDPOINT_XFER_INT)
...@@ -126,6 +129,11 @@ static void dwc2_qh_init(struct dwc2_hsotg *hsotg, struct dwc2_qh *qh, ...@@ -126,6 +129,11 @@ static void dwc2_qh_init(struct dwc2_hsotg *hsotg, struct dwc2_qh *qh,
qh->interval *= 8; qh->interval *= 8;
qh->sched_frame |= 0x7; qh->sched_frame |= 0x7;
qh->start_split_frame = qh->sched_frame; qh->start_split_frame = qh->sched_frame;
dwc2_sch_dbg(hsotg,
"QH=%p init*8 sch=%04x, fn=%04x, int=%#x\n",
qh, qh->sched_frame, hsotg->frame_number,
qh->interval);
} }
dev_dbg(hsotg->dev, "interval=%d\n", qh->interval); dev_dbg(hsotg->dev, "interval=%d\n", qh->interval);
} }
...@@ -482,6 +490,8 @@ static int dwc2_schedule_periodic(struct dwc2_hsotg *hsotg, struct dwc2_qh *qh) ...@@ -482,6 +490,8 @@ static int dwc2_schedule_periodic(struct dwc2_hsotg *hsotg, struct dwc2_qh *qh)
if (frame >= 0) { if (frame >= 0) {
qh->sched_frame &= ~0x7; qh->sched_frame &= ~0x7;
qh->sched_frame |= (frame & 7); qh->sched_frame |= (frame & 7);
dwc2_sch_dbg(hsotg, "QH=%p sched_p sch=%04x, uf=%d\n",
qh, qh->sched_frame, frame);
} }
if (status > 0) if (status > 0)
...@@ -583,10 +593,16 @@ int dwc2_hcd_qh_add(struct dwc2_hsotg *hsotg, struct dwc2_qh *qh) ...@@ -583,10 +593,16 @@ int dwc2_hcd_qh_add(struct dwc2_hsotg *hsotg, struct dwc2_qh *qh)
if (!dwc2_frame_num_le(qh->sched_frame, hsotg->frame_number) && if (!dwc2_frame_num_le(qh->sched_frame, hsotg->frame_number) &&
!hsotg->frame_number) { !hsotg->frame_number) {
u16 new_frame;
dev_dbg(hsotg->dev, dev_dbg(hsotg->dev,
"reset frame number counter\n"); "reset frame number counter\n");
qh->sched_frame = dwc2_frame_num_inc(hsotg->frame_number, new_frame = dwc2_frame_num_inc(hsotg->frame_number,
SCHEDULE_SLOP); SCHEDULE_SLOP);
dwc2_sch_vdbg(hsotg, "QH=%p reset sch=%04x=>%04x\n",
qh, qh->sched_frame, new_frame);
qh->sched_frame = new_frame;
} }
/* Add the new QH to the appropriate schedule */ /* Add the new QH to the appropriate schedule */
...@@ -652,6 +668,7 @@ static void dwc2_sched_periodic_split(struct dwc2_hsotg *hsotg, ...@@ -652,6 +668,7 @@ static void dwc2_sched_periodic_split(struct dwc2_hsotg *hsotg,
int sched_next_periodic_split) int sched_next_periodic_split)
{ {
u16 incr; u16 incr;
u16 old_frame = qh->sched_frame;
if (sched_next_periodic_split) { if (sched_next_periodic_split) {
qh->sched_frame = frame_number; qh->sched_frame = frame_number;
...@@ -677,6 +694,11 @@ static void dwc2_sched_periodic_split(struct dwc2_hsotg *hsotg, ...@@ -677,6 +694,11 @@ static void dwc2_sched_periodic_split(struct dwc2_hsotg *hsotg,
qh->sched_frame |= 0x7; qh->sched_frame |= 0x7;
qh->start_split_frame = qh->sched_frame; qh->start_split_frame = qh->sched_frame;
} }
dwc2_sch_vdbg(hsotg, "QH=%p next(%d) fn=%04x, sch=%04x=>%04x (%+d)\n",
qh, sched_next_periodic_split, frame_number, old_frame,
qh->sched_frame,
dwc2_frame_num_dec(qh->sched_frame, old_frame));
} }
/* /*
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册