From patchwork Fri Dec 22 21:56:51 2023 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Ajit Khaparde X-Patchwork-Id: 135540 X-Patchwork-Delegate: ajit.khaparde@broadcom.com Return-Path: X-Original-To: patchwork@inbox.dpdk.org Delivered-To: patchwork@inbox.dpdk.org Received: from mails.dpdk.org (mails.dpdk.org [217.70.189.124]) by inbox.dpdk.org (Postfix) with ESMTP id C451143762; Fri, 22 Dec 2023 22:58:24 +0100 (CET) Received: from mails.dpdk.org (localhost [127.0.0.1]) by mails.dpdk.org (Postfix) with ESMTP id D956942E8C; Fri, 22 Dec 2023 22:57:22 +0100 (CET) Received: from mail-pj1-f46.google.com (mail-pj1-f46.google.com [209.85.216.46]) by mails.dpdk.org (Postfix) with ESMTP id 3B14642E79 for ; Fri, 22 Dec 2023 22:57:20 +0100 (CET) Received: by mail-pj1-f46.google.com with SMTP id 98e67ed59e1d1-28bc870c540so1751258a91.2 for ; Fri, 22 Dec 2023 13:57:20 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=broadcom.com; s=google; t=1703282239; x=1703887039; darn=dpdk.org; h=mime-version:references:in-reply-to:message-id:date:subject:cc:to :from:from:to:cc:subject:date:message-id:reply-to; bh=Zizz6VTPiIdA4iy3GDL6A+reHYGnpLHCOEAKi8t1RdU=; b=BlgC2j7aPf8xSKL20EW8usA8d5AxOKC2VL/ZV5oXMOLWiWzRp5IS3a+PIAXeBiwFCD bNjcuLyt+ByzYmDJGBHK5TKZA60rely9ar3yRhKCxIUlkRdubsc4dUWIrUHdFuXBMoaT APxCwj5uZj82zXOYnr8OBTX8PHen9vG0gzG8Q= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1703282239; x=1703887039; h=mime-version:references:in-reply-to:message-id:date:subject:cc:to :from:x-gm-message-state:from:to:cc:subject:date:message-id:reply-to; bh=Zizz6VTPiIdA4iy3GDL6A+reHYGnpLHCOEAKi8t1RdU=; b=nF2GsiJQ1j2dKkOfg8gybu82sE2QP5ePH90ZvK7q3Qd3WMy5Svvi0B9zY8ACzwkwdx IRxN2BFORSPYgP0g9YmbUFQfp/HkYaMC3PVJe06om8UcO0rI/Q9+FjmCu78v2Irn1103 M301BsQqtdhLCcnDx1BH36weTlQIyomRGff+RY4RMrVZCzCv7HspKDMSIAwS/9AXc8fY 6A3mt7DVlz76+jm2EnkGbTGooSBZktNbKlX+jE7A5PvmB+Dw8MVCTl2YjhdINCs/HbNf Qsfs7jnAf1PWZdaiuTjVMVRs/i9aVgl8L99CJA1Mx0Gw2BW8N+cL42CkTOtZ1dCW09mz d3mQ== X-Gm-Message-State: AOJu0YxydmONopXN81K5OF8FsgQCT0w8NQFECByu8Y8eXktbqkJDtvQs qZ22gLkhGHvExnaXH9Zi4gE/XZxxpdiJQX6gpg/R+Uhz57GqtVrXaq/CaJ/KDvZbnXv3ZWUCVcz SbiTSg9J0x0UsgBCVuORKJPxtfsDKC69xcl8Gjfqd05KtkGFBhCjK9S5Y9rFgw1vgiLH+iUaAlB c= X-Google-Smtp-Source: AGHT+IGrx8D4u99rABv43yFWaC5iAFmuWhjHRVWI+KcvXupnA380SRMlFVX25i0SQQLfsY05nxlHJQ== X-Received: by 2002:a17:90b:690:b0:28b:d14d:ba9a with SMTP id m16-20020a17090b069000b0028bd14dba9amr1506524pjz.91.1703282238459; Fri, 22 Dec 2023 13:57:18 -0800 (PST) Received: from C02GC2QQMD6T.wifi.broadcom.net ([192.19.223.252]) by smtp.gmail.com with ESMTPSA id sr5-20020a17090b4e8500b0028afd8b1e0bsm3540700pjb.57.2023.12.22.13.57.17 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 22 Dec 2023 13:57:17 -0800 (PST) From: Ajit Khaparde To: dev@dpdk.org Cc: Damodharam Ammepalli Subject: [PATCH v2 10/18] net/bnxt: add flow query callback Date: Fri, 22 Dec 2023 13:56:51 -0800 Message-Id: <20231222215659.64993-11-ajit.khaparde@broadcom.com> X-Mailer: git-send-email 2.39.2 (Apple Git-143) In-Reply-To: <20231222215659.64993-1-ajit.khaparde@broadcom.com> References: <20231222215659.64993-1-ajit.khaparde@broadcom.com> MIME-Version: 1.0 X-BeenThere: dev@dpdk.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: DPDK patches and discussions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dev-bounces@dpdk.org From: Damodharam Ammepalli This patch addsbnxt query callback to rte_flow_ops in non TruFlow mode. At this point only the RSS hash function type is displayed. Signed-off-by: Damodharam Ammepalli Reviewed-by: Ajit Khaparde --- drivers/net/bnxt/bnxt_flow.c | 61 ++++++++++++++++++++++++++++++++++++ drivers/net/bnxt/bnxt_vnic.c | 11 +++++++ drivers/net/bnxt/bnxt_vnic.h | 2 ++ 3 files changed, 74 insertions(+) diff --git a/drivers/net/bnxt/bnxt_flow.c b/drivers/net/bnxt/bnxt_flow.c index 2d707b48d2..f25bc6ff78 100644 --- a/drivers/net/bnxt/bnxt_flow.c +++ b/drivers/net/bnxt/bnxt_flow.c @@ -1917,6 +1917,66 @@ void bnxt_flow_cnt_alarm_cb(void *arg) (void *)bp); } +/* Query an requested flow rule. */ +static int +bnxt_flow_query_all(struct rte_flow *flow, + const struct rte_flow_action *actions, void *data, + struct rte_flow_error *error) +{ + struct rte_flow_action_rss *rss_conf; + struct bnxt_vnic_info *vnic; + + vnic = flow->vnic; + if (vnic == NULL) + return rte_flow_error_set(error, EINVAL, + RTE_FLOW_ERROR_TYPE_HANDLE, flow, + "Invalid flow: failed to query flow."); + + for (; actions->type != RTE_FLOW_ACTION_TYPE_END; actions++) { + switch (actions->type) { + case RTE_FLOW_ACTION_TYPE_VOID: + break; + case RTE_FLOW_ACTION_TYPE_COUNT: + break; + case RTE_FLOW_ACTION_TYPE_RSS: + /* Full details of rte_flow_action_rss not available yet TBD*/ + rss_conf = (struct rte_flow_action_rss *)data; + + /* toeplitz is default */ + if (vnic->ring_select_mode == + HWRM_VNIC_RSS_CFG_INPUT_RING_SELECT_MODE_TOEPLITZ) + rss_conf->func = vnic->hash_f_local; + else + rss_conf->func = RTE_ETH_HASH_FUNCTION_SIMPLE_XOR; + + break; + default: + return rte_flow_error_set(error, ENOTSUP, + RTE_FLOW_ERROR_TYPE_ACTION, actions, + "action is not supported"); + } + } + + return 0; +} + +static int +bnxt_flow_query(struct rte_eth_dev *dev, struct rte_flow *flow, + const struct rte_flow_action *actions, void *data, + struct rte_flow_error *error) +{ + struct bnxt *bp = dev->data->dev_private; + int ret = 0; + + if (bp == NULL) + return -ENODEV; + + bnxt_acquire_flow_lock(bp); + ret = bnxt_flow_query_all(flow, actions, data, error); + bnxt_release_flow_lock(bp); + + return ret; +} static struct rte_flow * bnxt_flow_create(struct rte_eth_dev *dev, @@ -2374,4 +2434,5 @@ const struct rte_flow_ops bnxt_flow_ops = { .create = bnxt_flow_create, .destroy = bnxt_flow_destroy, .flush = bnxt_flow_flush, + .query = bnxt_flow_query, }; diff --git a/drivers/net/bnxt/bnxt_vnic.c b/drivers/net/bnxt/bnxt_vnic.c index 6a57f85ea7..bf1f0ea09f 100644 --- a/drivers/net/bnxt/bnxt_vnic.c +++ b/drivers/net/bnxt/bnxt_vnic.c @@ -1335,6 +1335,9 @@ int bnxt_rte_flow_to_hwrm_ring_select_mode(enum rte_eth_hash_function hash_f, } vnic->ring_select_mode = _bnxt_rte_to_hwrm_ring_select_mode(hash_f); + vnic->hash_f_local = hash_f; + /* shadow copy types as !hash_f is always true with default func */ + vnic->rss_types_local = types; return 0; } @@ -1359,6 +1362,8 @@ int bnxt_rte_eth_to_hwrm_ring_select_mode(struct bnxt *bp, uint64_t types, */ vnic->ring_select_mode = HWRM_VNIC_RSS_CFG_INPUT_RING_SELECT_MODE_TOEPLITZ; + vnic->hash_f_local = + HWRM_VNIC_RSS_CFG_INPUT_RING_SELECT_MODE_TOEPLITZ; return 0; } @@ -1367,6 +1372,12 @@ void bnxt_hwrm_rss_to_rte_hash_conf(struct bnxt_vnic_info *vnic, { uint32_t hash_types; + /* check for local shadow rte types */ + if (vnic->rss_types_local != 0) { + *rss_conf = vnic->rss_types_local; + return; + } + hash_types = vnic->hash_type; *rss_conf = 0; if (hash_types & HWRM_VNIC_RSS_CFG_INPUT_HASH_TYPE_IPV4) diff --git a/drivers/net/bnxt/bnxt_vnic.h b/drivers/net/bnxt/bnxt_vnic.h index d01c9ebdb4..93155648e2 100644 --- a/drivers/net/bnxt/bnxt_vnic.h +++ b/drivers/net/bnxt/bnxt_vnic.h @@ -79,6 +79,8 @@ struct bnxt_vnic_info { STAILQ_HEAD(, bnxt_filter_info) filter; STAILQ_HEAD(, rte_flow) flow_list; uint8_t ring_select_mode; + enum rte_eth_hash_function hash_f_local; + uint64_t rss_types_local; }; struct bnxt_vnic_queue_db {