sdk-hwV1.3/lichee/linux-4.9/drivers/net/phy/rtl8363_nb/trap.c

1433 lines
39 KiB
C
Executable File

/*
* Copyright (C) 2013 Realtek Semiconductor Corp.
* All Rights Reserved.
*
* This program is the proprietary software of Realtek Semiconductor
* Corporation and/or its licensors, and only be used, duplicated,
* modified or distributed under the authorized license from Realtek.
*
* ANY USE OF THE SOFTWARE OTHER THAN AS AUTHORIZED UNDER
* THIS LICENSE OR COPYRIGHT LAW IS PROHIBITED.
*
* $Revision: 79496 $
* $Date: 2017-06-08 17:31:25 +0800 (週四, 08 六月 2017) $
*
* Purpose : RTK switch high-level API for RTL8367/RTL8367C
* Feature : Here is a list of all functions and variables in Trap module.
*
*/
#include <rtk_switch.h>
#include <rtk_error.h>
#include <trap.h>
#include <linux/string.h>
#include <rtl8367c_asicdrv.h>
#include <rtl8367c_asicdrv_port.h>
#include <rtl8367c_asicdrv_igmp.h>
#include <rtl8367c_asicdrv_rma.h>
#include <rtl8367c_asicdrv_eav.h>
#include <rtl8367c_asicdrv_oam.h>
#include <rtl8367c_asicdrv_svlan.h>
#include <rtl8367c_asicdrv_unknownMulticast.h>
#include <rtl8367c_asicdrv_dot1x.h>
static rtk_api_ret_t _rtk_trap_unknownUnicastPktAction_set(rtk_port_t port, rtk_trap_ucast_action_t ucast_action)
{
rtk_api_ret_t retVal;
/* Check initialization state */
RTK_CHK_INIT_STATE();
/* check port valid */
RTK_CHK_PORT_VALID(port);
if (ucast_action >= UCAST_ACTION_END)
return RT_ERR_INPUT;
if ((retVal = rtl8367c_setAsicPortUnknownDaBehavior(rtk_switch_port_L2P_get(port), ucast_action)) != RT_ERR_OK)
return retVal;
return RT_ERR_OK;
}
static rtk_api_ret_t _rtk_trap_unknownUnicastPktAction_get(rtk_port_t port, rtk_trap_ucast_action_t *pUcast_action)
{
rtk_api_ret_t retVal;
/* Check initialization state */
RTK_CHK_INIT_STATE();
/* check port valid */
RTK_CHK_PORT_VALID(port);
if (NULL == pUcast_action)
return RT_ERR_NULL_POINTER;
if ((retVal = rtl8367c_getAsicPortUnknownDaBehavior(rtk_switch_port_L2P_get(port), pUcast_action)) != RT_ERR_OK)
return retVal;
return RT_ERR_OK;
}
static rtk_api_ret_t _rtk_trap_unknownMacPktAction_set(rtk_trap_ucast_action_t ucast_action)
{
rtk_api_ret_t retVal;
/* Check initialization state */
RTK_CHK_INIT_STATE();
if (ucast_action >= UCAST_ACTION_FLOODING)
return RT_ERR_INPUT;
if ((retVal = rtl8367c_setAsicPortUnknownSaBehavior(ucast_action)) != RT_ERR_OK)
return retVal;
return RT_ERR_OK;
}
static rtk_api_ret_t _rtk_trap_unknownMacPktAction_get(rtk_trap_ucast_action_t *pUcast_action)
{
rtk_api_ret_t retVal;
/* Check initialization state */
RTK_CHK_INIT_STATE();
if(NULL == pUcast_action)
return RT_ERR_NULL_POINTER;
if ((retVal = rtl8367c_getAsicPortUnknownSaBehavior(pUcast_action)) != RT_ERR_OK)
return retVal;
return RT_ERR_OK;
}
static rtk_api_ret_t _rtk_trap_unmatchMacPktAction_set(rtk_trap_ucast_action_t ucast_action)
{
rtk_api_ret_t retVal;
/* Check initialization state */
RTK_CHK_INIT_STATE();
if (ucast_action >= UCAST_ACTION_FLOODING)
return RT_ERR_INPUT;
if ((retVal = rtl8367c_setAsicPortUnmatchedSaBehavior(ucast_action)) != RT_ERR_OK)
return retVal;
return RT_ERR_OK;
}
static rtk_api_ret_t _rtk_trap_unmatchMacPktAction_get(rtk_trap_ucast_action_t *pUcast_action)
{
rtk_api_ret_t retVal;
/* Check initialization state */
RTK_CHK_INIT_STATE();
if(NULL == pUcast_action)
return RT_ERR_NULL_POINTER;
if ((retVal = rtl8367c_getAsicPortUnmatchedSaBehavior(pUcast_action)) != RT_ERR_OK)
return retVal;
return RT_ERR_OK;
}
static rtk_api_ret_t _rtk_trap_unmatchMacMoving_set(rtk_port_t port, rtk_enable_t enable)
{
rtk_api_ret_t retVal;
/* Check initialization state */
RTK_CHK_INIT_STATE();
/* check port valid */
RTK_CHK_PORT_VALID(port);
if(enable >= RTK_ENABLE_END)
return RT_ERR_INPUT;
if ((retVal = rtl8367c_setAsicPortUnmatchedSaMoving(rtk_switch_port_L2P_get(port), enable)) != RT_ERR_OK)
return retVal;
return RT_ERR_OK;
}
static rtk_api_ret_t _rtk_trap_unmatchMacMoving_get(rtk_port_t port, rtk_enable_t *pEnable)
{
rtk_api_ret_t retVal;
/* Check initialization state */
RTK_CHK_INIT_STATE();
/* check port valid */
RTK_CHK_PORT_VALID(port);
if(NULL == pEnable)
return RT_ERR_NULL_POINTER;
if ((retVal = rtl8367c_getAsicPortUnmatchedSaMoving(rtk_switch_port_L2P_get(port), pEnable)) != RT_ERR_OK)
return retVal;
return RT_ERR_OK;
}
static rtk_api_ret_t _rtk_trap_unknownMcastPktAction_set(rtk_port_t port, rtk_mcast_type_t type, rtk_trap_mcast_action_t mcast_action)
{
rtk_api_ret_t retVal;
rtk_uint32 rawAction;
/* Check initialization state */
RTK_CHK_INIT_STATE();
/* Check Port Valid */
RTK_CHK_PORT_VALID(port);
if (type >= MCAST_END)
return RT_ERR_INPUT;
if (mcast_action >= MCAST_ACTION_END)
return RT_ERR_INPUT;
switch (type)
{
case MCAST_L2:
if (MCAST_ACTION_ROUTER_PORT == mcast_action)
return RT_ERR_INPUT;
else if(MCAST_ACTION_DROP_EX_RMA == mcast_action)
rawAction = L2_UNKOWN_MULTICAST_DROP_EXCLUDE_RMA;
else
rawAction = (rtk_uint32)mcast_action;
if ((retVal = rtl8367c_setAsicUnknownL2MulticastBehavior(rtk_switch_port_L2P_get(port), rawAction)) != RT_ERR_OK)
return retVal;
break;
case MCAST_IPV4:
if (MCAST_ACTION_DROP_EX_RMA == mcast_action)
return RT_ERR_INPUT;
else
rawAction = (rtk_uint32)mcast_action;
if ((retVal = rtl8367c_setAsicUnknownIPv4MulticastBehavior(rtk_switch_port_L2P_get(port), rawAction)) != RT_ERR_OK)
return retVal;
break;
case MCAST_IPV6:
if (MCAST_ACTION_DROP_EX_RMA == mcast_action)
return RT_ERR_INPUT;
else
rawAction = (rtk_uint32)mcast_action;
if ((retVal = rtl8367c_setAsicUnknownIPv6MulticastBehavior(rtk_switch_port_L2P_get(port), rawAction)) != RT_ERR_OK)
return retVal;
break;
default:
break;
}
return RT_ERR_OK;
}
static rtk_api_ret_t _rtk_trap_unknownMcastPktAction_get(rtk_port_t port, rtk_mcast_type_t type, rtk_trap_mcast_action_t *pMcast_action)
{
rtk_api_ret_t retVal;
rtk_uint32 rawAction;
/* Check initialization state */
RTK_CHK_INIT_STATE();
/* Check Port Valid */
RTK_CHK_PORT_VALID(port);
if (type >= MCAST_END)
return RT_ERR_INPUT;
if(NULL == pMcast_action)
return RT_ERR_NULL_POINTER;
switch (type)
{
case MCAST_L2:
if ((retVal = rtl8367c_getAsicUnknownL2MulticastBehavior(rtk_switch_port_L2P_get(port), &rawAction)) != RT_ERR_OK)
return retVal;
if(L2_UNKOWN_MULTICAST_DROP_EXCLUDE_RMA == rawAction)
*pMcast_action = MCAST_ACTION_DROP_EX_RMA;
else
*pMcast_action = (rtk_trap_mcast_action_t)rawAction;
break;
case MCAST_IPV4:
if ((retVal = rtl8367c_getAsicUnknownIPv4MulticastBehavior(rtk_switch_port_L2P_get(port), &rawAction)) != RT_ERR_OK)
return retVal;
*pMcast_action = (rtk_trap_mcast_action_t)rawAction;
break;
case MCAST_IPV6:
if ((retVal = rtl8367c_getAsicUnknownIPv6MulticastBehavior(rtk_switch_port_L2P_get(port), &rawAction)) != RT_ERR_OK)
return retVal;
*pMcast_action = (rtk_trap_mcast_action_t)rawAction;
break;
default:
break;
}
return RT_ERR_OK;
}
static rtk_api_ret_t _rtk_trap_lldpEnable_set(rtk_enable_t enabled)
{
rtk_api_ret_t retVal;
rtl8367c_rma_t rmacfg;
rtk_enable_t tmp;
/* Check initialization state */
RTK_CHK_INIT_STATE();
if (enabled >= RTK_ENABLE_END)
return RT_ERR_ENABLE;
if ((retVal = rtl8367c_getAsicRmaLldp(&tmp, &rmacfg)) != RT_ERR_OK)
return retVal;
if ((retVal = rtl8367c_setAsicRmaLldp(enabled, &rmacfg)) != RT_ERR_OK)
return retVal;
return RT_ERR_OK;
}
static rtk_api_ret_t _rtk_trap_lldpEnable_get(rtk_enable_t *pEnabled)
{
rtk_api_ret_t retVal;
rtl8367c_rma_t rmacfg;
/* Check initialization state */
RTK_CHK_INIT_STATE();
if(NULL == pEnabled)
return RT_ERR_NULL_POINTER;
if ((retVal = rtl8367c_getAsicRmaLldp(pEnabled, &rmacfg)) != RT_ERR_OK)
return retVal;
return RT_ERR_OK;
}
static rtk_api_ret_t _rtk_trap_reasonTrapToCpuPriority_set(rtk_trap_reason_type_t type, rtk_pri_t priority)
{
rtk_api_ret_t retVal;
rtl8367c_rma_t rmacfg;
/* Check initialization state */
RTK_CHK_INIT_STATE();
if (type >= TRAP_REASON_END)
return RT_ERR_INPUT;
if (priority > RTL8367C_PRIMAX)
return RT_ERR_QOS_INT_PRIORITY;
switch (type)
{
case TRAP_REASON_RMA:
if ((retVal = rtl8367c_getAsicRma(0, &rmacfg)) != RT_ERR_OK)
return retVal;
rmacfg.trap_priority= priority;
if ((retVal = rtl8367c_setAsicRma(0, &rmacfg)) != RT_ERR_OK)
return retVal;
break;
case TRAP_REASON_OAM:
if ((retVal = rtl8367c_setAsicOamCpuPri(priority)) != RT_ERR_OK)
return retVal;
break;
case TRAP_REASON_1XUNAUTH:
if ((retVal = rtl8367c_setAsic1xTrapPriority(priority)) != RT_ERR_OK)
return retVal;
break;
case TRAP_REASON_VLANSTACK:
if ((retVal = rtl8367c_setAsicSvlanTrapPriority(priority)) != RT_ERR_OK)
return retVal;
break;
case TRAP_REASON_UNKNOWNMC:
if ((retVal = rtl8367c_setAsicUnknownMulticastTrapPriority(priority)) != RT_ERR_OK)
return retVal;
break;
default:
return RT_ERR_CHIP_NOT_SUPPORTED;
}
return RT_ERR_OK;
}
static rtk_api_ret_t _rtk_trap_reasonTrapToCpuPriority_get(rtk_trap_reason_type_t type, rtk_pri_t *pPriority)
{
rtk_api_ret_t retVal;
rtl8367c_rma_t rmacfg;
/* Check initialization state */
RTK_CHK_INIT_STATE();
if (type >= TRAP_REASON_END)
return RT_ERR_INPUT;
if(NULL == pPriority)
return RT_ERR_NULL_POINTER;
switch (type)
{
case TRAP_REASON_RMA:
if ((retVal = rtl8367c_getAsicRma(0, &rmacfg)) != RT_ERR_OK)
return retVal;
*pPriority = rmacfg.trap_priority;
break;
case TRAP_REASON_OAM:
if ((retVal = rtl8367c_getAsicOamCpuPri(pPriority)) != RT_ERR_OK)
return retVal;
break;
case TRAP_REASON_1XUNAUTH:
if ((retVal = rtl8367c_getAsic1xTrapPriority(pPriority)) != RT_ERR_OK)
return retVal;
break;
case TRAP_REASON_VLANSTACK:
if ((retVal = rtl8367c_getAsicSvlanTrapPriority(pPriority)) != RT_ERR_OK)
return retVal;
break;
case TRAP_REASON_UNKNOWNMC:
if ((retVal = rtl8367c_getAsicUnknownMulticastTrapPriority(pPriority)) != RT_ERR_OK)
return retVal;
break;
default:
return RT_ERR_CHIP_NOT_SUPPORTED;
}
return RT_ERR_OK;
}
static rtk_api_ret_t _rtk_trap_rmaAction_set(rtk_trap_type_t type, rtk_trap_rma_action_t rma_action)
{
rtk_api_ret_t retVal;
rtl8367c_rma_t rmacfg;
rtk_uint32 tmp;
/* Check initialization state */
RTK_CHK_INIT_STATE();
if (type >= TRAP_END)
return RT_ERR_INPUT;
if (rma_action >= RMA_ACTION_END)
return RT_ERR_RMA_ACTION;
if (type >= 0 && type <= TRAP_UNDEF_GARP_2F)
{
if ((retVal = rtl8367c_getAsicRma(type, &rmacfg)) != RT_ERR_OK)
return retVal;
rmacfg.operation = rma_action;
if ((retVal = rtl8367c_setAsicRma(type, &rmacfg)) != RT_ERR_OK)
return retVal;
}
else if (type == TRAP_CDP)
{
if ((retVal = rtl8367c_getAsicRmaCdp(&rmacfg)) != RT_ERR_OK)
return retVal;
rmacfg.operation = rma_action;
if ((retVal = rtl8367c_setAsicRmaCdp(&rmacfg)) != RT_ERR_OK)
return retVal;
}
else if (type == TRAP_CSSTP)
{
if ((retVal = rtl8367c_getAsicRmaCsstp(&rmacfg)) != RT_ERR_OK)
return retVal;
rmacfg.operation = rma_action;
if ((retVal = rtl8367c_setAsicRmaCsstp(&rmacfg)) != RT_ERR_OK)
return retVal;
}
else if (type == TRAP_LLDP)
{
if ((retVal = rtl8367c_getAsicRmaLldp(&tmp, &rmacfg)) != RT_ERR_OK)
return retVal;
rmacfg.operation = rma_action;
if ((retVal = rtl8367c_setAsicRmaLldp(tmp, &rmacfg)) != RT_ERR_OK)
return retVal;
}
else
return RT_ERR_INPUT;
return RT_ERR_OK;
}
static rtk_api_ret_t _rtk_trap_rmaAction_get(rtk_trap_type_t type, rtk_trap_rma_action_t *pRma_action)
{
rtk_api_ret_t retVal;
rtl8367c_rma_t rmacfg;
rtk_uint32 tmp;
/* Check initialization state */
RTK_CHK_INIT_STATE();
if (type >= TRAP_END)
return RT_ERR_INPUT;
if(NULL == pRma_action)
return RT_ERR_NULL_POINTER;
if (type >= 0 && type <= TRAP_UNDEF_GARP_2F)
{
if ((retVal = rtl8367c_getAsicRma(type, &rmacfg)) != RT_ERR_OK)
return retVal;
*pRma_action = rmacfg.operation;
}
else if (type == TRAP_CDP)
{
if ((retVal = rtl8367c_getAsicRmaCdp(&rmacfg)) != RT_ERR_OK)
return retVal;
*pRma_action = rmacfg.operation;
}
else if (type == TRAP_CSSTP)
{
if ((retVal = rtl8367c_getAsicRmaCsstp(&rmacfg)) != RT_ERR_OK)
return retVal;
*pRma_action = rmacfg.operation;
}
else if (type == TRAP_LLDP)
{
if ((retVal = rtl8367c_getAsicRmaLldp(&tmp,&rmacfg)) != RT_ERR_OK)
return retVal;
*pRma_action = rmacfg.operation;
}
else
return RT_ERR_INPUT;
return RT_ERR_OK;
}
static rtk_api_ret_t _rtk_trap_rmaKeepFormat_set(rtk_trap_type_t type, rtk_enable_t enable)
{
rtk_api_ret_t retVal;
rtl8367c_rma_t rmacfg;
rtk_uint32 tmp;
/* Check initialization state */
RTK_CHK_INIT_STATE();
if (type >= TRAP_END)
return RT_ERR_INPUT;
if (enable >= RTK_ENABLE_END)
return RT_ERR_INPUT;
if (type >= 0 && type <= TRAP_UNDEF_GARP_2F)
{
if ((retVal = rtl8367c_getAsicRma(type, &rmacfg)) != RT_ERR_OK)
return retVal;
rmacfg.keep_format = enable;
if ((retVal = rtl8367c_setAsicRma(type, &rmacfg)) != RT_ERR_OK)
return retVal;
}
else if (type == TRAP_CDP)
{
if ((retVal = rtl8367c_getAsicRmaCdp(&rmacfg)) != RT_ERR_OK)
return retVal;
rmacfg.keep_format = enable;
if ((retVal = rtl8367c_setAsicRmaCdp(&rmacfg)) != RT_ERR_OK)
return retVal;
}
else if (type == TRAP_CSSTP)
{
if ((retVal = rtl8367c_getAsicRmaCsstp(&rmacfg)) != RT_ERR_OK)
return retVal;
rmacfg.keep_format = enable;
if ((retVal = rtl8367c_setAsicRmaCsstp(&rmacfg)) != RT_ERR_OK)
return retVal;
}
else if (type == TRAP_LLDP)
{
if ((retVal = rtl8367c_getAsicRmaLldp(&tmp, &rmacfg)) != RT_ERR_OK)
return retVal;
rmacfg.keep_format = enable;
if ((retVal = rtl8367c_setAsicRmaLldp(tmp, &rmacfg)) != RT_ERR_OK)
return retVal;
}
else
return RT_ERR_INPUT;
return RT_ERR_OK;
}
static rtk_api_ret_t _rtk_trap_rmaKeepFormat_get(rtk_trap_type_t type, rtk_enable_t *pEnable)
{
rtk_api_ret_t retVal;
rtl8367c_rma_t rmacfg;
rtk_uint32 tmp;
/* Check initialization state */
RTK_CHK_INIT_STATE();
if (type >= TRAP_END)
return RT_ERR_INPUT;
if(NULL == pEnable)
return RT_ERR_NULL_POINTER;
if (type >= 0 && type <= TRAP_UNDEF_GARP_2F)
{
if ((retVal = rtl8367c_getAsicRma(type, &rmacfg)) != RT_ERR_OK)
return retVal;
*pEnable = rmacfg.keep_format;
}
else if (type == TRAP_CDP)
{
if ((retVal = rtl8367c_getAsicRmaCdp(&rmacfg)) != RT_ERR_OK)
return retVal;
*pEnable = rmacfg.keep_format;
}
else if (type == TRAP_CSSTP)
{
if ((retVal = rtl8367c_getAsicRmaCsstp(&rmacfg)) != RT_ERR_OK)
return retVal;
*pEnable = rmacfg.keep_format;
}
else if (type == TRAP_LLDP)
{
if ((retVal = rtl8367c_getAsicRmaLldp(&tmp,&rmacfg)) != RT_ERR_OK)
return retVal;
*pEnable = rmacfg.keep_format;
}
else
return RT_ERR_INPUT;
return RT_ERR_OK;
}
/* Function Name:
* rtk_trap_unknownUnicastPktAction_set
* Description:
* Set unknown unicast packet action configuration.
* Input:
* port - ingress port ID for unknown unicast packet
* ucast_action - Unknown unicast action.
* Output:
* None
* Return:
* RT_ERR_OK - OK
* RT_ERR_FAILED - Failed
* RT_ERR_SMI - SMI access error
* RT_ERR_NOT_ALLOWED - Invalid action.
* RT_ERR_INPUT - Invalid input parameters.
* Note:
* This API can set unknown unicast packet action configuration.
* The unknown unicast action is as following:
* - UCAST_ACTION_FORWARD_PMASK
* - UCAST_ACTION_DROP
* - UCAST_ACTION_TRAP2CPU
* - UCAST_ACTION_FLOODING
*/
rtk_api_ret_t rtk_trap_unknownUnicastPktAction_set(rtk_port_t port, rtk_trap_ucast_action_t ucast_action)
{
rtk_api_ret_t retVal;
RTK_API_LOCK();
retVal = _rtk_trap_unknownUnicastPktAction_set(port, ucast_action);
RTK_API_UNLOCK();
return retVal;
}
/* Function Name:
* rtk_trap_unknownUnicastPktAction_get
* Description:
* Get unknown unicast packet action configuration.
* Input:
* port - ingress port ID for unknown unicast packet
* Output:
* pUcast_action - Unknown unicast action.
* Return:
* RT_ERR_OK - OK
* RT_ERR_FAILED - Failed
* RT_ERR_SMI - SMI access error
* RT_ERR_NOT_ALLOWED - Invalid action.
* RT_ERR_INPUT - Invalid input parameters.
* RT_ERR_NULL_POINTER - Null pointer
* Note:
* This API can get unknown unicast packet action configuration.
* The unknown unicast action is as following:
* - UCAST_ACTION_FORWARD_PMASK
* - UCAST_ACTION_DROP
* - UCAST_ACTION_TRAP2CPU
* - UCAST_ACTION_FLOODING
*/
rtk_api_ret_t rtk_trap_unknownUnicastPktAction_get(rtk_port_t port, rtk_trap_ucast_action_t *pUcast_action)
{
rtk_api_ret_t retVal;
RTK_API_LOCK();
retVal = _rtk_trap_unknownUnicastPktAction_get(port, pUcast_action);
RTK_API_UNLOCK();
return retVal;
}
/* Function Name:
* rtk_trap_unknownMacPktAction_set
* Description:
* Set unknown source MAC packet action configuration.
* Input:
* ucast_action - Unknown source MAC action.
* Output:
* None
* Return:
* RT_ERR_OK - OK
* RT_ERR_FAILED - Failed
* RT_ERR_SMI - SMI access error
* RT_ERR_NOT_ALLOWED - Invalid action.
* RT_ERR_INPUT - Invalid input parameters.
* Note:
* This API can set unknown unicast packet action configuration.
* The unknown unicast action is as following:
* - UCAST_ACTION_FORWARD_PMASK
* - UCAST_ACTION_DROP
* - UCAST_ACTION_TRAP2CPU
*/
rtk_api_ret_t rtk_trap_unknownMacPktAction_set(rtk_trap_ucast_action_t ucast_action)
{
rtk_api_ret_t retVal;
RTK_API_LOCK();
retVal = _rtk_trap_unknownMacPktAction_set(ucast_action);
RTK_API_UNLOCK();
return retVal;
}
/* Function Name:
* rtk_trap_unknownMacPktAction_get
* Description:
* Get unknown source MAC packet action configuration.
* Input:
* None.
* Output:
* pUcast_action - Unknown source MAC action.
* Return:
* RT_ERR_OK - OK
* RT_ERR_FAILED - Failed
* RT_ERR_SMI - SMI access error
* RT_ERR_NULL_POINTER - Null Pointer.
* RT_ERR_INPUT - Invalid input parameters.
* Note:
*
*/
rtk_api_ret_t rtk_trap_unknownMacPktAction_get(rtk_trap_ucast_action_t *pUcast_action)
{
rtk_api_ret_t retVal;
RTK_API_LOCK();
retVal = _rtk_trap_unknownMacPktAction_get(pUcast_action);
RTK_API_UNLOCK();
return retVal;
}
/* Function Name:
* rtk_trap_unmatchMacPktAction_set
* Description:
* Set unmatch source MAC packet action configuration.
* Input:
* ucast_action - Unknown source MAC action.
* Output:
* None
* Return:
* RT_ERR_OK - OK
* RT_ERR_FAILED - Failed
* RT_ERR_SMI - SMI access error
* RT_ERR_NOT_ALLOWED - Invalid action.
* RT_ERR_INPUT - Invalid input parameters.
* Note:
* This API can set unknown unicast packet action configuration.
* The unknown unicast action is as following:
* - UCAST_ACTION_FORWARD_PMASK
* - UCAST_ACTION_DROP
* - UCAST_ACTION_TRAP2CPU
*/
rtk_api_ret_t rtk_trap_unmatchMacPktAction_set(rtk_trap_ucast_action_t ucast_action)
{
rtk_api_ret_t retVal;
RTK_API_LOCK();
retVal = _rtk_trap_unmatchMacPktAction_set(ucast_action);
RTK_API_UNLOCK();
return retVal;
}
/* Function Name:
* rtk_trap_unmatchMacPktAction_get
* Description:
* Get unmatch source MAC packet action configuration.
* Input:
* None.
* Output:
* pUcast_action - Unknown source MAC action.
* Return:
* RT_ERR_OK - OK
* RT_ERR_FAILED - Failed
* RT_ERR_SMI - SMI access error
* RT_ERR_NOT_ALLOWED - Invalid action.
* RT_ERR_INPUT - Invalid input parameters.
* Note:
* This API can set unknown unicast packet action configuration.
* The unknown unicast action is as following:
* - UCAST_ACTION_FORWARD_PMASK
* - UCAST_ACTION_DROP
* - UCAST_ACTION_TRAP2CPU
*/
rtk_api_ret_t rtk_trap_unmatchMacPktAction_get(rtk_trap_ucast_action_t *pUcast_action)
{
rtk_api_ret_t retVal;
RTK_API_LOCK();
retVal = _rtk_trap_unmatchMacPktAction_get(pUcast_action);
RTK_API_UNLOCK();
return retVal;
}
/* Function Name:
* rtk_trap_unmatchMacMoving_set
* Description:
* Set unmatch source MAC packet moving state.
* Input:
* port - Port ID.
* enable - ENABLED: allow SA moving, DISABLE: don't allow SA moving.
* Output:
* None
* Return:
* RT_ERR_OK - OK
* RT_ERR_FAILED - Failed
* RT_ERR_SMI - SMI access error
* RT_ERR_NOT_ALLOWED - Invalid action.
* RT_ERR_INPUT - Invalid input parameters.
* Note:
*/
rtk_api_ret_t rtk_trap_unmatchMacMoving_set(rtk_port_t port, rtk_enable_t enable)
{
rtk_api_ret_t retVal;
RTK_API_LOCK();
retVal = _rtk_trap_unmatchMacMoving_set(port, enable);
RTK_API_UNLOCK();
return retVal;
}
/* Function Name:
* rtk_trap_unmatchMacMoving_get
* Description:
* Set unmatch source MAC packet moving state.
* Input:
* port - Port ID.
* Output:
* pEnable - ENABLED: allow SA moving, DISABLE: don't allow SA moving.
* Return:
* RT_ERR_OK - OK
* RT_ERR_FAILED - Failed
* RT_ERR_SMI - SMI access error
* RT_ERR_NOT_ALLOWED - Invalid action.
* RT_ERR_INPUT - Invalid input parameters.
* Note:
*/
rtk_api_ret_t rtk_trap_unmatchMacMoving_get(rtk_port_t port, rtk_enable_t *pEnable)
{
rtk_api_ret_t retVal;
RTK_API_LOCK();
retVal = _rtk_trap_unmatchMacMoving_get(port, pEnable);
RTK_API_UNLOCK();
return retVal;
}
/* Function Name:
* rtk_trap_unknownMcastPktAction_set
* Description:
* Set behavior of unknown multicast
* Input:
* port - Port id.
* type - unknown multicast packet type.
* mcast_action - unknown multicast action.
* Output:
* None
* Return:
* RT_ERR_OK - OK
* RT_ERR_FAILED - Failed
* RT_ERR_SMI - SMI access error
* RT_ERR_PORT_ID - Invalid port number.
* RT_ERR_NOT_ALLOWED - Invalid action.
* RT_ERR_INPUT - Invalid input parameters.
* Note:
* When receives an unknown multicast packet, switch may trap, drop or flood this packet
* (1) The unknown multicast packet type is as following:
* - MCAST_L2
* - MCAST_IPV4
* - MCAST_IPV6
* (2) The unknown multicast action is as following:
* - MCAST_ACTION_FORWARD
* - MCAST_ACTION_DROP
* - MCAST_ACTION_TRAP2CPU
*/
rtk_api_ret_t rtk_trap_unknownMcastPktAction_set(rtk_port_t port, rtk_mcast_type_t type, rtk_trap_mcast_action_t mcast_action)
{
rtk_api_ret_t retVal;
RTK_API_LOCK();
retVal = _rtk_trap_unknownMcastPktAction_set(port, type, mcast_action);
RTK_API_UNLOCK();
return retVal;
}
/* Function Name:
* rtk_trap_unknownMcastPktAction_get
* Description:
* Get behavior of unknown multicast
* Input:
* type - unknown multicast packet type.
* Output:
* pMcast_action - unknown multicast action.
* Return:
* RT_ERR_OK - OK
* RT_ERR_FAILED - Failed
* RT_ERR_SMI - SMI access error
* RT_ERR_PORT_ID - Invalid port number.
* RT_ERR_NOT_ALLOWED - Invalid operation.
* RT_ERR_INPUT - Invalid input parameters.
* Note:
* When receives an unknown multicast packet, switch may trap, drop or flood this packet
* (1) The unknown multicast packet type is as following:
* - MCAST_L2
* - MCAST_IPV4
* - MCAST_IPV6
* (2) The unknown multicast action is as following:
* - MCAST_ACTION_FORWARD
* - MCAST_ACTION_DROP
* - MCAST_ACTION_TRAP2CPU
*/
rtk_api_ret_t rtk_trap_unknownMcastPktAction_get(rtk_port_t port, rtk_mcast_type_t type, rtk_trap_mcast_action_t *pMcast_action)
{
rtk_api_ret_t retVal;
RTK_API_LOCK();
retVal = _rtk_trap_unknownMcastPktAction_get(port, type, pMcast_action);
RTK_API_UNLOCK();
return retVal;
}
/* Function Name:
* rtk_trap_lldpEnable_set
* Description:
* Set LLDP enable.
* Input:
* enabled - LLDP enable, 0: follow RMA, 1: use LLDP action.
* Output:
* None
* Return:
* RT_ERR_OK - OK
* RT_ERR_FAILED - Failed
* RT_ERR_SMI - SMI access error
* RT_ERR_NOT_ALLOWED - Invalid action.
* RT_ERR_INPUT - Invalid input parameters.
* Note:
* - DMAC Assignment
* - 01:80:c2:00:00:0e ethertype = 0x88CC LLDP
* - 01:80:c2:00:00:03 ethertype = 0x88CC
* - 01:80:c2:00:00:00 ethertype = 0x88CC
*/
rtk_api_ret_t rtk_trap_lldpEnable_set(rtk_enable_t enabled)
{
rtk_api_ret_t retVal;
RTK_API_LOCK();
retVal = _rtk_trap_lldpEnable_set(enabled);
RTK_API_UNLOCK();
return retVal;
}
/* Function Name:
* rtk_trap_lldpEnable_get
* Description:
* Get LLDP status.
* Input:
* None
* Output:
* pEnabled - LLDP enable, 0: follow RMA, 1: use LLDP action.
* Return:
* RT_ERR_OK - OK
* RT_ERR_FAILED - Failed
* RT_ERR_SMI - SMI access error
* RT_ERR_INPUT - Invalid input parameters.
* Note:
* LLDP is as following definition.
* - DMAC Assignment
* - 01:80:c2:00:00:0e ethertype = 0x88CC LLDP
* - 01:80:c2:00:00:03 ethertype = 0x88CC
* - 01:80:c2:00:00:00 ethertype = 0x88CC
*/
rtk_api_ret_t rtk_trap_lldpEnable_get(rtk_enable_t *pEnabled)
{
rtk_api_ret_t retVal;
RTK_API_LOCK();
retVal = _rtk_trap_lldpEnable_get(pEnabled);
RTK_API_UNLOCK();
return retVal;
}
/* Function Name:
* rtk_trap_reasonTrapToCpuPriority_set
* Description:
* Set priority value of a packet that trapped to CPU port according to specific reason.
* Input:
* type - reason that trap to CPU port.
* priority - internal priority that is going to be set for specific trap reason.
* Output:
* None.
* Return:
* RT_ERR_OK
* RT_ERR_FAILED
* RT_ERR_NOT_INIT - The module is not initial
* RT_ERR_INPUT - Invalid input parameter
* Note:
* Currently the trap reason that supported are listed as follows:
* - TRAP_REASON_RMA
* - TRAP_REASON_OAM
* - TRAP_REASON_1XUNAUTH
* - TRAP_REASON_VLANSTACK
* - TRAP_REASON_UNKNOWNMC
*/
rtk_api_ret_t rtk_trap_reasonTrapToCpuPriority_set(rtk_trap_reason_type_t type, rtk_pri_t priority)
{
rtk_api_ret_t retVal;
RTK_API_LOCK();
retVal = _rtk_trap_reasonTrapToCpuPriority_set(type, priority);
RTK_API_UNLOCK();
return retVal;
}
/* Function Name:
* rtk_trap_reasonTrapToCpuPriority_get
* Description:
* Get priority value of a packet that trapped to CPU port according to specific reason.
* Input:
* type - reason that trap to CPU port.
* Output:
* pPriority - configured internal priority for such reason.
* Return:
* RT_ERR_OK
* RT_ERR_FAILED
* RT_ERR_NOT_INIT - The module is not initial
* RT_ERR_INPUT - Invalid input parameter
* RT_ERR_NULL_POINTER - NULL pointer
* Note:
* Currently the trap reason that supported are listed as follows:
* - TRAP_REASON_RMA
* - TRAP_REASON_OAM
* - TRAP_REASON_1XUNAUTH
* - TRAP_REASON_VLANSTACK
* - TRAP_REASON_UNKNOWNMC
*/
rtk_api_ret_t rtk_trap_reasonTrapToCpuPriority_get(rtk_trap_reason_type_t type, rtk_pri_t *pPriority)
{
rtk_api_ret_t retVal;
RTK_API_LOCK();
retVal = _rtk_trap_reasonTrapToCpuPriority_get(type, pPriority);
RTK_API_UNLOCK();
return retVal;
}
/* Function Name:
* rtk_trap_rmaAction_set
* Description:
* Set Reserved multicast address action configuration.
* Input:
* type - rma type.
* rma_action - RMA action.
* Output:
* None
* Return:
* RT_ERR_OK - OK
* RT_ERR_FAILED - Failed
* RT_ERR_SMI - SMI access error
* RT_ERR_INPUT - Invalid input parameters.
* Note:
*
* There are 48 types of Reserved Multicast Address frame for application usage.
* (1)They are as following definition.
* - TRAP_BRG_GROUP,
* - TRAP_FD_PAUSE,
* - TRAP_SP_MCAST,
* - TRAP_1X_PAE,
* - TRAP_UNDEF_BRG_04,
* - TRAP_UNDEF_BRG_05,
* - TRAP_UNDEF_BRG_06,
* - TRAP_UNDEF_BRG_07,
* - TRAP_PROVIDER_BRIDGE_GROUP_ADDRESS,
* - TRAP_UNDEF_BRG_09,
* - TRAP_UNDEF_BRG_0A,
* - TRAP_UNDEF_BRG_0B,
* - TRAP_UNDEF_BRG_0C,
* - TRAP_PROVIDER_BRIDGE_GVRP_ADDRESS,
* - TRAP_8021AB,
* - TRAP_UNDEF_BRG_0F,
* - TRAP_BRG_MNGEMENT,
* - TRAP_UNDEFINED_11,
* - TRAP_UNDEFINED_12,
* - TRAP_UNDEFINED_13,
* - TRAP_UNDEFINED_14,
* - TRAP_UNDEFINED_15,
* - TRAP_UNDEFINED_16,
* - TRAP_UNDEFINED_17,
* - TRAP_UNDEFINED_18,
* - TRAP_UNDEFINED_19,
* - TRAP_UNDEFINED_1A,
* - TRAP_UNDEFINED_1B,
* - TRAP_UNDEFINED_1C,
* - TRAP_UNDEFINED_1D,
* - TRAP_UNDEFINED_1E,
* - TRAP_UNDEFINED_1F,
* - TRAP_GMRP,
* - TRAP_GVRP,
* - TRAP_UNDEF_GARP_22,
* - TRAP_UNDEF_GARP_23,
* - TRAP_UNDEF_GARP_24,
* - TRAP_UNDEF_GARP_25,
* - TRAP_UNDEF_GARP_26,
* - TRAP_UNDEF_GARP_27,
* - TRAP_UNDEF_GARP_28,
* - TRAP_UNDEF_GARP_29,
* - TRAP_UNDEF_GARP_2A,
* - TRAP_UNDEF_GARP_2B,
* - TRAP_UNDEF_GARP_2C,
* - TRAP_UNDEF_GARP_2D,
* - TRAP_UNDEF_GARP_2E,
* - TRAP_UNDEF_GARP_2F,
* - TRAP_CDP.
* - TRAP_CSSTP.
* - TRAP_LLDP.
* (2) The RMA action is as following:
* - RMA_ACTION_FORWARD
* - RMA_ACTION_TRAP2CPU
* - RMA_ACTION_DROP
* - RMA_ACTION_FORWARD_EXCLUDE_CPU
*/
rtk_api_ret_t rtk_trap_rmaAction_set(rtk_trap_type_t type, rtk_trap_rma_action_t rma_action)
{
rtk_api_ret_t retVal;
RTK_API_LOCK();
retVal = _rtk_trap_rmaAction_set(type, rma_action);
RTK_API_UNLOCK();
return retVal;
}
/* Function Name:
* rtk_trap_rmaAction_get
* Description:
* Get Reserved multicast address action configuration.
* Input:
* type - rma type.
* Output:
* pRma_action - RMA action.
* Return:
* RT_ERR_OK - OK
* RT_ERR_FAILED - Failed
* RT_ERR_SMI - SMI access error
* RT_ERR_INPUT - Invalid input parameters.
* Note:
* There are 48 types of Reserved Multicast Address frame for application usage.
* (1)They are as following definition.
* - TRAP_BRG_GROUP,
* - TRAP_FD_PAUSE,
* - TRAP_SP_MCAST,
* - TRAP_1X_PAE,
* - TRAP_UNDEF_BRG_04,
* - TRAP_UNDEF_BRG_05,
* - TRAP_UNDEF_BRG_06,
* - TRAP_UNDEF_BRG_07,
* - TRAP_PROVIDER_BRIDGE_GROUP_ADDRESS,
* - TRAP_UNDEF_BRG_09,
* - TRAP_UNDEF_BRG_0A,
* - TRAP_UNDEF_BRG_0B,
* - TRAP_UNDEF_BRG_0C,
* - TRAP_PROVIDER_BRIDGE_GVRP_ADDRESS,
* - TRAP_8021AB,
* - TRAP_UNDEF_BRG_0F,
* - TRAP_BRG_MNGEMENT,
* - TRAP_UNDEFINED_11,
* - TRAP_UNDEFINED_12,
* - TRAP_UNDEFINED_13,
* - TRAP_UNDEFINED_14,
* - TRAP_UNDEFINED_15,
* - TRAP_UNDEFINED_16,
* - TRAP_UNDEFINED_17,
* - TRAP_UNDEFINED_18,
* - TRAP_UNDEFINED_19,
* - TRAP_UNDEFINED_1A,
* - TRAP_UNDEFINED_1B,
* - TRAP_UNDEFINED_1C,
* - TRAP_UNDEFINED_1D,
* - TRAP_UNDEFINED_1E,
* - TRAP_UNDEFINED_1F,
* - TRAP_GMRP,
* - TRAP_GVRP,
* - TRAP_UNDEF_GARP_22,
* - TRAP_UNDEF_GARP_23,
* - TRAP_UNDEF_GARP_24,
* - TRAP_UNDEF_GARP_25,
* - TRAP_UNDEF_GARP_26,
* - TRAP_UNDEF_GARP_27,
* - TRAP_UNDEF_GARP_28,
* - TRAP_UNDEF_GARP_29,
* - TRAP_UNDEF_GARP_2A,
* - TRAP_UNDEF_GARP_2B,
* - TRAP_UNDEF_GARP_2C,
* - TRAP_UNDEF_GARP_2D,
* - TRAP_UNDEF_GARP_2E,
* - TRAP_UNDEF_GARP_2F,
* - TRAP_CDP.
* - TRAP_CSSTP.
* - TRAP_LLDP.
* (2) The RMA action is as following:
* - RMA_ACTION_FORWARD
* - RMA_ACTION_TRAP2CPU
* - RMA_ACTION_DROP
* - RMA_ACTION_FORWARD_EXCLUDE_CPU
*/
rtk_api_ret_t rtk_trap_rmaAction_get(rtk_trap_type_t type, rtk_trap_rma_action_t *pRma_action)
{
rtk_api_ret_t retVal;
RTK_API_LOCK();
retVal = _rtk_trap_rmaAction_get(type, pRma_action);
RTK_API_UNLOCK();
return retVal;
}
/* Function Name:
* rtk_trap_rmaKeepFormat_set
* Description:
* Set Reserved multicast address keep format configuration.
* Input:
* type - rma type.
* enable - enable keep format.
* Output:
* None
* Return:
* RT_ERR_OK - OK
* RT_ERR_FAILED - Failed
* RT_ERR_SMI - SMI access error
* RT_ERR_INPUT - Invalid input parameters.
* RT_ERR_ENABLE - Invalid IFG parameter
* Note:
*
* There are 48 types of Reserved Multicast Address frame for application usage.
* They are as following definition.
* - TRAP_BRG_GROUP,
* - TRAP_FD_PAUSE,
* - TRAP_SP_MCAST,
* - TRAP_1X_PAE,
* - TRAP_UNDEF_BRG_04,
* - TRAP_UNDEF_BRG_05,
* - TRAP_UNDEF_BRG_06,
* - TRAP_UNDEF_BRG_07,
* - TRAP_PROVIDER_BRIDGE_GROUP_ADDRESS,
* - TRAP_UNDEF_BRG_09,
* - TRAP_UNDEF_BRG_0A,
* - TRAP_UNDEF_BRG_0B,
* - TRAP_UNDEF_BRG_0C,
* - TRAP_PROVIDER_BRIDGE_GVRP_ADDRESS,
* - TRAP_8021AB,
* - TRAP_UNDEF_BRG_0F,
* - TRAP_BRG_MNGEMENT,
* - TRAP_UNDEFINED_11,
* - TRAP_UNDEFINED_12,
* - TRAP_UNDEFINED_13,
* - TRAP_UNDEFINED_14,
* - TRAP_UNDEFINED_15,
* - TRAP_UNDEFINED_16,
* - TRAP_UNDEFINED_17,
* - TRAP_UNDEFINED_18,
* - TRAP_UNDEFINED_19,
* - TRAP_UNDEFINED_1A,
* - TRAP_UNDEFINED_1B,
* - TRAP_UNDEFINED_1C,
* - TRAP_UNDEFINED_1D,
* - TRAP_UNDEFINED_1E,
* - TRAP_UNDEFINED_1F,
* - TRAP_GMRP,
* - TRAP_GVRP,
* - TRAP_UNDEF_GARP_22,
* - TRAP_UNDEF_GARP_23,
* - TRAP_UNDEF_GARP_24,
* - TRAP_UNDEF_GARP_25,
* - TRAP_UNDEF_GARP_26,
* - TRAP_UNDEF_GARP_27,
* - TRAP_UNDEF_GARP_28,
* - TRAP_UNDEF_GARP_29,
* - TRAP_UNDEF_GARP_2A,
* - TRAP_UNDEF_GARP_2B,
* - TRAP_UNDEF_GARP_2C,
* - TRAP_UNDEF_GARP_2D,
* - TRAP_UNDEF_GARP_2E,
* - TRAP_UNDEF_GARP_2F,
* - TRAP_CDP.
* - TRAP_CSSTP.
* - TRAP_LLDP.
*/
rtk_api_ret_t rtk_trap_rmaKeepFormat_set(rtk_trap_type_t type, rtk_enable_t enable)
{
rtk_api_ret_t retVal;
RTK_API_LOCK();
retVal = _rtk_trap_rmaKeepFormat_set(type, enable);
RTK_API_UNLOCK();
return retVal;
}
/* Function Name:
* rtk_trap_rmaKeepFormat_get
* Description:
* Get Reserved multicast address action configuration.
* Input:
* type - rma type.
* Output:
* pEnable - keep format status.
* Return:
* RT_ERR_OK - OK
* RT_ERR_FAILED - Failed
* RT_ERR_SMI - SMI access error
* RT_ERR_INPUT - Invalid input parameters.
* Note:
* There are 48 types of Reserved Multicast Address frame for application usage.
* They are as following definition.
* - TRAP_BRG_GROUP,
* - TRAP_FD_PAUSE,
* - TRAP_SP_MCAST,
* - TRAP_1X_PAE,
* - TRAP_UNDEF_BRG_04,
* - TRAP_UNDEF_BRG_05,
* - TRAP_UNDEF_BRG_06,
* - TRAP_UNDEF_BRG_07,
* - TRAP_PROVIDER_BRIDGE_GROUP_ADDRESS,
* - TRAP_UNDEF_BRG_09,
* - TRAP_UNDEF_BRG_0A,
* - TRAP_UNDEF_BRG_0B,
* - TRAP_UNDEF_BRG_0C,
* - TRAP_PROVIDER_BRIDGE_GVRP_ADDRESS,
* - TRAP_8021AB,
* - TRAP_UNDEF_BRG_0F,
* - TRAP_BRG_MNGEMENT,
* - TRAP_UNDEFINED_11,
* - TRAP_UNDEFINED_12,
* - TRAP_UNDEFINED_13,
* - TRAP_UNDEFINED_14,
* - TRAP_UNDEFINED_15,
* - TRAP_UNDEFINED_16,
* - TRAP_UNDEFINED_17,
* - TRAP_UNDEFINED_18,
* - TRAP_UNDEFINED_19,
* - TRAP_UNDEFINED_1A,
* - TRAP_UNDEFINED_1B,
* - TRAP_UNDEFINED_1C,
* - TRAP_UNDEFINED_1D,
* - TRAP_UNDEFINED_1E,
* - TRAP_UNDEFINED_1F,
* - TRAP_GMRP,
* - TRAP_GVRP,
* - TRAP_UNDEF_GARP_22,
* - TRAP_UNDEF_GARP_23,
* - TRAP_UNDEF_GARP_24,
* - TRAP_UNDEF_GARP_25,
* - TRAP_UNDEF_GARP_26,
* - TRAP_UNDEF_GARP_27,
* - TRAP_UNDEF_GARP_28,
* - TRAP_UNDEF_GARP_29,
* - TRAP_UNDEF_GARP_2A,
* - TRAP_UNDEF_GARP_2B,
* - TRAP_UNDEF_GARP_2C,
* - TRAP_UNDEF_GARP_2D,
* - TRAP_UNDEF_GARP_2E,
* - TRAP_UNDEF_GARP_2F,
* - TRAP_CDP.
* - TRAP_CSSTP.
* - TRAP_LLDP.
*/
rtk_api_ret_t rtk_trap_rmaKeepFormat_get(rtk_trap_type_t type, rtk_enable_t *pEnable)
{
rtk_api_ret_t retVal;
RTK_API_LOCK();
retVal = _rtk_trap_rmaKeepFormat_get(type, pEnable);
RTK_API_UNLOCK();
return retVal;
}