| /* |
| * Copyright (c) 2014-2015, The Linux Foundation. All rights reserved. |
| * Permission to use, copy, modify, and/or distribute this software for |
| * any purpose with or without fee is hereby granted, provided that the |
| * above copyright notice and this permission notice appear in all copies. |
| * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES |
| * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF |
| * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR |
| * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES |
| * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN |
| * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT |
| * OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. |
| */ |
| |
| |
| #ifndef _DESS_PORT_CTRL_H_ |
| #define _DESS_PORT_CTRL_H_ |
| |
| #ifdef __cplusplus |
| extern "C" |
| { |
| #endif /* __cplusplus */ |
| |
| #include "fal/fal_port_ctrl.h" |
| |
| sw_error_t dess_port_ctrl_init (a_uint32_t dev_id); |
| |
| #ifdef IN_PORTCONTROL |
| #define DESS_PORT_CTRL_INIT(rv, dev_id) \ |
| { \ |
| rv = dess_port_ctrl_init(dev_id); \ |
| SW_RTN_ON_ERROR(rv); \ |
| } |
| #else |
| #define DESS_PORT_CTRL_INIT(rv, dev_id) |
| #endif |
| |
| #ifdef HSL_STANDALONG |
| |
| |
| HSL_LOCAL sw_error_t |
| dess_port_duplex_set (a_uint32_t dev_id, fal_port_t port_id, |
| fal_port_duplex_t duplex); |
| |
| |
| HSL_LOCAL sw_error_t |
| dess_port_duplex_get (a_uint32_t dev_id, fal_port_t port_id, |
| fal_port_duplex_t * pduplex); |
| |
| |
| HSL_LOCAL sw_error_t |
| dess_port_speed_set (a_uint32_t dev_id, fal_port_t port_id, |
| fal_port_speed_t speed); |
| |
| |
| HSL_LOCAL sw_error_t |
| dess_port_speed_get (a_uint32_t dev_id, fal_port_t port_id, |
| fal_port_speed_t * pspeed); |
| |
| |
| HSL_LOCAL sw_error_t |
| dess_port_autoneg_status_get (a_uint32_t dev_id, fal_port_t port_id, |
| a_bool_t * status); |
| |
| |
| HSL_LOCAL sw_error_t |
| dess_port_autoneg_enable (a_uint32_t dev_id, fal_port_t port_id); |
| |
| |
| HSL_LOCAL sw_error_t |
| dess_port_autoneg_restart (a_uint32_t dev_id, fal_port_t port_id); |
| |
| |
| HSL_LOCAL sw_error_t |
| dess_port_autoneg_adv_set (a_uint32_t dev_id, fal_port_t port_id, |
| a_uint32_t autoadv); |
| |
| |
| HSL_LOCAL sw_error_t |
| dess_port_autoneg_adv_get (a_uint32_t dev_id, fal_port_t port_id, |
| a_uint32_t * autoadv); |
| |
| |
| HSL_LOCAL sw_error_t |
| dess_port_flowctrl_set (a_uint32_t dev_id, fal_port_t port_id, |
| a_bool_t enable); |
| |
| |
| HSL_LOCAL sw_error_t |
| dess_port_flowctrl_get (a_uint32_t dev_id, fal_port_t port_id, |
| a_bool_t * enable); |
| |
| |
| HSL_LOCAL sw_error_t |
| dess_port_flowctrl_forcemode_set (a_uint32_t dev_id, |
| fal_port_t port_id, a_bool_t enable); |
| |
| |
| HSL_LOCAL sw_error_t |
| dess_port_flowctrl_forcemode_get (a_uint32_t dev_id, |
| fal_port_t port_id, a_bool_t * enable); |
| |
| |
| HSL_LOCAL sw_error_t |
| dess_port_powersave_set (a_uint32_t dev_id, fal_port_t port_id, |
| a_bool_t enable); |
| |
| |
| HSL_LOCAL sw_error_t |
| dess_port_powersave_get (a_uint32_t dev_id, fal_port_t port_id, |
| a_bool_t * enable); |
| |
| |
| HSL_LOCAL sw_error_t |
| dess_port_hibernate_set (a_uint32_t dev_id, fal_port_t port_id, |
| a_bool_t enable); |
| |
| |
| HSL_LOCAL sw_error_t |
| dess_port_hibernate_get (a_uint32_t dev_id, fal_port_t port_id, |
| a_bool_t * enable); |
| |
| |
| HSL_LOCAL sw_error_t |
| dess_port_cdt (a_uint32_t dev_id, fal_port_t port_id, a_uint32_t mdi_pair, |
| fal_cable_status_t * cable_status, a_uint32_t * cable_len); |
| |
| |
| HSL_LOCAL sw_error_t |
| dess_port_rxhdr_mode_set (a_uint32_t dev_id, fal_port_t port_id, |
| fal_port_header_mode_t mode); |
| |
| |
| HSL_LOCAL sw_error_t |
| dess_port_rxhdr_mode_get (a_uint32_t dev_id, fal_port_t port_id, |
| fal_port_header_mode_t * mode); |
| |
| |
| HSL_LOCAL sw_error_t |
| dess_port_txhdr_mode_set (a_uint32_t dev_id, fal_port_t port_id, |
| fal_port_header_mode_t mode); |
| |
| |
| HSL_LOCAL sw_error_t |
| dess_port_txhdr_mode_get (a_uint32_t dev_id, fal_port_t port_id, |
| fal_port_header_mode_t * mode); |
| |
| |
| HSL_LOCAL sw_error_t |
| dess_header_type_set (a_uint32_t dev_id, a_bool_t enable, |
| a_uint32_t type); |
| |
| |
| HSL_LOCAL sw_error_t |
| dess_header_type_get (a_uint32_t dev_id, a_bool_t * enable, |
| a_uint32_t * type); |
| |
| |
| HSL_LOCAL sw_error_t |
| dess_port_txmac_status_set (a_uint32_t dev_id, fal_port_t port_id, |
| a_bool_t enable); |
| |
| |
| HSL_LOCAL sw_error_t |
| dess_port_txmac_status_get (a_uint32_t dev_id, fal_port_t port_id, |
| a_bool_t * enable); |
| |
| |
| HSL_LOCAL sw_error_t |
| dess_port_rxmac_status_set (a_uint32_t dev_id, fal_port_t port_id, |
| a_bool_t enable); |
| |
| |
| HSL_LOCAL sw_error_t |
| dess_port_rxmac_status_get (a_uint32_t dev_id, fal_port_t port_id, |
| a_bool_t * enable); |
| |
| |
| HSL_LOCAL sw_error_t |
| dess_port_txfc_status_set (a_uint32_t dev_id, fal_port_t port_id, |
| a_bool_t enable); |
| |
| |
| HSL_LOCAL sw_error_t |
| dess_port_txfc_status_get (a_uint32_t dev_id, fal_port_t port_id, |
| a_bool_t * enable); |
| |
| |
| HSL_LOCAL sw_error_t |
| dess_port_rxfc_status_set (a_uint32_t dev_id, fal_port_t port_id, |
| a_bool_t enable); |
| |
| |
| HSL_LOCAL sw_error_t |
| dess_port_rxfc_status_get (a_uint32_t dev_id, fal_port_t port_id, |
| a_bool_t * enable); |
| |
| |
| HSL_LOCAL sw_error_t |
| dess_port_bp_status_set (a_uint32_t dev_id, fal_port_t port_id, |
| a_bool_t enable); |
| |
| |
| HSL_LOCAL sw_error_t |
| dess_port_bp_status_get (a_uint32_t dev_id, fal_port_t port_id, |
| a_bool_t * enable); |
| |
| |
| HSL_LOCAL sw_error_t |
| dess_port_link_forcemode_set (a_uint32_t dev_id, fal_port_t port_id, |
| a_bool_t enable); |
| |
| |
| HSL_LOCAL sw_error_t |
| dess_port_link_forcemode_get (a_uint32_t dev_id, fal_port_t port_id, |
| a_bool_t * enable); |
| |
| |
| HSL_LOCAL sw_error_t |
| dess_port_link_status_get (a_uint32_t dev_id, fal_port_t port_id, |
| a_bool_t * status); |
| |
| HSL_LOCAL sw_error_t |
| dess_port_mac_loopback_set (a_uint32_t dev_id, fal_port_t port_id, |
| a_bool_t enable); |
| |
| |
| HSL_LOCAL sw_error_t |
| dess_port_mac_loopback_get (a_uint32_t dev_id, fal_port_t port_id, |
| a_bool_t * enable); |
| |
| HSL_LOCAL sw_error_t |
| dess_port_congestion_drop_set (a_uint32_t dev_id, fal_port_t port_id, |
| a_uint32_t queue_id, a_bool_t enable); |
| |
| HSL_LOCAL sw_error_t |
| dess_port_congestion_drop_get (a_uint32_t dev_id, fal_port_t port_id, |
| a_uint32_t queue_id, a_bool_t * enable); |
| |
| HSL_LOCAL sw_error_t |
| dess_ring_flow_ctrl_thres_set (a_uint32_t dev_id, a_uint32_t ring_id, |
| a_uint8_t on_thres, a_uint8_t off_thres); |
| |
| HSL_LOCAL sw_error_t |
| dess_ring_flow_ctrl_thres_get (a_uint32_t dev_id, a_uint32_t ring_id, |
| a_uint8_t * on_thres, |
| a_uint8_t * off_thres); |
| |
| HSL_LOCAL sw_error_t |
| dess_port_8023az_set (a_uint32_t dev_id, fal_port_t port_id, |
| a_bool_t enable); |
| |
| HSL_LOCAL sw_error_t |
| dess_port_8023az_get (a_uint32_t dev_id, fal_port_t port_id, |
| a_bool_t * enable); |
| |
| HSL_LOCAL sw_error_t |
| dess_port_mdix_set (a_uint32_t dev_id, a_uint32_t phy_id, |
| fal_port_mdix_mode_t mode); |
| |
| HSL_LOCAL sw_error_t |
| dess_port_mdix_get (a_uint32_t dev_id, fal_port_t port_id, |
| fal_port_mdix_mode_t * mode); |
| |
| HSL_LOCAL sw_error_t |
| dess_port_mdix_status_get (a_uint32_t dev_id, fal_port_t port_id, |
| fal_port_mdix_status_t * mode); |
| |
| HSL_LOCAL sw_error_t |
| dess_port_combo_prefer_medium_set (a_uint32_t dev_id, a_uint32_t phy_id, |
| fal_port_medium_t phy_medium); |
| |
| HSL_LOCAL sw_error_t |
| dess_port_combo_prefer_medium_get (a_uint32_t dev_id, a_uint32_t phy_id, |
| fal_port_medium_t * phy_medium); |
| |
| HSL_LOCAL sw_error_t |
| dess_port_combo_medium_status_get (a_uint32_t dev_id, a_uint32_t phy_id, |
| fal_port_medium_t * phy_medium); |
| |
| HSL_LOCAL sw_error_t |
| dess_port_combo_fiber_mode_set (a_uint32_t dev_id, a_uint32_t phy_id, |
| fal_port_fiber_mode_t fiber_mode); |
| |
| HSL_LOCAL sw_error_t |
| dess_port_combo_fiber_mode_get (a_uint32_t dev_id, a_uint32_t phy_id, |
| fal_port_fiber_mode_t * fiber_mode); |
| |
| HSL_LOCAL sw_error_t |
| dess_port_local_loopback_set (a_uint32_t dev_id, fal_port_t port_id, |
| a_bool_t enable); |
| |
| HSL_LOCAL sw_error_t |
| dess_port_local_loopback_get (a_uint32_t dev_id, fal_port_t port_id, |
| a_bool_t * enable); |
| |
| HSL_LOCAL sw_error_t |
| dess_port_remote_loopback_set (a_uint32_t dev_id, fal_port_t port_id, |
| a_bool_t enable); |
| |
| HSL_LOCAL sw_error_t |
| dess_port_remote_loopback_get (a_uint32_t dev_id, fal_port_t port_id, |
| a_bool_t * enable); |
| |
| HSL_LOCAL sw_error_t |
| dess_port_magic_frame_mac_set (a_uint32_t dev_id, fal_port_t port_id, |
| fal_mac_addr_t * mac); |
| |
| HSL_LOCAL sw_error_t |
| dess_port_magic_frame_mac_get (a_uint32_t dev_id, fal_port_t port_id, |
| fal_mac_addr_t * mac); |
| |
| HSL_LOCAL sw_error_t |
| dess_port_phy_id_get (a_uint32_t dev_id, fal_port_t port_id, |
| a_uint16_t * org_id, a_uint16_t * rev_id); |
| |
| HSL_LOCAL sw_error_t |
| dess_port_wol_status_set (a_uint32_t dev_id, fal_port_t port_id, |
| a_bool_t enable); |
| |
| HSL_LOCAL sw_error_t |
| dess_port_wol_status_get (a_uint32_t dev_id, fal_port_t port_id, |
| a_bool_t * enable); |
| |
| HSL_LOCAL sw_error_t |
| dess_port_reset (a_uint32_t dev_id, fal_port_t port_id); |
| |
| HSL_LOCAL sw_error_t |
| dess_port_power_off (a_uint32_t dev_id, fal_port_t port_id); |
| |
| HSL_LOCAL sw_error_t |
| dess_port_power_on (a_uint32_t dev_id, fal_port_t port_id); |
| |
| HSL_LOCAL sw_error_t |
| dess_port_interface_mode_set (a_uint32_t dev_id, fal_port_t port_id, |
| fal_port_interface_mode_t mode); |
| |
| HSL_LOCAL sw_error_t |
| dess_port_interface_mode_get (a_uint32_t dev_id, fal_port_t port_id, |
| fal_port_interface_mode_t * mode); |
| |
| HSL_LOCAL sw_error_t |
| dess_port_interface_mode_status_get (a_uint32_t dev_id, fal_port_t port_id, |
| fal_port_interface_mode_t * mode); |
| HSL_LOCAL sw_error_t |
| dess_port_counter_set (a_uint32_t dev_id, fal_port_t port_id, |
| a_bool_t enable); |
| |
| HSL_LOCAL sw_error_t |
| dess_port_counter_get (a_uint32_t dev_id, fal_port_t port_id, |
| a_bool_t * enable); |
| HSL_LOCAL sw_error_t |
| dess_port_counter_show (a_uint32_t dev_id, fal_port_t port_id, |
| fal_port_counter_info_t * counter_info); |
| #endif |
| |
| #ifdef __cplusplus |
| } |
| #endif /* __cplusplus */ |
| #endif /* _DESS_PORT_CTRL_H_ */ |