|
|
|
/*
|
|
|
|
* TI DaVinci EMAC platform support
|
|
|
|
*
|
|
|
|
* Author: Kevin Hilman, Deep Root Systems, LLC
|
|
|
|
*
|
|
|
|
* 2007 (c) Deep Root Systems, LLC. This file is licensed under
|
|
|
|
* the terms of the GNU General Public License version 2. This program
|
|
|
|
* is licensed "as is" without any warranty of any kind, whether express
|
|
|
|
* or implied.
|
|
|
|
*/
|
|
|
|
#ifndef _LINUX_DAVINCI_EMAC_H
|
|
|
|
#define _LINUX_DAVINCI_EMAC_H
|
|
|
|
|
|
|
|
#include <linux/if_ether.h>
|
|
|
|
#include <linux/memory.h>
|
|
|
|
|
|
|
|
struct mdio_platform_data {
|
|
|
|
unsigned long bus_freq;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct emac_platform_data {
|
|
|
|
char mac_addr[ETH_ALEN];
|
|
|
|
u32 ctrl_reg_offset;
|
|
|
|
u32 ctrl_mod_reg_offset;
|
|
|
|
u32 ctrl_ram_offset;
|
|
|
|
u32 hw_ram_addr;
|
|
|
|
u32 ctrl_ram_size;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* phy_id can be one of the following:
|
|
|
|
* - NULL : use the first phy on the bus,
|
|
|
|
* - "" : force to 100/full, no mdio control
|
|
|
|
* - "<bus>:<addr>" : use the specified bus and phy
|
|
|
|
*/
|
|
|
|
const char *phy_id;
|
|
|
|
|
|
|
|
u8 rmii_en;
|
|
|
|
u8 version;
|
|
|
|
bool no_bd_ram;
|
|
|
|
void (*interrupt_enable) (void);
|
|
|
|
void (*interrupt_disable) (void);
|
|
|
|
};
|
|
|
|
|
|
|
|
enum {
|
|
|
|
EMAC_VERSION_1, /* DM644x */
|
|
|
|
EMAC_VERSION_2, /* DM646x */
|
|
|
|
};
|
|
|
|
|
|
|
|
void davinci_get_mac_addr(struct memory_accessor *mem_acc, void *context);
|
|
|
|
#endif
|