summaryrefslogtreecommitdiffstats
path: root/include/linux/usb_isp116x.h
blob: 0d21407ccfc2657bf59df44c9f4dd8f210cf4c71 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
/*
 * Board initialization code should put one of these into dev->platform_data
 * and place the isp116x onto platform_bus.
 */

struct isp116x_platform_data {
	/* Enable internal resistors on downstream ports */
	unsigned sel15Kres:1;
	/* On-chip overcurrent protection */
	unsigned oc_enable:1;
	/* INT output polarity */
	unsigned int_act_high:1;
	/* INT edge or level triggered */
	unsigned int_edge_triggered:1;
	/* Enable wakeup by devices on usb bus (e.g. wakeup
	   by attachment/detachment or by device activity
	   such as moving a mouse). When chosen, this option
	   prevents stopping internal clock, increasing
	   thereby power consumption in suspended state. */
	unsigned remote_wakeup_enable:1;
	/* Switch or not to switch (keep always powered) */
	unsigned no_power_switching:1;
	/* Ganged port power switching (0) or individual port
	   power switching (1) */
	unsigned power_switching_mode:1;
	/* Hardware reset set/clear. If implemented, this function must:
	   if set == 0,   deassert chip's HW reset pin
	   otherwise,     assert chip's HW reset pin       */
	void (*reset) (struct device * dev, int set);
	/* Hardware clock start/stop. If implemented, this function must:
	   if start == 0,    stop the external clock
	   otherwise,        start the external clock
	 */
	void (*clock) (struct device * dev, int start);
	/* Inter-io delay (ns). The chip is picky about access timings; it
	   expects at least:
	   150ns delay between consecutive accesses to DATA_REG,
	   300ns delay between access to ADDR_REG and DATA_REG
	   OE, WE MUST NOT be changed during these intervals
	 */
	void (*delay) (struct device * dev, int delay);
};