cpsw.h 1.28 KB
#ifndef __CPSW_H__
#define __CPSW_H__

#include <linux/if_ether.h>

enum {
	CPSW_VERSION_1 = 0,    /* TI8148 */
	CPSW_VERSION_2,        /* AM33XX */
};

struct cpsw_slave_data {
	u32		slave_reg_ofs;
	u32		sliver_reg_ofs;
	const char	*phy_id;
	int		phy_if;
	u8	mac_addr[ETH_ALEN];
};

struct cpsw_platform_data {
	u32	ss_reg_ofs;	/* Subsystem control register offset */
	int	channels;	/* number of cpdma channels (symmetric) */
	u32	cpdma_reg_ofs;	/* cpdma register offset */

	int	slaves;		/* number of slave cpgmac ports */
	struct cpsw_slave_data	*slave_data;

	u32	ale_reg_ofs;	/* address lookup engine reg offset */
	int	ale_entries;	/* ale table size */

	u32	host_port_reg_ofs; /* cpsw cpdma host port registers */

	u32	hw_stats_reg_ofs;  /* cpsw hardware statistics counters */

	u32	bd_ram_ofs;   /* embedded buffer descriptor RAM offset*/
	u32	bd_ram_size;  /*buffer descriptor ram size */
	u32	hw_ram_addr; /*if the HW address for BD RAM is different */

	u8	mac_addr[ETH_ALEN];

	int	rx_descs;

	void	(*phy_control)(bool enabled);

	u32	mac_control;

	u32	gigabit_en; /* Is gigabit capable AND enabled */
	u32	rmii_en; /* Is RMII mode capable AND enabled */
	u32	host_port_num; /* The port number for the host port */

	bool	no_bd_ram; /* no embedded BD ram*/
	u8	version;
};

#endif /* __CPSW_H__ */