git.droids-corp.org
/
dpdk.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
net/octeontx2: setup link config based on BP level
[dpdk.git]
/
drivers
/
net
/
qede
/
qede_filter.c
diff --git
a/drivers/net/qede/qede_filter.c
b/drivers/net/qede/qede_filter.c
index
b3f62e0
..
bad5574
100644
(file)
--- a/
drivers/net/qede/qede_filter.c
+++ b/
drivers/net/qede/qede_filter.c
@@
-272,6
+272,7
@@
qede_config_arfs_filter(struct rte_eth_dev *eth_dev,
{
struct qede_dev *qdev = QEDE_INIT_QDEV(eth_dev);
struct ecore_dev *edev = QEDE_INIT_EDEV(qdev);
{
struct qede_dev *qdev = QEDE_INIT_QDEV(eth_dev);
struct ecore_dev *edev = QEDE_INIT_EDEV(qdev);
+ struct ecore_ntuple_filter_params params;
char mz_name[RTE_MEMZONE_NAMESIZE] = {0};
struct qede_arfs_entry *tmp = NULL;
const struct rte_memzone *mz;
char mz_name[RTE_MEMZONE_NAMESIZE] = {0};
struct qede_arfs_entry *tmp = NULL;
const struct rte_memzone *mz;
@@
-344,12
+345,18
@@
qede_config_arfs_filter(struct rte_eth_dev *eth_dev,
ecore_arfs_mode_configure(p_hwfn, p_hwfn->p_arfs_ptt,
&qdev->arfs_info.arfs);
}
ecore_arfs_mode_configure(p_hwfn, p_hwfn->p_arfs_ptt,
&qdev->arfs_info.arfs);
}
+
+ memset(¶ms, 0, sizeof(params));
+ params.addr = (dma_addr_t)mz->iova;
+ params.length = pkt_len;
+ params.qid = arfs->rx_queue;
+ params.vport_id = 0;
+ params.b_is_add = add;
+ params.b_is_drop = arfs->is_drop;
+
/* configure filter with ECORE_SPQ_MODE_EBLOCK */
rc = ecore_configure_rfs_ntuple_filter(p_hwfn, NULL,
/* configure filter with ECORE_SPQ_MODE_EBLOCK */
rc = ecore_configure_rfs_ntuple_filter(p_hwfn, NULL,
- (dma_addr_t)mz->iova,
- pkt_len,
- arfs->rx_queue,
- 0, add);
+ ¶ms);
if (rc == ECORE_SUCCESS) {
if (add) {
arfs->pkt_len = pkt_len;
if (rc == ECORE_SUCCESS) {
if (add) {
arfs->pkt_len = pkt_len;
@@
-431,7
+438,7
@@
qede_fdir_filter_add(struct rte_eth_dev *eth_dev,
return -EINVAL;
}
return -EINVAL;
}
- if (fdir->action.rx_queue >= QEDE_RSS_COUNT(
q
dev)) {
+ if (fdir->action.rx_queue >= QEDE_RSS_COUNT(
eth_
dev)) {
DP_ERR(edev, "invalid queue number %u\n",
fdir->action.rx_queue);
return -EINVAL;
DP_ERR(edev, "invalid queue number %u\n",
fdir->action.rx_queue);
return -EINVAL;
@@
-1023,7
+1030,7
@@
qede_set_ucast_tunn_cmn_param(struct ecore_filter_ucast *ucast,
static int
_qede_tunn_filter_config(struct rte_eth_dev *eth_dev,
const struct rte_eth_tunnel_filter_conf *conf,
static int
_qede_tunn_filter_config(struct rte_eth_dev *eth_dev,
const struct rte_eth_tunnel_filter_conf *conf,
- __
attribute__((unused))
enum rte_filter_op filter_op,
+ __
rte_unused
enum rte_filter_op filter_op,
enum ecore_tunn_clss *clss,
bool add)
{
enum ecore_tunn_clss *clss,
bool add)
{
@@
-1161,7
+1168,7
@@
qede_tunn_filter_config(struct rte_eth_dev *eth_dev,
}
static int
}
static int
-qede_flow_validate_attr(__
attribute__((unused))
struct rte_eth_dev *dev,
+qede_flow_validate_attr(__
rte_unused
struct rte_eth_dev *dev,
const struct rte_flow_attr *attr,
struct rte_flow_error *error)
{
const struct rte_flow_attr *attr,
struct rte_flow_error *error)
{
@@
-1211,7
+1218,7
@@
qede_flow_validate_attr(__attribute__((unused))struct rte_eth_dev *dev,
}
static int
}
static int
-qede_flow_parse_pattern(__
attribute__((unused))
struct rte_eth_dev *dev,
+qede_flow_parse_pattern(__
rte_unused
struct rte_eth_dev *dev,
const struct rte_flow_item pattern[],
struct rte_flow_error *error,
struct rte_flow *flow)
const struct rte_flow_item pattern[],
struct rte_flow_error *error,
struct rte_flow *flow)
@@
-1345,7
+1352,6
@@
qede_flow_parse_actions(struct rte_eth_dev *dev,
struct rte_flow_error *error,
struct rte_flow *flow)
{
struct rte_flow_error *error,
struct rte_flow *flow)
{
- struct qede_dev *qdev = QEDE_INIT_QDEV(dev);
const struct rte_flow_action_queue *queue;
if (actions == NULL) {
const struct rte_flow_action_queue *queue;
if (actions == NULL) {
@@
-1360,7
+1366,7
@@
qede_flow_parse_actions(struct rte_eth_dev *dev,
case RTE_FLOW_ACTION_TYPE_QUEUE:
queue = actions->conf;
case RTE_FLOW_ACTION_TYPE_QUEUE:
queue = actions->conf;
- if (queue->index >= QEDE_RSS_COUNT(
q
dev)) {
+ if (queue->index >= QEDE_RSS_COUNT(dev)) {
rte_flow_error_set(error, EINVAL,
RTE_FLOW_ERROR_TYPE_ACTION,
actions,
rte_flow_error_set(error, EINVAL,
RTE_FLOW_ERROR_TYPE_ACTION,
actions,
@@
-1372,12
+1378,15
@@
qede_flow_parse_actions(struct rte_eth_dev *dev,
flow->entry.rx_queue = queue->index;
break;
flow->entry.rx_queue = queue->index;
break;
-
+ case RTE_FLOW_ACTION_TYPE_DROP:
+ if (flow)
+ flow->entry.is_drop = true;
+ break;
default:
rte_flow_error_set(error, ENOTSUP,
RTE_FLOW_ERROR_TYPE_ACTION,
actions,
default:
rte_flow_error_set(error, ENOTSUP,
RTE_FLOW_ERROR_TYPE_ACTION,
actions,
- "Action is not supported - only ACTION_TYPE_QUEUE supported");
+ "Action is not supported - only ACTION_TYPE_QUEUE
and ACTION_TYPE_DROP
supported");
return -rte_errno;
}
}
return -rte_errno;
}
}