OpenCores
URL https://opencores.org/ocsvn/or1k/or1k/trunk

Subversion Repositories or1k

[/] [or1k/] [trunk/] [linux/] [linux-2.4/] [drivers/] [usb/] [pegasus.h] - Blame information for rev 1780

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 1275 phoenix
/*
2
 * Copyright (c) 1999-2003 Petko Manolov - Petkan (petkan@users.sourceforge.net)
3
 *
4
 * This program is free software; you can redistribute it and/or modify
5
 * it under the terms of the GNU General Public License version 2 as published
6
 * by the Free Software Foundation.
7
 *
8
 */
9
 
10
 
11
#ifndef PEGASUS_DEV
12
 
13
#define PEGASUS_II              0x80000000
14
#define HAS_HOME_PNA            0x40000000
15
 
16
#define PEGASUS_MTU             1500
17
#define PEGASUS_MAX_MTU         1536
18
 
19
#define EPROM_WRITE             0x01
20
#define EPROM_READ              0x02
21
#define EPROM_DONE              0x04
22
#define EPROM_WR_ENABLE         0x10
23
#define EPROM_LOAD              0x20
24
 
25
#define PHY_DONE                0x80
26
#define PHY_READ                0x40
27
#define PHY_WRITE               0x20
28
#define DEFAULT_GPIO_RESET      0x24
29
#define LINKSYS_GPIO_RESET      0x24
30
#define DEFAULT_GPIO_SET        0x26
31
 
32
#define PEGASUS_PRESENT         0x00000001
33
#define PEGASUS_RUNNING         0x00000002
34
#define PEGASUS_TX_BUSY         0x00000004
35
#define PEGASUS_RX_BUSY         0x00000008
36
#define CTRL_URB_RUNNING        0x00000010
37
#define CTRL_URB_SLEEP          0x00000020
38
#define PEGASUS_UNPLUG          0x00000040
39
#define ETH_REGS_CHANGE         0x40000000
40
#define ETH_REGS_CHANGED        0x80000000
41
 
42
#define RX_MULTICAST            2
43
#define RX_PROMISCUOUS          4
44
 
45
#define REG_TIMEOUT             (HZ)
46
#define PEGASUS_TX_TIMEOUT      (HZ*10)
47
 
48
#define TX_UNDERRUN             0x80
49
#define EXCESSIVE_COL           0x40
50
#define LATE_COL                0x20
51
#define NO_CARRIER              0x10
52
#define LOSS_CARRIER            0x08
53
#define JABBER_TIMEOUT          0x04
54
 
55
#define LINK_STATUS             0x01
56
 
57
#define PEGASUS_REQT_READ       0xc0
58
#define PEGASUS_REQT_WRITE      0x40
59
#define PEGASUS_REQ_GET_REGS    0xf0
60
#define PEGASUS_REQ_SET_REGS    0xf1
61
#define PEGASUS_REQ_SET_REG     PEGASUS_REQ_SET_REGS
62
 
63
enum pegasus_registers {
64
        EthCtrl0 = 0,
65
        EthCtrl1 = 1,
66
        EthCtrl2 = 2,
67
        EthID = 0x10,
68
        Reg1d = 0x1d,
69
        EpromOffset = 0x20,
70
        EpromData = 0x21,       /* 0x21 low, 0x22 high byte */
71
        EpromCtrl = 0x23,
72
        PhyAddr = 0x25,
73
        PhyData = 0x26,         /* 0x26 low, 0x27 high byte */
74
        PhyCtrl = 0x28,
75
        UsbStst = 0x2a,
76
        EthTxStat0 = 0x2b,
77
        EthTxStat1 = 0x2c,
78
        EthRxStat = 0x2d,
79
        Reg7b = 0x7b,
80
        Gpio0 = 0x7e,
81
        Gpio1 = 0x7f,
82
        Reg81 = 0x81,
83
};
84
 
