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#ifndef _MCS7780_H
29#define _MCS7780_H
30
31#define MCS_MODE_SIR 0
32#define MCS_MODE_MIR 1
33#define MCS_MODE_FIR 2
34
35#define MCS_CTRL_TIMEOUT 500
36#define MCS_XMIT_TIMEOUT 500
37
38#define MCS_TSC_VISHAY 0
39#define MCS_TSC_AGILENT 1
40#define MCS_TSC_SHARP 2
41
42
43#define MCS_RD_RTYPE 0xC0
44#define MCS_WR_RTYPE 0x40
45#define MCS_RDREQ 0x0F
46#define MCS_WRREQ 0x0E
47
48
49#define MCS_MODE_REG 0
50#define MCS_FIR ((__u16)0x0001)
51#define MCS_SIR16US ((__u16)0x0002)
52#define MCS_BBTG ((__u16)0x0004)
53#define MCS_ASK ((__u16)0x0008)
54#define MCS_PARITY ((__u16)0x0010)
55
56
57#define MCS_SPEED_SHIFT 5
58#define MCS_SPEED_MASK ((__u16)0x00E0)
59#define MCS_SPEED(x) ((x & MCS_SPEED_MASK) >> MCS_SPEED_SHIFT)
60#define MCS_SPEED_2400 ((0 << MCS_SPEED_SHIFT) & MCS_SPEED_MASK)
61#define MCS_SPEED_9600 ((1 << MCS_SPEED_SHIFT) & MCS_SPEED_MASK)
62#define MCS_SPEED_19200 ((2 << MCS_SPEED_SHIFT) & MCS_SPEED_MASK)
63#define MCS_SPEED_38400 ((3 << MCS_SPEED_SHIFT) & MCS_SPEED_MASK)
64#define MCS_SPEED_57600 ((4 << MCS_SPEED_SHIFT) & MCS_SPEED_MASK)
65#define MCS_SPEED_115200 ((5 << MCS_SPEED_SHIFT) & MCS_SPEED_MASK)
66#define MCS_SPEED_576000 ((6 << MCS_SPEED_SHIFT) & MCS_SPEED_MASK)
67#define MCS_SPEED_1152000 ((7 << MCS_SPEED_SHIFT) & MCS_SPEED_MASK)
68
69#define MCS_PLLPWDN ((__u16)0x0100)
70#define MCS_DRIVER ((__u16)0x0200)
71#define MCS_DTD ((__u16)0x0400)
72#define MCS_DIR ((__u16)0x0800)
73#define MCS_SIPEN ((__u16)0x1000)
74#define MCS_SENDSIP ((__u16)0x2000)
75#define MCS_CHGDIR ((__u16)0x4000)
76#define MCS_RESET ((__u16)0x8000)
77
78
79#define MCS_XCVR_REG 2
80#define MCS_MODE0 ((__u16)0x0001)
81#define MCS_STFIR ((__u16)0x0002)
82#define MCS_XCVR_CONF ((__u16)0x0004)
83#define MCS_RXFAST ((__u16)0x0008)
84
85#define MCS_TXCUR_SHIFT 4
86#define MCS_TXCUR_MASK ((__u16)0x0070)
87#define MCS_TXCUR(x) ((x & MCS_TXCUR_MASK) >> MCS_TXCUR_SHIFT)
88#define MCS_SETTXCUR(x,y) \
89 ((x & ~MCS_TXCUR_MASK) | (y << MCS_TXCUR_SHIFT) & MCS_TXCUR_MASK)
90
91#define MCS_MODE1 ((__u16)0x0080)
92#define MCS_SMODE0 ((__u16)0x0100)
93#define MCS_SMODE1 ((__u16)0x0200)
94#define MCS_INVTX ((__u16)0x0400)
95#define MCS_INVRX ((__u16)0x0800)
96
97#define MCS_MINRXPW_REG 4
98
99#define MCS_RESV_REG 7
100#define MCS_IRINTX ((__u16)0x0001)
101#define MCS_IRINRX ((__u16)0x0002)
102
103struct mcs_cb {
104 struct usb_device *usbdev;
105 struct net_device *netdev;
106 struct irlap_cb *irlap;
107 struct qos_info qos;
108 unsigned int speed;
109 unsigned int new_speed;
110
111 struct work_struct work;
112
113 struct sk_buff *tx_pending;
114 char in_buf[4096];
115 char out_buf[4096];
116 __u8 *fifo_status;
117
118 iobuff_t rx_buff;
119 struct timeval rx_time;
120 spinlock_t lock;
121 int receiving;
122
123 __u8 ep_in;
124 __u8 ep_out;
125
126 struct urb *rx_urb;
127 struct urb *tx_urb;
128
129 int transceiver_type;
130 int sir_tweak;
131 int receive_mode;
132};
133
134static int mcs_set_reg(struct mcs_cb *mcs, __u16 reg, __u16 val);
135static int mcs_get_reg(struct mcs_cb *mcs, __u16 reg, __u16 * val);
136
137static inline int mcs_setup_transceiver_vishay(struct mcs_cb *mcs);
138static inline int mcs_setup_transceiver_agilent(struct mcs_cb *mcs);
139static inline int mcs_setup_transceiver_sharp(struct mcs_cb *mcs);
140static inline int mcs_setup_transceiver(struct mcs_cb *mcs);
141static inline int mcs_wrap_sir_skb(struct sk_buff *skb, __u8 * buf);
142static unsigned mcs_wrap_fir_skb(const struct sk_buff *skb, __u8 *buf);
143static unsigned mcs_wrap_mir_skb(const struct sk_buff *skb, __u8 *buf);
144static void mcs_unwrap_mir(struct mcs_cb *mcs, __u8 *buf, int len);
145static void mcs_unwrap_fir(struct mcs_cb *mcs, __u8 *buf, int len);
146static inline int mcs_setup_urbs(struct mcs_cb *mcs);
147static inline int mcs_receive_start(struct mcs_cb *mcs);
148static inline int mcs_find_endpoints(struct mcs_cb *mcs,
149 struct usb_host_endpoint *ep, int epnum);
150
151static int mcs_speed_change(struct mcs_cb *mcs);
152
153static int mcs_net_ioctl(struct net_device *netdev, struct ifreq *rq, int cmd);
154static int mcs_net_close(struct net_device *netdev);
155static int mcs_net_open(struct net_device *netdev);
156
157static void mcs_receive_irq(struct urb *urb);
158static void mcs_send_irq(struct urb *urb);
159static netdev_tx_t mcs_hard_xmit(struct sk_buff *skb,
160 struct net_device *netdev);
161
162static int mcs_probe(struct usb_interface *intf,
163 const struct usb_device_id *id);
164static void mcs_disconnect(struct usb_interface *intf);
165
166#endif
167