[v2,00/10] net/mlx5: optimize flow resource allocation
Message ID | 1587004928-328077-1-git-send-email-suanmingm@mellanox.com (mailing list archive) |
---|---|
Headers |
Return-Path: <dev-bounces@dpdk.org> X-Original-To: patchwork@inbox.dpdk.org Delivered-To: patchwork@inbox.dpdk.org Received: from dpdk.org (dpdk.org [92.243.14.124]) by inbox.dpdk.org (Postfix) with ESMTP id 04DD0A0588; Thu, 16 Apr 2020 04:42:19 +0200 (CEST) Received: from [92.243.14.124] (localhost [127.0.0.1]) by dpdk.org (Postfix) with ESMTP id 1F5C81D99C; Thu, 16 Apr 2020 04:42:19 +0200 (CEST) Received: from git-send-mailer.rdmz.labs.mlnx (unknown [37.142.13.130]) by dpdk.org (Postfix) with ESMTP id 1893F1D996 for <dev@dpdk.org>; Thu, 16 Apr 2020 04:42:17 +0200 (CEST) From: Suanming Mou <suanmingm@mellanox.com> To: viacheslavo@mellanox.com, matan@mellanox.com Cc: rasland@mellanox.com, dev@dpdk.org Date: Thu, 16 Apr 2020 10:41:58 +0800 Message-Id: <1587004928-328077-1-git-send-email-suanmingm@mellanox.com> X-Mailer: git-send-email 1.8.3.1 In-Reply-To: <1586740309-449310-1-git-send-email-suanmingm@mellanox.com> References: <1586740309-449310-1-git-send-email-suanmingm@mellanox.com> Subject: [dpdk-dev] [PATCH v2 00/10] net/mlx5: optimize flow resource allocation X-BeenThere: dev@dpdk.org X-Mailman-Version: 2.1.15 Precedence: list List-Id: DPDK patches and discussions <dev.dpdk.org> List-Unsubscribe: <https://mails.dpdk.org/options/dev>, <mailto:dev-request@dpdk.org?subject=unsubscribe> List-Archive: <http://mails.dpdk.org/archives/dev/> List-Post: <mailto:dev@dpdk.org> List-Help: <mailto:dev-request@dpdk.org?subject=help> List-Subscribe: <https://mails.dpdk.org/listinfo/dev>, <mailto:dev-request@dpdk.org?subject=subscribe> Errors-To: dev-bounces@dpdk.org Sender: "dev" <dev-bounces@dpdk.org> |
Message
Suanming Mou
April 16, 2020, 2:41 a.m. UTC
Currently, flow may allocate several action resources during creation. Both allocate the individual resources and save the object handles have big memory overhead for the flow. Indexed memory pool is introduced to optimize the memory overhead. The resources can be allocated from the resource's own individual memory pool and only the 32-bits index is saved to the flow. In this case, it saves MALLOC_ELEM_OVERHEAD and 4 bytes for every flow resources. This patch series depends on the path which has been acked as below: https://patches.dpdk.org/patch/68143/ v2: - rebase to the lastet version. - add the missing 10th patch. Suanming Mou (10): net/mlx5: add indexed memory pool net/mlx5: add trunk dynamic grow for indexed pool net/mlx5: add trunk release for indexed pool net/mlx5: convert encap/decap resource to indexed net/mlx5: convert push VLAN resource to indexed net/mlx5: convert tag resource to indexed net/mlx5: convert port id action to indexed net/mlx5: convert jump resource to indexed net/mlx5: convert hrxq to indexed net/mlx5: convert flow dev handle to indexed drivers/net/mlx5/mlx5.c | 148 ++++++++++++++- drivers/net/mlx5/mlx5.h | 26 ++- drivers/net/mlx5/mlx5_flow.c | 23 ++- drivers/net/mlx5/mlx5_flow.h | 47 +++-- drivers/net/mlx5/mlx5_flow_dv.c | 271 +++++++++++++++++++--------- drivers/net/mlx5/mlx5_flow_verbs.c | 53 ++++-- drivers/net/mlx5/mlx5_rxq.c | 47 +++-- drivers/net/mlx5/mlx5_rxtx.h | 22 +-- drivers/net/mlx5/mlx5_utils.c | 361 +++++++++++++++++++++++++++++++++++++ drivers/net/mlx5/mlx5_utils.h | 247 +++++++++++++++++++++++++ 10 files changed, 1071 insertions(+), 174 deletions(-)