85
 
86
typedef struct pegasus {
87
        struct usb_device       *usb;
88
        struct net_device       *net;
89
        struct net_device_stats stats;
90
        struct mii_if_info      mii;
91
        unsigned                flags;
92
        unsigned                features;
93
        int                     dev_index;
94
        int                     intr_interval;
95
        struct urb              *ctrl_urb, *rx_urb, *tx_urb, *intr_urb;
96
        struct usb_ctrlrequest  dr;
97
        wait_queue_head_t       ctrl_wait;
98
        struct semaphore        sem;
99
        int                     chip;
100
        unsigned char           rx_buff[PEGASUS_MAX_MTU];
101
        unsigned char           tx_buff[PEGASUS_MAX_MTU];
102
        unsigned char           intr_buff[8];
103
        __u8                    eth_regs[4];
104
        __u8                    phy;
105
        __u8                    gpio_res;
106
} pegasus_t;
107
 
108
 
109
struct usb_eth_dev {
110
        char    *name;
111
        __u16   vendor;
112
        __u16   device;
113
        __u32   private; /* LSB is gpio reset value */
114
};
115
 
116
#define VENDOR_3COM             0x0506
117
#define VENDOR_ABOCOM           0x07b8
118
#define VENDOR_ACCTON           0x083a
119
#define VENDOR_ADMTEK           0x07a6
120
#define VENDOR_AEILAB           0x3334
121
#define VENDOR_ALLIEDTEL        0x07c9
122
#define VENDOR_BELKIN           0x050d
123
#define VENDOR_BILLIONTON       0x08dd
124
#define VENDOR_COMPAQ           0x049f
125
#define VENDOR_COREGA           0x07aa
126
#define VENDOR_DLINK            0x2001
127
#define VENDOR_ELCON            0x0db7
128
#define VENDOR_ELSA             0x05cc
129
#define VENDOR_GIGABYTE         0x1044
130
#define VENDOR_HAWKING          0x0e66
131
#define VENDOR_HP               0x03f0
132
#define VENDOR_IODATA           0x04bb
133
#define VENDOR_KINGSTON         0x0951
134
#define VENDOR_LANEED           0x056e
135
#define VENDOR_LINKSYS          0x066b
136
#define VENDOR_MELCO            0x0411
137
#define VENDOR_MICROSOFT        0x045e
138
#define VENDOR_MOBILITY         0x1342
139
#define VENDOR_NETGEAR          0x0846
140
#define VENDOR_OCT              0x0b39
141
#define VENDOR_SMARTBRIDGES     0x08d1
142
#define VENDOR_SMC              0x0707
143
#define VENDOR_SOHOWARE         0x15e8
144
#define VENDOR_SIEMENS          0x067c
145
 
146
#else   /* PEGASUS_DEV */
147
 
148
PEGASUS_DEV( "3Com USB Ethernet 3C460B", VENDOR_3COM, 0x4601,
149
                DEFAULT_GPIO_RESET | PEGASUS_II )
150
PEGASUS_DEV( "USB HPNA/Ethernet", VENDOR_ABOCOM, 0x110c,
151
                DEFAULT_GPIO_RESET | PEGASUS_II | HAS_HOME_PNA )
152
PEGASUS_DEV( "USB HPNA/Ethernet", VENDOR_ABOCOM, 0x4104,
153
                DEFAULT_GPIO_RESET | HAS_HOME_PNA )
154
PEGASUS_DEV( "USB HPNA/Ethernet", VENDOR_ABOCOM, 0x4004,
155
                DEFAULT_GPIO_RESET | HAS_HOME_PNA )
156
PEGASUS_DEV( "USB HPNA/Ethernet", VENDOR_ABOCOM, 0x4007,
157
                DEFAULT_GPIO_RESET | HAS_HOME_PNA )
