From patchwork Tue Oct 3 11:00:28 2017 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Raslan Darawsheh X-Patchwork-Id: 29529 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 C4ACB1B33F; Tue, 3 Oct 2017 13:00:45 +0200 (CEST) Received: from EUR03-DB5-obe.outbound.protection.outlook.com (mail-eopbgr40040.outbound.protection.outlook.com [40.107.4.40]) by dpdk.org (Postfix) with ESMTP id 45FA71B323 for ; Tue, 3 Oct 2017 13:00:44 +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=UMdfW0nhh8Nu6uAGWRoZAYWQzgdzVsF5bP4uQdTtb73HMLIpZpBWI7DkRHi9zj+SC8p0bphf+X+lAswV5GUdfjr/GwZYTOrL8OhIQ5RpG/2kvqWJPrZEOs2zt4UnsJdzMw3JaMket3uxQIfz/WkZiwBm08TxzeZHdGxqtBOi5JI= Authentication-Results: spf=none (sender IP is ) smtp.mailfrom=rasland@mellanox.com; Received: from mellanox.com (37.142.13.130) by AM2PR05MB1220.eurprd05.prod.outlook.com (2a01:111:e400:8450::18) 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 11:00:41 +0000 From: Raslan Darawsheh To: dev@dpdk.org Cc: yskoh@mellanox.com, shahafs@mellanox.com, ferruh.yigit@intel.com Date: Tue, 3 Oct 2017 14:00:28 +0300 Message-Id: <1507028429-23944-2-git-send-email-rasland@mellanox.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1507028429-23944-1-git-send-email-rasland@mellanox.com> References: <1506617303-32509-1-git-send-email-rasland@mellanox.com> <1507028429-23944-1-git-send-email-rasland@mellanox.com> MIME-Version: 1.0 X-Originating-IP: [37.142.13.130] X-ClientProxiedBy: AM5PR0602CA0002.eurprd06.prod.outlook.com (2603:10a6:203:a3::12) To AM2PR05MB1220.eurprd05.prod.outlook.com (2a01:111:e400:8450::18) X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: a5b8e636-ba3d-49bb-9e1b-08d50a4dfd7d X-MS-Office365-Filtering-HT: Tenant X-Microsoft-Antispam: UriScan:; BCL:0; PCL:0; RULEID:(22001)(2017030254152)(48565401081)(2017052603199)(201703131423075)(201703031133081)(201702281549075); SRVR:AM2PR05MB1220; X-Microsoft-Exchange-Diagnostics: 1; AM2PR05MB1220; 3:6cWy7DTsORldmZOZnfWcYAKRPRDTKENkH8adAfKSVrEgpB+i5VoeSo2UqdifLVNkBm60cL27BrH5Hj4zsWjLnGiBVIrUMVx+cK+8ygg+kN43XOolEwTlcyHdpvZIuOPkaAPLeYDLyF3xpIDB+0NGnwdZlEpac+joVtqu0BVUAyao1SZMKHHBkfGw5MZznoeeCZ90fGMOJtdzPqkArDCscU/61s6VN2Fx/EIwuEvC5cphP0v13P9/ihWXMOTubdA0; 25:Rj/QNqMYgac7kw3XI0QAWsRg0EA6AHjwZgpd6+v61Yp3lFsq9ClaHQuTjDnqwHHaeH8NjguS7Q/BkFlBGZN7klD1++8gcI09S0Yh1kcI4iOSF2Jd/TakYsb1ZH+e4tjU9vJKkjWAV3hdSBirl/0cY9sE44+O92J0mrS/6hMKIptJ4UNJVOz9xwilGGdjWFMkvu8hwHuiUtSxKDj4fY++nQWFEoNPewPYOqsiQc8zwtvdftGjxZMZPo1Pgt8364IyEhd/lYcpaFuaBATVYKps78DsheI0DrGJn8TiexY2UhsJgDjdfPt8m3cEwO9UXPOdUTtwVM2eCtRAvF0/WdbrA3digTQtFCe8+MJv1R5JIxo=; 31:VQIt+nXh90wnkdzg5fhJ9uzm+KWYunODkV40SYml+dwxlQTlS5rt/IB1KQ1iHtkPf2jyrkyaItkpttutSmeZymNjtF2YeYf52/mlpXMrTDr08VbFEjqo//ARldgK5vYqMEdKMbaCmMlgyV60HJQZTanrhcUdJhSFOHyBt5vAVdZ67c4+FdASy/CI1L/jjpZVCjVODIbdBALCd3S0cNyDtUt7ep/Hd6RYykk/RyczFu0= X-MS-TrafficTypeDiagnostic: AM2PR05MB1220: X-Microsoft-Exchange-Diagnostics: 1; AM2PR05MB1220; 20:/MOmAIbC6amd/zMNuW/1GHK03QDBmxhDS79KIpxGdagOFzY6O+u3f7ybl1REsnMQPBpyTK1QJzBR8bfqrtA/T/QO4lSlG2IQsG4rt0z/9Iij/HKW3n/HJ8a0NNokZIkYbG+SYj5B0LCjdPwibEo446tI5uNa48jCdQpgyPd0xDiAso5WPxn7RWSOZ5tqwMO+k5xPD/6jKre02cq0CpFSZWQ3kz51nlhltb4JRcB+Oe6NConf2KVK1NlYQXpEkzsYsuYMOz+snxwq7luf0uBDmHno8QmV15v41R9/RkWTTgQRmhR9lS7JJLR3tNe00TzY6VVDzZj67Ea6K2chycj/ddP8apb8nLshHCvwuaSh9mdCpFO+UwEs1+1iaiMQc68ipLdA0cY19Yr5QgjiQIg+LXo2fwz6G/L3CZNQ3+eSkurh7daD1K8y2WeSZqd2FJqYH4YTb+kzOUolki5F3PlCsiI2EG3hgfK0yOPzXH4rPFqC97YaF/oGqfub6QsXPt7a; 4:RhFpnDPHilxyHAw9vWheyqlgPAtACvLqTyEyeMKw2HjUYaIxaMtBfCG8xY6jmj19GK+DltIxJWWigoFw11oWbd6UPHV/PLzHDDS9mBHsXrVeqZIfkvJ7slB7Dm5G8qtBUGdUeFTU4iwS+P8bHBi8OrlMlceK8ER4uKT2Hj920wKDnnwaY0zmQUyfY7HLla6WI2F+j+QCdW01yqc9XBrLoHdqLYvJJpewVi6DL1VU/85N1zMptAVjXsSJQVIUWMRq 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)(100000703101)(100105400095)(10201501046)(3002001)(6055026)(6041248)(201703131423075)(201702281528075)(201703061421075)(201703061406153)(20161123562025)(20161123555025)(20161123558100)(20161123564025)(20161123560025)(6072148)(201708071742011)(100000704101)(100105200095)(100000705101)(100105500095); SRVR:AM2PR05MB1220; BCL:0; PCL:0; RULEID:(100000800101)(100110000095)(100000801101)(100110300095)(100000802101)(100110100095)(100000803101)(100110400095)(100000804101)(100110200095)(100000805101)(100110500095); SRVR:AM2PR05MB1220; X-Forefront-PRVS: 044968D9E1 X-Forefront-Antispam-Report: SFV:NSPM; SFS:(10009020)(6009001)(376002)(346002)(39860400002)(199003)(189002)(101416001)(97736004)(36756003)(4326008)(2351001)(2361001)(106356001)(48376002)(33646002)(6116002)(3846002)(2950100002)(76176999)(53936002)(55016002)(47776003)(50986999)(50466002)(66066001)(6666003)(6916009)(105586002)(305945005)(68736007)(5660300001)(5003940100001)(7736002)(16586007)(2906002)(8936002)(189998001)(81156014)(8676002)(69596002)(316002)(21086003)(575784001)(33026002)(81166006)(50226002)(86362001)(478600001)(16526017)(25786009); DIR:OUT; SFP:1101; SCL:1; SRVR:AM2PR05MB1220; 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; AM2PR05MB1220; 23:BaqmyOPFuRwllzP9HYw3UBS2pnsD13C+z8AoNwJdg?= vLIbRGWH0evVuqJJDDgNvduQn3DdFMne6kKdoLvA7L9IWNkay0pFXWmyS6jaKcAfBXECqXr2MabfU+hOfVmw0jO+4Y1gajLAra84gsfqMqZapjhK92hQFcefiGmsS9+sOlaIN1hOxqzFCynqUIWjA9UARrr1t1ArCsRyFGaJlOSJCuThPbth29k32N+DsOFnUtdo+fBRRqpX0LC4nAvXck8vZ7GDyCJW9Q/L8tSyJF/5mh3deThEL9urcH14fN9efmw7gnlbrOwjwPVLxSyp9QreBaIBflJR0p4y27q4sq3WqJXJEMTErjEBtslxXZcdt+Z1x4BdWXjYMpvUdDixz1lUh705cbWF2bHmyc7JIum+YHPM46c+p+F+uGkghWKa+di0ORi+r1XWFI0As/cUPPVRqq5PDq2dWxpm3Yrmf0lmetUqGjwKWeR1ELy+fqQ5rW2YNL12UesWzV9JC41E0olqKttTwsJbqQBfjyLVskB1rfwnJan6quGSpeUCPPrEX1OtGqMRnHk/0TGLWke7t2puRf94hiw52pGrMLQa9Q/8/2XTZ4YJMn47dRKViHz0tYm2LvYPB/T6pVcq84uySVNnKxLLmSGM1UcMvA9PFJXAtCIdxvhp3KVSl3EKFpWzA2C72A7/9c3eZgfD32HMCvqAFQQXtRn79wPHNTXlrDW2aKZy0n6PGgaxzLA7QmTWHWin2jaLX8mkZ4+FzkOKGsg5EK2d57J6/J38K0XwcMKiaFnPxt80oST6tVJCifcoxPaizRWJ7reDpGPQquG2WaEMYGBYMimkFTOJCg4o4xDRwXMcQrqksnOzXqCCaIcHYVGhCiEizQgH3T/0ZkwNMYDq7TA3F/O3cp/dqwi4GcZ8+0+DC+kGYyZEZeWiAyrTitEdSnMdSPvaeJC/fnu8NEJ8eLIT3ntF01Fy5SlWFYGitGz5Yb6vBMIVMZ/aYbsazU2G8vsXMtsRvQckY+l+xE/+0ful0UFFTfB51Ns+du6cQ9hX2rHPmTN72YPFL8o7yUy0U8azEMcWmyiKzByfcXVVAhM0nhfOCBX45IjtP+yiDEMgwupUuanmcPhhfXgPgXgOyRNEmMtAc+OPQgL9yNrs7VklicRa7kYxhDqn/y/tdPh+IExhxFIg9LYejXUJkw= X-Microsoft-Exchange-Diagnostics: 1; AM2PR05MB1220; 6:qwU9Z64k2QU7FsBhOzsKEFYhXgDLNbfHoYZuPSyEFg3E55eBIxh0Ks6Ofvgg/9f+QEt2788sNGFf8Wz6Ysm90RozgoFxqcquPlh3uHh1tF/iGxZNOFlrIluBnofEp70JkAaLNygomxy7cF4WguCeyEvTazDHU40ikjPO06cDYGH0EJTvPE2HEhueWNtbZ1WZO5gHhcQP5vVyrJL4PhmvcFkqYqZwJwdGu4TMATG8QLREVeyPMN2SO8a9Jns/zb5gr2R6B3y+XEt5FpaCAdodiUMFc5HmKukzlN+mCaiiNAYaEJ3js6gn/2HQ/Tiy4hKhloQ1KRpEzTp1QavtGaX7gg==; 5:8YBIH9WUELRX5BmZz/MewXVVnO1esTzAz/8IFyZ7LrhroNd8Wdufz+ABhlScEwvn4FvIEwr++mEQxyv3CYFTIDVCI7H6zCkMs9issHAfM0+WciTvN38ve8+xGGpxiXWBxIk3992L8uO4Dv79aOquQQTBCrDG73Bxp0h9OsGkzt8=; 24:yT5ft8I0yGBVeihMewwTj8pYrwszBnbVqn2h0K0XOw5jiwxyVnF/Wsp+UanxZRepwDEgVRBQi5mpxgN35zWzlbsgV3G3yiQ0DZu2kdroFUA=; 7:TSAkbX8btLkX9TPWF8XXTzQmoGxkbXg3ljBkAIq0RbmFaf6UGm0Mf+bGRYleU3Z145nQPLGcolpn3/XXTSz9XYu/+eRNRzdwz0LYuJ+LlzgZy9bNyglBBvIXq7tLKGbOIgvrz2V7BUC6kG9AAHpoyX4ltPtm8tY0pnDIF46zPC+Nb5F3DZQArZJwj9iAjTIgA+qrQvX6HHT7YG/OQbvCVUAHAnWi8QpoBqXQjqrbo40= SpamDiagnosticOutput: 1:99 SpamDiagnosticMetadata: NSPM X-OriginatorOrg: Mellanox.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 03 Oct 2017 11:00:41.8014 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: a652971c-7d2e-4d9b-a6a4-d149256f461b X-MS-Exchange-Transport-CrossTenantHeadersStamped: AM2PR05MB1220 Subject: [dpdk-dev] [PATCH v6 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 Acked-by: Yongseok Koh --- 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 = {