From patchwork Fri Jun 26 22:45:30 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Petr Machata X-Patchwork-Id: 1318157 X-Patchwork-Delegate: dsahern@gmail.com Return-Path: X-Original-To: patchwork-incoming-netdev@ozlabs.org Delivered-To: patchwork-incoming-netdev@ozlabs.org Authentication-Results: ozlabs.org; spf=pass (sender SPF authorized) smtp.mailfrom=vger.kernel.org (client-ip=23.128.96.18; helo=vger.kernel.org; envelope-from=netdev-owner@vger.kernel.org; receiver=) Authentication-Results: ozlabs.org; dmarc=pass (p=none dis=none) header.from=mellanox.com Authentication-Results: ozlabs.org; dkim=pass (1024-bit key; unprotected) header.d=Mellanox.com header.i=@Mellanox.com header.a=rsa-sha256 header.s=selector1 header.b=EdtUbrWK; dkim-atps=neutral Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by ozlabs.org (Postfix) with ESMTP id 49tsSt0fc5z9sQx for ; Sat, 27 Jun 2020 08:46:54 +1000 (AEST) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726296AbgFZWqw (ORCPT ); Fri, 26 Jun 2020 18:46:52 -0400 Received: from mail-am6eur05on2082.outbound.protection.outlook.com ([40.107.22.82]:6168 "EHLO EUR05-AM6-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1726110AbgFZWqv (ORCPT ); Fri, 26 Jun 2020 18:46:51 -0400 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=l7gtVuKx+v4bo4hwaQDpoRmiYECZnWdRxdXJdO6RZ78ubhv1x4NpZSgqlzXxzxowY33wZux60ZZl1mqmO1lKQihyYLXetEm477R4T8gg+i0Bu4r+A16xY3yU4KVXA53FH9kmem4DCQ1qO+Km+TPkit4mltoVWiFe5wQCi0bZvw+WUOvSbQFVNfQ++Ea3CVbtfdR3NfgAarfDA1SNde1fi3kHXctFIMiqINtjjbxiMAq9/XVZWTG/jc4kEsNBVPBrbOUhTZVXpxsWnf6MUrc5tumdQfLvomPRyBmQPcs1MmioCSMhtdF9HW9RYMAPXPEMmwbwAa4Dnd3IW2T27zv83Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=jRxdpXo7jQzFsbHqqUB0EBJmSyht6vtbl+S0T/P/pLI=; b=oI17y6A2Nfot/zYm8qduMGAwHzUXfFYcuqaAEE2beLYHK+IEIFvfB9JTfmUyEBI7R0IqE5OhSEpOjyykTafUfYivySf4isoZmrlbKudzFczLv0tdT6AjqVFAHane/Qz805BioBYBmCeF9P1e73UM8IT9UuQyEMhTPSTaVQkKNFiy7DF7Sdf5hw36ffvvxt7Lsma3gkgjCtvGj6Zf19/uN7uADLcRVCIhpTRKgdo8/d6Xok9Sovg7uicnvrhtYOghNfELQsREi3/g9CDxcJp03i+Av5uDe8aOLzUMKrncLPqGNIl27c+bMdOOwkyFqtC0oKbN+CA4dP+HtLVDrZ6zLA== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=mellanox.com; dmarc=pass action=none header.from=mellanox.com; dkim=pass header.d=mellanox.com; arc=none 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:X-MS-Exchange-SenderADCheck; bh=jRxdpXo7jQzFsbHqqUB0EBJmSyht6vtbl+S0T/P/pLI=; b=EdtUbrWKgyqedhHZ+1lGaLsjOtJIqMjCqNsrBvscu9S5DEL2BeqQHZaz0wakIxKQK6+Ck64uxc7flsZXVYDesN7Rru3suRbdZdRBUXg+6XlmBmvkkbsZ17yiZnC2la+H15Gj+QHELANHCABiWUS1lk9nEI68n/gHyMxMw1HyQow= Authentication-Results: vger.kernel.org; dkim=none (message not signed) header.d=none;vger.kernel.org; dmarc=none action=none header.from=mellanox.com; Received: from HE1PR05MB4746.eurprd05.prod.outlook.com (2603:10a6:7:a3::22) by HE1PR05MB3196.eurprd05.prod.outlook.com (2603:10a6:7:33::23) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.3131.21; Fri, 26 Jun 2020 22:46:18 +0000 Received: from HE1PR05MB4746.eurprd05.prod.outlook.com ([fe80::78f6:fb7a:ea76:c2d6]) by HE1PR05MB4746.eurprd05.prod.outlook.com ([fe80::78f6:fb7a:ea76:c2d6%7]) with mapi id 15.20.3131.024; Fri, 26 Jun 2020 22:46:18 +0000 From: Petr Machata To: netdev@vger.kernel.org Cc: David Miller , Jakub Kicinski , Cong Wang , Eric Dumazet , jiri@mellanox.com, idosch@mellanox.com, Petr Machata Subject: [PATCH iproute2-next v1 1/4] uapi: pkt_sched: Add two new RED attributes Date: Sat, 27 Jun 2020 01:45:30 +0300 Message-Id: X-Mailer: git-send-email 2.20.1 In-Reply-To: References: X-ClientProxiedBy: AM3PR05CA0139.eurprd05.prod.outlook.com (2603:10a6:207:3::17) To HE1PR05MB4746.eurprd05.prod.outlook.com (2603:10a6:7:a3::22) MIME-Version: 1.0 X-MS-Exchange-MessageSentRepresentingType: 1 Received: from dev-r-vrt-156.mtr.labs.mlnx (37.142.13.130) by AM3PR05CA0139.eurprd05.prod.outlook.com (2603:10a6:207:3::17) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.3131.21 via Frontend Transport; Fri, 26 Jun 2020 22:46:16 +0000 X-Mailer: git-send-email 2.20.1 X-Originating-IP: [37.142.13.130] X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-HT: Tenant X-MS-Office365-Filtering-Correlation-Id: f736c954-a8a8-4412-31c1-08d81a22bd25 X-MS-TrafficTypeDiagnostic: HE1PR05MB3196: X-MS-Exchange-Transport-Forked: True X-Microsoft-Antispam-PRVS: X-MS-Oob-TLC-OOBClassifiers: OLM:296; X-Forefront-PRVS: 0446F0FCE1 X-MS-Exchange-SenderADCheck: 1 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: tQVmrWrXXz8pKTyGVy6xj1jHgFXmWoupYzgHkWjrf7ghQtCTEoHLPi8bRjOFZP5FkEcQPfmzGADr82ce1AoejDgf6+DusuDlqH71vHwHGIZhlQIL/COuMPs1YzBtpPlgtPrYQnV1VNcqgvpJukJU0uNypAJFhIQwYIOIcdEnWAReci7MjKdQbVUEYhde9CTXYzbwWq6euYQPeniD45UpWW1m3/bb66OUDKOm6+PjfpnXv9QqSTkg2zEg/2PYjLhv9t1ohKrxpCpZxWeHWEDKudxgamJpi8QAi8UdF4tbjlp4hMBXqLVaCqTyT8cnjYHttPxx9PYi0JpEBDjALUB6rA== X-Forefront-Antispam-Report: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:HE1PR05MB4746.eurprd05.prod.outlook.com;PTR:;CAT:NONE;SFTY:;SFS:(4636009)(39860400002)(396003)(136003)(366004)(346002)(376002)(5660300002)(66476007)(8676002)(956004)(54906003)(52116002)(2616005)(6666004)(83380400001)(4744005)(4326008)(6512007)(2906002)(26005)(8936002)(6916009)(107886003)(66556008)(36756003)(478600001)(86362001)(66946007)(186003)(316002)(6486002)(6506007)(16526019);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData: x2qTuYw1/t1jMHb9V94tQ5MoL7UE2kF0mW2n4fFgv0Div074VnnzOCwyu3X7qa1Yw29wHpYbRal6rtgNMSSIZ1RxxSUlysGetoTOY7ma2Du+swSZRoN8afErn0EO8cog3JJdd+hJPUv0K1Qo4oHnm9rlG2p57ztpE7gr8Pa2ipHp/ZbVZ11iHjPMjGRKC+kp7YOlP0hWE7oprCUYl1brbGJMl/wBN9YZXuTGPqtrBEgI7QVZyfnnUEsTL9bn6HK9iTOUDpVXVlZL4htYnc0b6rgMwj5yPzD0eCfukmRFr/ysG7w+OZ1ZES8jpQEScmKRdDXomYmnty93EjGKHVMo46PNmxivapP6nskUwyj3vhH5QdhDJOOjkVYmedxFnfRWo5ovszVkgdrg3MzFhRnFz1FqjysHEh2cU5iPax04DtbBhsM7/tinC2Z0101Jo2docVDzxulws3EaZO10OAblFWr7MyMxiGRue7rWpCS7I4Y= X-OriginatorOrg: Mellanox.com X-MS-Exchange-CrossTenant-Network-Message-Id: f736c954-a8a8-4412-31c1-08d81a22bd25 X-MS-Exchange-CrossTenant-AuthSource: HE1PR05MB4746.eurprd05.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 26 Jun 2020 22:46:18.0195 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: a652971c-7d2e-4d9b-a6a4-d149256f461b X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: jQO9N+JiFrBEexYsEiJQS7TG8ATrwmTdzFIZdo2caDuyNY4+Ug0qrQNYfG7sP9D3JCn99xAuTMkj/Gh++L1XWA== X-MS-Exchange-Transport-CrossTenantHeadersStamped: HE1PR05MB3196 Sender: netdev-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: netdev@vger.kernel.org Signed-off-by: Petr Machata --- include/uapi/linux/pkt_sched.h | 2 ++ 1 file changed, 2 insertions(+) diff --git a/include/uapi/linux/pkt_sched.h b/include/uapi/linux/pkt_sched.h index a95f3ae7..9e7c2c60 100644 --- a/include/uapi/linux/pkt_sched.h +++ b/include/uapi/linux/pkt_sched.h @@ -257,6 +257,8 @@ enum { TCA_RED_STAB, TCA_RED_MAX_P, TCA_RED_FLAGS, /* bitfield32 */ + TCA_RED_EARLY_DROP_BLOCK, /* u32 */ + TCA_RED_MARK_BLOCK, /* u32 */ __TCA_RED_MAX, }; From patchwork Fri Jun 26 22:45:31 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Petr Machata X-Patchwork-Id: 1318158 X-Patchwork-Delegate: dsahern@gmail.com Return-Path: X-Original-To: patchwork-incoming-netdev@ozlabs.org Delivered-To: patchwork-incoming-netdev@ozlabs.org Authentication-Results: ozlabs.org; spf=pass (sender SPF authorized) smtp.mailfrom=vger.kernel.org (client-ip=23.128.96.18; helo=vger.kernel.org; envelope-from=netdev-owner@vger.kernel.org; receiver=) Authentication-Results: ozlabs.org; dmarc=pass (p=none dis=none) header.from=mellanox.com Authentication-Results: ozlabs.org; dkim=pass (1024-bit key; unprotected) header.d=Mellanox.com header.i=@Mellanox.com header.a=rsa-sha256 header.s=selector1 header.b=rdEPnVQq; dkim-atps=neutral Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by ozlabs.org (Postfix) with ESMTP id 49tsSx6VqSz9sRk for ; Sat, 27 Jun 2020 08:46:57 +1000 (AEST) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726344AbgFZWq4 (ORCPT ); Fri, 26 Jun 2020 18:46:56 -0400 Received: from mail-am6eur05on2082.outbound.protection.outlook.com ([40.107.22.82]:6168 "EHLO EUR05-AM6-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1725883AbgFZWq4 (ORCPT ); Fri, 26 Jun 2020 18:46:56 -0400 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=D4qJ7q6TYokHcDO38G+yS4P4b90h94MN820Z1eth72hPGp562CBnTkyJmEXsuct53KUh4Jb3GRtaa2pXSvOHou3bAMzHFg1dmslbJLr41WZTj4ul28fX/TaZ24vaTVpdsCBQEgz3qLv9NSQyxjVR3BJmu4/YXHxORSY+6CEVnPN4/K7kS4PJsaZlxrYO3D3D0raKZd8076/t8gb7KQGOwLmobwj1bco6XQ/4bH31mNbI52Orj/qdrU3IjrIGj6yT3O+em7Ovv+fwRndr/zbF7bXr09Mhk8iKn7It4+U8WkBMYxafrT0/q8EglT7OUeVkMnpYGXAPOcWi+A6Ez29QnQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=MUVcaCQdJlQbz8ULpfnrRQ9M6rGk1trJ7w+kZNXgnq4=; b=ElELP9PfJ+NavXOHomzpgA/lqgTbkyZk+2NcTIWnbR6WFQ0sdXnQtMObTAatkV4og3XLM4vR1F7/t48C4HonKG3oW5/3RI/vPn7NA76knOvAE/JVeGboLolfoHvJWfhxooE+VUtGPkpBEUyJ0m5DjVqzr86URaSe9qnwu/wE2KEz6vNg07NaaoC4jArsxPlDI4AxbuJO8pZ/+oqa/ukTDuuQ3GqfHW8fH1chws5d6k7p52cmrOCjrHJoQ6MwqLwFx8iIWGEEyvC2VXAW60y/dCAnX9bk1VE7vbWKAVGWfHpxp3+QRRNehSTGZZ4RGlIv3Is3scnplBgwe2V1mNgjcA== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=mellanox.com; dmarc=pass action=none header.from=mellanox.com; dkim=pass header.d=mellanox.com; arc=none 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:X-MS-Exchange-SenderADCheck; bh=MUVcaCQdJlQbz8ULpfnrRQ9M6rGk1trJ7w+kZNXgnq4=; b=rdEPnVQqN9SLeHG8mUicQCwRPO+W8oXePbg+RcGxfSVk2QOZOJhE3g9d7AHg14aMj3n0WTmQJI6xgN1f/E3IAG3Xn8xD4FAXB6hEEoEd982JDlXxUosFkaqjbJ1TUqtuiTZy3v8vRvlgeFDiciS5qvTfL0d3Tz0ca/xMym8urSE= Authentication-Results: vger.kernel.org; dkim=none (message not signed) header.d=none;vger.kernel.org; dmarc=none action=none header.from=mellanox.com; Received: from HE1PR05MB4746.eurprd05.prod.outlook.com (2603:10a6:7:a3::22) by HE1PR05MB3196.eurprd05.prod.outlook.com (2603:10a6:7:33::23) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.3131.21; Fri, 26 Jun 2020 22:46:19 +0000 Received: from HE1PR05MB4746.eurprd05.prod.outlook.com ([fe80::78f6:fb7a:ea76:c2d6]) by HE1PR05MB4746.eurprd05.prod.outlook.com ([fe80::78f6:fb7a:ea76:c2d6%7]) with mapi id 15.20.3131.024; Fri, 26 Jun 2020 22:46:19 +0000 From: Petr Machata To: netdev@vger.kernel.org Cc: David Miller , Jakub Kicinski , Cong Wang , Eric Dumazet , jiri@mellanox.com, idosch@mellanox.com, Petr Machata Subject: [PATCH iproute2-next v1 2/4] tc: Add helpers to support qevent handling Date: Sat, 27 Jun 2020 01:45:31 +0300 Message-Id: X-Mailer: git-send-email 2.20.1 In-Reply-To: References: X-ClientProxiedBy: AM3PR05CA0139.eurprd05.prod.outlook.com (2603:10a6:207:3::17) To HE1PR05MB4746.eurprd05.prod.outlook.com (2603:10a6:7:a3::22) MIME-Version: 1.0 X-MS-Exchange-MessageSentRepresentingType: 1 Received: from dev-r-vrt-156.mtr.labs.mlnx (37.142.13.130) by AM3PR05CA0139.eurprd05.prod.outlook.com (2603:10a6:207:3::17) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.3131.21 via Frontend Transport; Fri, 26 Jun 2020 22:46:18 +0000 X-Mailer: git-send-email 2.20.1 X-Originating-IP: [37.142.13.130] X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-HT: Tenant X-MS-Office365-Filtering-Correlation-Id: fb4ac406-e58b-458b-29f5-08d81a22be0b X-MS-TrafficTypeDiagnostic: HE1PR05MB3196: X-MS-Exchange-Transport-Forked: True X-Microsoft-Antispam-PRVS: X-MS-Oob-TLC-OOBClassifiers: OLM:374; X-Forefront-PRVS: 0446F0FCE1 X-MS-Exchange-SenderADCheck: 1 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: IcLKm1Z34OKjCAX4lQGvsZsJsTno66Wrt42iihqqenvMlgQeoqJI8yW0TF6Axv2ew8ioQy1RTc8pSgCUypPWB07zoKuYlMwX6yDbyHc3dL9VZuITtDfMWnHPYo3InPOzq/QjnkjqVrzFOzcdjHpCz+NSf8Un5aPVfx19yE+InsRq19l9L1ReT0ir+6ECvGMeUq2agDBnYyM0u1huQysgnTKNkbxRjqLb6scW83PMPjC3ckWGCMLSLbe4zE/GEXgbgThtpeEIvFRLmkF27PJ/CBGz13k3txewfGpwJ01Y12QJfXuArXq0i/P+HcMcRWy1OZqRRK3JCjiV9mu6x9MDQw== X-Forefront-Antispam-Report: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:HE1PR05MB4746.eurprd05.prod.outlook.com;PTR:;CAT:NONE;SFTY:;SFS:(4636009)(39860400002)(396003)(136003)(366004)(346002)(376002)(5660300002)(66476007)(8676002)(956004)(54906003)(52116002)(2616005)(6666004)(83380400001)(4326008)(6512007)(2906002)(26005)(8936002)(6916009)(107886003)(66556008)(36756003)(478600001)(86362001)(66946007)(186003)(316002)(6486002)(6506007)(16526019);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData: yzGQZjNUTYvnZMxwZXzv7lfvIk1BFflU1M1dZ9fxqkLNoP1PnFWZiVNcO3w/aepqGKDV+a0XXrXB7P6RREFb5m77Yb1GOEW7rhFE7fCoRdLhCkKMOGS8+f61GPsRYuLhp53r+OAgYOKC/agmXOPpKIHqWL9vNN3DFgFYj8y2je1/ZE4CTuT0h9Oq61yKKGPMQQsgXpR6Qo3jNy3/fp5otDsBGsr8WJ2aeycYnn4e5qUsjCQekys6MZSZ0WSQMYZtCd16csU/MKsCrsiQ17XNve/jUQdsKlIq41gtWP3/QVXIJsKx/SYnI8Ipuz0QYEekzrTEFK4Ijrs4LFHH0XezWPh2wN/veJ3PAUfVbUK0QqJaRKKN7S2RKPj1X5rF7yUOIPFmoAPZcSkroBSIfpSAIKsH3a4Cicr/CwOjrh6DYaTixzC7kKew9EImkOGXxfRj/7exgP+aiuWRI8mLovhLPz/UmXqzZmcKg3xRjfy0kF0= X-OriginatorOrg: Mellanox.com X-MS-Exchange-CrossTenant-Network-Message-Id: fb4ac406-e58b-458b-29f5-08d81a22be0b X-MS-Exchange-CrossTenant-AuthSource: HE1PR05MB4746.eurprd05.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 26 Jun 2020 22:46:19.6375 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: a652971c-7d2e-4d9b-a6a4-d149256f461b X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: YIluPUqbVWEBbM7zO/npwYrWj+14pT5rFzcuKQLOQ4bXBRZQqgr8ULcxcwc2RH3ICdlqQWUTR2U8s6iJ7vmiXA== X-MS-Exchange-Transport-CrossTenantHeadersStamped: HE1PR05MB3196 Sender: netdev-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: netdev@vger.kernel.org Introduce a set of helpers to make it easy to add support for qevents into qdisc. The idea behind this is that qevent types will be generally reused between qdiscs, rather than each having a completely idiosyncratic set of qevents. The qevent module holds functions for parsing, dumping and formatting of these common qevent types, and for dispatch to the appropriate set of handlers based on the qevent name. Signed-off-by: Petr Machata --- tc/Makefile | 1 + tc/tc_qevent.c | 202 +++++++++++++++++++++++++++++++++++++++++++++++++ tc/tc_qevent.h | 49 ++++++++++++ 3 files changed, 252 insertions(+) create mode 100644 tc/tc_qevent.c create mode 100644 tc/tc_qevent.h diff --git a/tc/Makefile b/tc/Makefile index 79c9c1dd..5a517af2 100644 --- a/tc/Makefile +++ b/tc/Makefile @@ -122,6 +122,7 @@ TCLIB += tc_red.o TCLIB += tc_cbq.o TCLIB += tc_estimator.o TCLIB += tc_stab.o +TCLIB += tc_qevent.o CFLAGS += -DCONFIG_GACT -DCONFIG_GACT_PROB ifneq ($(IPT_LIB_DIR),) diff --git a/tc/tc_qevent.c b/tc/tc_qevent.c new file mode 100644 index 00000000..1f8e6506 --- /dev/null +++ b/tc/tc_qevent.c @@ -0,0 +1,202 @@ +// SPDX-License-Identifier: GPL-2.0 OR BSD-3-Clause + +/* + * Helpers for handling qevents. + */ + +#include +#include + +#include "tc_qevent.h" +#include "utils.h" + +void qevents_init(struct qevent_util *qevents) +{ + if (!qevents) + return; + + for (; qevents->id; qevents++) + memset(qevents->data, 0, qevents->data_size); +} + +int qevent_parse(struct qevent_util *qevents, int *p_argc, char ***p_argv) +{ + char **argv = *p_argv; + int argc = *p_argc; + const char *name = *argv; + int err; + + if (!qevents) + goto out; + + for (; qevents->id; qevents++) { + if (strcmp(name, qevents->id) == 0) { + NEXT_ARG(); + err = qevents->parse_qevent(qevents, &argc, &argv); + if (err) + return err; + + *p_argc = argc; + *p_argv = argv; + return 0; + } + } + +out: + fprintf(stderr, "Unknown qevent `%s'\n", name); + return -1; +} + +int qevents_read(struct qevent_util *qevents, struct rtattr **tb) +{ + int err; + + if (!qevents) + return 0; + + for (; qevents->id; qevents++) { + if (tb[qevents->attr]) { + err = qevents->read_qevent(qevents, tb); + if (err) + return err; + } + } + + return 0; +} + +void qevents_print(struct qevent_util *qevents, FILE *f) +{ + int first = true; + + if (!qevents) + return; + + for (; qevents->id; qevents++) { + struct qevent_base *qeb = qevents->data; + + if (qeb->block_idx) { + if (first) { + open_json_array(PRINT_JSON, "qevents"); + first = false; + } + + open_json_object(NULL); + print_string(PRINT_ANY, "kind", " qevent %s", qevents->id); + qevents->print_qevent(qevents, f); + close_json_object(); + } + } + + if (!first) + close_json_array(PRINT_ANY, ""); +} + +int qevents_dump(struct qevent_util *qevents, struct nlmsghdr *n) +{ + int err; + + if (!qevents) + return 0; + + for (; qevents->id; qevents++) { + struct qevent_base *qeb = qevents->data; + + if (qeb->block_idx) { + err = qevents->dump_qevent(qevents, n); + if (err) + return err; + } + } + + return 0; +} + +static int parse_block_idx(const char *arg, struct qevent_base *qeb) +{ + if (qeb->block_idx) { + fprintf(stderr, "Qevent block index already specified\n"); + return -1; + } + + if (get_unsigned(&qeb->block_idx, arg, 10) || !qeb->block_idx) { + fprintf(stderr, "Illegal qevent block index\n"); + return -1; + } + + return 0; +} + +static int read_block_idx(struct rtattr *attr, struct qevent_base *qeb) +{ + if (qeb->block_idx) { + fprintf(stderr, "Qevent block index already specified\n"); + return -1; + } + + qeb->block_idx = rta_getattr_u32(attr); + if (!qeb->block_idx) { + fprintf(stderr, "Illegal qevent block index\n"); + return -1; + } + + return 0; +} + +static void print_block_idx(FILE *f, __u32 block_idx) +{ + print_uint(PRINT_ANY, "block", " block %u", block_idx); +} + +int qevent_parse_plain(struct qevent_util *qu, int *p_argc, char ***p_argv) +{ + struct qevent_plain *qe = qu->data; + char **argv = *p_argv; + int argc = *p_argc; + + if (qe->base.block_idx) { + fprintf(stderr, "Duplicate qevent\n"); + return -1; + } + + while (argc > 0) { + if (strcmp(*argv, "block") == 0) { + NEXT_ARG(); + if (parse_block_idx(*argv, &qe->base)) + return -1; + } else { + break; + } + NEXT_ARG_FWD(); + } + + if (!qe->base.block_idx) { + fprintf(stderr, "Unspecified qevent block index\n"); + return -1; + } + + *p_argc = argc; + *p_argv = argv; + return 0; +} + +int qevent_read_plain(struct qevent_util *qu, struct rtattr **tb) +{ + struct qevent_plain *qe = qu->data; + + return read_block_idx(tb[qu->attr], &qe->base); +} + +void qevent_print_plain(struct qevent_util *qu, FILE *f) +{ + struct qevent_plain *qe = qu->data; + + print_block_idx(f, qe->base.block_idx); +} + +int qevent_dump_plain(struct qevent_util *qu, struct nlmsghdr *n) +{ + struct qevent_plain *qe = qu->data; + + return addattr32(n, 1024, qu->attr, qe->base.block_idx); +} diff --git a/tc/tc_qevent.h b/tc/tc_qevent.h new file mode 100644 index 00000000..574e7cff --- /dev/null +++ b/tc/tc_qevent.h @@ -0,0 +1,49 @@ +/* SPDX-License-Identifier: GPL-2.0 */ +#ifndef _TC_QEVENT_H_ +#define _TC_QEVENT_H_ + +#include +#include + +struct qevent_base { + __u32 block_idx; +}; + +struct qevent_util { + const char *id; + int (*parse_qevent)(struct qevent_util *qu, int *argc, char ***argv); + int (*read_qevent)(struct qevent_util *qu, struct rtattr **tb); + void (*print_qevent)(struct qevent_util *qu, FILE *f); + int (*dump_qevent)(struct qevent_util *qu, struct nlmsghdr *n); + size_t data_size; + void *data; + int attr; +}; + +#define QEVENT(_name, _form, _data, _attr) \ + { \ + .id = _name, \ + .parse_qevent = qevent_parse_##_form, \ + .read_qevent = qevent_read_##_form, \ + .print_qevent = qevent_print_##_form, \ + .dump_qevent = qevent_dump_##_form, \ + .data_size = sizeof(struct qevent_##_form), \ + .data = _data, \ + .attr = _attr, \ + } + +void qevents_init(struct qevent_util *qevents); +int qevent_parse(struct qevent_util *qevents, int *p_argc, char ***p_argv); +int qevents_read(struct qevent_util *qevents, struct rtattr **tb); +int qevents_dump(struct qevent_util *qevents, struct nlmsghdr *n); +void qevents_print(struct qevent_util *qevents, FILE *f); + +struct qevent_plain { + struct qevent_base base; +}; +int qevent_parse_plain(struct qevent_util *qu, int *p_argc, char ***p_argv); +int qevent_read_plain(struct qevent_util *qu, struct rtattr **tb); +void qevent_print_plain(struct qevent_util *qu, FILE *f); +int qevent_dump_plain(struct qevent_util *qu, struct nlmsghdr *n); + +#endif From patchwork Fri Jun 26 22:45:32 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Petr Machata X-Patchwork-Id: 1318159 X-Patchwork-Delegate: dsahern@gmail.com Return-Path: X-Original-To: patchwork-incoming-netdev@ozlabs.org Delivered-To: patchwork-incoming-netdev@ozlabs.org Authentication-Results: ozlabs.org; spf=pass (sender SPF authorized) smtp.mailfrom=vger.kernel.org (client-ip=23.128.96.18; helo=vger.kernel.org; envelope-from=netdev-owner@vger.kernel.org; receiver=) Authentication-Results: ozlabs.org; dmarc=pass (p=none dis=none) header.from=mellanox.com Authentication-Results: ozlabs.org; dkim=pass (1024-bit key; unprotected) header.d=Mellanox.com header.i=@Mellanox.com header.a=rsa-sha256 header.s=selector1 header.b=IarEyr+g; dkim-atps=neutral Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by ozlabs.org (Postfix) with ESMTP id 49tsT11VpGz9sQx for ; Sat, 27 Jun 2020 08:47:01 +1000 (AEST) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726364AbgFZWrA (ORCPT ); Fri, 26 Jun 2020 18:47:00 -0400 Received: from mail-am6eur05on2082.outbound.protection.outlook.com ([40.107.22.82]:6168 "EHLO EUR05-AM6-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1726110AbgFZWq6 (ORCPT ); Fri, 26 Jun 2020 18:46:58 -0400 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=Mv+3yo/L4FeJq5rWtysKpedFJcNuD7ZLSBJtttRpBd0KWNmm6ZOrJZJ3GKxg6VxwqV6U9df5JZQKx68aZ/gotz5tsTQfs/nv8+SF4pov/yMsV60b9JnTxyFhW0vl3oAjiGfgmKpmAIgtwAbb6Sv3kU1DU3BKJf2Dcl5crJ0z1OJnAk4nuim5AFb0iNq7/N/XxmJxciwJbpsgHeJyGWAsaGE1w7cDo/ar8NIBu/oat43t326gN8JSabii4ovvqsITsd3xnY9ZfGy4oKrKA9RvQcoe2T52G9SRpOM00dYXqlxMJaDhTyBKYFXsbjJXz2DafhC4/a05TkpaFOXkXufTEg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=NFvt3AYzLc8vnVuXKAbqnOwhelN/2Q1uZcpGzQ5CF1A=; b=At3SXB02MIv4bswHch5dd346Dt6Yc1i+elCaJw8A7FUsB/jNtW8ErwCnsyc9jhBkErzZqsT9dTz5qkNQCzJUlsgbgWNgdgrNH8Vsitcr4PIwGr5Qg3KUC8rLg/37qJzvM08qXilm7gl4LCF9xXINTfdCY53l2w/BuwJvj6JeHpxCPe6eZPyYY7ZuGlE/4ZBKp/fG6uH35303FoIbDHRDo+8ZTG6RJGXCSPYmjjPw8kpKZtTXeD5F67O+V/CmCngzxN+h2jk56p9FxpJgqPS1leIwPZzrB1wxwMoLVdXz6MGPFb4sQUPnt2GpFIbbjSbDSyY4WF0yBJjZ6glewp8bTg== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=mellanox.com; dmarc=pass action=none header.from=mellanox.com; dkim=pass header.d=mellanox.com; arc=none 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:X-MS-Exchange-SenderADCheck; bh=NFvt3AYzLc8vnVuXKAbqnOwhelN/2Q1uZcpGzQ5CF1A=; b=IarEyr+gMGvpyGYHAfgKTo9+AeNLPY1AwNbxjwxjMmgdH6RVzaiNFc3Exizr4kojqBXzC5N8AdtaoRzOTB6/R02m/T+1cpl5VW4z7wgMdHazvinNO/dsdadsmxmiccnDZ8sgoGjN4hIeCvSnHwK9O+bXgIK9OBfY7M7qy28xSmc= Authentication-Results: vger.kernel.org; dkim=none (message not signed) header.d=none;vger.kernel.org; dmarc=none action=none header.from=mellanox.com; Received: from HE1PR05MB4746.eurprd05.prod.outlook.com (2603:10a6:7:a3::22) by HE1PR05MB3196.eurprd05.prod.outlook.com (2603:10a6:7:33::23) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.3131.21; Fri, 26 Jun 2020 22:46:21 +0000 Received: from HE1PR05MB4746.eurprd05.prod.outlook.com ([fe80::78f6:fb7a:ea76:c2d6]) by HE1PR05MB4746.eurprd05.prod.outlook.com ([fe80::78f6:fb7a:ea76:c2d6%7]) with mapi id 15.20.3131.024; Fri, 26 Jun 2020 22:46:21 +0000 From: Petr Machata To: netdev@vger.kernel.org Cc: David Miller , Jakub Kicinski , Cong Wang , Eric Dumazet , jiri@mellanox.com, idosch@mellanox.com, Petr Machata Subject: [PATCH iproute2-next v1 3/4] man: tc: Describe qevents Date: Sat, 27 Jun 2020 01:45:32 +0300 Message-Id: <098797720a8835bf1e3c891f4c4ad6a4270b48b0.1593211071.git.petrm@mellanox.com> X-Mailer: git-send-email 2.20.1 In-Reply-To: References: X-ClientProxiedBy: AM3PR05CA0139.eurprd05.prod.outlook.com (2603:10a6:207:3::17) To HE1PR05MB4746.eurprd05.prod.outlook.com (2603:10a6:7:a3::22) MIME-Version: 1.0 X-MS-Exchange-MessageSentRepresentingType: 1 Received: from dev-r-vrt-156.mtr.labs.mlnx (37.142.13.130) by AM3PR05CA0139.eurprd05.prod.outlook.com (2603:10a6:207:3::17) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.3131.21 via Frontend Transport; Fri, 26 Jun 2020 22:46:19 +0000 X-Mailer: git-send-email 2.20.1 X-Originating-IP: [37.142.13.130] X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-HT: Tenant X-MS-Office365-Filtering-Correlation-Id: 50daf393-6348-441c-edaa-08d81a22bef6 X-MS-TrafficTypeDiagnostic: HE1PR05MB3196: X-MS-Exchange-Transport-Forked: True X-Microsoft-Antispam-PRVS: X-MS-Oob-TLC-OOBClassifiers: OLM:6430; X-Forefront-PRVS: 0446F0FCE1 X-MS-Exchange-SenderADCheck: 1 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: 3c1h9bTAyamHI8d6pCPF+GgIuaQ7XIp702/6TCjIHzcDKCL7dHCkJUPGyYPsIuvVEw+45wRZN97jBa+98mMENm9etrsKsp5jeuFTqssdINTv5Klq1Ce21GHWGqWQk3mZsxe+rsVEyhjpckGwkRXlHRuY/Rn5upWW9j0Hg8MoC3HCWwy4P+dZfg4osGn1QMDcs0XSFx9iOFPXQc1yIeeaPuxftPhZstx8HDORziW218yrPtcEieqUwOQFMlYYK2fho+0Jot6RHunA2bEWmu4rNYOBa9nfdX3u+uccFrg46uH8u4WFEOESW+l/85XpqQNRORrbxLUIKtEPiwH7G8bdyQ== X-Forefront-Antispam-Report: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:HE1PR05MB4746.eurprd05.prod.outlook.com;PTR:;CAT:NONE;SFTY:;SFS:(4636009)(39860400002)(396003)(136003)(366004)(346002)(376002)(5660300002)(66476007)(8676002)(956004)(54906003)(52116002)(2616005)(6666004)(83380400001)(4326008)(6512007)(2906002)(26005)(8936002)(6916009)(107886003)(66556008)(36756003)(478600001)(86362001)(66946007)(186003)(316002)(6486002)(6506007)(16526019);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData: MykgRdclZVsfKoZVB4aONZQv7OHD/252I7wpuDUB1Z5mvVeDQMaV8Bf+C9qeLoPrmtsRZcT/aP7BBjCVcsyBEnreqYBLG9iZ5FTCX7DoZ0LquBACW2df9zGjOEdvZpvORbPw4gv9bLHLs/bCyZhwubY85FRv/2sgHGGwzU6Qgil6T0qI3C487GVFo7W24QYopfuG59d0NulIc0J18AWGTRVQe/9/dCg3Xnhl5tf7c16yVtiXuF9svQQ5lawLRqoaaNHOkHhH+OAGHBFILreMzQ5otFqciTsCIupAsgEZP+krrKIPFFkcKXKo+iF8lFW8AuQ6ir4z6vOxuuF0n1b8TZ9faM52xZuJKpnPUW3G4Xi8nz9JwwseYWqKopa18TBDPYkpHFI2NyXUW3ZMdp8RKARedcFGlrBPLTF7lC8VbRFZbg8/CgjOxwTaLiwRJaz03HqqGFmshMLjiKaM8z5IvHHQjymOZdqk61PWQouOpMM= X-OriginatorOrg: Mellanox.com X-MS-Exchange-CrossTenant-Network-Message-Id: 50daf393-6348-441c-edaa-08d81a22bef6 X-MS-Exchange-CrossTenant-AuthSource: HE1PR05MB4746.eurprd05.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 26 Jun 2020 22:46:21.1087 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: a652971c-7d2e-4d9b-a6a4-d149256f461b X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: AJ/2WgRg8T/FwHu96egl7tqXQ0YaUM9YDlBTKu0kIm29ayBaL1yrrYuApz8sgAd1qygzYNfa7KVwVMNpQQh8nw== X-MS-Exchange-Transport-CrossTenantHeadersStamped: HE1PR05MB3196 Sender: netdev-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: netdev@vger.kernel.org Add some general remarks about qevents. Signed-off-by: Petr Machata --- man/man8/tc.8 | 19 +++++++++++++++++++ 1 file changed, 19 insertions(+) diff --git a/man/man8/tc.8 b/man/man8/tc.8 index e8e0cd0f..970440f6 100644 --- a/man/man8/tc.8 +++ b/man/man8/tc.8 @@ -254,6 +254,25 @@ Traffic control filter that matches every packet. See .BR tc-matchall (8) for details. +.SH QEVENTS +Qdiscs may invoke user-configured actions when certain interesting events +take place in the qdisc. Each qevent can either be unused, or can have a +block attached to it. To this block are then attached filters using the "tc +block BLOCK_IDX" syntax. The block is executed when the qevent associated +with the attachment point takes place. For example, packet could be +dropped, or delayed, etc., depending on the qdisc and the qevent in +question. + +For example: +.PP +.RS +tc qdisc add dev eth0 root handle 1: red limit 500K avpkt 1K \\ + qevent early block 10 +.RE +.RS +tc filter add block 10 matchall action mirred egress mirror dev eth1 +.RE + .SH CLASSLESS QDISCS The classless qdiscs are: .TP From patchwork Fri Jun 26 22:45:33 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Petr Machata X-Patchwork-Id: 1318153 X-Patchwork-Delegate: dsahern@gmail.com Return-Path: X-Original-To: patchwork-incoming-netdev@ozlabs.org Delivered-To: patchwork-incoming-netdev@ozlabs.org Authentication-Results: ozlabs.org; spf=pass (sender SPF authorized) smtp.mailfrom=vger.kernel.org (client-ip=23.128.96.18; helo=vger.kernel.org; envelope-from=netdev-owner@vger.kernel.org; receiver=) Authentication-Results: ozlabs.org; dmarc=pass (p=none dis=none) header.from=mellanox.com Authentication-Results: ozlabs.org; dkim=pass (1024-bit key; unprotected) header.d=Mellanox.com header.i=@Mellanox.com header.a=rsa-sha256 header.s=selector1 header.b=rbsx4jaf; dkim-atps=neutral Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by ozlabs.org (Postfix) with ESMTP id 49tsST1GMNz9sRk for ; Sat, 27 Jun 2020 08:46:33 +1000 (AEST) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726107AbgFZWqb (ORCPT ); Fri, 26 Jun 2020 18:46:31 -0400 Received: from mail-eopbgr50045.outbound.protection.outlook.com ([40.107.5.45]:16979 "EHLO EUR03-VE1-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1725836AbgFZWqa (ORCPT ); Fri, 26 Jun 2020 18:46:30 -0400 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=VJF4ig9YLYwayqOiffhC523dhYVgSA5XbM7t6o/boFPwE0OhgydNet28K74VaeFLhG4Z1WyS35C1uz0vHafIvkZ235MIqhFEB6rUxIyGwCHvy4DIcMT6vYMvWOzojr1b7Z4fX4lFAfLoSTpx/IPPjFSHh3ZxsQmg+CmQ9vV+GXQUnJSVgrK95NZqUWAoxmuzke7ACWXSFnZq0ptmu/R85Hmo906kJHLzm5QfFDHS6vZd1Wi6QlMU01RFNIhbVvOJ/iCOLLUQebzriv/P1nsQeRwvgNXg39EkG3aq2D2ejwQ5gEBG0//ays25/gaLC5AUrTXw60TeWKiQfkHFL76EvQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=ndyWQNZcVFEwJnhZBLwApPvfSG8J7sth2i0NHwevsKk=; b=kgLvBj5DoV3GN3LjZsxjRdE51ASPEoD/MPUcmZOgunfjkZfIShsYMF4b84aAqhNvWka3BKGLsqs4nwaZxIWptpGsc2g1n3ka2Va6oZGS5SJbU0JsH1YloKMT/VYXCeP9xHeWeOSHCrySomFRRXuk08gsRckoqJUhvRH36xr8faS5ThmdbZAvoOgT/RX2mhktpjcG4mgwmY2Tc81ZR6xBwJ924rRPfC8GKrcIUXJtbTsnwbooDbFDVCBS8GhdTW3pctzj8KBCiaZ3xOENBT+r/WXy0k638QPY98JiUSqVRLc2urkk4VcdzaDYsiWjKSa9fjKaeaMJ+L5tfl4PF8QnHg== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=mellanox.com; dmarc=pass action=none header.from=mellanox.com; dkim=pass header.d=mellanox.com; arc=none 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:X-MS-Exchange-SenderADCheck; bh=ndyWQNZcVFEwJnhZBLwApPvfSG8J7sth2i0NHwevsKk=; b=rbsx4jafhP0iWdV1ifoBochDvQubiJ5giO58nhwnuSgk1XcM0jlI2ieXUwFPxAswR+S9JRWAoqMDOiy3qejFO0TwkWz0J7vRfTz9LojSm5vAiaFn7uG34m+6MEE7RIvnS4Jcq4AUOhpud8T4GIGNtLl5DmufiiQhaTrVrdMXpkA= Authentication-Results: vger.kernel.org; dkim=none (message not signed) header.d=none;vger.kernel.org; dmarc=none action=none header.from=mellanox.com; Received: from HE1PR05MB4746.eurprd05.prod.outlook.com (2603:10a6:7:a3::22) by HE1PR05MB4745.eurprd05.prod.outlook.com (2603:10a6:7:9a::22) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.3131.25; Fri, 26 Jun 2020 22:46:22 +0000 Received: from HE1PR05MB4746.eurprd05.prod.outlook.com ([fe80::78f6:fb7a:ea76:c2d6]) by HE1PR05MB4746.eurprd05.prod.outlook.com ([fe80::78f6:fb7a:ea76:c2d6%7]) with mapi id 15.20.3131.024; Fri, 26 Jun 2020 22:46:22 +0000 From: Petr Machata To: netdev@vger.kernel.org Cc: David Miller , Jakub Kicinski , Cong Wang , Eric Dumazet , jiri@mellanox.com, idosch@mellanox.com, Petr Machata Subject: [PATCH iproute2-next v1 4/4] tc: q_red: Add support for qevents "mark" and "early_drop" Date: Sat, 27 Jun 2020 01:45:33 +0300 Message-Id: X-Mailer: git-send-email 2.20.1 In-Reply-To: References: X-ClientProxiedBy: AM3PR05CA0139.eurprd05.prod.outlook.com (2603:10a6:207:3::17) To HE1PR05MB4746.eurprd05.prod.outlook.com (2603:10a6:7:a3::22) MIME-Version: 1.0 X-MS-Exchange-MessageSentRepresentingType: 1 Received: from dev-r-vrt-156.mtr.labs.mlnx (37.142.13.130) by AM3PR05CA0139.eurprd05.prod.outlook.com (2603:10a6:207:3::17) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.3131.21 via Frontend Transport; Fri, 26 Jun 2020 22:46:21 +0000 X-Mailer: git-send-email 2.20.1 X-Originating-IP: [37.142.13.130] X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-HT: Tenant X-MS-Office365-Filtering-Correlation-Id: 2b9d1a2e-60d2-446b-03f0-08d81a22bfe1 X-MS-TrafficTypeDiagnostic: HE1PR05MB4745: X-MS-Exchange-Transport-Forked: True X-Microsoft-Antispam-PRVS: X-MS-Oob-TLC-OOBClassifiers: OLM:210; X-Forefront-PRVS: 0446F0FCE1 X-MS-Exchange-SenderADCheck: 1 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: 3nnBGjJ6YWPPQlvHXZ4wPW0VW5t04bGElQqiP8fVf4Phs9b5e6zU52uPFScSd4qiTk3OBZZnG0kPTqGwBxOLoabwsy4lpgfAMV0CIZAewdgVzUVLvbNs/fUcVS7GrXneE9tEHyIaps7OmAvOXHhcJRycc7aDiggYbKurVvi1qyWwGslxc83DMqoSm8lHwFhAa6AFnf6poDIjvM1OjwbF11nXeDChulRzk2xdvflSlmmUhKnfouxEDjq0e1z8A92gm0wB9KHC/bNZ05scimwAF5nlD2JIZKs/1cYY/danloQXtpM+lWmrSAQO8iY6a42W X-Forefront-Antispam-Report: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:HE1PR05MB4746.eurprd05.prod.outlook.com;PTR:;CAT:NONE;SFTY:;SFS:(4636009)(396003)(136003)(376002)(346002)(39860400002)(366004)(86362001)(26005)(54906003)(4326008)(36756003)(66476007)(66556008)(316002)(186003)(16526019)(6666004)(478600001)(5660300002)(52116002)(6486002)(66946007)(6512007)(6506007)(107886003)(2906002)(2616005)(8676002)(956004)(6916009)(8936002)(83380400001);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData: erAhVOElOHHcIoZaEezbHfusVCZDVW84NwfBENaYr1yK2IHMkf+2r7MiDydjutjNylk5NOP8eQsy1A8hmQ/q8vJVXfSbgeIQj5baLSG+DIWj8AKUqGg0InZR66QqE0bW4rSRLhIfaHpjemcgQZm5v/pcVpB4aLSEysO87i/PX5TPEdRYtesy0jTvNQVXs43FWBUkT/Th/ayiN8LPxX/4qXKpxQT7x0y2SGFM8EQA3whw8g0A0OBht+zcmI3yULh41u9gB4Gaq0F4u9QVfUveYgur8OgzOuRvhJPUoUP+h2U2E4ZseNahe78DIyfB1/sDM8smKWBrMrsewY5d5AHT2RQcwgtqUZV8hGfVPui6Cp89KUO3Ldp6+7x+EaupqkFkXXigfUj67ahXQNWEmLzTF6zTCPBT/7HGcjPmXDhNJlqfulAhX6YjKHsTCtZnhSHAK/0QYBvSMdgIKEisX+ROdkNLwK1W4x5t7Y6Be/8n5Uo= X-OriginatorOrg: Mellanox.com X-MS-Exchange-CrossTenant-Network-Message-Id: 2b9d1a2e-60d2-446b-03f0-08d81a22bfe1 X-MS-Exchange-CrossTenant-AuthSource: HE1PR05MB4746.eurprd05.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 26 Jun 2020 22:46:22.5928 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: a652971c-7d2e-4d9b-a6a4-d149256f461b X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: j/dUPjSkCmjQ/ZtAhly5tdZ0PtA0d4y25haUvZUAOcekDwfQqLDgk2prAUI7XJP5JJPFxdJfNDgaww4bRASrNQ== X-MS-Exchange-Transport-CrossTenantHeadersStamped: HE1PR05MB4745 Sender: netdev-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: netdev@vger.kernel.org The "early_drop" qevent matches packets that have been early-dropped. The "mark" qevent matches packets that have been ECN-marked. Signed-off-by: Petr Machata --- man/man8/tc-red.8 | 18 +++++++++++++++++- tc/q_red.c | 30 +++++++++++++++++++++++++++--- 2 files changed, 44 insertions(+), 4 deletions(-) diff --git a/man/man8/tc-red.8 b/man/man8/tc-red.8 index b5aaa986..662e4d8b 100644 --- a/man/man8/tc-red.8 +++ b/man/man8/tc-red.8 @@ -17,7 +17,11 @@ packets rate .B ] [ probability chance -.B ] [ adaptive ] +.B ] [ adaptive ] [ qevent early_drop block +index +.B ] [ qevent mark block +index +.B ] .SH DESCRIPTION Random Early Detection is a classless qdisc which manages its queue size @@ -134,6 +138,18 @@ Goal of Adaptive RED is to make 'probability' dynamic value between 1% and 50% t .B (max - min) / 2 .fi +.SH QEVENTS +See tc (8) for some general notes about qevents. The RED qdisc supports the +following qevents: + +.TP +early_drop +The associated block is executed when packets are early-dropped. This includes +non-ECT packets in ECN mode. +.TP +mark +The associated block is executed when packets are marked in ECN mode. + .SH EXAMPLE .P diff --git a/tc/q_red.c b/tc/q_red.c index 53181c82..97856f03 100644 --- a/tc/q_red.c +++ b/tc/q_red.c @@ -22,6 +22,7 @@ #include "utils.h" #include "tc_util.h" +#include "tc_qevent.h" #include "tc_red.h" @@ -30,11 +31,20 @@ static void explain(void) fprintf(stderr, "Usage: ... red limit BYTES [min BYTES] [max BYTES] avpkt BYTES [burst PACKETS]\n" " [adaptive] [probability PROBABILITY] [bandwidth KBPS]\n" - " [ecn] [harddrop] [nodrop]\n"); + " [ecn] [harddrop] [nodrop]\n" + " [qevent early_drop block IDX] [qevent mark block IDX]\n"); } #define RED_SUPPORTED_FLAGS (TC_RED_HISTORIC_FLAGS | TC_RED_NODROP) +static struct qevent_plain qe_early_drop = {}; +static struct qevent_plain qe_mark = {}; +static struct qevent_util qevents[] = { + QEVENT("early_drop", plain, &qe_early_drop, TCA_RED_EARLY_DROP_BLOCK), + QEVENT("mark", plain, &qe_mark, TCA_RED_MARK_BLOCK), + {}, +}; + static int red_parse_opt(struct qdisc_util *qu, int argc, char **argv, struct nlmsghdr *n, const char *dev) { @@ -51,6 +61,8 @@ static int red_parse_opt(struct qdisc_util *qu, int argc, char **argv, __u32 max_P; struct rtattr *tail; + qevents_init(qevents); + while (argc > 0) { if (strcmp(*argv, "limit") == 0) { NEXT_ARG(); @@ -109,6 +121,11 @@ static int red_parse_opt(struct qdisc_util *qu, int argc, char **argv, flags_bf.value |= TC_RED_ADAPTATIVE; } else if (strcmp(*argv, "adaptive") == 0) { flags_bf.value |= TC_RED_ADAPTATIVE; + } else if (matches(*argv, "qevent") == 0) { + NEXT_ARG(); + if (qevent_parse(qevents, &argc, &argv)) + return -1; + continue; } else if (strcmp(*argv, "help") == 0) { explain(); return -1; @@ -162,6 +179,8 @@ static int red_parse_opt(struct qdisc_util *qu, int argc, char **argv, max_P = probability * pow(2, 32); addattr_l(n, 1024, TCA_RED_MAX_P, &max_P, sizeof(max_P)); addattr_l(n, 1024, TCA_RED_FLAGS, &flags_bf, sizeof(flags_bf)); + if (qevents_dump(qevents, n)) + return -1; addattr_nest_end(n, tail); return 0; } @@ -203,12 +222,12 @@ static int red_print_opt(struct qdisc_util *qu, FILE *f, struct rtattr *opt) print_uint(PRINT_JSON, "min", NULL, qopt->qth_min); print_string(PRINT_FP, NULL, "min %s ", sprint_size(qopt->qth_min, b2)); print_uint(PRINT_JSON, "max", NULL, qopt->qth_max); - print_string(PRINT_FP, NULL, "max %s ", sprint_size(qopt->qth_max, b3)); + print_string(PRINT_FP, NULL, "max %s", sprint_size(qopt->qth_max, b3)); tc_red_print_flags(qopt->flags); if (show_details) { - print_uint(PRINT_ANY, "ewma", "ewma %u ", qopt->Wlog); + print_uint(PRINT_ANY, "ewma", " ewma %u ", qopt->Wlog); if (max_P) print_float(PRINT_ANY, "probability", "probability %lg ", max_P / pow(2, 32)); @@ -217,6 +236,11 @@ static int red_print_opt(struct qdisc_util *qu, FILE *f, struct rtattr *opt) print_uint(PRINT_ANY, "Scell_log", "Scell_log %u", qopt->Scell_log); } + + qevents_init(qevents); + if (qevents_read(qevents, tb)) + return -1; + qevents_print(qevents, f); return 0; }