158
PEGASUS_DEV( "USB 10/100 Fast Ethernet", VENDOR_ABOCOM, 0x4102,
159
                DEFAULT_GPIO_RESET | PEGASUS_II )
160
PEGASUS_DEV( "USB 10/100 Fast Ethernet", VENDOR_ABOCOM, 0x4002,
161
                DEFAULT_GPIO_RESET )
162
PEGASUS_DEV( "USB 10/100 Fast Ethernet", VENDOR_ABOCOM, 0x400b,
163
                DEFAULT_GPIO_RESET | PEGASUS_II )
164
PEGASUS_DEV( "USB 10/100 Fast Ethernet", VENDOR_ABOCOM, 0x400c,
165
                DEFAULT_GPIO_RESET | PEGASUS_II )
166
PEGASUS_DEV( "USB 10/100 Fast Ethernet", VENDOR_ABOCOM, 0xabc1,
167
                DEFAULT_GPIO_RESET )
168
PEGASUS_DEV( "USB 10/100 Fast Ethernet", VENDOR_ABOCOM, 0x200c,
169
                DEFAULT_GPIO_RESET | PEGASUS_II )
170
PEGASUS_DEV( "Accton USB 10/100 Ethernet Adapter", VENDOR_ACCTON, 0x1046,
171
                DEFAULT_GPIO_RESET )
172
PEGASUS_DEV( "SpeedStream USB 10/100 Ethernet", VENDOR_ACCTON, 0x5046,
173
                DEFAULT_GPIO_RESET | PEGASUS_II )
174
PEGASUS_DEV( "ADMtek ADM8511 \"Pegasus II\" USB Ethernet",
175
                VENDOR_ADMTEK, 0x8511,
176
                DEFAULT_GPIO_RESET | PEGASUS_II | HAS_HOME_PNA )
177
PEGASUS_DEV( "ADMtek ADM8513 \"Pegasus II\" USB Ethernet",
178
                VENDOR_ADMTEK, 0x8513,
179
                DEFAULT_GPIO_RESET | PEGASUS_II )
180
PEGASUS_DEV( "ADMtek AN986 \"Pegasus\" USB Ethernet (evaluation board)",
181
                VENDOR_ADMTEK, 0x0986,
182
                DEFAULT_GPIO_RESET | HAS_HOME_PNA )
183
PEGASUS_DEV( "ADMtek AN986A USB MAC", VENDOR_ADMTEK, 0x1986,
184
                DEFAULT_GPIO_RESET | PEGASUS_II )
185
PEGASUS_DEV( "AEI USB Fast Ethernet Adapter", VENDOR_AEILAB, 0x1701,
186
                DEFAULT_GPIO_RESET | PEGASUS_II )
187
PEGASUS_DEV( "Allied Telesyn Int. AT-USB100", VENDOR_ALLIEDTEL, 0xb100,
188
                DEFAULT_GPIO_RESET | PEGASUS_II )
189
PEGASUS_DEV( "Belkin F5D5050 USB Ethernet", VENDOR_BELKIN, 0x0121,
190
                DEFAULT_GPIO_RESET | PEGASUS_II )
191
PEGASUS_DEV( "Billionton USB-100", VENDOR_BILLIONTON, 0x0986,
192
                DEFAULT_GPIO_RESET )
193
PEGASUS_DEV( "Billionton USBLP-100", VENDOR_BILLIONTON, 0x0987,
194
                DEFAULT_GPIO_RESET | HAS_HOME_PNA )
195
PEGASUS_DEV( "iPAQ Networking 10/100 USB", VENDOR_COMPAQ, 0x8511,
196
                DEFAULT_GPIO_RESET | PEGASUS_II )
197
PEGASUS_DEV( "Billionton USBEL-100", VENDOR_BILLIONTON, 0x0988,
198
                DEFAULT_GPIO_RESET )
199
PEGASUS_DEV( "Billionton USBE-100", VENDOR_BILLIONTON, 0x8511,
200
                DEFAULT_GPIO_RESET | PEGASUS_II )
