From patchwork Tue Oct 3 06:33:49 2017 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Raslan Darawsheh X-Patchwork-Id: 29506 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 2D5521B2DA; Tue, 3 Oct 2017 08:34:07 +0200 (CEST) Received: from EUR03-DB5-obe.outbound.protection.outlook.com (mail-eopbgr40076.outbound.protection.outlook.com [40.107.4.76]) by dpdk.org (Postfix) with ESMTP id DF0301B2DA for ; Tue, 3 Oct 2017 08:34:05 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=Mellanox.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version; bh=Ce39xDp5x4H8kPSmW69kHrarItj2bIroUtVCxsuZVJo=; b=ho2550oqzZtzVidzKm96d6gB9lCq/69vXjVoN/Gr90ki2tD0pIK0VZ3DygdEvLxml3oiMaIP02D+efbxM89gQfAr5Ks0hkDU78cFEqL7SAr85I6CEh8lAfJ9GXcG5P1OHJTECIV82CqyzjJjzRHs2aRFcEtY95CFEXxObEAA8vs= Authentication-Results: spf=none (sender IP is ) smtp.mailfrom=rasland@mellanox.com; Received: from mellanox.com (37.142.13.130) by AM2PR05MB1217.eurprd05.prod.outlook.com (2a01:111:e400:8450::15) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384_P256) id 15.20.77.7; Tue, 3 Oct 2017 06:34:03 +0000 From: Raslan Darawsheh To: dev@dpdk.org Cc: yskoh@mellanox.com, shahafs@mellanox.com, ferruh.yigit@intel.com Date: Tue, 3 Oct 2017 09:33:49 +0300 Message-Id: <1507012430-8421-2-git-send-email-rasland@mellanox.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1507012430-8421-1-git-send-email-rasland@mellanox.com> References: <1506617303-32509-1-git-send-email-rasland@mellanox.com> <1507012430-8421-1-git-send-email-rasland@mellanox.com> MIME-Version: 1.0 X-Originating-IP: [37.142.13.130] X-ClientProxiedBy: DB6PR0202CA0020.eurprd02.prod.outlook.com (2603:10a6:4:29::30) To AM2PR05MB1217.eurprd05.prod.outlook.com (2a01:111:e400:8450::15) X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: 340dfaef-55d8-45b5-8b53-08d50a28bd92 X-MS-Office365-Filtering-HT: Tenant X-Microsoft-Antispam: UriScan:; BCL:0; PCL:0; RULEID:(22001)(2017030254152)(48565401081)(2017052603199)(201703131423075)(201703031133081)(201702281549075); SRVR:AM2PR05MB1217; X-Microsoft-Exchange-Diagnostics: 1; AM2PR05MB1217; 3:GgKaEpoQ9052wXLix67SgESWLQFe36j2AYpjPA38vhqhTRpyl6t/sR7ViHf82m+ys8Lbq7gd3q+jjp8pSmVTZH6H9YORUT+xnZfHC68gG9KVKNUoWHglW16cCLGH1wmpiOu9V6rIvSsMf6tTMfC6RgLHJoiBMN6YvxzYC+r/GMxTko4Sk0QJBKydEbBtuRRaC9xGZvlAg4k3BdGwJwVLyoV6MoK8Yt7hkV7fOPJcWNxbMOST9Ebvq23TOv13F2YZ; 25:Puki3mDp2x/tijV005zcxgYFViJXFZu575s/e7phQKS8q8lS0C9acrVjknhrwa1D+Gg1Z44UldgRdrsK/0mGN3i/BmzNJVHDL2LaAmCoVHkgZOYxZpX+fPD5JtZTX4mcW1ES2AYHKBMjQbrDqRFoZheWhfHZ9Gad+1N/0pPJ3ezmgI6x5kfM0nQ9Bj7DTYUTOVywMGPpwP3tQOUfMh71uUNGk1dcALZGt4mTovlgBOD9HBUXZosTkqG3oNv+Jot5VXNPUpc97a5eYkEkZ8tQ4o9kgBs0wm9hYScljrZ7u9J7budLAZi6ScOtwOL5uxy+C2nTzc2zW2d/OR5J7TIXBQ==; 31:GRFF7ZSjDnVFGvxq26yblrWiw1fskXDcOVqQn77VqrTuziaTQUOpM/PSNCVsjpXoUMSq64TTjYZHrjv6Un4dPnD58j+5tiRkBJIu31ebUIUETZlQi+HSJkqpn6Q0SSaH+i4BlS7xIRDzvS+13lMUIpePk0ZnLOBetWw3EwP6kVuzJU3jLhbMx3E57o38vhEs8qdnEODxbCtzqQu4uHJAu235vsTEbnOTy9rlYKsesrg= X-MS-TrafficTypeDiagnostic: AM2PR05MB1217: X-Microsoft-Exchange-Diagnostics: 1; AM2PR05MB1217; 20:fuy7mBZjiQONP7kSvGsWGLyaYSEhX7k/iq3V/ENF6Y3406d8UBK6BAjZaSGTPi8F5MbZmbPR3brokA36BZF/ixjbS/I8EX8YkvJwMHGcQMUFEL9a/qzVp6KZT5sTp+Nl/Gkw2p80qd3lIsxLmhnR9pCVXUIRVPyvKECLjZSjQHFMo67pU43x6/xBalH3r7EYrISnG+f9HS2DfvVvIMbGWbZbucRXpqczm+L+3WTUywx5A4t5RyVXQbtiVkutxTRQ8z5HNDVh2YCkMMWLro+9I31bGoHo3Mk/3lU6fB/jmWkOMMBXM+m+u0UikNPQhVaG7JEAGSv0cMt8sX1Gr3CSYmftdrZBEHAD5zOugb2MVXwzSa0yHxPJlneGDmPrpmQN5TdZ4w0Piz23+FLFiBFhGdR+pQypXrN5q/znyWTLb0ewgU6dX6FFs8u+Onm2AQDD3Qg9COyKBVFc1N3VvIEJq2vwP0B1wFRd/5GXj+PejwAJciNCzGUEuBvl3eLCh0OA; 4:eMD3Gx+ida7b3+xc2izCKkN/jRs0as3sUQvADkWqVXQy0RF9g8PyJV2vLLYK6sS6iJ/TQlMv9s/Zss8uUSJEbS7J0lwT5zjvLbcqTO5tCElP5zraJsY7MUcpJk3EGHcvwe3p8uzyFMJi+Pou7XLB2tiUs3tTweoCL+KeeGwPfUw0h0Q8QZ898r4EeitdxK0Up32VNEXdwWeTTZBWLD3pHgFuw0d33r+LDJH4/Wg9BJroTl5rzZVAAomOkQdU2+P5 X-Exchange-Antispam-Report-Test: UriScan:; X-Microsoft-Antispam-PRVS: X-Exchange-Antispam-Report-CFA-Test: BCL:0; PCL:0; RULEID:(100000700101)(100105000095)(100000701101)(100105300095)(100000702101)(100105100095)(6040450)(2401047)(5005006)(8121501046)(93006095)(93001095)(10201501046)(3002001)(100000703101)(100105400095)(6055026)(6041248)(20161123564025)(20161123558100)(20161123560025)(20161123555025)(201703131423075)(201702281528075)(201703061421075)(201703061406153)(20161123562025)(6072148)(201708071742011)(100000704101)(100105200095)(100000705101)(100105500095); SRVR:AM2PR05MB1217; BCL:0; PCL:0; RULEID:(100000800101)(100110000095)(100000801101)(100110300095)(100000802101)(100110100095)(100000803101)(100110400095)(100000804101)(100110200095)(100000805101)(100110500095); SRVR:AM2PR05MB1217; X-Forefront-PRVS: 044968D9E1 X-Forefront-Antispam-Report: SFV:NSPM; SFS:(10009020)(6009001)(376002)(346002)(199003)(189002)(478600001)(33026002)(6666003)(4326008)(50466002)(2906002)(5003940100001)(55016002)(53936002)(48376002)(36756003)(7736002)(21086003)(66066001)(47776003)(81156014)(81166006)(8676002)(305945005)(6116002)(50226002)(189998001)(6916009)(2950100002)(25786009)(5660300001)(16526017)(3846002)(76176999)(97736004)(33646002)(16586007)(50986999)(86362001)(2351001)(2361001)(106356001)(105586002)(68736007)(575784001)(69596002)(101416001)(8936002)(316002); DIR:OUT; SFP:1101; SCL:1; SRVR:AM2PR05MB1217; H:mellanox.com; FPR:; SPF:None; PTR:InfoNoRecords; A:1; MX:1; LANG:en; Received-SPF: None (protection.outlook.com: mellanox.com does not designate permitted sender hosts) X-Microsoft-Exchange-Diagnostics: =?us-ascii?Q?1; AM2PR05MB1217; 23:XaZzN53FlQhqhMxQapydH6N7UW4fjdMEm7F+MMm83?= YwQE5nSFatmYLw0jWgRguMyeXgw6fO35D8Ti3ldJtLD/phMVrPhXU+v+i5S3F3j/tM4VkhNGuPKDIuRU/RoiuvW868uMpxjaswgFSqXXDxP58itkFQp88Z9rdKlBVs/al95U2gJ9yuQ0Wv5ZCJr0J3g3PzC7nRGR0Ex7COaNro6d9XvB9k7xWKvQfQdAT/tqWJavdQ1nsmeVxSy3IYH4MgjeRDsv48FFMa2l++gHLdMZQtNHghmUG5U5kVIryYOiGoBSsZikgukzNVpbZBBQ9GLFlvXmsWxzZG45hvK1vPNOqdm53EGpu+gxtWDQVrIohpL6yNScn8xIVe9M5l3OUdS9LY+on/tL8QPsEb9UDeWhGtV00j/cpFtbW9oh+HxBteFa+c9kwd5f4ql+hLZIAxvlfqnBY+o5l5I5NE9tHscFs+sRu3puUri5iNNDe6Qd8BtFaQXVVEvqkmukDS4APd6HxrHTTUbSrppm3zTCqVH1lEm/pXfccfgROg4MZZOQCRxN0VeXClfaiepB3dB/IsvnALn+ZOVxCbSblLMNnTrKBwkHPQXgluvbBdRQVjkyJJ7VlOrpFlKF2KeJTkwrLheTejiLPeu8StM+WeYH5Fd8nlzt09Y6WQ9wFzcEy8H5kNes3TyyihcNzTsR1RBSIpQ5++w0MhDV0H6wqGvFGpdPQaOs/vVvKFVXatsVOyW4cRVTuAR1Lfk6acM9beD4Fj/x1HUhL7OHeMVsfbqXQ79wetjMYY4P0CA9pD+DVV8lgZ3ZKeqBkKLpsBAeySmJ3i1ObpolUhk4ArAYExsdSOO3kc31nS/uTITCxuYm5OZgeVIIapQ6WiUtQxCWuUPJZYSP3C1zV/XhvlePHg9nYzWGivbbX41NaChPJDdx3xiPOWh5skttb2aFVTsxz3KNaerfYinU+FtYTt45dtJNos/1vkhOLGO/GHZkp0au0K1p+7pIR6Sxv6hwTB07GkYvClz7vWeBdy/DXdndoRWwJOWT3PYScm1i44+/PhlT54mu6hurvNvNreJG0Ap0F6HgiN9kXuY1ENZ++UDhI7xanfb4ExjUIOjCxJI5oZ5LHlGXN4cCacrPYwNxc72nxgL0yae5MuLPBepGF7ha2DHjuk0tw== X-Microsoft-Exchange-Diagnostics: 1; AM2PR05MB1217; 6:zsYsSB2sG44pP0zUV7aY0xR6foSmAacB6ZkYFddLySUI8AtkOZ6uTSr9TZPmDiitM8lqmDqOpSrmuICLdpACjTt68hVRw/ueEaAVlEQrPJZpR3Bxad1TB2Q3tCbgUd+TRnxPKI9EQDPMUTAIYt/ERBiewsGYYiYdEEwJ7JHCAxvuLWDpBLUzqAQeXfPAvTewgHMrRDs9RpYLLMRXdrZkbst8+7e/RwypbKhQI1JfZhnFoWNC+D1fbW4A4e8h6E1hJlRUBGLc4dXX0186Z4SyxTR/bZNsjnm7JSFa6QJ9jzv7otOx31r9URYnEpTGjQi9Zx0N4au2HP4ZMLZrVKRL8g==; 5:SzwSkP4lphGKjuYJjeEs0vF6qZj0+eRXZIkhH5bv76VYCnvRjGEuCv/SoIiCqY3/jYhTECdBuc6AJqPmd1b+QrKfz4aY2nT6Kpzry4NxcVllN3V4aXRm9F+cuMm38/MXciMlikXEEYl0w/jtBMMtZw==; 24:KJxgB9jJDIRXeFtWHm5pzu+YiUOPrywG/xrtBvYrxO2vpTshRb3jvdl0pF7U6vopbeZUON89J2k8xSYoyI6G/Zl4Njc5smOwxBHM/HxWzi0=; 7:IuAaFhzxKCZ6G5SCVi2z6ns1s4RpcXXinMwlfz275ldVgRGAnEK3eIr7pPfu4SKx2Vk1EpcWIZM/RUPtazS2NhWQA20go1e6qLXSBAR49z8O+r4aPm+tmEJ0CQP7P9a0yrZEt/0cxzvoZcQsjCSu+0g/yDJFfP2MS6qS67TbXfHz0MAgUIRDrWWe3wTOIIcu6LVWWTfzSIO+XjwE42W5c+TsPAxNYkv9H+qUnutsOa8= SpamDiagnosticOutput: 1:99 SpamDiagnosticMetadata: NSPM X-OriginatorOrg: Mellanox.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 03 Oct 2017 06:34:03.0135 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: a652971c-7d2e-4d9b-a6a4-d149256f461b X-MS-Exchange-Transport-CrossTenantHeadersStamped: AM2PR05MB1217 Subject: [dpdk-dev] [PATCH v5 2/3] app/testpmd: add Rx HW timestamp 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 enabling/disabling Rx HW timestamp from command line and parameter. Signed-off-by: Raslan Darawsheh --- app/test-pmd/cmdline.c | 15 ++++++++++++--- app/test-pmd/config.c | 8 ++++++++ app/test-pmd/parameters.c | 5 +++++ app/test-pmd/rxonly.c | 2 ++ app/test-pmd/testpmd.c | 1 + 5 files changed, 28 insertions(+), 3 deletions(-) diff --git a/app/test-pmd/cmdline.c b/app/test-pmd/cmdline.c index 4f2d731..80a249e 100644 --- a/app/test-pmd/cmdline.c +++ b/app/test-pmd/cmdline.c @@ -675,7 +675,7 @@ static void cmd_help_long_parsed(void *parsed_result, "port config all max-pkt-len (value)\n" " Set the max packet length.\n\n" - "port config all (crc-strip|scatter|rx-cksum|hw-vlan|hw-vlan-filter|" + "port config all (crc-strip|scatter|rx-cksum|rx-timestamp|hw-vlan|hw-vlan-filter|" "hw-vlan-strip|hw-vlan-extend|drop-en)" " (on|off)\n" " Set crc-strip/scatter/rx-checksum/hardware-vlan/drop_en" @@ -1588,6 +1588,15 @@ cmd_config_rx_mode_flag_parsed(void *parsed_result, printf("Unknown parameter\n"); return; } + } else if (!strcmp(res->name, "rx-timestamp")) { + if (!strcmp(res->value, "on")) + rx_mode.hw_timestamp = 1; + else if (!strcmp(res->value, "off")) + rx_mode.hw_timestamp = 0; + else { + printf("Unknown parameter\n"); + return; + } } else if (!strcmp(res->name, "hw-vlan")) { if (!strcmp(res->value, "on")) { rx_mode.hw_vlan_filter = 1; @@ -1656,7 +1665,7 @@ cmdline_parse_token_string_t cmd_config_rx_mode_flag_all = TOKEN_STRING_INITIALIZER(struct cmd_config_rx_mode_flag, all, "all"); cmdline_parse_token_string_t cmd_config_rx_mode_flag_name = TOKEN_STRING_INITIALIZER(struct cmd_config_rx_mode_flag, name, - "crc-strip#scatter#rx-cksum#hw-vlan#" + "crc-strip#scatter#rx-cksum#rx-timestamp#hw-vlan#" "hw-vlan-filter#hw-vlan-strip#hw-vlan-extend"); cmdline_parse_token_string_t cmd_config_rx_mode_flag_value = TOKEN_STRING_INITIALIZER(struct cmd_config_rx_mode_flag, value, @@ -1665,7 +1674,7 @@ cmdline_parse_token_string_t cmd_config_rx_mode_flag_value = cmdline_parse_inst_t cmd_config_rx_mode_flag = { .f = cmd_config_rx_mode_flag_parsed, .data = NULL, - .help_str = "port config all crc-strip|scatter|rx-cksum|hw-vlan|" + .help_str = "port config all crc-strip|scatter|rx-cksum|rx-timestamp|hw-vlan|" "hw-vlan-filter|hw-vlan-strip|hw-vlan-extend on|off", .tokens = { (void *)&cmd_config_rx_mode_flag_port, diff --git a/app/test-pmd/config.c b/app/test-pmd/config.c index e8e311c..76addf3 100644 --- a/app/test-pmd/config.c +++ b/app/test-pmd/config.c @@ -600,6 +600,14 @@ port_offload_cap_display(portid_t port_id) printf("off\n"); } + if (dev_info.rx_offload_capa & DEV_RX_OFFLOAD_TIMESTAMP) { + printf("HW timestamp: "); + if (dev->data->dev_conf.rxmode.hw_timestamp) + printf("on\n"); + else + printf("off\n"); + } + if (dev_info.tx_offload_capa & DEV_TX_OFFLOAD_QINQ_INSERT) { printf("Double VLANs insert: "); if (ports[port_id].tx_ol_flags & diff --git a/app/test-pmd/parameters.c b/app/test-pmd/parameters.c index 2f7f70f..602d98d 100644 --- a/app/test-pmd/parameters.c +++ b/app/test-pmd/parameters.c @@ -162,6 +162,7 @@ usage(char* progname) printf(" --disable-crc-strip: disable CRC stripping by hardware.\n"); printf(" --enable-lro: enable large receive offload.\n"); printf(" --enable-rx-cksum: enable rx hardware checksum offload.\n"); + printf(" --enable-rx-timestamp: enable rx hardware timestamp offload.\n"); printf(" --disable-hw-vlan: disable hardware vlan.\n"); printf(" --disable-hw-vlan-filter: disable hardware vlan filter.\n"); printf(" --disable-hw-vlan-strip: disable hardware vlan strip.\n"); @@ -601,6 +602,7 @@ launch_args_parse(int argc, char** argv) { "disable-crc-strip", 0, 0, 0 }, { "enable-lro", 0, 0, 0 }, { "enable-rx-cksum", 0, 0, 0 }, + { "enable-rx-timestamp", 0, 0, 0 }, { "enable-scatter", 0, 0, 0 }, { "disable-hw-vlan", 0, 0, 0 }, { "disable-hw-vlan-filter", 0, 0, 0 }, @@ -899,6 +901,9 @@ launch_args_parse(int argc, char** argv) rx_mode.enable_scatter = 1; if (!strcmp(lgopts[opt_idx].name, "enable-rx-cksum")) rx_mode.hw_ip_checksum = 1; + if (!strcmp(lgopts[opt_idx].name, + "enable-rx-timestamp")) + rx_mode.hw_timestamp = 1; if (!strcmp(lgopts[opt_idx].name, "disable-hw-vlan")) { rx_mode.hw_vlan_filter = 0; diff --git a/app/test-pmd/rxonly.c b/app/test-pmd/rxonly.c index 5ef0219..f4d35d7 100644 --- a/app/test-pmd/rxonly.c +++ b/app/test-pmd/rxonly.c @@ -158,6 +158,8 @@ pkt_burst_receive(struct fwd_stream *fs) printf("hash=0x%x ID=0x%x ", mb->hash.fdir.hash, mb->hash.fdir.id); } + if (ol_flags & PKT_RX_TIMESTAMP) + printf(" - timestamp %lu ", mb->timestamp); if (ol_flags & PKT_RX_VLAN_STRIPPED) printf(" - VLAN tci=0x%x", mb->vlan_tci); if (ol_flags & PKT_RX_QINQ_STRIPPED) diff --git a/app/test-pmd/testpmd.c b/app/test-pmd/testpmd.c index 5507c0f..ec29908 100644 --- a/app/test-pmd/testpmd.c +++ b/app/test-pmd/testpmd.c @@ -339,6 +339,7 @@ struct rte_eth_rxmode rx_mode = { .hw_vlan_extend = 0, /**< Extended VLAN disabled. */ .jumbo_frame = 0, /**< Jumbo Frame Support disabled. */ .hw_strip_crc = 1, /**< CRC stripping by hardware enabled. */ + .hw_timestamp = 0, /**< HW timestamp enabled. */ }; struct rte_fdir_conf fdir_conf = {