From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from dpdk.org (dpdk.org [92.243.14.124]) by inbox.dpdk.org (Postfix) with ESMTP id 7259BA0562; Thu, 2 Apr 2020 21:36:06 +0200 (CEST) Received: from [92.243.14.124] (localhost [127.0.0.1]) by dpdk.org (Postfix) with ESMTP id 945951C032; Thu, 2 Apr 2020 21:35:27 +0200 (CEST) Received: from mail-pj1-f65.google.com (mail-pj1-f65.google.com [209.85.216.65]) by dpdk.org (Postfix) with ESMTP id 81DF21C032 for ; Thu, 2 Apr 2020 21:35:25 +0200 (CEST) Received: by mail-pj1-f65.google.com with SMTP id l36so1944358pjb.3 for ; Thu, 02 Apr 2020 12:35:25 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:in-reply-to:references; bh=7ZtBtLjvkgnbYqyqfcv2nc5ne3CDyosjkaCXPuE9Qoo=; b=CfV+aEdy9xLG6jHH4riUzORNK0wj3jXT0sPHnPm7BvVQmy45+idxRdmp9EUroLj1VM XujXwcIpPLC+rnpO4aRUw2VOTMczvggUQYbE0+Gd+I2B3HhTnv/jTEsaWk7KBo2fFIM6 9H45N4t+My0LCZC6uC9SDjqNe0Cq5GbtvReGpsdCf8gCEa2Z3dp/aePyQAogAhVzSyYF 4AXFcNvLlv2nA/U84Z8+oKr//yLUntRwIBh4DamLplxMgEd21sZUoBAPmBXje0svm8Bk hmE6Rlanr2HZyrZgwBEOMEEFXwKBFbQFaPnv6JEGnVV5FV6JVzQUCx1X1r5W/lB+4G3U Fb8Q== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references; bh=7ZtBtLjvkgnbYqyqfcv2nc5ne3CDyosjkaCXPuE9Qoo=; b=kByEmJljTNZ2CM3OPSs/HCh0sOr94zTGetpbhGV4pgWjSraE6aOBgAvhZMeWtq0qA7 di1THJjq4NignpXkQpKx0RNYgCqRh9Fc06kKn/TRSccQERlfLn8IvNxg0V6KlxuFQvas xgEsuEp5j32Gm15Ifi/v2wIcye9mxeboRHfGWJb/CmUCIu6DTd6ioFD2/ShQBqxG9ffI eQrUKBtJu3WzBd5RdhmR7qTvYQdpMomaUFkHNKq28ubHJ7Ss60Fm7GUqD8R1ddlKBGSY +XY0tj+CuY20F7jNmhKJhvb95FULNUEVft1jK51H97H2wpf3/GIE0r6APcv6LP8cmgnF OHUA== X-Gm-Message-State: AGi0PuavcwpV/6XzK4hDuXUsex2xCPN8X0RUkhzQ4l0t+JdxveQBF1kQ GAVY+Q+newfcJw/5hJAyTfU= X-Google-Smtp-Source: APiQypIBdDaEb4YxTJ31bYo/4qMAm4PAFIgLaNbhyLIAIs/mMnC5iOlPUA2LWff/TSeWoeyjTYnrLQ== X-Received: by 2002:a17:90b:4d0b:: with SMTP id mw11mr5601038pjb.45.1585856124626; Thu, 02 Apr 2020 12:35:24 -0700 (PDT) Received: from hyd1588t430.marvell.com ([115.113.156.2]) by smtp.gmail.com with ESMTPSA id k70sm3898259pga.91.2020.04.02.12.35.22 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Thu, 02 Apr 2020 12:35:23 -0700 (PDT) From: Nithin Dabilpuram To: Jerin Jacob , Nithin Dabilpuram , Kiran Kumar K Cc: dev@dpdk.org, kkanas@marvell.com Date: Fri, 3 Apr 2020 01:04:47 +0530 Message-Id: <20200402193453.17266-6-nithind1988@gmail.com> X-Mailer: git-send-email 2.8.4 In-Reply-To: <20200402193453.17266-1-nithind1988@gmail.com> References: <20200312111907.31555-1-ndabilpuram@marvell.com> <20200402193453.17266-1-nithind1988@gmail.com> Subject: [dpdk-dev] [PATCH v2 05/11] net/octeontx2: add tm node suspend and resume cb X-BeenThere: dev@dpdk.org X-Mailman-Version: 2.1.15 Precedence: list List-Id: DPDK patches and discussions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dev-bounces@dpdk.org Sender: "dev" From: Krzysztof Kanas Add TM support to suspend and resume nodes post hierarchy commit. Signed-off-by: Krzysztof Kanas Signed-off-by: Nithin Dabilpuram --- drivers/net/octeontx2/otx2_tm.c | 81 +++++++++++++++++++++++++++++++++++++++++ 1 file changed, 81 insertions(+) diff --git a/drivers/net/octeontx2/otx2_tm.c b/drivers/net/octeontx2/otx2_tm.c index bbd8e19..36cc0a4 100644 --- a/drivers/net/octeontx2/otx2_tm.c +++ b/drivers/net/octeontx2/otx2_tm.c @@ -1540,6 +1540,28 @@ nix_tm_alloc_resources(struct rte_eth_dev *eth_dev, bool xmit_enable) return 0; } +static int +send_tm_reqval(struct otx2_mbox *mbox, + struct nix_txschq_config *req, + struct rte_tm_error *error) +{ + int rc; + + if (!req->num_regs || + req->num_regs > MAX_REGS_PER_MBOX_MSG) { + error->type = RTE_TM_ERROR_TYPE_UNSPECIFIED; + error->message = "invalid config"; + return -EIO; + } + + rc = otx2_mbox_process(mbox); + if (rc) { + error->type = RTE_TM_ERROR_TYPE_UNSPECIFIED; + error->message = "unexpected fatal error"; + } + return rc; +} + static uint16_t nix_tm_lvl2nix(struct otx2_eth_dev *dev, uint32_t lvl) { @@ -1806,9 +1828,68 @@ otx2_nix_tm_node_delete(struct rte_eth_dev *eth_dev, uint32_t node_id, return 0; } +static int +nix_tm_node_suspend_resume(struct rte_eth_dev *eth_dev, uint32_t node_id, + struct rte_tm_error *error, bool suspend) +{ + struct otx2_eth_dev *dev = otx2_eth_pmd_priv(eth_dev); + struct otx2_mbox *mbox = dev->mbox; + struct otx2_nix_tm_node *tm_node; + struct nix_txschq_config *req; + uint16_t flags; + int rc; + + tm_node = nix_tm_node_search(dev, node_id, true); + if (!tm_node) { + error->type = RTE_TM_ERROR_TYPE_NODE_ID; + error->message = "no such node"; + return -EINVAL; + } + + if (!(dev->tm_flags & NIX_TM_COMMITTED)) { + error->type = RTE_TM_ERROR_TYPE_UNSPECIFIED; + error->message = "hierarchy doesn't exist"; + return -EINVAL; + } + + flags = tm_node->flags; + flags = suspend ? (flags & ~NIX_TM_NODE_ENABLED) : + (flags | NIX_TM_NODE_ENABLED); + + if (tm_node->flags == flags) + return 0; + + /* send mbox for state change */ + req = otx2_mbox_alloc_msg_nix_txschq_cfg(mbox); + + req->lvl = tm_node->hw_lvl; + req->num_regs = prepare_tm_sw_xoff(tm_node, suspend, + req->reg, req->regval); + rc = send_tm_reqval(mbox, req, error); + if (!rc) + tm_node->flags = flags; + return rc; +} + +static int +otx2_nix_tm_node_suspend(struct rte_eth_dev *eth_dev, uint32_t node_id, + struct rte_tm_error *error) +{ + return nix_tm_node_suspend_resume(eth_dev, node_id, error, true); +} + +static int +otx2_nix_tm_node_resume(struct rte_eth_dev *eth_dev, uint32_t node_id, + struct rte_tm_error *error) +{ + return nix_tm_node_suspend_resume(eth_dev, node_id, error, false); +} + const struct rte_tm_ops otx2_tm_ops = { .node_add = otx2_nix_tm_node_add, .node_delete = otx2_nix_tm_node_delete, + .node_suspend = otx2_nix_tm_node_suspend, + .node_resume = otx2_nix_tm_node_resume, }; static int -- 2.8.4