201
PEGASUS_DEV( "Corega FEter USB-TX", VENDOR_COREGA, 0x0004,
202
                DEFAULT_GPIO_RESET )
203
PEGASUS_DEV( "Corega FEter USB-TXS", VENDOR_COREGA, 0x000d,
204
                DEFAULT_GPIO_RESET | PEGASUS_II )
205
PEGASUS_DEV( "D-Link DSB-650TX", VENDOR_DLINK, 0x4001,
206
                LINKSYS_GPIO_RESET )
207
PEGASUS_DEV( "D-Link DSB-650TX", VENDOR_DLINK, 0x4002,
208
                LINKSYS_GPIO_RESET )
209
PEGASUS_DEV( "D-Link DSB-650TX", VENDOR_DLINK, 0x4102,
210
                LINKSYS_GPIO_RESET | PEGASUS_II )
211
PEGASUS_DEV( "D-Link DSB-650TX", VENDOR_DLINK, 0x400b,
212
                LINKSYS_GPIO_RESET | PEGASUS_II )
213
PEGASUS_DEV( "D-Link DSB-650TX", VENDOR_DLINK, 0x200c,
214
                LINKSYS_GPIO_RESET | PEGASUS_II )
215
PEGASUS_DEV( "D-Link DSB-650TX(PNA)", VENDOR_DLINK, 0x4003,
216
                DEFAULT_GPIO_RESET | HAS_HOME_PNA )
217
PEGASUS_DEV( "D-Link DSB-650", VENDOR_DLINK, 0xabc1,
218
                DEFAULT_GPIO_RESET )
219
PEGASUS_DEV( "GOLDPFEIL USB Adapter", VENDOR_ELCON, 0x0002,
220
                DEFAULT_GPIO_RESET | PEGASUS_II | HAS_HOME_PNA )
221
PEGASUS_DEV( "EasiDock Ethernet", VENDOR_MOBILITY, 0x0304,
222
                DEFAULT_GPIO_RESET )
223
PEGASUS_DEV( "Elsa Micolink USB2Ethernet", VENDOR_ELSA, 0x3000,
224
                DEFAULT_GPIO_RESET )
225
PEGASUS_DEV( "GIGABYTE GN-BR402W Wireless Router", VENDOR_GIGABYTE, 0x8002,
226
                DEFAULT_GPIO_RESET )
227
PEGASUS_DEV( "Hawking UF100 10/100 Ethernet", VENDOR_HAWKING, 0x400c,
228
                DEFAULT_GPIO_RESET | PEGASUS_II )
229
PEGASUS_DEV( "HP hn210c Ethernet USB", VENDOR_HP, 0x811c,
230
                DEFAULT_GPIO_RESET | PEGASUS_II )
231
PEGASUS_DEV( "IO DATA USB ET/TX", VENDOR_IODATA, 0x0904,
232
                DEFAULT_GPIO_RESET )
233
PEGASUS_DEV( "IO DATA USB ET/TX-S", VENDOR_IODATA, 0x0913,
234
                DEFAULT_GPIO_RESET | PEGASUS_II )
235
PEGASUS_DEV( "Kingston KNU101TX Ethernet", VENDOR_KINGSTON, 0x000a,
236
                DEFAULT_GPIO_RESET)
237
PEGASUS_DEV( "LANEED USB Ethernet LD-USB/TX", VENDOR_LANEED, 0x4002,
238
                DEFAULT_GPIO_RESET )
239
PEGASUS_DEV( "LANEED USB Ethernet LD-USB/TX", VENDOR_LANEED, 0x400b,
240
                DEFAULT_GPIO_RESET | PEGASUS_II )
241
PEGASUS_DEV( "LANEED USB Ethernet LD-USB/T", VENDOR_LANEED, 0xabc1,
242
                DEFAULT_GPIO_RESET )
