blob: 2d372c56a5ea59a8d327287f5ac8d68ed756be60 [file] [log] [blame]
/*
* Copyright (c) 2012, 2016-2019, 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.
*/
/*qca808x_start*/
/**
* @defgroup fal_init FAL_INIT
* @{
*/
#ifndef _FAL_INIT_H_
#define _FAL_INIT_H_
#ifdef __cplusplus
extern "C" {
#endif /* __cplusplus */
#include "ssdk_init.h"
/*qca808x_end*/
enum{
FAL_MODULE_ACL,
FAL_MODULE_VSI,
FAL_MODULE_IP,
FAL_MODULE_FLOW,
FAL_MODULE_QM,
FAL_MODULE_QOS,
FAL_MODULE_BM,
FAL_MODULE_SERVCODE,
FAL_MODULE_RSS_HASH,
FAL_MODULE_PPPOE,
FAL_MODULE_SHAPER,
FAL_MODULE_PORTCTRL,
FAL_MODULE_MIB,
FAL_MODULE_MIRROR,
FAL_MODULE_FDB,
FAL_MODULE_STP,
FAL_MODULE_TRUNK,
FAL_MODULE_PORTVLAN,
FAL_MODULE_CTRLPKT,
FAL_MODULE_SEC,
FAL_MODULE_POLICER,
FAL_MODULE_MISC,
FAL_MODULE_PTP,
FAL_MODULE_SFP,
FAL_MODULE_MAX,
};
typedef struct
{
a_uint32_t bitmap[3];
}fal_func_ctrl_t;
/*qca808x_start*/
sw_error_t fal_init(a_uint32_t dev_id, ssdk_init_cfg * cfg);
/*qca808x_end*/
sw_error_t fal_reset(a_uint32_t dev_id);
sw_error_t fal_ssdk_cfg(a_uint32_t dev_id, ssdk_cfg_t *ssdk_cfg);
/*qca808x_start*/
sw_error_t fal_cleanup(void);
/*qca808x_end*/
sw_error_t fal_module_func_ctrl_set(a_uint32_t dev_id,
a_uint32_t module, fal_func_ctrl_t *func_ctrl);
sw_error_t fal_module_func_ctrl_get(a_uint32_t dev_id,
a_uint32_t module, fal_func_ctrl_t *func_ctrl);
sw_error_t fal_module_func_init(a_uint32_t dev_id, ssdk_init_cfg *cfg);
sw_error_t fal_switch_devid_get(ssdk_chip_type chip_type, a_uint32_t *pdev_id);
/*qca808x_start*/
#ifdef __cplusplus
}
#endif /* __cplusplus */
#endif /* _FAL_INIT_H_ */
/**
* @}
*/
/*qca808x_end*/