port.h 3.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. /*
  2. * Marvell 88E6xxx Switch Port Registers support
  3. *
  4. * Copyright (c) 2008 Marvell Semiconductor
  5. *
  6. * Copyright (c) 2016-2017 Savoir-faire Linux Inc.
  7. * Vivien Didelot <vivien.didelot@savoirfairelinux.com>
  8. *
  9. * This program is free software; you can redistribute it and/or modify
  10. * it under the terms of the GNU General Public License as published by
  11. * the Free Software Foundation; either version 2 of the License, or
  12. * (at your option) any later version.
  13. */
  14. #ifndef _MV88E6XXX_PORT_H
  15. #define _MV88E6XXX_PORT_H
  16. #include "mv88e6xxx.h"
  17. int mv88e6xxx_port_read(struct mv88e6xxx_chip *chip, int port, int reg,
  18. u16 *val);
  19. int mv88e6xxx_port_write(struct mv88e6xxx_chip *chip, int port, int reg,
  20. u16 val);
  21. int mv88e6352_port_set_rgmii_delay(struct mv88e6xxx_chip *chip, int port,
  22. phy_interface_t mode);
  23. int mv88e6390_port_set_rgmii_delay(struct mv88e6xxx_chip *chip, int port,
  24. phy_interface_t mode);
  25. int mv88e6xxx_port_set_link(struct mv88e6xxx_chip *chip, int port, int link);
  26. int mv88e6xxx_port_set_duplex(struct mv88e6xxx_chip *chip, int port, int dup);
  27. int mv88e6065_port_set_speed(struct mv88e6xxx_chip *chip, int port, int speed);
  28. int mv88e6185_port_set_speed(struct mv88e6xxx_chip *chip, int port, int speed);
  29. int mv88e6352_port_set_speed(struct mv88e6xxx_chip *chip, int port, int speed);
  30. int mv88e6390_port_set_speed(struct mv88e6xxx_chip *chip, int port, int speed);
  31. int mv88e6390x_port_set_speed(struct mv88e6xxx_chip *chip, int port, int speed);
  32. int mv88e6xxx_port_set_state(struct mv88e6xxx_chip *chip, int port, u8 state);
  33. int mv88e6xxx_port_set_vlan_map(struct mv88e6xxx_chip *chip, int port, u16 map);
  34. int mv88e6xxx_port_get_fid(struct mv88e6xxx_chip *chip, int port, u16 *fid);
  35. int mv88e6xxx_port_set_fid(struct mv88e6xxx_chip *chip, int port, u16 fid);
  36. int mv88e6xxx_port_get_pvid(struct mv88e6xxx_chip *chip, int port, u16 *pvid);
  37. int mv88e6xxx_port_set_pvid(struct mv88e6xxx_chip *chip, int port, u16 pvid);
  38. int mv88e6xxx_port_set_8021q_mode(struct mv88e6xxx_chip *chip, int port,
  39. u16 mode);
  40. int mv88e6095_port_tag_remap(struct mv88e6xxx_chip *chip, int port);
  41. int mv88e6390_port_tag_remap(struct mv88e6xxx_chip *chip, int port);
  42. int mv88e6xxx_port_set_egress_mode(struct mv88e6xxx_chip *chip, int port,
  43. u16 mode);
  44. int mv88e6085_port_set_frame_mode(struct mv88e6xxx_chip *chip, int port,
  45. enum mv88e6xxx_frame_mode mode);
  46. int mv88e6351_port_set_frame_mode(struct mv88e6xxx_chip *chip, int port,
  47. enum mv88e6xxx_frame_mode mode);
  48. int mv88e6185_port_set_egress_floods(struct mv88e6xxx_chip *chip, int port,
  49. bool unicast, bool multicast);
  50. int mv88e6352_port_set_egress_floods(struct mv88e6xxx_chip *chip, int port,
  51. bool unicast, bool multicast);
  52. int mv88e6351_port_set_ether_type(struct mv88e6xxx_chip *chip, int port,
  53. u16 etype);
  54. int mv88e6xxx_port_set_message_port(struct mv88e6xxx_chip *chip, int port,
  55. bool message_port);
  56. int mv88e6165_port_jumbo_config(struct mv88e6xxx_chip *chip, int port);
  57. int mv88e6095_port_egress_rate_limiting(struct mv88e6xxx_chip *chip, int port);
  58. int mv88e6097_port_egress_rate_limiting(struct mv88e6xxx_chip *chip, int port);
  59. int mv88e6097_port_pause_config(struct mv88e6xxx_chip *chip, int port);
  60. int mv88e6390_port_pause_config(struct mv88e6xxx_chip *chip, int port);
  61. int mv88e6390x_port_set_cmode(struct mv88e6xxx_chip *chip, int port,
  62. phy_interface_t mode);
  63. int mv88e6xxx_port_get_cmode(struct mv88e6xxx_chip *chip, int port, u8 *cmode);
  64. int mv88e6xxx_port_set_map_da(struct mv88e6xxx_chip *chip, int port);
  65. int mv88e6095_port_set_upstream_port(struct mv88e6xxx_chip *chip, int port,
  66. int upstream_port);
  67. int mv88e6xxx_port_disable_learn_limit(struct mv88e6xxx_chip *chip, int port);
  68. int mv88e6xxx_port_disable_pri_override(struct mv88e6xxx_chip *chip, int port);
  69. #endif /* _MV88E6XXX_PORT_H */