243
PEGASUS_DEV( "LANEED USB Ethernet LD-USB/TX", VENDOR_LANEED, 0x200c,
244
                DEFAULT_GPIO_RESET | PEGASUS_II )
245
PEGASUS_DEV( "Linksys USB10TX", VENDOR_LINKSYS, 0x2202,
246
                LINKSYS_GPIO_RESET )
247
PEGASUS_DEV( "Linksys USB100TX", VENDOR_LINKSYS, 0x2203,
248
                LINKSYS_GPIO_RESET )
249
PEGASUS_DEV( "Linksys USB100TX", VENDOR_LINKSYS, 0x2204,
250
                LINKSYS_GPIO_RESET | HAS_HOME_PNA )
251
PEGASUS_DEV( "Linksys USB10T Ethernet Adapter", VENDOR_LINKSYS, 0x2206,
252
                LINKSYS_GPIO_RESET | PEGASUS_II)
253
PEGASUS_DEV( "Linksys USB USB10TX", VENDOR_LINKSYS, 0x400b,
254
                LINKSYS_GPIO_RESET | PEGASUS_II )
255
PEGASUS_DEV( "Linksys USB10TX", VENDOR_LINKSYS, 0x200c,
256
                LINKSYS_GPIO_RESET | PEGASUS_II )
257
PEGASUS_DEV( "MELCO/BUFFALO LUA-TX", VENDOR_MELCO, 0x0001,
258
                DEFAULT_GPIO_RESET )
259
PEGASUS_DEV( "MELCO/BUFFALO LUA-TX", VENDOR_MELCO, 0x0005,
260
                DEFAULT_GPIO_RESET )
261
PEGASUS_DEV( "MELCO/BUFFALO LUA2-TX", VENDOR_MELCO, 0x0009,
262
                DEFAULT_GPIO_RESET | PEGASUS_II )
263
PEGASUS_DEV( "Microsoft MN-110", VENDOR_MICROSOFT, 0x007a,
264
                DEFAULT_GPIO_RESET | PEGASUS_II )
265
PEGASUS_DEV( "NETGEAR FA101", VENDOR_NETGEAR, 0x1020,
266
                DEFAULT_GPIO_RESET | PEGASUS_II )
267
PEGASUS_DEV( "OCT Inc.", VENDOR_OCT, 0x0109,
268
                DEFAULT_GPIO_RESET | PEGASUS_II )
269
PEGASUS_DEV( "OCT USB TO Ethernet", VENDOR_OCT, 0x0901,
270
                DEFAULT_GPIO_RESET | PEGASUS_II )
271
PEGASUS_DEV( "smartNIC 2 PnP Adapter", VENDOR_SMARTBRIDGES, 0x0003,
272
                DEFAULT_GPIO_RESET | PEGASUS_II )
273
PEGASUS_DEV( "SMC 202 USB Ethernet", VENDOR_SMC, 0x0200,
274
                DEFAULT_GPIO_RESET )
275
PEGASUS_DEV( "SMC 2206 USB Ethernet", VENDOR_SMC, 0x0201,
276
                DEFAULT_GPIO_RESET | PEGASUS_II )
277
PEGASUS_DEV( "SOHOware NUB100 Ethernet", VENDOR_SOHOWARE, 0x9100,
278
                DEFAULT_GPIO_RESET )
279
PEGASUS_DEV( "SOHOware NUB110 Ethernet", VENDOR_SOHOWARE, 0x9110,
280
                DEFAULT_GPIO_RESET | PEGASUS_II )
281
PEGASUS_DEV( "SpeedStream USB 10/100 Ethernet", VENDOR_SIEMENS, 0x1001,
282
                DEFAULT_GPIO_RESET | PEGASUS_II )
283
 
284
#endif  /* PEGASUS_DEV */

powered by: WebSVN 2.1.0

© copyright 1999-2025 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.