get:
Show a patch.

patch:
Update a patch.

put:
Update a patch.

GET /api/patches/117767/?format=api
HTTP 200 OK
Allow: GET, PUT, PATCH, HEAD, OPTIONS
Content-Type: application/json
Vary: Accept

{
    "id": 117767,
    "url": "http://patches.dpdk.org/api/patches/117767/?format=api",
    "web_url": "http://patches.dpdk.org/project/dpdk/patch/1665382142-21684-6-git-send-email-chaoyong.he@corigine.com/",
    "project": {
        "id": 1,
        "url": "http://patches.dpdk.org/api/projects/1/?format=api",
        "name": "DPDK",
        "link_name": "dpdk",
        "list_id": "dev.dpdk.org",
        "list_email": "dev@dpdk.org",
        "web_url": "http://core.dpdk.org",
        "scm_url": "git://dpdk.org/dpdk",
        "webscm_url": "http://git.dpdk.org/dpdk",
        "list_archive_url": "https://inbox.dpdk.org/dev",
        "list_archive_url_format": "https://inbox.dpdk.org/dev/{}",
        "commit_url_format": ""
    },
    "msgid": "<1665382142-21684-6-git-send-email-chaoyong.he@corigine.com>",
    "list_archive_url": "https://inbox.dpdk.org/dev/1665382142-21684-6-git-send-email-chaoyong.he@corigine.com",
    "date": "2022-10-10T06:08:43",
    "name": "[v2,05/24] net/nfp: add the offload support of basic actions",
    "commit_ref": null,
    "pull_url": null,
    "state": "superseded",
    "archived": true,
    "hash": "cff2e4ac7048faa046484e23b14430190d217fa9",
    "submitter": {
        "id": 2554,
        "url": "http://patches.dpdk.org/api/people/2554/?format=api",
        "name": "Chaoyong He",
        "email": "chaoyong.he@corigine.com"
    },
    "delegate": {
        "id": 319,
        "url": "http://patches.dpdk.org/api/users/319/?format=api",
        "username": "fyigit",
        "first_name": "Ferruh",
        "last_name": "Yigit",
        "email": "ferruh.yigit@amd.com"
    },
    "mbox": "http://patches.dpdk.org/project/dpdk/patch/1665382142-21684-6-git-send-email-chaoyong.he@corigine.com/mbox/",
    "series": [
        {
            "id": 25072,
            "url": "http://patches.dpdk.org/api/series/25072/?format=api",
            "web_url": "http://patches.dpdk.org/project/dpdk/list/?series=25072",
            "date": "2022-10-10T06:08:38",
            "name": "add the basic rte_flow offload support of nfp PMD",
            "version": 2,
            "mbox": "http://patches.dpdk.org/series/25072/mbox/"
        }
    ],
    "comments": "http://patches.dpdk.org/api/patches/117767/comments/",
    "check": "success",
    "checks": "http://patches.dpdk.org/api/patches/117767/checks/",
    "tags": {},
    "related": [],
    "headers": {
        "Return-Path": "<dev-bounces@dpdk.org>",
        "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])\n\tby inbox.dpdk.org (Postfix) with ESMTP id 6D8F2A0544;\n\tMon, 10 Oct 2022 08:09:58 +0200 (CEST)",
            "from [217.70.189.124] (localhost [127.0.0.1])\n\tby mails.dpdk.org (Postfix) with ESMTP id 2BAF042B72;\n\tMon, 10 Oct 2022 08:09:33 +0200 (CEST)",
            "from NAM02-SN1-obe.outbound.protection.outlook.com\n (mail-sn1anam02on2136.outbound.protection.outlook.com [40.107.96.136])\n by mails.dpdk.org (Postfix) with ESMTP id 11FAF427ED\n for <dev@dpdk.org>; Mon, 10 Oct 2022 08:09:31 +0200 (CEST)",
            "from SJ0PR13MB5545.namprd13.prod.outlook.com (2603:10b6:a03:424::5)\n by SN4PR13MB5296.namprd13.prod.outlook.com (2603:10b6:806:207::14)\n with Microsoft SMTP Server (version=TLS1_2,\n cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5723.14; Mon, 10 Oct\n 2022 06:09:29 +0000",
            "from SJ0PR13MB5545.namprd13.prod.outlook.com\n ([fe80::7c26:1a0b:2825:6f4b]) by SJ0PR13MB5545.namprd13.prod.outlook.com\n ([fe80::7c26:1a0b:2825:6f4b%4]) with mapi id 15.20.5723.014; Mon, 10 Oct 2022\n 06:09:29 +0000"
        ],
        "ARC-Seal": "i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none;\n b=GlRb/eXaFFoOUGlvCSNVaCnbKt40wUt8TeTsKzXb79HX96XBwMpHNAJikcvcp0DQLUWXXX9vMHikAO2O1gOOhzuOgYH0Bl7ltPzoQmBesrouKojj5JiC58xabR843ccjwveTRhMD0O0xyGkMhF+5C2vI0Z1vdyLEi988wzJSXylpjGbEhlJaW0edjLVEJnBK9zu5mc6wrE2TVqKX2ZAaZciykq1Uwih5AUieJxkqXbXQmZlbSutpDcqrG4DWC4STh4HKqxdXT5y8NqhMUxtgxvQm1s9WmBQC7HmC3cqH/GRa1HrOQ2UNE0YyoMOTuITTUNTeoL+63CFGfV6jiev+kw==",
        "ARC-Message-Signature": "i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com;\n s=arcselector9901;\n h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1;\n bh=bsqcC6bwaXzKZBSv8ceO6aeVhrhPXgpFQK2wm8LTVTw=;\n b=h8JMOueORJXNX84g+bHCxWSlsuYRhWWGiXnKdbjudQ6Wn3Bxd00BJQzQbz1mgIT9+4w+1N9hjDvvI6dlB04gRQ8hWGGwnkrKuMv/gZ3Mld7vFpYU4Eu1LzDp0v5QjzwvE7YfTfM71KCdi0EVGuL6w0lLKoZNDcwnxXjUdBwPN7Ui93rmcBs4c4XeSoV+FwrMLURKvcAXP3QXFvTfWTQrYcWCqNjM4NBmlzijjlR22zTscgDlyQpqp3e3VBQXZzbPsDqZFmfP+rQ/D1Ve2P48d7ios9jxcAk2IrwBcmZaavU7YkAPDv971hdTtReJ5ejxC4l9gApJA775mZbvV5KfHg==",
        "ARC-Authentication-Results": "i=1; mx.microsoft.com 1; spf=pass\n smtp.mailfrom=corigine.com; dmarc=pass action=none header.from=corigine.com;\n dkim=pass header.d=corigine.com; arc=none",
        "DKIM-Signature": "v=1; a=rsa-sha256; c=relaxed/relaxed;\n d=corigine.onmicrosoft.com; s=selector2-corigine-onmicrosoft-com;\n h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck;\n bh=bsqcC6bwaXzKZBSv8ceO6aeVhrhPXgpFQK2wm8LTVTw=;\n b=u2SqzyLR/eOEy+YHXCEiYdwGqpQC6WRHcgV8Dff9o93EDXFVtA5NolmKhjZ22VNjqwpH4foMZIsBU6g06i36xwf1D1gfxpupd+tkiMHc/LEsT/ofZPWDsOp61FvKwRM0lDnkQfFppLg+6b1Hx70G7qNz4mS+CHKmRp/WddIm5Jo=",
        "Authentication-Results": "dkim=none (message not signed)\n header.d=none;dmarc=none action=none header.from=corigine.com;",
        "From": "Chaoyong He <chaoyong.he@corigine.com>",
        "To": "dev@dpdk.org",
        "Cc": "oss-drivers@corigine.com, niklas.soderlund@corigine.com,\n Chaoyong He <chaoyong.he@corigine.com>",
        "Subject": "[PATCH v2 05/24] net/nfp: add the offload support of basic actions",
        "Date": "Mon, 10 Oct 2022 14:08:43 +0800",
        "Message-Id": "<1665382142-21684-6-git-send-email-chaoyong.he@corigine.com>",
        "X-Mailer": "git-send-email 1.8.3.1",
        "In-Reply-To": "<1665382142-21684-1-git-send-email-chaoyong.he@corigine.com>",
        "References": "<1665382142-21684-1-git-send-email-chaoyong.he@corigine.com>",
        "Content-Type": "text/plain; charset=UTF-8",
        "Content-Transfer-Encoding": "8bit",
        "X-ClientProxiedBy": "SI2PR01CA0051.apcprd01.prod.exchangelabs.com\n (2603:1096:4:193::6) To SJ0PR13MB5545.namprd13.prod.outlook.com\n (2603:10b6:a03:424::5)",
        "MIME-Version": "1.0",
        "X-MS-PublicTrafficType": "Email",
        "X-MS-TrafficTypeDiagnostic": "SJ0PR13MB5545:EE_|SN4PR13MB5296:EE_",
        "X-MS-Office365-Filtering-Correlation-Id": "37249d54-6d91-4994-257e-08daaa85fdda",
        "X-MS-Exchange-SenderADCheck": "1",
        "X-MS-Exchange-AntiSpam-Relay": "0",
        "X-Microsoft-Antispam": "BCL:0;",
        "X-Microsoft-Antispam-Message-Info": "\n jcZAgkVQXjp4OPzKK7VZS4Xp3XKo6lycM7kNfTSJ0+qUdzh+jTVJTtx1iGotkho+40AlBEpoZsifJFp3enghNNAoJC+5UlRzfZakYvG4R6WLb//T9p8i+8SGu5Mjb8MHE3pF3eG8oT/wyTxcCa5OznjgK2Q4M2Ko69KLp2LQ3v9VOOxwIMehFf/abeIZBJLGnsMQXs6bJGQXtNW4fTcI1DqezK25YTh0IwbUQLbrJlfUZGrXIyms4kTT5eNDmXAPg5apfxYWt7g90FSJb4esX2N606qA4V2N3W+miU5XF3H7tZz3I2s7s4Y4dGRhl8BTKsoFRDbpj05XPtxZpZev+AEkfuEq9GJY06EhIDH6fFRUVw9/ieN3EpSALKJpN3PpL2mcllI6K8zvSsb+TsEwLrP3SkCXW00bRYUGzuNnO1IwMhgzRWa9s09ASXcyeIGLbNxRuosFyhI4QbA068FZ4FprRiH9NN3BAuyclj8FJPrXjfYZaatk5LUa/6gur/0Am5rC3j5puLC5V/24knSK+hROz2eTpqo7aF9rqmjDAMg2GvH1zxzQIvDJ2Db7RjpKznQe1PiL9Cd/vMX3AuVENvjF2N4UWgE3zqu7AiZO6zP9sky+VVt5Gk3t/HJMLqYpPpPdhAmdEW5568WcePJ5VEeziSQA8AHzWmvue5iAwo7WJaPMurRUKuo/YRrfMN0yWz3cthBPOuzji08Uf46t1+8NjBJzN7CKBBceeDolnkYCvbwItuvljhHd4j4mWoQDjK8b2fLpqDAw6SxRY5TCL+0HSByJ1otCg5hjvdrMK+nk9yAiNDhHsyhH5mjRfP9TwgSBOgszuJIoAfvBcgpE0Q==",
        "X-Forefront-Antispam-Report": "CIP:255.255.255.255; CTRY:; LANG:en; SCL:1; SRV:;\n IPV:NLI; SFV:NSPM; H:SJ0PR13MB5545.namprd13.prod.outlook.com; PTR:; CAT:NONE;\n SFS:(13230022)(4636009)(366004)(396003)(346002)(376002)(136003)(39830400003)(451199015)(6916009)(316002)(2906002)(186003)(6486002)(2616005)(66476007)(6666004)(107886003)(66556008)(41300700001)(66946007)(83380400001)(8936002)(8676002)(4326008)(5660300002)(44832011)(26005)(6506007)(6512007)(52116002)(86362001)(478600001)(36756003)(38350700002)(38100700002)(473944003);\n DIR:OUT; SFP:1102;",
        "X-MS-Exchange-AntiSpam-MessageData-ChunkCount": "1",
        "X-MS-Exchange-AntiSpam-MessageData-0": "=?utf-8?q?edGyotF/hhEiIwGXyFsRUcW3mGjp?=\n\t=?utf-8?q?fPqBD6gWA9yvcPLPxcpt1dC9NXmbRcjPAYxbYmVaGJA1r1PEuG51TWI/ynFv1yR3P?=\n\t=?utf-8?q?XPJe8ZkPhknaO3zYvm6GWPz7jhznxviq/2sMXqazzzUVu0Zzc3nX+CqcHWPIbRKu+?=\n\t=?utf-8?q?IxO6s3VFVOxDVWpD3ko8BrivGsv2222eNwubo5tIUhlCdRQGWr5m9oYMA6cNdwOfN?=\n\t=?utf-8?q?fRv5CaI4XVfc/WcsQhLu+dVNjeeDmTXvqi3fRhQKVQPGES3OU61ox+LgpxQS0/Tz2?=\n\t=?utf-8?q?C4hdnGBFumiDTqIJOV/7Pc4x1xlg2HnscJnPZnZ44AWDoNvQFxgc6Kwt95Iwzgans?=\n\t=?utf-8?q?gMJN0VyRRGf0yjSGmzfOrxsvWS8Ec3Zgme8qeM+VVzQP0y87h7Qf1P3ElIXaKw2Ih?=\n\t=?utf-8?q?ovBUD+RqGglTeMC7Qb9wZAj/z2sxi29Z+WV78DrAajeuB1vWuTiErUJvAl8RawiZd?=\n\t=?utf-8?q?3xwSU9wB/NN4P4mlYfdjrHI6ayYwikgAqAcnw2EgY4hY20JOuYKPgEslJJk0+ySTe?=\n\t=?utf-8?q?5EeNuRfs+snxkVtPfLCghgSc5HuX/FBhIgPJhI22BLdsq+yxtOuByJ2vyN7fVBvM8?=\n\t=?utf-8?q?z2hZmYao8OSkOkokBQ74H73jRayKqiWKt8ilTPDzUo9GNGLcEOUKdOtlncIpbNcW3?=\n\t=?utf-8?q?IZupuFJQbpnFUqkKJdrLcOtgV5HtsFfVkWZHCaV0w97jAj6AqlMLaALkofZOwpk9j?=\n\t=?utf-8?q?m1Q+QIAFWNRor2PKyyhwpBBGdsJRIFxjD22s8zgyON37AQGli5qmEXhArfsua4wK8?=\n\t=?utf-8?q?sBGbTvEm3YNX3CS4/8Q3ZE6Q66K2RJ3FHq3yyCFDWnkO/ZHbziYNEOJ5nCpmSGXpV?=\n\t=?utf-8?q?GQKtTZxq2U2AWEwvK1aQiouVNvp81T5lAw/mcQ99z6VKle4FQ7GRDa/RD3/h+py4T?=\n\t=?utf-8?q?7N/mVeKpQlK1nl8Qiax3gBLW3+hyZKWgCAiuz4o/TRD5/E9POaSp1NrSMEq6MhLm0?=\n\t=?utf-8?q?s2MFwetIbs2RmVpIRjdudhCAGWkVKreTDJr8yssbUdo2KJ/VTwMPnKM9lJhd5Y8S+?=\n\t=?utf-8?q?2NI/NOcTEgRah2Ar3bHo5+KVh+sirNuj9/JIRiZzBsw1nY0oaCs5YhmJJRDxpNtzC?=\n\t=?utf-8?q?SP7ku80NA8AhxpQ4BqQD64Wu8ICCIdwxcjF4E1Aye4Cnjelrk+DdB1wdSdAJuasD7?=\n\t=?utf-8?q?uifxgzqstWTZG77+02/YYDexRxU22g/MKnFHIrd3DRzk9LfqhJ9fZ/HkYgSb76x4N?=\n\t=?utf-8?q?s05lC9l7lcpLsZWPc6xSJ1adcStwl0PXPIitud2vgv5qHISapYiFbo2npqrJ68zBV?=\n\t=?utf-8?q?23uxbNYneKqlytqPlm144MDNSP/EaqnyhFEZVuDiPUssF0RfNU1LSxK0QLcBv8gGp?=\n\t=?utf-8?q?tljvEsF2ewr940m4tyUeOqmUrjSbbOn2tBVhMQ87gSH56HTLqTn+QMd4rUkK5GKew?=\n\t=?utf-8?q?MzmqFrAEiSqmr9K5K63T6BEkZgvRFiJHyHvITzp7eCHvzoIgbvlHMOXUwcXXpKPNR?=\n\t=?utf-8?q?8ZMQimrI82Y2ybUwJpphYOjyXoOmKKOCwaM0N77fPJlKPsatZJ5DPkZMkd5aLnzZp?=\n\t=?utf-8?q?9GnUJooJ+EB6BSeEqD2Ojxbgcake7Jkwbw=3D=3D?=",
        "X-OriginatorOrg": "corigine.com",
        "X-MS-Exchange-CrossTenant-Network-Message-Id": "\n 37249d54-6d91-4994-257e-08daaa85fdda",
        "X-MS-Exchange-CrossTenant-AuthSource": "SJ0PR13MB5545.namprd13.prod.outlook.com",
        "X-MS-Exchange-CrossTenant-AuthAs": "Internal",
        "X-MS-Exchange-CrossTenant-OriginalArrivalTime": "10 Oct 2022 06:09:29.4056 (UTC)",
        "X-MS-Exchange-CrossTenant-FromEntityHeader": "Hosted",
        "X-MS-Exchange-CrossTenant-Id": "fe128f2c-073b-4c20-818e-7246a585940c",
        "X-MS-Exchange-CrossTenant-MailboxType": "HOSTED",
        "X-MS-Exchange-CrossTenant-UserPrincipalName": "\n Iqz12+KTR7hVgb5s+pk77DCiTwhEohoPJ0l+81S5ZZEOGmirTIVf3GLnkJ8vhFbml9VmRS5L8NQZcnc8918FuSjycEGHpyA9yLJl5PEYKFs=",
        "X-MS-Exchange-Transport-CrossTenantHeadersStamped": "SN4PR13MB5296",
        "X-BeenThere": "dev@dpdk.org",
        "X-Mailman-Version": "2.1.29",
        "Precedence": "list",
        "List-Id": "DPDK patches and discussions <dev.dpdk.org>",
        "List-Unsubscribe": "<https://mails.dpdk.org/options/dev>,\n <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>,\n <mailto:dev-request@dpdk.org?subject=subscribe>",
        "Errors-To": "dev-bounces@dpdk.org"
    },
    "content": "Add the offload support of very basic actions: mark, rss,\ncount, drop and output.\n\nSigned-off-by: Chaoyong He <chaoyong.he@corigine.com>\nReviewed-by: Niklas Söderlund <niklas.soderlund@corigine.com>\n---\n doc/guides/nics/features/nfp.ini         |   6 ++\n doc/guides/rel_notes/release_22_11.rst   |   6 ++\n drivers/net/nfp/flower/nfp_flower_cmsg.h |  11 +++\n drivers/net/nfp/nfp_flow.c               | 112 +++++++++++++++++++++++++++++++\n drivers/net/nfp/nfp_flow.h               |  37 ++++++++++\n 5 files changed, 172 insertions(+)",
    "diff": "diff --git a/doc/guides/nics/features/nfp.ini b/doc/guides/nics/features/nfp.ini\nindex 4460cf0..194fe64 100644\n--- a/doc/guides/nics/features/nfp.ini\n+++ b/doc/guides/nics/features/nfp.ini\n@@ -29,3 +29,9 @@ Usage doc            = Y\n [rte_flow items]\n eth                  = Y\n port_id              = Y\n+\n+[rte_flow actions]\n+count                = Y\n+dec_ttl              = Y\n+drop                 = Y\n+port_id              = Y\ndiff --git a/doc/guides/rel_notes/release_22_11.rst b/doc/guides/rel_notes/release_22_11.rst\nindex cd22d95..ac0223f 100644\n--- a/doc/guides/rel_notes/release_22_11.rst\n+++ b/doc/guides/rel_notes/release_22_11.rst\n@@ -155,6 +155,12 @@ New Features\n \n     * Ethernet\n \n+  Add the support of rte_flow actions as follow:\n+\n+    * Count\n+    * Drop\n+    * TTL decrement\n+\n * **Updated NXP dpaa2 driver.**\n \n   * Added support for flow action REPRESENTED_PORT.\ndiff --git a/drivers/net/nfp/flower/nfp_flower_cmsg.h b/drivers/net/nfp/flower/nfp_flower_cmsg.h\nindex 75a3b91..d776e37 100644\n--- a/drivers/net/nfp/flower/nfp_flower_cmsg.h\n+++ b/drivers/net/nfp/flower/nfp_flower_cmsg.h\n@@ -253,6 +253,17 @@ struct nfp_flower_mac_mpls {\n \trte_be32_t mpls_lse;\n };\n \n+struct nfp_fl_act_head {\n+\tuint8_t jump_id;\n+\tuint8_t len_lw;\n+};\n+\n+struct nfp_fl_act_output {\n+\tstruct nfp_fl_act_head head;\n+\trte_be16_t flags;\n+\trte_be32_t port;\n+};\n+\n int nfp_flower_cmsg_mac_repr(struct nfp_app_fw_flower *app_fw_flower);\n int nfp_flower_cmsg_repr_reify(struct nfp_app_fw_flower *app_fw_flower,\n \t\tstruct nfp_flower_representor *repr);\ndiff --git a/drivers/net/nfp/nfp_flow.c b/drivers/net/nfp/nfp_flow.c\nindex a077423..ec021f0 100644\n--- a/drivers/net/nfp/nfp_flow.c\n+++ b/drivers/net/nfp/nfp_flow.c\n@@ -558,6 +558,22 @@ struct nfp_mask_id_entry {\n \t\tcase RTE_FLOW_ACTION_TYPE_VOID:\n \t\t\tPMD_DRV_LOG(DEBUG, \"RTE_FLOW_ACTION_TYPE_VOID detected\");\n \t\t\tbreak;\n+\t\tcase RTE_FLOW_ACTION_TYPE_MARK:\n+\t\t\tPMD_DRV_LOG(DEBUG, \"RTE_FLOW_ACTION_TYPE_MARK detected\");\n+\t\t\tbreak;\n+\t\tcase RTE_FLOW_ACTION_TYPE_DROP:\n+\t\t\tPMD_DRV_LOG(DEBUG, \"RTE_FLOW_ACTION_TYPE_DROP detected\");\n+\t\t\tbreak;\n+\t\tcase RTE_FLOW_ACTION_TYPE_COUNT:\n+\t\t\tPMD_DRV_LOG(DEBUG, \"RTE_FLOW_ACTION_TYPE_COUNT detected\");\n+\t\t\tbreak;\n+\t\tcase RTE_FLOW_ACTION_TYPE_RSS:\n+\t\t\tPMD_DRV_LOG(DEBUG, \"RTE_FLOW_ACTION_TYPE_RSS detected\");\n+\t\t\tbreak;\n+\t\tcase RTE_FLOW_ACTION_TYPE_PORT_ID:\n+\t\t\tPMD_DRV_LOG(DEBUG, \"RTE_FLOW_ACTION_TYPE_PORT_ID detected\");\n+\t\t\tkey_ls->act_size += sizeof(struct nfp_fl_act_output);\n+\t\t\tbreak;\n \t\tdefault:\n \t\t\tPMD_DRV_LOG(ERR, \"Action type %d not supported.\", action->type);\n \t\t\treturn -ENOTSUP;\n@@ -785,6 +801,96 @@ struct nfp_mask_id_entry {\n \treturn 0;\n }\n \n+static int\n+nfp_flow_action_output(char *act_data,\n+\t\tconst struct rte_flow_action *action,\n+\t\tstruct nfp_fl_rule_metadata *nfp_flow_meta)\n+{\n+\tsize_t act_size;\n+\tstruct rte_eth_dev *ethdev;\n+\tstruct nfp_fl_act_output *output;\n+\tstruct nfp_flower_representor *representor;\n+\tconst struct rte_flow_action_port_id *port_id;\n+\n+\tport_id = action->conf;\n+\tif (port_id == NULL || port_id->id >= RTE_MAX_ETHPORTS)\n+\t\treturn -ERANGE;\n+\n+\tethdev = &rte_eth_devices[port_id->id];\n+\trepresentor = (struct nfp_flower_representor *)ethdev->data->dev_private;\n+\tact_size = sizeof(struct nfp_fl_act_output);\n+\n+\toutput = (struct nfp_fl_act_output *)act_data;\n+\toutput->head.jump_id = NFP_FL_ACTION_OPCODE_OUTPUT;\n+\toutput->head.len_lw  = act_size >> NFP_FL_LW_SIZ;\n+\toutput->flags        = rte_cpu_to_be_16(NFP_FL_OUT_FLAGS_LAST);\n+\toutput->port         = rte_cpu_to_be_32(representor->port_id);\n+\n+\tnfp_flow_meta->shortcut = rte_cpu_to_be_32(representor->port_id);\n+\n+\treturn 0;\n+}\n+\n+static int\n+nfp_flow_compile_action(__rte_unused struct nfp_flower_representor *representor,\n+\t\tconst struct rte_flow_action actions[],\n+\t\tstruct rte_flow *nfp_flow)\n+{\n+\tint ret = 0;\n+\tchar *position;\n+\tchar *action_data;\n+\tbool drop_flag = false;\n+\tuint32_t total_actions = 0;\n+\tconst struct rte_flow_action *action;\n+\tstruct nfp_fl_rule_metadata *nfp_flow_meta;\n+\n+\tnfp_flow_meta = nfp_flow->payload.meta;\n+\taction_data   = nfp_flow->payload.action_data;\n+\tposition      = action_data;\n+\n+\tfor (action = actions; action->type != RTE_FLOW_ACTION_TYPE_END; ++action) {\n+\t\tswitch (action->type) {\n+\t\tcase RTE_FLOW_ACTION_TYPE_VOID:\n+\t\t\tbreak;\n+\t\tcase RTE_FLOW_ACTION_TYPE_MARK:\n+\t\t\tPMD_DRV_LOG(DEBUG, \"Process RTE_FLOW_ACTION_TYPE_MARK\");\n+\t\t\tbreak;\n+\t\tcase RTE_FLOW_ACTION_TYPE_DROP:\n+\t\t\tPMD_DRV_LOG(DEBUG, \"Process RTE_FLOW_ACTION_TYPE_DROP\");\n+\t\t\tdrop_flag = true;\n+\t\t\tbreak;\n+\t\tcase RTE_FLOW_ACTION_TYPE_COUNT:\n+\t\t\tPMD_DRV_LOG(DEBUG, \"Process RTE_FLOW_ACTION_TYPE_COUNT\");\n+\t\t\tbreak;\n+\t\tcase RTE_FLOW_ACTION_TYPE_RSS:\n+\t\t\tPMD_DRV_LOG(DEBUG, \"Process RTE_FLOW_ACTION_TYPE_RSS\");\n+\t\t\tbreak;\n+\t\tcase RTE_FLOW_ACTION_TYPE_PORT_ID:\n+\t\t\tPMD_DRV_LOG(DEBUG, \"Process RTE_FLOW_ACTION_TYPE_PORT_ID\");\n+\t\t\tret = nfp_flow_action_output(position, action, nfp_flow_meta);\n+\t\t\tif (ret != 0) {\n+\t\t\t\tPMD_DRV_LOG(ERR, \"Failed when process\"\n+\t\t\t\t\t\t\" RTE_FLOW_ACTION_TYPE_PORT_ID\");\n+\t\t\t\treturn ret;\n+\t\t\t}\n+\n+\t\t\tposition += sizeof(struct nfp_fl_act_output);\n+\t\t\tbreak;\n+\t\tdefault:\n+\t\t\tPMD_DRV_LOG(ERR, \"Unsupported action type: %d\", action->type);\n+\t\t\treturn -ENOTSUP;\n+\t\t}\n+\t\ttotal_actions++;\n+\t}\n+\n+\tif (drop_flag)\n+\t\tnfp_flow_meta->shortcut = rte_cpu_to_be_32(NFP_FL_SC_ACT_DROP);\n+\telse if (total_actions > 1)\n+\t\tnfp_flow_meta->shortcut = rte_cpu_to_be_32(NFP_FL_SC_ACT_NULL);\n+\n+\treturn 0;\n+}\n+\n static struct rte_flow *\n nfp_flow_process(struct nfp_flower_representor *representor,\n \t\tconst struct rte_flow_item items[],\n@@ -833,6 +939,12 @@ struct nfp_mask_id_entry {\n \t\tgoto free_flow;\n \t}\n \n+\tret = nfp_flow_compile_action(representor, actions, nfp_flow);\n+\tif (ret != 0) {\n+\t\tPMD_DRV_LOG(ERR, \"nfp flow action process failed.\");\n+\t\tgoto free_flow;\n+\t}\n+\n \tnfp_flow_meta = nfp_flow->payload.meta;\n \tmask_data = nfp_flow->payload.mask_data;\n \tmask_len = key_layer.key_size;\ndiff --git a/drivers/net/nfp/nfp_flow.h b/drivers/net/nfp/nfp_flow.h\nindex 83f9f29..f1fbada 100644\n--- a/drivers/net/nfp/nfp_flow.h\n+++ b/drivers/net/nfp/nfp_flow.h\n@@ -33,6 +33,43 @@\n /* The firmware expects lengths in units of long words */\n #define NFP_FL_LW_SIZ                   2\n \n+#define NFP_FL_SC_ACT_DROP      0x80000000\n+#define NFP_FL_SC_ACT_USER      0x7D000000\n+#define NFP_FL_SC_ACT_POPV      0x6A000000\n+#define NFP_FL_SC_ACT_NULL      0x00000000\n+\n+/* Action opcodes */\n+#define NFP_FL_ACTION_OPCODE_OUTPUT             0\n+#define NFP_FL_ACTION_OPCODE_PUSH_VLAN          1\n+#define NFP_FL_ACTION_OPCODE_POP_VLAN           2\n+#define NFP_FL_ACTION_OPCODE_PUSH_MPLS          3\n+#define NFP_FL_ACTION_OPCODE_POP_MPLS           4\n+#define NFP_FL_ACTION_OPCODE_USERSPACE          5\n+#define NFP_FL_ACTION_OPCODE_SET_TUNNEL         6\n+#define NFP_FL_ACTION_OPCODE_SET_ETHERNET       7\n+#define NFP_FL_ACTION_OPCODE_SET_MPLS           8\n+#define NFP_FL_ACTION_OPCODE_SET_IPV4_ADDRS     9\n+#define NFP_FL_ACTION_OPCODE_SET_IPV4_TTL_TOS   10\n+#define NFP_FL_ACTION_OPCODE_SET_IPV6_SRC       11\n+#define NFP_FL_ACTION_OPCODE_SET_IPV6_DST       12\n+#define NFP_FL_ACTION_OPCODE_SET_IPV6_TC_HL_FL  13\n+#define NFP_FL_ACTION_OPCODE_SET_UDP            14\n+#define NFP_FL_ACTION_OPCODE_SET_TCP            15\n+#define NFP_FL_ACTION_OPCODE_PRE_LAG            16\n+#define NFP_FL_ACTION_OPCODE_PRE_TUNNEL         17\n+#define NFP_FL_ACTION_OPCODE_PRE_GS             18\n+#define NFP_FL_ACTION_OPCODE_GS                 19\n+#define NFP_FL_ACTION_OPCODE_PUSH_NSH           20\n+#define NFP_FL_ACTION_OPCODE_POP_NSH            21\n+#define NFP_FL_ACTION_OPCODE_SET_QUEUE          22\n+#define NFP_FL_ACTION_OPCODE_CONNTRACK          23\n+#define NFP_FL_ACTION_OPCODE_METER              24\n+#define NFP_FL_ACTION_OPCODE_CT_NAT_EXT         25\n+#define NFP_FL_ACTION_OPCODE_PUSH_GENEVE        26\n+#define NFP_FL_ACTION_OPCODE_NUM                32\n+\n+#define NFP_FL_OUT_FLAGS_LAST            (1 << 15)\n+\n /* Tunnel ports */\n #define NFP_FL_PORT_TYPE_TUN            0x50000000\n \n",
    "prefixes": [
        "v2",
        "05/24"
    ]
}