blob: f4383eed020a5f68355a11dbd866d53f435946ad [file] [log] [blame]
/*
* Copyright (c) 2012,2018, 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.
*/
/**
* @defgroup fal_interface_ctrl FAL_INTERFACE_CONTROL
* @{
*/
#ifndef _FAL_INTERFACECTRL_H_
#define _FAL_INTERFACECTRL_H_
#ifdef __cplusplus
extern "c" {
#endif
#include "sw.h"
#include "fal/fal_type.h"
typedef enum {
FAL_MAC_MODE_RGMII = 0,
FAL_MAC_MODE_GMII,
FAL_MAC_MODE_MII,
FAL_MAC_MODE_SGMII,
FAL_MAC_MODE_FIBER,
FAL_MAC_MODE_RMII,
FAL_MAC_MODE_DEFAULT
}
fal_interface_mac_mode_t;
typedef enum
{
FAL_INTERFACE_CLOCK_MAC_MODE = 0,
FAL_INTERFACE_CLOCK_PHY_MODE = 1,
} fal_interface_clock_mode_t;
typedef struct
{
a_bool_t txclk_delay_cmd;
a_bool_t rxclk_delay_cmd;
a_uint32_t txclk_delay_sel;
a_uint32_t rxclk_delay_sel;
} fal_mac_rgmii_config_t;
typedef struct
{
a_bool_t master_mode;
a_bool_t slave_mode;
a_bool_t clock_inverse;
a_bool_t pipe_rxclk_sel;
} fal_mac_rmii_config_t;
typedef struct
{
fal_interface_clock_mode_t clock_mode;
a_uint32_t txclk_select;
a_uint32_t rxclk_select;
} fal_mac_gmii_config_t;
typedef struct
{
fal_interface_clock_mode_t clock_mode;
a_uint32_t txclk_select;
a_uint32_t rxclk_select;
} fal_mac_mii_config_t;
typedef struct
{
fal_interface_clock_mode_t clock_mode;
a_bool_t auto_neg;
a_bool_t force_speed;
a_bool_t prbs_enable;
a_bool_t rem_phy_lpbk;
} fal_mac_sgmii_config_t;
typedef struct
{
a_bool_t auto_neg;
a_bool_t fx100_enable;
} fal_mac_fiber_config_t;
typedef struct
{
fal_interface_mac_mode_t mac_mode;
union
{
fal_mac_rgmii_config_t rgmii;
fal_mac_gmii_config_t gmii;
fal_mac_mii_config_t mii;
fal_mac_sgmii_config_t sgmii;
fal_mac_rmii_config_t rmii;
fal_mac_fiber_config_t fiber;
} config;
} fal_mac_config_t;
typedef struct
{
fal_interface_mac_mode_t mac_mode;
a_bool_t txclk_delay_cmd;
a_bool_t rxclk_delay_cmd;
a_uint32_t txclk_delay_sel;
a_uint32_t rxclk_delay_sel;
} fal_phy_config_t;
typedef enum
{
Fx100BASE_MODE = 2,
} fx100_ctrl_link_mode_t;
typedef enum
{
FX100_SERDS_MODE = 1,
} sgmii_fiber_mode_t;
#define FX100_HALF_DUPLEX 0
#define FX100_FULL_DUPLEX 1
typedef struct
{
fx100_ctrl_link_mode_t link_mode;
a_bool_t overshoot;
a_bool_t loopback;
a_bool_t fd_mode;
a_bool_t col_test;
sgmii_fiber_mode_t sgmii_fiber_mode;
a_bool_t crs_ctrl;
a_bool_t loopback_ctrl;
a_bool_t crs_col_100_ctrl;
a_bool_t loop_en;
} fal_fx100_ctrl_config_t;
sw_error_t
fal_port_3az_status_set(a_uint32_t dev_id, fal_port_t port_id, a_bool_t enable);
sw_error_t
fal_port_3az_status_get(a_uint32_t dev_id, fal_port_t port_id, a_bool_t * enable);
sw_error_t
fal_interface_mac_mode_set(a_uint32_t dev_id, fal_port_t port_id, fal_mac_config_t * config);
sw_error_t
fal_interface_mac_mode_get(a_uint32_t dev_id, fal_port_t port_id, fal_mac_config_t * config);
sw_error_t
fal_interface_phy_mode_set(a_uint32_t dev_id, a_uint32_t phy_id, fal_phy_config_t * config);
sw_error_t
fal_interface_phy_mode_get(a_uint32_t dev_id, a_uint32_t phy_id, fal_phy_config_t * config);
sw_error_t
fal_interface_fx100_ctrl_set(a_uint32_t dev_id, fal_fx100_ctrl_config_t * config);
sw_error_t
fal_interface_fx100_ctrl_get(a_uint32_t dev_id, fal_fx100_ctrl_config_t * config);
sw_error_t
fal_interface_fx100_status_get(a_uint32_t dev_id, a_uint32_t* status);
sw_error_t
fal_interface_mac06_exch_set(a_uint32_t dev_id, a_bool_t enable);
sw_error_t
fal_interface_mac06_exch_get(a_uint32_t dev_id, a_bool_t* enable);
#ifdef __cplusplus
}
#endif /* __cplusplus */
#endif /* _FAL_INTERFACECTRL_H_ */
/**
* @}
*/