| /* |
| * Copyright (c) 2012, 2016-2017, 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_trunk FAL_TRUNK |
| * @{ |
| */ |
| #include "sw.h" |
| #include "fal_trunk.h" |
| #include "hsl_api.h" |
| #include "adpt.h" |
| |
| #include <linux/kernel.h> |
| #include <linux/module.h> |
| |
| |
| static sw_error_t |
| _fal_trunk_group_set(a_uint32_t dev_id, a_uint32_t trunk_id, |
| a_bool_t enable, fal_pbmp_t member) |
| { |
| sw_error_t rv; |
| hsl_api_t *p_api; |
| adpt_api_t *p_adpt_api; |
| |
| if((p_adpt_api = adpt_api_ptr_get(dev_id)) != NULL) { |
| if (NULL == p_adpt_api->adpt_trunk_group_set) |
| return SW_NOT_SUPPORTED; |
| |
| rv = p_adpt_api->adpt_trunk_group_set(dev_id, trunk_id, enable, member); |
| return rv; |
| } |
| |
| SW_RTN_ON_NULL(p_api = hsl_api_ptr_get(dev_id)); |
| |
| if (NULL == p_api->trunk_group_set) |
| return SW_NOT_SUPPORTED; |
| |
| rv = p_api->trunk_group_set(dev_id, trunk_id, enable, member); |
| return rv; |
| } |
| |
| static sw_error_t |
| _fal_trunk_group_get(a_uint32_t dev_id, a_uint32_t trunk_id, |
| a_bool_t * enable, fal_pbmp_t * member) |
| { |
| sw_error_t rv; |
| hsl_api_t *p_api; |
| adpt_api_t *p_adpt_api; |
| |
| if((p_adpt_api = adpt_api_ptr_get(dev_id)) != NULL) { |
| if (NULL == p_adpt_api->adpt_trunk_group_get) |
| return SW_NOT_SUPPORTED; |
| |
| rv = p_adpt_api->adpt_trunk_group_get(dev_id, trunk_id, enable, member); |
| return rv; |
| } |
| |
| SW_RTN_ON_NULL(p_api = hsl_api_ptr_get(dev_id)); |
| |
| if (NULL == p_api->trunk_group_get) |
| return SW_NOT_SUPPORTED; |
| |
| rv = p_api->trunk_group_get(dev_id, trunk_id, enable, member); |
| return rv; |
| } |
| |
| static sw_error_t |
| _fal_trunk_hash_mode_set(a_uint32_t dev_id, a_uint32_t hash_mode) |
| { |
| sw_error_t rv; |
| hsl_api_t *p_api; |
| adpt_api_t *p_adpt_api; |
| |
| if((p_adpt_api = adpt_api_ptr_get(dev_id)) != NULL) { |
| if (NULL == p_adpt_api->adpt_trunk_hash_mode_set) |
| return SW_NOT_SUPPORTED; |
| |
| rv = p_adpt_api->adpt_trunk_hash_mode_set(dev_id, hash_mode); |
| return rv; |
| } |
| |
| SW_RTN_ON_NULL(p_api = hsl_api_ptr_get(dev_id)); |
| |
| if (NULL == p_api->trunk_hash_mode_set) |
| return SW_NOT_SUPPORTED; |
| |
| rv = p_api->trunk_hash_mode_set(dev_id, hash_mode); |
| return rv; |
| } |
| |
| static sw_error_t |
| _fal_trunk_hash_mode_get(a_uint32_t dev_id, a_uint32_t * hash_mode) |
| { |
| sw_error_t rv; |
| hsl_api_t *p_api; |
| adpt_api_t *p_adpt_api; |
| |
| if((p_adpt_api = adpt_api_ptr_get(dev_id)) != NULL) { |
| if (NULL == p_adpt_api->adpt_trunk_hash_mode_get) |
| return SW_NOT_SUPPORTED; |
| |
| rv = p_adpt_api->adpt_trunk_hash_mode_get(dev_id, hash_mode); |
| return rv; |
| } |
| |
| SW_RTN_ON_NULL(p_api = hsl_api_ptr_get(dev_id)); |
| |
| if (NULL == p_api->trunk_hash_mode_get) |
| return SW_NOT_SUPPORTED; |
| |
| rv = p_api->trunk_hash_mode_get(dev_id, hash_mode); |
| return rv; |
| } |
| |
| static sw_error_t |
| _fal_trunk_manipulate_sa_set(a_uint32_t dev_id, fal_mac_addr_t * addr) |
| { |
| sw_error_t rv; |
| hsl_api_t *p_api; |
| |
| SW_RTN_ON_NULL(p_api = hsl_api_ptr_get(dev_id)); |
| |
| if (NULL == p_api->trunk_manipulate_sa_set) |
| return SW_NOT_SUPPORTED; |
| |
| rv = p_api->trunk_manipulate_sa_set(dev_id, addr); |
| return rv; |
| } |
| |
| static sw_error_t |
| _fal_trunk_manipulate_sa_get(a_uint32_t dev_id, fal_mac_addr_t * addr) |
| { |
| sw_error_t rv; |
| hsl_api_t *p_api; |
| |
| SW_RTN_ON_NULL(p_api = hsl_api_ptr_get(dev_id)); |
| |
| if (NULL == p_api->trunk_manipulate_sa_get) |
| return SW_NOT_SUPPORTED; |
| |
| rv = p_api->trunk_manipulate_sa_get(dev_id, addr); |
| return rv; |
| } |
| sw_error_t |
| _fal_trunk_failover_status_get(a_uint32_t dev_id, a_bool_t * failover) |
| { |
| adpt_api_t *p_api; |
| sw_error_t rv = SW_OK; |
| |
| SW_RTN_ON_NULL(p_api = adpt_api_ptr_get(dev_id)); |
| |
| if (NULL == p_api->adpt_trunk_fail_over_en_get) |
| return SW_NOT_SUPPORTED; |
| |
| rv = p_api->adpt_trunk_fail_over_en_get(dev_id, failover); |
| return rv; |
| } |
| sw_error_t |
| _fal_trunk_failover_enable(a_uint32_t dev_id, a_bool_t failover) |
| { |
| adpt_api_t *p_api; |
| sw_error_t rv = SW_OK; |
| |
| SW_RTN_ON_NULL(p_api = adpt_api_ptr_get(dev_id)); |
| |
| if (NULL == p_api->adpt_trunk_fail_over_en_set) |
| return SW_NOT_SUPPORTED; |
| |
| rv = p_api->adpt_trunk_fail_over_en_set(dev_id, failover); |
| return rv; |
| } |
| |
| /*insert flag for inner fal, don't remove it*/ |
| /** |
| * @brief Set particular trunk group information on particular device. |
| * @param[in] dev_id device id |
| * @param[in] trunk_id trunk group id |
| * @param[in] enable trunk group status, enable or disable |
| * @param[in] member port member information |
| * @return SW_OK or error code |
| */ |
| sw_error_t |
| fal_trunk_group_set(a_uint32_t dev_id, a_uint32_t trunk_id, |
| a_bool_t enable, fal_pbmp_t member) |
| { |
| sw_error_t rv; |
| |
| FAL_API_LOCK; |
| rv = _fal_trunk_group_set(dev_id, trunk_id, enable, member); |
| FAL_API_UNLOCK; |
| return rv; |
| } |
| |
| /** |
| * @brief Get particular trunk group information on particular device. |
| * @param[in] dev_id device id |
| * @param[in] trunk_id trunk group id |
| * @param[out] enable trunk group status, enable or disable |
| * @param[out] member port member information |
| * @return SW_OK or error code |
| */ |
| sw_error_t |
| fal_trunk_group_get(a_uint32_t dev_id, a_uint32_t trunk_id, |
| a_bool_t * enable, fal_pbmp_t * member) |
| { |
| sw_error_t rv; |
| |
| FAL_API_LOCK; |
| rv = _fal_trunk_group_get(dev_id, trunk_id, enable, member); |
| FAL_API_UNLOCK; |
| return rv; |
| } |
| |
| /** |
| * @brief Set trunk hash mode on particular device. |
| * @param[in] dev_id device id |
| * @param[in] hash_mode trunk hash mode |
| * @return SW_OK or error code |
| */ |
| sw_error_t |
| fal_trunk_hash_mode_set(a_uint32_t dev_id, a_uint32_t hash_mode) |
| { |
| sw_error_t rv; |
| |
| FAL_API_LOCK; |
| rv = _fal_trunk_hash_mode_set(dev_id, hash_mode); |
| FAL_API_UNLOCK; |
| return rv; |
| } |
| |
| /** |
| * @brief Get trunk hash mode on particular device. |
| * @param[in] dev_id device id |
| * @param[out] hash_mode trunk hash mode |
| * @return SW_OK or error code |
| */ |
| sw_error_t |
| fal_trunk_hash_mode_get(a_uint32_t dev_id, a_uint32_t * hash_mode) |
| { |
| sw_error_t rv; |
| |
| FAL_API_LOCK; |
| rv = _fal_trunk_hash_mode_get(dev_id, hash_mode); |
| FAL_API_UNLOCK; |
| return rv; |
| } |
| |
| /** |
| * @brief Set trunk manipulate SA on particular device. |
| * @param[in] dev_id device id |
| * @param[in] addr manipulate SA |
| * @return SW_OK or error code |
| */ |
| sw_error_t |
| fal_trunk_manipulate_sa_set(a_uint32_t dev_id, fal_mac_addr_t * addr) |
| { |
| sw_error_t rv; |
| |
| FAL_API_LOCK; |
| rv = _fal_trunk_manipulate_sa_set(dev_id, addr); |
| FAL_API_UNLOCK; |
| return rv; |
| } |
| |
| /** |
| * @brief Get trunk manipulate SA on particular device. |
| * @param[in] dev_id device id |
| * @param[out] addr manipulate SA |
| * @return SW_OK or error code |
| */ |
| sw_error_t |
| fal_trunk_manipulate_sa_get(a_uint32_t dev_id, fal_mac_addr_t * addr) |
| { |
| sw_error_t rv; |
| |
| FAL_API_LOCK; |
| rv = _fal_trunk_manipulate_sa_get(dev_id, addr); |
| FAL_API_UNLOCK; |
| return rv; |
| } |
| sw_error_t |
| fal_trunk_failover_status_get(a_uint32_t dev_id, a_bool_t * failover) |
| { |
| sw_error_t rv = SW_OK; |
| |
| FAL_API_LOCK; |
| rv = _fal_trunk_failover_status_get(dev_id, failover); |
| FAL_API_UNLOCK; |
| return rv; |
| } |
| sw_error_t |
| fal_trunk_failover_enable(a_uint32_t dev_id, a_bool_t failover) |
| { |
| sw_error_t rv = SW_OK; |
| |
| FAL_API_LOCK; |
| rv = _fal_trunk_failover_enable(dev_id, failover); |
| FAL_API_UNLOCK; |
| return rv; |
| } |
| /*insert flag for outter fal, don't remove it*/ |
| |
| EXPORT_SYMBOL(fal_trunk_group_set); |
| EXPORT_SYMBOL(fal_trunk_group_get); |
| EXPORT_SYMBOL(fal_trunk_hash_mode_set); |
| EXPORT_SYMBOL(fal_trunk_hash_mode_get); |
| EXPORT_SYMBOL(fal_trunk_failover_status_get); |
| EXPORT_SYMBOL(fal_trunk_failover_enable); |
| |
| /** |
| * @} |
| */ |