blob: 76199b75d5845d21cbcfb67786dfec757e30a446 [file] [log] [blame]
Magnus Damm3e947942008-02-22 19:55:15 +09001#ifndef __SMC91X_H__
2#define __SMC91X_H__
3
4#define SMC91X_USE_8BIT (1 << 0)
5#define SMC91X_USE_16BIT (1 << 1)
6#define SMC91X_USE_32BIT (1 << 2)
7
Eric Miaoc4f0e762008-06-19 17:39:03 +08008#define SMC91X_NOWAIT (1 << 3)
9
Eric Miao15919882008-06-24 13:38:50 +080010/* two bits for IO_SHIFT, let's hope later designs will keep this sane */
11#define SMC91X_IO_SHIFT_0 (0 << 4)
12#define SMC91X_IO_SHIFT_1 (1 << 4)
13#define SMC91X_IO_SHIFT_2 (2 << 4)
14#define SMC91X_IO_SHIFT_3 (3 << 4)
15#define SMC91X_IO_SHIFT(x) (((x) >> 4) & 0x3)
16
Eric Miao52256c02008-06-24 15:36:05 +080017#define SMC91X_USE_DMA (1 << 6)
18
Marc Zyngierfb683f12008-08-22 16:36:28 +020019#define RPC_LED_100_10 (0x00) /* LED = 100Mbps OR's with 10Mbps link detect */
20#define RPC_LED_RES (0x01) /* LED = Reserved */
21#define RPC_LED_10 (0x02) /* LED = 10Mbps link detect */
22#define RPC_LED_FD (0x03) /* LED = Full Duplex Mode */
23#define RPC_LED_TX_RX (0x04) /* LED = TX or RX packet occurred */
Lucas De Marchi25985ed2011-03-30 22:57:33 -030024#define RPC_LED_100 (0x05) /* LED = 100Mbps link detect */
Marc Zyngierfb683f12008-08-22 16:36:28 +020025#define RPC_LED_TX (0x06) /* LED = TX packet occurred */
26#define RPC_LED_RX (0x07) /* LED = RX packet occurred */
27
Magnus Damm3e947942008-02-22 19:55:15 +090028struct smc91x_platdata {
29 unsigned long flags;
Russell Kingb0dbcf52008-09-04 21:13:37 +010030 unsigned char leda;
31 unsigned char ledb;
Magnus Damm3e947942008-02-22 19:55:15 +090032};
33
34#endif /* __SMC91X_H__ */