aboutsummaryrefslogtreecommitdiffstats
path: root/include/linux/usb/musb.h
diff options
context:
space:
mode:
Diffstat (limited to 'include/linux/usb/musb.h')
-rw-r--r--include/linux/usb/musb.h38
1 files changed, 33 insertions, 5 deletions
diff --git a/include/linux/usb/musb.h b/include/linux/usb/musb.h
index d325a0d5bf4f..630962c04ca4 100644
--- a/include/linux/usb/musb.h
+++ b/include/linux/usb/musb.h
@@ -19,6 +19,36 @@ enum musb_mode {
19 19
20struct clk; 20struct clk;
21 21
22struct musb_hdrc_eps_bits {
23 const char name[16];
24 u8 bits;
25};
26
27struct musb_hdrc_config {
28 /* MUSB configuration-specific details */
29 unsigned multipoint:1; /* multipoint device */
30 unsigned dyn_fifo:1; /* supports dynamic fifo sizing */
31 unsigned soft_con:1; /* soft connect required */
32 unsigned utm_16:1; /* utm data witdh is 16 bits */
33 unsigned big_endian:1; /* true if CPU uses big-endian */
34 unsigned mult_bulk_tx:1; /* Tx ep required for multbulk pkts */
35 unsigned mult_bulk_rx:1; /* Rx ep required for multbulk pkts */
36 unsigned high_iso_tx:1; /* Tx ep required for HB iso */
37 unsigned high_iso_rx:1; /* Rx ep required for HD iso */
38 unsigned dma:1; /* supports DMA */
39 unsigned vendor_req:1; /* vendor registers required */
40
41 u8 num_eps; /* number of endpoints _with_ ep0 */
42 u8 dma_channels; /* number of dma channels */
43 u8 dyn_fifo_size; /* dynamic size in bytes */
44 u8 vendor_ctrl; /* vendor control reg width */
45 u8 vendor_stat; /* vendor status reg witdh */
46 u8 dma_req_chan; /* bitmask for required dma channels */
47 u8 ram_bits; /* ram address size */
48
49 struct musb_hdrc_eps_bits *eps_bits;
50};
51
22struct musb_hdrc_platform_data { 52struct musb_hdrc_platform_data {
23 /* MUSB_HOST, MUSB_PERIPHERAL, or MUSB_OTG */ 53 /* MUSB_HOST, MUSB_PERIPHERAL, or MUSB_OTG */
24 u8 mode; 54 u8 mode;
@@ -38,16 +68,14 @@ struct musb_hdrc_platform_data {
38 /* (HOST or OTG) msec/2 after VBUS on till power good */ 68 /* (HOST or OTG) msec/2 after VBUS on till power good */
39 u8 potpgt; 69 u8 potpgt;
40 70
41 /* TBD: chip defaults should probably go someplace else,
42 * e.g. number of tx/rx endpoints, etc
43 */
44 unsigned multipoint:1;
45
46 /* Power the device on or off */ 71 /* Power the device on or off */
47 int (*set_power)(int state); 72 int (*set_power)(int state);
48 73
49 /* Turn device clock on or off */ 74 /* Turn device clock on or off */
50 int (*set_clock)(struct clk *clock, int is_on); 75 int (*set_clock)(struct clk *clock, int is_on);
76
77 /* MUSB configuration-specific details */
78 struct musb_hdrc_config *config;
51}; 79};
52 80
53 81