2021-01-28 10:38:47 -06:00
|
|
|
/*! \file ngknet_extra.h
|
|
|
|
*
|
|
|
|
* Generic data structure definitions for NGKNET enhancement.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
/*
|
2023-10-26 05:58:34 -05:00
|
|
|
* $Copyright: Copyright 2018-2022 Broadcom. All rights reserved.
|
2021-01-28 10:38:47 -06:00
|
|
|
* The term 'Broadcom' refers to Broadcom Inc. and/or its subsidiaries.
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License
|
|
|
|
* version 2 as published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* A copy of the GNU General Public License version 2 (GPLv2) can
|
|
|
|
* be found in the LICENSES folder.$
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef NGKNET_EXTRA_H
|
|
|
|
#define NGKNET_EXTRA_H
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* \brief Filter control.
|
|
|
|
*/
|
|
|
|
struct filt_ctrl {
|
|
|
|
/*! List head */
|
|
|
|
struct list_head list;
|
|
|
|
|
|
|
|
/*! Device number */
|
|
|
|
int dev_no;
|
|
|
|
|
|
|
|
/*! Number of hits */
|
|
|
|
uint64_t hits;
|
|
|
|
|
|
|
|
/*! Filter description */
|
|
|
|
ngknet_filter_t filt;
|
|
|
|
};
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* \brief Create filter.
|
|
|
|
*
|
|
|
|
* \param [in] dev Device structure point.
|
|
|
|
* \param [in] filter Filter structure point.
|
|
|
|
*
|
|
|
|
* \retval SHR_E_NONE No errors.
|
|
|
|
* \retval SHR_E_XXXX Operation failed.
|
|
|
|
*/
|
|
|
|
extern int
|
|
|
|
ngknet_filter_create(struct ngknet_dev *dev, ngknet_filter_t *filter);
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* \brief Destroy filter.
|
|
|
|
*
|
|
|
|
* \param [in] dev Device structure point.
|
|
|
|
* \param [in] id Filter ID.
|
|
|
|
*
|
|
|
|
* \retval SHR_E_NONE No errors.
|
|
|
|
* \retval SHR_E_XXXX Operation failed.
|
|
|
|
*/
|
|
|
|
extern int
|
|
|
|
ngknet_filter_destroy(struct ngknet_dev *dev, int id);
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* \brief Destroy all the filters.
|
|
|
|
*
|
|
|
|
* \param [in] dev Device structure point.
|
|
|
|
*
|
|
|
|
* \retval SHR_E_NONE No errors.
|
|
|
|
* \retval SHR_E_XXXX Operation failed.
|
|
|
|
*/
|
|
|
|
extern int
|
|
|
|
ngknet_filter_destroy_all(struct ngknet_dev *dev);
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* \brief Get filter.
|
|
|
|
*
|
|
|
|
* \param [in] dev Device structure point.
|
|
|
|
* \param [in] id Filter ID.
|
|
|
|
* \param [out] filter Filter structure point.
|
|
|
|
*
|
|
|
|
* \retval SHR_E_NONE No errors.
|
|
|
|
* \retval SHR_E_XXXX Operation failed.
|
|
|
|
*/
|
|
|
|
extern int
|
|
|
|
ngknet_filter_get(struct ngknet_dev *dev, int id, ngknet_filter_t *filter);
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* \brief Get the next filter.
|
|
|
|
*
|
|
|
|
* \param [in] dev Device structure point.
|
|
|
|
* \param [out] filter Filter structure point.
|
|
|
|
*
|
|
|
|
* \retval SHR_E_NONE No errors.
|
|
|
|
* \retval SHR_E_XXXX Operation failed.
|
|
|
|
*/
|
|
|
|
extern int
|
|
|
|
ngknet_filter_get_next(struct ngknet_dev *dev, ngknet_filter_t *filter);
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* \brief Filter packet.
|
|
|
|
*
|
|
|
|
* \param [in] dev Device structure point.
|
|
|
|
* \param [in] skb Rx packet SKB.
|
|
|
|
* \param [out] mndev Mirror network interface.
|
|
|
|
* \param [out] mskb Mirror Rx packet SKB.
|
|
|
|
*
|
|
|
|
* \retval Matched network interface.
|
|
|
|
* \retval NULL No matched network interface.
|
|
|
|
*/
|
|
|
|
extern int
|
|
|
|
ngknet_rx_pkt_filter(struct ngknet_dev *dev, struct sk_buff *skb, struct net_device **ndev,
|
|
|
|
struct net_device **mndev, struct sk_buff **mskb);
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* \brief Rx rate limit control.
|
|
|
|
*
|
|
|
|
* This contains all the control information for Rx rate limit such as
|
|
|
|
* the number of Rx packets, status related to Rx rate limit, etc.
|
|
|
|
*
|
|
|
|
* The rate limit is kernel-oriented, i.e. all the Rx packets from any
|
|
|
|
* device/channel will be accounted for. Once the received packets reach
|
|
|
|
* the limit value in an 1-Sec interval, the driver API XXXX_rx_suspend()
|
|
|
|
* will be called to suspend Rx. The 1-Sec basis timer will call the driver
|
|
|
|
* API XXXX_rx_resume() to resume Rx and reset rate-related status/counters
|
|
|
|
* at the begin of the next 1-Sec interval.
|
|
|
|
*
|
|
|
|
* The NGKNET module parameter 'rx_rate_limit' is used to decide the maximum
|
|
|
|
* Rx rate. Disable Rx rate limit if set 0. It can be set when inserting
|
|
|
|
* NGKNET module or modified using its SYSFS attributions.
|
|
|
|
*/
|
|
|
|
struct ngknet_rl_ctrl {
|
|
|
|
/*! Rx packets */
|
|
|
|
int rx_pkts;
|
|
|
|
|
|
|
|
/*! Rx overruns */
|
|
|
|
int rx_overruns;
|
|
|
|
|
|
|
|
/*! Rx ticks */
|
|
|
|
int rx_ticks;
|
|
|
|
|
|
|
|
/*! Active devices under rate control */
|
|
|
|
int dev_active[NUM_PDMA_DEV_MAX];
|
|
|
|
|
|
|
|
/*! Paused devices due to no Rx credit */
|
|
|
|
int dev_paused[NUM_PDMA_DEV_MAX];
|
|
|
|
|
|
|
|
/*! Rate limit timer */
|
|
|
|
struct timer_list timer;
|
|
|
|
|
|
|
|
/*! Rate limit lock */
|
|
|
|
spinlock_t lock;
|
|
|
|
|
|
|
|
/*! Devices */
|
|
|
|
struct ngknet_dev *devs;
|
|
|
|
|
|
|
|
/*! Rate limit status indicator */
|
|
|
|
int started;
|
|
|
|
};
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* \brief Initialize Rx rate limit.
|
|
|
|
*
|
|
|
|
* \param [in] devs Devices array.
|
|
|
|
*/
|
|
|
|
extern void
|
|
|
|
ngknet_rx_rate_limit_init(struct ngknet_dev *devs);
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* \brief Cleanup Rx rate limit.
|
|
|
|
*/
|
|
|
|
extern void
|
|
|
|
ngknet_rx_rate_limit_cleanup(void);
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* \brief Get Rx rate limit state.
|
|
|
|
*/
|
|
|
|
extern int
|
|
|
|
ngknet_rx_rate_limit_started(void);
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* \brief Start Rx rate limit.
|
|
|
|
*
|
|
|
|
* \param [in] dev Device structure point.
|
|
|
|
*/
|
|
|
|
extern void
|
|
|
|
ngknet_rx_rate_limit_start(struct ngknet_dev *dev);
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* \brief Stop Rx rate limit.
|
|
|
|
*
|
|
|
|
* \param [in] dev Device structure point.
|
|
|
|
*/
|
|
|
|
extern void
|
|
|
|
ngknet_rx_rate_limit_stop(struct ngknet_dev *dev);
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* \brief Limit Rx rate.
|
|
|
|
*
|
|
|
|
* \param [in] dev Device structure point.
|
|
|
|
*/
|
|
|
|
extern void
|
|
|
|
ngknet_rx_rate_limit(struct ngknet_dev *dev, int limit);
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* \brief Schedule Tx queue.
|
|
|
|
*
|
|
|
|
* \param [in] dev Device structure point.
|
|
|
|
* \param [in] queue Tx queue number.
|
|
|
|
*/
|
|
|
|
extern void
|
|
|
|
ngknet_tx_queue_schedule(struct ngknet_dev *dev, struct sk_buff *skb, int *queue);
|
|
|
|
|
|
|
|
#endif /* NGKNET_EXTRA_H */
|
|
|
|
|