blob: 5dd428532f794c387533633cba57e6e12957cb01 [file] [log] [blame]
Kevin Hilmanac7b75b2009-05-07 06:19:40 -07001/*
2 * TI DaVinci EMAC platform support
3 *
4 * Author: Kevin Hilman, Deep Root Systems, LLC
5 *
6 * 2007 (c) Deep Root Systems, LLC. This file is licensed under
7 * the terms of the GNU General Public License version 2. This program
8 * is licensed "as is" without any warranty of any kind, whether express
9 * or implied.
10 */
Sriramakrishnan8ee2bf92009-11-19 15:58:25 +053011#ifndef _LINUX_DAVINCI_EMAC_H
12#define _LINUX_DAVINCI_EMAC_H
Kevin Hilmanac7b75b2009-05-07 06:19:40 -070013
14#include <linux/if_ether.h>
Mark A. Greerb14dc0f2009-04-15 12:41:27 -070015#include <linux/memory.h>
Kevin Hilmanac7b75b2009-05-07 06:19:40 -070016
Cyril Chemparathyf20136e2010-09-15 10:11:21 -040017struct mdio_platform_data {
18 unsigned long bus_freq;
19};
20
Kevin Hilmanac7b75b2009-05-07 06:19:40 -070021struct emac_platform_data {
22 char mac_addr[ETH_ALEN];
23 u32 ctrl_reg_offset;
24 u32 ctrl_mod_reg_offset;
25 u32 ctrl_ram_offset;
Sriramakrishnanad021ae2009-11-19 15:58:27 +053026 u32 hw_ram_addr;
Kevin Hilmanac7b75b2009-05-07 06:19:40 -070027 u32 ctrl_ram_size;
Cyril Chemparathy5d69e002010-09-15 10:11:24 -040028
29 /*
30 * phy_id can be one of the following:
31 * - NULL : use the first phy on the bus,
32 * - "" : force to 100/full, no mdio control
33 * - "<bus>:<addr>" : use the specified bus and phy
34 */
35 const char *phy_id;
36
Kevin Hilmanac7b75b2009-05-07 06:19:40 -070037 u8 rmii_en;
38 u8 version;
Sriramakrishnan01a9af32009-11-19 15:58:26 +053039 void (*interrupt_enable) (void);
40 void (*interrupt_disable) (void);
Kevin Hilmanac7b75b2009-05-07 06:19:40 -070041};
42
43enum {
44 EMAC_VERSION_1, /* DM644x */
45 EMAC_VERSION_2, /* DM646x */
46};
Mark A. Greerb14dc0f2009-04-15 12:41:27 -070047
48void davinci_get_mac_addr(struct memory_accessor *mem_acc, void *context);
Kevin Hilmanac7b75b2009-05-07 06:19:40 -070049#endif