aboutsummaryrefslogtreecommitdiffstats
path: root/include/linux/usb
diff options
context:
space:
mode:
authorFelipe Balbi <felipe.balbi@nokia.com>2008-08-08 05:40:54 -0400
committerGreg Kroah-Hartman <gregkh@suse.de>2008-08-13 20:33:01 -0400
commitca6d1b1333bc2e61e37982de1f28d8604c232414 (patch)
tree6675d284fc932e9125fc7fd083eebb7f0a1d5695 /include/linux/usb
parentf362a47560070ec0aaf68ac6b45901eeed1c844f (diff)
usb: musb: pass configuration specifics via pdata
Use platform_data to pass musb configuration-specific details to musb driver. This patch will prevent that other platforms selecting HAVE_CLK and enabling musb won't break tree building. The other parts of it will come when linux-omap merge up more omap2/3 board-files. Signed-off-by: Felipe Balbi <felipe.balbi@nokia.com> Acked-by: Paul Mundt <lethal@linux-sh.org> Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Diffstat (limited to 'include/linux/usb')
-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