cpsw.h 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  1. /* Texas Instruments Ethernet Switch Driver
  2. *
  3. * Copyright (C) 2013 Texas Instruments
  4. *
  5. * This program is free software; you can redistribute it and/or
  6. * modify it under the terms of the GNU General Public License
  7. * version 2 as published by the Free Software Foundation.
  8. *
  9. * This program is distributed "as is" WITHOUT ANY WARRANTY of any
  10. * kind, whether express or implied; without even the implied warranty
  11. * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  12. * GNU General Public License for more details.
  13. */
  14. #ifndef __CPSW_H__
  15. #define __CPSW_H__
  16. #include <linux/if_ether.h>
  17. #include <linux/phy.h>
  18. struct cpsw_slave_data {
  19. struct device_node *phy_node;
  20. char phy_id[MII_BUS_ID_SIZE];
  21. int phy_if;
  22. u8 mac_addr[ETH_ALEN];
  23. u16 dual_emac_res_vlan; /* Reserved VLAN for DualEMAC */
  24. };
  25. struct cpsw_platform_data {
  26. struct cpsw_slave_data *slave_data;
  27. u32 ss_reg_ofs; /* Subsystem control register offset */
  28. u32 channels; /* number of cpdma channels (symmetric) */
  29. u32 slaves; /* number of slave cpgmac ports */
  30. u32 active_slave; /* time stamping, ethtool and SIOCGMIIPHY slave */
  31. u32 cpts_clock_mult; /* convert input clock ticks to nanoseconds */
  32. u32 cpts_clock_shift; /* convert input clock ticks to nanoseconds */
  33. u32 ale_entries; /* ale table size */
  34. u32 bd_ram_size; /*buffer descriptor ram size */
  35. u32 rx_descs; /* Number of Rx Descriptios */
  36. u32 mac_control; /* Mac control register */
  37. u16 default_vlan; /* Def VLAN for ALE lookup in VLAN aware mode*/
  38. bool dual_emac; /* Enable Dual EMAC mode */
  39. };
  40. void cpsw_phy_sel(struct device *dev, phy_interface_t phy_mode, int slave);
  41. int ti_cm_get_macid(struct device *dev, int slave, u8 *mac_addr);
  42. #endif /* __CPSW_H__ */