提交 557f3586 编写于 作者: J Joe Perches 提交者: Felipe Balbi

usb: gadget: goku_udc: Remove uses of seq_<foo> return values

The seq_printf/seq_puts/seq_putc return values, because they
are frequently misused, will eventually be converted to void.

See: commit 1f33c41c ("seq_file: Rename seq_overflow() to
     seq_has_overflowed() and make public")

Miscellanea:

o Coalesce formats, realign arguments
o Create static functions for statement expression macros
o Use c90 style comments instead of c99
Signed-off-by: NJoe Perches <joe@perches.com>
Signed-off-by: NFelipe Balbi <balbi@ti.com>
上级 00f30d29
...@@ -1024,35 +1024,79 @@ static const char proc_node_name [] = "driver/udc"; ...@@ -1024,35 +1024,79 @@ static const char proc_node_name [] = "driver/udc";
static void dump_intmask(struct seq_file *m, const char *label, u32 mask) static void dump_intmask(struct seq_file *m, const char *label, u32 mask)
{ {
/* int_status is the same format ... */ /* int_status is the same format ... */
seq_printf(m, seq_printf(m, "%s %05X =" FOURBITS EIGHTBITS EIGHTBITS "\n",
"%s %05X =" FOURBITS EIGHTBITS EIGHTBITS "\n", label, mask,
label, mask, (mask & INT_PWRDETECT) ? " power" : "",
(mask & INT_PWRDETECT) ? " power" : "", (mask & INT_SYSERROR) ? " sys" : "",
(mask & INT_SYSERROR) ? " sys" : "", (mask & INT_MSTRDEND) ? " in-dma" : "",
(mask & INT_MSTRDEND) ? " in-dma" : "", (mask & INT_MSTWRTMOUT) ? " wrtmo" : "",
(mask & INT_MSTWRTMOUT) ? " wrtmo" : "",
(mask & INT_MSTWREND) ? " out-dma" : "",
(mask & INT_MSTWREND) ? " out-dma" : "", (mask & INT_MSTWRSET) ? " wrset" : "",
(mask & INT_MSTWRSET) ? " wrset" : "", (mask & INT_ERR) ? " err" : "",
(mask & INT_ERR) ? " err" : "", (mask & INT_SOF) ? " sof" : "",
(mask & INT_SOF) ? " sof" : "",
(mask & INT_EP3NAK) ? " ep3nak" : "",
(mask & INT_EP3NAK) ? " ep3nak" : "", (mask & INT_EP2NAK) ? " ep2nak" : "",
(mask & INT_EP2NAK) ? " ep2nak" : "", (mask & INT_EP1NAK) ? " ep1nak" : "",
(mask & INT_EP1NAK) ? " ep1nak" : "", (mask & INT_EP3DATASET) ? " ep3" : "",
(mask & INT_EP3DATASET) ? " ep3" : "",
(mask & INT_EP2DATASET) ? " ep2" : "",
(mask & INT_EP2DATASET) ? " ep2" : "", (mask & INT_EP1DATASET) ? " ep1" : "",
(mask & INT_EP1DATASET) ? " ep1" : "", (mask & INT_STATUSNAK) ? " ep0snak" : "",
(mask & INT_STATUSNAK) ? " ep0snak" : "", (mask & INT_STATUS) ? " ep0status" : "",
(mask & INT_STATUS) ? " ep0status" : "",
(mask & INT_SETUP) ? " setup" : "",
(mask & INT_SETUP) ? " setup" : "", (mask & INT_ENDPOINT0) ? " ep0" : "",
(mask & INT_ENDPOINT0) ? " ep0" : "", (mask & INT_USBRESET) ? " reset" : "",
(mask & INT_USBRESET) ? " reset" : "", (mask & INT_SUSPEND) ? " suspend" : "");
(mask & INT_SUSPEND) ? " suspend" : ""); }
static const char *udc_ep_state(enum ep0state state)
{
switch (state) {
case EP0_DISCONNECT:
return "ep0_disconnect";
case EP0_IDLE:
return "ep0_idle";
case EP0_IN:
return "ep0_in";
case EP0_OUT:
return "ep0_out";
case EP0_STATUS:
return "ep0_status";
case EP0_STALL:
return "ep0_stall";
case EP0_SUSPEND:
return "ep0_suspend";
}
return "ep0_?";
} }
static const char *udc_ep_status(u32 status)
{
switch (status & EPxSTATUS_EP_MASK) {
case EPxSTATUS_EP_READY:
return "ready";
case EPxSTATUS_EP_DATAIN:
return "packet";
case EPxSTATUS_EP_FULL:
return "full";
case EPxSTATUS_EP_TX_ERR: /* host will retry */
return "tx_err";
case EPxSTATUS_EP_RX_ERR:
return "rx_err";
case EPxSTATUS_EP_BUSY: /* ep0 only */
return "busy";
case EPxSTATUS_EP_STALL:
return "stall";
case EPxSTATUS_EP_INVALID: /* these "can't happen" */
return "invalid";
}
return "?";
}
static int udc_proc_read(struct seq_file *m, void *v) static int udc_proc_read(struct seq_file *m, void *v)
{ {
...@@ -1068,29 +1112,18 @@ static int udc_proc_read(struct seq_file *m, void *v) ...@@ -1068,29 +1112,18 @@ static int udc_proc_read(struct seq_file *m, void *v)
tmp = readl(&regs->power_detect); tmp = readl(&regs->power_detect);
is_usb_connected = tmp & PW_DETECT; is_usb_connected = tmp & PW_DETECT;
seq_printf(m, seq_printf(m,
"%s - %s\n" "%s - %s\n"
"%s version: %s %s\n" "%s version: %s %s\n"
"Gadget driver: %s\n" "Gadget driver: %s\n"
"Host %s, %s\n" "Host %s, %s\n"
"\n", "\n",
pci_name(dev->pdev), driver_desc, pci_name(dev->pdev), driver_desc,
driver_name, DRIVER_VERSION, dmastr(), driver_name, DRIVER_VERSION, dmastr(),
dev->driver ? dev->driver->driver.name : "(none)", dev->driver ? dev->driver->driver.name : "(none)",
is_usb_connected is_usb_connected
? ((tmp & PW_PULLUP) ? "full speed" : "powered") ? ((tmp & PW_PULLUP) ? "full speed" : "powered")
: "disconnected", : "disconnected",
({const char *state; udc_ep_state(dev->ep0state));
switch(dev->ep0state){
case EP0_DISCONNECT: state = "ep0_disconnect"; break;
case EP0_IDLE: state = "ep0_idle"; break;
case EP0_IN: state = "ep0_in"; break;
case EP0_OUT: state = "ep0_out"; break;
case EP0_STATUS: state = "ep0_status"; break;
case EP0_STALL: state = "ep0_stall"; break;
case EP0_SUSPEND: state = "ep0_suspend"; break;
default: state = "ep0_?"; break;
} state; })
);
dump_intmask(m, "int_status", readl(&regs->int_status)); dump_intmask(m, "int_status", readl(&regs->int_status));
dump_intmask(m, "int_enable", readl(&regs->int_enable)); dump_intmask(m, "int_enable", readl(&regs->int_enable));
...@@ -1099,31 +1132,30 @@ static int udc_proc_read(struct seq_file *m, void *v) ...@@ -1099,31 +1132,30 @@ static int udc_proc_read(struct seq_file *m, void *v)
goto done; goto done;
/* registers for (active) device and ep0 */ /* registers for (active) device and ep0 */
if (seq_printf(m, "\nirqs %lu\ndataset %02x " seq_printf(m, "\nirqs %lu\ndataset %02x single.bcs %02x.%02x state %x addr %u\n",
"single.bcs %02x.%02x state %x addr %u\n", dev->irqs, readl(&regs->DataSet),
dev->irqs, readl(&regs->DataSet), readl(&regs->EPxSingle), readl(&regs->EPxBCS),
readl(&regs->EPxSingle), readl(&regs->EPxBCS), readl(&regs->UsbState),
readl(&regs->UsbState), readl(&regs->address));
readl(&regs->address)) < 0) if (seq_has_overflowed(m))
goto done; goto done;
tmp = readl(&regs->dma_master); tmp = readl(&regs->dma_master);
if (seq_printf(m, seq_printf(m, "dma %03X =" EIGHTBITS "%s %s\n",
"dma %03X =" EIGHTBITS "%s %s\n", tmp, tmp,
(tmp & MST_EOPB_DIS) ? " eopb-" : "", (tmp & MST_EOPB_DIS) ? " eopb-" : "",
(tmp & MST_EOPB_ENA) ? " eopb+" : "", (tmp & MST_EOPB_ENA) ? " eopb+" : "",
(tmp & MST_TIMEOUT_DIS) ? " tmo-" : "", (tmp & MST_TIMEOUT_DIS) ? " tmo-" : "",
(tmp & MST_TIMEOUT_ENA) ? " tmo+" : "", (tmp & MST_TIMEOUT_ENA) ? " tmo+" : "",
(tmp & MST_RD_EOPB) ? " eopb" : "", (tmp & MST_RD_EOPB) ? " eopb" : "",
(tmp & MST_RD_RESET) ? " in_reset" : "", (tmp & MST_RD_RESET) ? " in_reset" : "",
(tmp & MST_WR_RESET) ? " out_reset" : "", (tmp & MST_WR_RESET) ? " out_reset" : "",
(tmp & MST_RD_ENA) ? " IN" : "", (tmp & MST_RD_ENA) ? " IN" : "",
(tmp & MST_WR_ENA) ? " OUT" : "", (tmp & MST_WR_ENA) ? " OUT" : "",
(tmp & MST_CONNECTION) (tmp & MST_CONNECTION) ? "ep1in/ep2out" : "ep1out/ep2in");
? "ep1in/ep2out" if (seq_has_overflowed(m))
: "ep1out/ep2in") < 0)
goto done; goto done;
/* dump endpoint queues */ /* dump endpoint queues */
...@@ -1135,44 +1167,23 @@ static int udc_proc_read(struct seq_file *m, void *v) ...@@ -1135,44 +1167,23 @@ static int udc_proc_read(struct seq_file *m, void *v)
continue; continue;
tmp = readl(ep->reg_status); tmp = readl(ep->reg_status);
if (seq_printf(m, seq_printf(m, "%s %s max %u %s, irqs %lu, status %02x (%s) " FOURBITS "\n",
"%s %s max %u %s, irqs %lu, " ep->ep.name,
"status %02x (%s) " FOURBITS "\n", ep->is_in ? "in" : "out",
ep->ep.name, ep->ep.maxpacket,
ep->is_in ? "in" : "out", ep->dma ? "dma" : "pio",
ep->ep.maxpacket, ep->irqs,
ep->dma ? "dma" : "pio", tmp, udc_ep_status(tmp),
ep->irqs, (tmp & EPxSTATUS_TOGGLE) ? "data1" : "data0",
tmp, ({ char *s; (tmp & EPxSTATUS_SUSPEND) ? " suspend" : "",
switch (tmp & EPxSTATUS_EP_MASK) { (tmp & EPxSTATUS_FIFO_DISABLE) ? " disable" : "",
case EPxSTATUS_EP_READY: (tmp & EPxSTATUS_STAGE_ERROR) ? " ep0stat" : "");
s = "ready"; break; if (seq_has_overflowed(m))
case EPxSTATUS_EP_DATAIN:
s = "packet"; break;
case EPxSTATUS_EP_FULL:
s = "full"; break;
case EPxSTATUS_EP_TX_ERR: // host will retry
s = "tx_err"; break;
case EPxSTATUS_EP_RX_ERR:
s = "rx_err"; break;
case EPxSTATUS_EP_BUSY: /* ep0 only */
s = "busy"; break;
case EPxSTATUS_EP_STALL:
s = "stall"; break;
case EPxSTATUS_EP_INVALID: // these "can't happen"
s = "invalid"; break;
default:
s = "?"; break;
} s; }),
(tmp & EPxSTATUS_TOGGLE) ? "data1" : "data0",
(tmp & EPxSTATUS_SUSPEND) ? " suspend" : "",
(tmp & EPxSTATUS_FIFO_DISABLE) ? " disable" : "",
(tmp & EPxSTATUS_STAGE_ERROR) ? " ep0stat" : ""
) < 0)
goto done; goto done;
if (list_empty(&ep->queue)) { if (list_empty(&ep->queue)) {
if (seq_puts(m, "\t(nothing queued)\n") < 0) seq_puts(m, "\t(nothing queued)\n");
if (seq_has_overflowed(m))
goto done; goto done;
continue; continue;
} }
...@@ -1187,10 +1198,10 @@ static int udc_proc_read(struct seq_file *m, void *v) ...@@ -1187,10 +1198,10 @@ static int udc_proc_read(struct seq_file *m, void *v)
} else } else
tmp = req->req.actual; tmp = req->req.actual;
if (seq_printf(m, seq_printf(m, "\treq %p len %u/%u buf %p\n",
"\treq %p len %u/%u buf %p\n", &req->req, tmp, req->req.length,
&req->req, tmp, req->req.length, req->req.buf);
req->req.buf) < 0) if (seq_has_overflowed(m))
goto done; goto done;
} }
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册