blob: a04fd8c9fbdfd5743d76c000f377b676631cbd78 [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 mdio_reg_offset;
28 u32 ctrl_ram_size;
29 u32 phy_mask;
30 u32 mdio_max_freq;
31 u8 rmii_en;
32 u8 version;
Sriramakrishnan01a9af32009-11-19 15:58:26 +053033 void (*interrupt_enable) (void);
34 void (*interrupt_disable) (void);
Kevin Hilmanac7b75b2009-05-07 06:19:40 -070035};
36
37enum {
38 EMAC_VERSION_1, /* DM644x */
39 EMAC_VERSION_2, /* DM646x */
40};
Mark A. Greerb14dc0f2009-04-15 12:41:27 -070041
42void davinci_get_mac_addr(struct memory_accessor *mem_acc, void *context);
Kevin Hilmanac7b75b2009-05-07 06:19:40 -070043#endif