mv643xx_eth: configurable t_clk
[deliverable/linux.git] / include / linux / mv643xx_eth.h
1 /*
2 * MV-643XX ethernet platform device data definition file.
3 */
4
5 #ifndef __LINUX_MV643XX_ETH_H
6 #define __LINUX_MV643XX_ETH_H
7
8 #include <linux/mbus.h>
9
10 #define MV643XX_ETH_SHARED_NAME "mv643xx_eth_shared"
11 #define MV643XX_ETH_NAME "mv643xx_eth"
12 #define MV643XX_ETH_SHARED_REGS 0x2000
13 #define MV643XX_ETH_SHARED_REGS_SIZE 0x2000
14 #define MV643XX_ETH_BAR_4 0x2220
15 #define MV643XX_ETH_SIZE_REG_4 0x2224
16 #define MV643XX_ETH_BASE_ADDR_ENABLE_REG 0x2290
17
18 struct mv643xx_eth_shared_platform_data {
19 struct mbus_dram_target_info *dram;
20 unsigned int t_clk;
21 };
22
23 struct mv643xx_eth_platform_data {
24 struct platform_device *shared;
25 int port_number;
26
27 u16 force_phy_addr; /* force override if phy_addr == 0 */
28 u16 phy_addr;
29
30 /* If speed is 0, then speed and duplex are autonegotiated. */
31 int speed; /* 0, SPEED_10, SPEED_100, SPEED_1000 */
32 int duplex; /* DUPLEX_HALF or DUPLEX_FULL */
33
34 /* non-zero values of the following fields override defaults */
35 u32 tx_queue_size;
36 u32 rx_queue_size;
37 u32 tx_sram_addr;
38 u32 tx_sram_size;
39 u32 rx_sram_addr;
40 u32 rx_sram_size;
41 u8 mac_addr[6]; /* mac address if non-zero*/
42 };
43
44 #endif /* __LINUX_MV643XX_ETH_H */
This page took 0.042954 seconds and 6 git commands to generate.