From patchwork Thu Sep 28 12:29:55 2017 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Shreyansh Jain X-Patchwork-Id: 29319 X-Patchwork-Delegate: ferruh.yigit@amd.com Return-Path: X-Original-To: patchwork@dpdk.org Delivered-To: patchwork@dpdk.org Received: from [92.243.14.124] (localhost [127.0.0.1]) by dpdk.org (Postfix) with ESMTP id 2A7AD1B28F; Thu, 28 Sep 2017 14:20:54 +0200 (CEST) Received: from NAM01-BN3-obe.outbound.protection.outlook.com (mail-bn3nam01on0076.outbound.protection.outlook.com [104.47.33.76]) by dpdk.org (Postfix) with ESMTP id 21CF9107A for ; Thu, 28 Sep 2017 14:20:17 +0200 (CEST) Received: from CY4PR03CA0099.namprd03.prod.outlook.com (10.171.242.168) by BN3PR03MB2354.namprd03.prod.outlook.com (10.166.74.149) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384_P256) id 15.20.77.7; Thu, 28 Sep 2017 12:20:15 +0000 Received: from BL2FFO11FD008.protection.gbl (2a01:111:f400:7c09::134) by CY4PR03CA0099.outlook.office365.com (2603:10b6:910:4d::40) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384_P256) id 15.20.56.11 via Frontend Transport; Thu, 28 Sep 2017 12:20:15 +0000 Authentication-Results: spf=fail (sender IP is 192.88.168.50) smtp.mailfrom=nxp.com; nxp.com; dkim=none (message not signed) header.d=none;nxp.com; dmarc=fail action=none header.from=nxp.com; Received-SPF: Fail (protection.outlook.com: domain of nxp.com does not designate 192.88.168.50 as permitted sender) receiver=protection.outlook.com; client-ip=192.88.168.50; helo=tx30smr01.am.freescale.net; Received: from tx30smr01.am.freescale.net (192.88.168.50) by BL2FFO11FD008.mail.protection.outlook.com (10.173.161.4) with Microsoft SMTP Server (version=TLS1_0, cipher=TLS_RSA_WITH_AES_256_CBC_SHA) id 15.20.56.11 via Frontend Transport; Thu, 28 Sep 2017 12:20:15 +0000 Received: from Tophie.ap.freescale.net ([10.232.14.39]) by tx30smr01.am.freescale.net (8.14.3/8.14.0) with ESMTP id v8SCJ72S008785; Thu, 28 Sep 2017 05:20:13 -0700 From: Shreyansh Jain To: CC: , Date: Thu, 28 Sep 2017 17:59:55 +0530 Message-ID: <20170928123000.1711-36-shreyansh.jain@nxp.com> X-Mailer: git-send-email 2.9.3 In-Reply-To: <20170928123000.1711-1-shreyansh.jain@nxp.com> References: <20170928113344.12248-1-shreyansh.jain@nxp.com> <20170928123000.1711-1-shreyansh.jain@nxp.com> X-EOPAttributedMessage: 0 X-Matching-Connectors: 131510748155285958; (91ab9b29-cfa4-454e-5278-08d120cd25b8); () X-Forefront-Antispam-Report: CIP:192.88.168.50; IPV:NLI; CTRY:US; EFV:NLI; SFV:NSPM; SFS:(10009020)(6009001)(336005)(376002)(346002)(39860400002)(39380400002)(2980300002)(1109001)(1110001)(339900001)(189002)(199003)(50986999)(8936002)(68736007)(106466001)(85426001)(50226002)(76176999)(50466002)(8656003)(48376002)(36756003)(47776003)(1076002)(4326008)(105606002)(189998001)(498600001)(81156014)(97736004)(33646002)(81166006)(5003940100001)(104016004)(6916009)(2950100002)(54906003)(5660300001)(8676002)(2906002)(6666003)(305945005)(16586007)(316002)(2351001)(77096006)(356003)(53936002)(86362001)(21314002); DIR:OUT; SFP:1101; SCL:1; SRVR:BN3PR03MB2354; H:tx30smr01.am.freescale.net; FPR:; SPF:Fail; PTR:InfoDomainNonexistent; MX:1; A:1; LANG:en; X-Microsoft-Exchange-Diagnostics: 1; BL2FFO11FD008; 1:ifMIqBXHWUHPQvn0gylpiDvqQ6PxA0nzNDq9RyuhYAJtC1rA20jN6lkKOez2u8EKrINZh1222qIT9qJZcPj49VFksc+8DjsTIpD4jwDxd+nVD7ZA6HI4qucZDdxw+dd3 MIME-Version: 1.0 X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: 3dfe2ae7-acf2-4da0-11c6-08d5066b4668 X-Microsoft-Antispam: UriScan:; BCL:0; PCL:0; RULEID:(22001)(2017052603199)(201703131430075)(201703131517081); SRVR:BN3PR03MB2354; X-Microsoft-Exchange-Diagnostics: 1; BN3PR03MB2354; 3:ojDHQ/IvN+A4jarG7vg9ceFyuphO4xJX6Kx7waCAEBq32hQ8TspdsqYPvFtbrmJlGO4SW/gyO9vA8mPQj5jkTaQ2lhGHTqHOLs94iQPc/3D22ooRij4vbXzIOf9seI5Y4bIJIlsfdIRbmlj5eV0Kv2jeYsQKBEVTHDHs6X1ZBnypTQLyK/VvYnhvHw6dnD3V7i749WZSox4onjYBycX6f0+WJUDcHFLWdov3040801TkWDp+7qiNrisHAqu0noq/08Rbg88P59HnU1a2n3bqYE7VzBusHzDHvUYoBy3NDOl3ZjKR8NUgvr+GU7PH2J8I9fps727zx1Y1IltQzXNCU/aJy2TjyFW8Q3GOl3Wii58=; 25:BkUSU7SQenSRhrelOed8zU52D9GxXas5Ey4nBwOy7hcYb8t5+ccsfdgbeG/NktNIjgUIiZL3MNsCFSLiEoRU6OZL/LPKKop3CEzPywGmq6txHGHUu3J8I1Ehr8OUIpGb+NuWaegEVA5CaZq/HenlAf4hjrzkBFI3wmfOiryo1V8Wlx9vDDrJpGRWeenJT5cT+3VkaC/6LgjPLGxolUAaCbmKwb6RbkvHBFEdPwwBvLN40wtk5oQs9UDEUA1Y6CLB1EUkfpxZycqWrR5hL9TRO7HHMgoh6yl/Y2yWmHnABbnnmhs+TXjEZvz4vHkwcdKibPKFfP0WNJdhEIX3iQOGQg== X-MS-TrafficTypeDiagnostic: BN3PR03MB2354: X-Microsoft-Exchange-Diagnostics: 1; BN3PR03MB2354; 31:TwGZ1pG+abT0KGRki8qIa7r1UcRIZHV8Cm3Iaa4gvh7B1CewJrgpee4K/zrqBYz9kQF/U+yDDVeMxVcEbPqDP63RkCclEPU2EId7PokM83jB5YbmVg4b3ck+ey+wAGg/DNV6nLkyqJWFCH/uAZPKLQd2/hleSxPMNmC4GpYYF+jWCqmJbeMgIRiurzh5pC5vwiZhhD9lN0kTQJY4xjyS/k9EkM2arYoaMNJaclF1RFo=; 4:a9cIXuM8ncKBRFC/6Vk1bhOVlCjocL/9aCrGagKLXWOLkjSEcQx54vbgLzCJbaw7NlBjO1/iGD6nrOKHOKAZF4txISpGZrE4T0jpXjzSUo7o9cdjbTqnRnt+GpoevLb6igXeLUyYSjrwhpVg76I790M2pbXa1fc5h3BD8PiZ3jf8B/PfuadwvAuCTkEmk8eZU+4tOXDh+aH0PcBkyO1qSc0ZSADAOa+FEWQW549t/+gBDLRqpZSOXcdX/LTxtzgPL9L1hCsV3dP0zLatYahfTS7anXf9NXcS+EniCIhl6PY= X-Exchange-Antispam-Report-Test: UriScan:(185117386973197); X-Microsoft-Antispam-PRVS: X-Exchange-Antispam-Report-CFA-Test: BCL:0; PCL:0; RULEID:(100000700101)(100105000095)(100000701101)(100105300095)(100000702101)(100105100095)(6095135)(2401047)(8121501046)(5005006)(100000703101)(100105400095)(93006095)(93001095)(3002001)(10201501046)(6055026)(6096035)(201703131430075)(201703131433075)(201703131448075)(201703161259150)(201703151042153)(20161123565025)(20161123559100)(20161123556025)(20161123563025)(20161123561025)(201708071742011)(100000704101)(100105200095)(100000705101)(100105500095); SRVR:BN3PR03MB2354; BCL:0; PCL:0; RULEID:(100000800101)(100110000095)(100000801101)(100110300095)(100000802101)(100110100095)(100000803101)(100110400095)(400006)(100000804101)(100110200095)(100000805101)(100110500095); SRVR:BN3PR03MB2354; X-Forefront-PRVS: 0444EB1997 X-Microsoft-Exchange-Diagnostics: =?us-ascii?Q?1; BN3PR03MB2354; 23:ZHeKlPcbJx5UkKR/iirraDDSpB6+Zrodl9mnN97xD?= lgjjm1nMWSzrXT9+Gz3ODrih1gqbIKuHO77AtsFeCYHGlna6OnNplvLxQnqqbbSHc9YxQRT6/Qtz39IjSS1FKyAnTuvkh11dDglAsxG+6YLFB2Pj9QjpLqrV6YG6oyvtYFiyTiGARBELj8+z0kSW+g4iC71ZkiJE94eez0bM+PcB38BZfR9zjNYGUgJ+4gCWeSRz/uElAgcO1LqxhjE8yhOdqKsITtce/Xylrw/O85HV37+6tiWCnMBdZHwHB09dTtcqR++HTN75Pho+yvq67hyeRG0KFwJlInBiTEI8A7b5+IRagiKCqHlV1GQzPm67BHxSrQJ3Xqkhn1QBfMX+ppFvNJvamGBZXD8qItxEvH/bLgUCtcC93c6BLfDZlSsFXxD1M8b0ev07NW7HuO9MD1wSzlfmMlF9X9gFyj5xuj7KgsQwrDDMUFH221J8Fw41b4avIaLViVVney0HpYNP3LPLFJjV9mzuZwVgVRRSncEGnBWB8oE2P0ZLGA3VBOpOJ0z6sr4Plu8dYsfCQNyGKkKA0tSEySH5P+v9ZmMoVKTVvhSHEvbo1ZW0MpP6/dtjD85W5pRazlSacjtTAHm67Eef2Vj8NcBqlgQV1VJ844M9Rk61zLenVtSHe34J+ulax6DWidjW1vX54o1gHAypyR7ZD4byAzMt18z2NncstszSBoLRr1J1i4kzLk6xUDaovdfH3D6bfboXQ4pEh9GBmcR6K3fcWpP5nBbPZ512kxd29FhI4mUFOEi8Khfsy+NTtb3/yKSCyhlAYukAT8j0nYH/3TTGldmhtq+bxK4NsN9e9zD7GwzxKqvHQFpEpeaBP72qqsDUePh5UF/MIkoxOx/uSlaCqkllFtxrWhmFSMg9PwBOUmMebpAnKfbDuSVvKxwdiV3vGwXswnJtFdy8Jw6IB35weAI1y2f9VStMZRfceXRQPNZgpdt+Y0SkvBRfthqhjbY+7uPqBPJoptylIi3fba39yymA9/qC+UEpZRpWMlRIO2ZCBQVOY5OsujtnukZ4UDwP343eMwvbtbOYbE6SfPtr33/m2RdCV7ThEDy9ZthX1EJEvKNPij/UWF7rqY3ETf99o4TK4f0iCcA+TcfpKW1vCpEOsg18yurnkKMaRL1h5uyad0YjiH7h981EgeeiL5/gSRIokutEEd1Z3uj X-Microsoft-Exchange-Diagnostics: 1; BN3PR03MB2354; 6:MYfO0zy202beLx4sZJzfoIBXn/dC5MfJJuFKrC/bAr44YTDk02VhrP/cFv1d5arwvKUCxt5dK+ERiTrXUP9s4TEaOlbfUKWWPOsfnYILDT5Viz8GirIySSQp9Gtz+02iVfkWiu77dup0dfycrZeCAVAl8wqAAusGVmbeCG5V8j2dTPFp4kFnwQSuvsx1IKoQdMSfXFW4HzN4FUU+FPPOkNOnWWle0W/wBLvI6fDeahRBn5lPH99SsbdTLr0oeqC9YGTaayKW8vYapukfwajjR8da2M1oAyIdJ8w6KFnPZZFbKd8d9uGQIC2MSv5TejiIqTsc0CXBxOaZ/RviTG2CYw==; 5:YinRaMoOXyl6dbViv5eUkV4FGTqVs/snFSiCtt6DBnFqhzcmBH3UOEqtUwpDNpICGZg9wQRfyAEZtQNAYEKd5aiZI0vKcLnseE7amL6o8wk0c4wAPtLI9N9apZH9llgL8U0yaKvNWopgu2Lbz/pWLQ==; 24:7L/vmW+bqrtU84w+01l1oXgnfjupWM1BulNZw18mHM+S2p8NJeWOfT+JqgzyAzP3RtWaNrwmUEZjROMHY3RxxmXo/g2b1yZVpu6vvEhG/8c=; 7:xIo6MP03p9D5DQs9fTrBnnFGnSZf34e9uM3Bt2Ui0H7GehqMEsx0wBKZA3XH+q3shvrU4BDopDIyAbDTtUG83C0akpppWVEegKAF3hY4pJYX99FgcvMzC3JW2oUzWfj5buhHGhKtmiTagbx8Gu4yQp4nPSqBCEexZN3BpPvmVQskUc82KaMZ5j7LKe1ygpENK6hk/h0h4ZGK1ERtISCNezFjjRD9nQtNnNooTwovwP8= SpamDiagnosticOutput: 1:99 SpamDiagnosticMetadata: NSPM X-MS-Exchange-CrossTenant-OriginalArrivalTime: 28 Sep 2017 12:20:15.3725 (UTC) X-MS-Exchange-CrossTenant-Id: 5afe0b00-7697-4969-b663-5eab37d5f47e X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=5afe0b00-7697-4969-b663-5eab37d5f47e; Ip=[192.88.168.50]; Helo=[tx30smr01.am.freescale.net] X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: BN3PR03MB2354 Subject: [dpdk-dev] [PATCH v6 35/40] net/dpaa: support packet type parsing 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" Add support for parsing the packet type and L2/L3 checksum offload capability information. Signed-off-by: Hemant Agrawal Signed-off-by: Shreyansh Jain --- doc/guides/nics/features/dpaa.ini | 2 + drivers/net/dpaa/dpaa_ethdev.c | 27 +++++ drivers/net/dpaa/dpaa_rxtx.c | 116 +++++++++++++++++++++ drivers/net/dpaa/dpaa_rxtx.h | 206 ++++++++++++++++++++++++++++++++++++++ 4 files changed, 351 insertions(+) diff --git a/doc/guides/nics/features/dpaa.ini b/doc/guides/nics/features/dpaa.ini index 1ba6b11..2ef1b56 100644 --- a/doc/guides/nics/features/dpaa.ini +++ b/doc/guides/nics/features/dpaa.ini @@ -11,7 +11,9 @@ MTU update = Y Promiscuous mode = Y Allmulticast mode = Y Unicast MAC filter = Y +RSS hash = Y Flow control = Y +Packet type parsing = Y Basic stats = Y ARMv8 = Y Usage doc = Y diff --git a/drivers/net/dpaa/dpaa_ethdev.c b/drivers/net/dpaa/dpaa_ethdev.c index a11edeb..8ee00ed 100644 --- a/drivers/net/dpaa/dpaa_ethdev.c +++ b/drivers/net/dpaa/dpaa_ethdev.c @@ -112,6 +112,28 @@ dpaa_eth_dev_configure(struct rte_eth_dev *dev __rte_unused) return 0; } +static const uint32_t * +dpaa_supported_ptypes_get(struct rte_eth_dev *dev) +{ + static const uint32_t ptypes[] = { + /*todo -= add more types */ + RTE_PTYPE_L2_ETHER, + RTE_PTYPE_L3_IPV4, + RTE_PTYPE_L3_IPV4_EXT, + RTE_PTYPE_L3_IPV6, + RTE_PTYPE_L3_IPV6_EXT, + RTE_PTYPE_L4_TCP, + RTE_PTYPE_L4_UDP, + RTE_PTYPE_L4_SCTP + }; + + PMD_INIT_FUNC_TRACE(); + + if (dev->rx_pkt_burst == dpaa_eth_queue_rx) + return ptypes; + return NULL; +} + static int dpaa_eth_dev_start(struct rte_eth_dev *dev) { struct dpaa_if *dpaa_intf = dev->data->dev_private; @@ -160,6 +182,10 @@ static void dpaa_eth_dev_info(struct rte_eth_dev *dev, dev_info->flow_type_rss_offloads = DPAA_RSS_OFFLOAD_ALL; dev_info->speed_capa = (ETH_LINK_SPEED_1G | ETH_LINK_SPEED_10G); + dev_info->rx_offload_capa = + (DEV_RX_OFFLOAD_IPV4_CKSUM | + DEV_RX_OFFLOAD_UDP_CKSUM | + DEV_RX_OFFLOAD_TCP_CKSUM); } static int dpaa_eth_link_update(struct rte_eth_dev *dev, @@ -458,6 +484,7 @@ static struct eth_dev_ops dpaa_devops = { .dev_stop = dpaa_eth_dev_stop, .dev_close = dpaa_eth_dev_close, .dev_infos_get = dpaa_eth_dev_info, + .dev_supported_ptypes_get = dpaa_supported_ptypes_get, .rx_queue_setup = dpaa_eth_rx_queue_setup, .tx_queue_setup = dpaa_eth_tx_queue_setup, diff --git a/drivers/net/dpaa/dpaa_rxtx.c b/drivers/net/dpaa/dpaa_rxtx.c index c4e67f5..f8ac711 100644 --- a/drivers/net/dpaa/dpaa_rxtx.c +++ b/drivers/net/dpaa/dpaa_rxtx.c @@ -85,6 +85,121 @@ (_fd)->bpid = _bpid; \ } while (0) +static inline void dpaa_slow_parsing(struct rte_mbuf *m __rte_unused, + uint64_t prs __rte_unused) +{ + DPAA_DP_LOG(DEBUG, "Slow parsing"); + /*TBD:XXX: to be implemented*/ +} + +static inline void dpaa_eth_packet_info(struct rte_mbuf *m, + uint64_t fd_virt_addr) +{ + struct annotations_t *annot = GET_ANNOTATIONS(fd_virt_addr); + uint64_t prs = *((uint64_t *)(&annot->parse)) & DPAA_PARSE_MASK; + + DPAA_DP_LOG(DEBUG, " Parsing mbuf: %p with annotations: %p", m, annot); + + switch (prs) { + case DPAA_PKT_TYPE_NONE: + m->packet_type = 0; + break; + case DPAA_PKT_TYPE_ETHER: + m->packet_type = RTE_PTYPE_L2_ETHER; + break; + case DPAA_PKT_TYPE_IPV4: + m->packet_type = RTE_PTYPE_L2_ETHER | + RTE_PTYPE_L3_IPV4; + break; + case DPAA_PKT_TYPE_IPV6: + m->packet_type = RTE_PTYPE_L2_ETHER | + RTE_PTYPE_L3_IPV6; + break; + case DPAA_PKT_TYPE_IPV4_FRAG: + case DPAA_PKT_TYPE_IPV4_FRAG_UDP: + case DPAA_PKT_TYPE_IPV4_FRAG_TCP: + case DPAA_PKT_TYPE_IPV4_FRAG_SCTP: + m->packet_type = RTE_PTYPE_L2_ETHER | + RTE_PTYPE_L3_IPV4 | RTE_PTYPE_L4_FRAG; + break; + case DPAA_PKT_TYPE_IPV6_FRAG: + case DPAA_PKT_TYPE_IPV6_FRAG_UDP: + case DPAA_PKT_TYPE_IPV6_FRAG_TCP: + case DPAA_PKT_TYPE_IPV6_FRAG_SCTP: + m->packet_type = RTE_PTYPE_L2_ETHER | + RTE_PTYPE_L3_IPV6 | RTE_PTYPE_L4_FRAG; + break; + case DPAA_PKT_TYPE_IPV4_EXT: + m->packet_type = RTE_PTYPE_L2_ETHER | + RTE_PTYPE_L3_IPV4_EXT; + break; + case DPAA_PKT_TYPE_IPV6_EXT: + m->packet_type = RTE_PTYPE_L2_ETHER | + RTE_PTYPE_L3_IPV6_EXT; + break; + case DPAA_PKT_TYPE_IPV4_TCP: + m->packet_type = RTE_PTYPE_L2_ETHER | + RTE_PTYPE_L3_IPV4 | RTE_PTYPE_L4_TCP; + break; + case DPAA_PKT_TYPE_IPV6_TCP: + m->packet_type = RTE_PTYPE_L2_ETHER | + RTE_PTYPE_L3_IPV6 | RTE_PTYPE_L4_TCP; + break; + case DPAA_PKT_TYPE_IPV4_UDP: + m->packet_type = RTE_PTYPE_L2_ETHER | + RTE_PTYPE_L3_IPV4 | RTE_PTYPE_L4_UDP; + break; + case DPAA_PKT_TYPE_IPV6_UDP: + m->packet_type = RTE_PTYPE_L2_ETHER | + RTE_PTYPE_L3_IPV6 | RTE_PTYPE_L4_UDP; + break; + case DPAA_PKT_TYPE_IPV4_EXT_UDP: + m->packet_type = RTE_PTYPE_L2_ETHER | + RTE_PTYPE_L3_IPV4_EXT | RTE_PTYPE_L4_UDP; + break; + case DPAA_PKT_TYPE_IPV6_EXT_UDP: + m->packet_type = RTE_PTYPE_L2_ETHER | + RTE_PTYPE_L3_IPV6_EXT | RTE_PTYPE_L4_UDP; + break; + case DPAA_PKT_TYPE_IPV4_EXT_TCP: + m->packet_type = RTE_PTYPE_L2_ETHER | + RTE_PTYPE_L3_IPV4_EXT | RTE_PTYPE_L4_TCP; + break; + case DPAA_PKT_TYPE_IPV6_EXT_TCP: + m->packet_type = RTE_PTYPE_L2_ETHER | + RTE_PTYPE_L3_IPV6_EXT | RTE_PTYPE_L4_TCP; + break; + case DPAA_PKT_TYPE_IPV4_SCTP: + m->packet_type = RTE_PTYPE_L2_ETHER | + RTE_PTYPE_L3_IPV4 | RTE_PTYPE_L4_SCTP; + break; + case DPAA_PKT_TYPE_IPV6_SCTP: + m->packet_type = RTE_PTYPE_L2_ETHER | + RTE_PTYPE_L3_IPV6 | RTE_PTYPE_L4_SCTP; + break; + /* More switch cases can be added */ + default: + dpaa_slow_parsing(m, prs); + } + + m->tx_offload = annot->parse.ip_off[0]; + m->tx_offload |= (annot->parse.l4_off - annot->parse.ip_off[0]) + << DPAA_PKT_L3_LEN_SHIFT; + + /* Set the hash values */ + m->hash.rss = (uint32_t)(rte_be_to_cpu_64(annot->hash)); + m->ol_flags = PKT_RX_RSS_HASH; + /* All packets with Bad checksum are dropped by interface (and + * corresponding notification issued to RX error queues). + */ + m->ol_flags |= PKT_RX_IP_CKSUM_GOOD; + + /* Check if Vlan is present */ + if (prs & DPAA_PARSE_VLAN_MASK) + m->ol_flags |= PKT_RX_VLAN_PKT; + /* Packet received without stripping the vlan */ +} + static inline struct rte_mbuf *dpaa_eth_fd_to_mbuf(struct qm_fd *fd, uint32_t ifid) { @@ -117,6 +232,7 @@ static inline struct rte_mbuf *dpaa_eth_fd_to_mbuf(struct qm_fd *fd, mbuf->ol_flags = 0; mbuf->next = NULL; rte_mbuf_refcnt_set(mbuf, 1); + dpaa_eth_packet_info(mbuf, (uint64_t)mbuf->buf_addr); return mbuf; } diff --git a/drivers/net/dpaa/dpaa_rxtx.h b/drivers/net/dpaa/dpaa_rxtx.h index 45bfae8..68d2c41 100644 --- a/drivers/net/dpaa/dpaa_rxtx.h +++ b/drivers/net/dpaa/dpaa_rxtx.h @@ -44,6 +44,7 @@ #define DPAA_MAX_DEQUEUE_NUM_FRAMES 63 /**