Received: by 2002:a25:ad19:0:0:0:0:0 with SMTP id y25csp10534219ybi; Thu, 11 Jul 2019 06:53:08 -0700 (PDT) X-Google-Smtp-Source: APXvYqwSsCx4rQbQk/NOVrFT0F8iwKIiUzCdwoJ8wAhdxzzs+/4cbl8nlb5xt9wdHZHaORlrQoRn X-Received: by 2002:a17:902:2bcb:: with SMTP id l69mr4843703plb.155.1562853188419; Thu, 11 Jul 2019 06:53:08 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1562853188; cv=pass; d=google.com; s=arc-20160816; b=w7SaYgCC3NM0zNGi2XuBz/Z2awjtVZIgt9JBiIs3gPj9C2VfMLDafyV9Ry45nmtWlV d9FR2rWFWeSn7TDshxQ0cVmcaONUV+dS4g/jdd67EKeE9remBqBSoEESC3bdyicTfvjp wPQB5bht2RkkZpYtEMpjs0jaL7Z/uBqJlBc9vatgZGxpgeGLaEv4SQ06jnrRHXRTQy/l zUMwReFeuCGH/RtsH8hjJZZ6q3kXK5WbxaoTr9QSE6gneSKtFIc1PA/yyke4Y4ipR4PS oPyR85qxEA+sYYtAvItOcrKy8p6XdsWpu1u2mFue0XSIj8Gb+E/Uk08l1/TWVM6p0jmV SPSQ== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:content-transfer-encoding :content-language:accept-language:in-reply-to:references:message-id :date:thread-index:thread-topic:subject:cc:to:from:dkim-signature; bh=oHusE5s48/RUxfaorid1+sFXXf8MjHECdJyzrTzuJ5o=; b=0YEIx5vsdirEmQXN55Zo0oAqFYmrGQ7dTxuVt64OgYB/RmL2ZRO4HribQMW+/j6ujd aYPHhGLRLbe3yw6NectJ+KHe85MGYTe9gQYS/I7/k1SGkoosyp6Tx9pZY8U35NmVXYvy FaZ9UWF+R1epM2vx3RjBe/mfXV9ohTdjNjWjKgYzWyaPrtiMiGh3kLL2rP6z8+g/Za+g XX+F1CW9gbYRHiNX8dt7xlEVZHHmQZ43YxrXg3Ik8m8T6Lr9/i3ELmGqi9KL0t9cZPSV iik3Ft1cptshErrMo30bBmIW8AUei+cFi+I8MYTsKeSnOxxljfcvVf8rFOqFwsua9WXm r3MA== ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@ericsson.com header.s=selector2 header.b=PX3hlwqf; arc=pass (i=1 spf=pass spfdomain=ericsson.com dkim=pass dkdomain=ericsson.com dmarc=pass fromdomain=ericsson.com); spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=ericsson.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 130si5669568pgg.18.2019.07.11.06.52.52; Thu, 11 Jul 2019 06:53:08 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@ericsson.com header.s=selector2 header.b=PX3hlwqf; arc=pass (i=1 spf=pass spfdomain=ericsson.com dkim=pass dkdomain=ericsson.com dmarc=pass fromdomain=ericsson.com); spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=ericsson.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728566AbfGKMzR (ORCPT + 99 others); Thu, 11 Jul 2019 08:55:17 -0400 Received: from mail-eopbgr740079.outbound.protection.outlook.com ([40.107.74.79]:6112 "EHLO NAM01-BN3-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1725971AbfGKMzQ (ORCPT ); Thu, 11 Jul 2019 08:55:16 -0400 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=JKCGbex8LSFEZD55rJhoZaAfa4vLX/uyUmcCYxaNCOAGBjg2vXoBAoi5JIPAXuN0s76b5ztnT2bvqQT16bSUBqEcVpb8y579/SOJzO1Sedy7k7J++AVnfLPzZnz+Hh2JojqWGPw+CcPwlDFn/hgaHL0UBmjT31SLvXegMgQy/ouMTmJFL73upjSHuPxil7vz3dzJxilYIislY2QiucRMN28eiFyk21A6MWvU25RVxgKsfpniOV2h+mg0qsyOp8cI9MdXc69QPbmDBY+Q4qzctE4+RtVufX8bnOk3Gl6iJvl8WQSmXCs15qwKqgAQqb860nzlFtXBdnJ5T1ox6jFAaw== 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=oHusE5s48/RUxfaorid1+sFXXf8MjHECdJyzrTzuJ5o=; b=HiFl7rKNOqHHq2FV8N+2WuJCHAWdfb2ANXiXu6YL01gmxHQlmrJvT9GWgd9NxkaxX3joE5aDBiZRQp1LQKmPkHV1asHoXUSSsO/pFrcbPTOU8YtvAD0gP/52TJ7CjLeK6TMz79qBC6dRyEl4mzUUwrySAMlDM32kswoEASGf//HjT3BlIJb4pOIxdD/JJILiWa0c+N8pWnE3NZy5xJsdZ0RmJZtbtBj2sdYEZE1BL1SjblcpFBHK2ZWbZbesYfbh2v0uJqcPXwWBOQF+gzPh95gZN4SysAoJVDQyA1U47r4ufhximc5kIPnMv5RwwDma91SyKZ2ZPDBicYSL5hJ9Lw== ARC-Authentication-Results: i=1; mx.microsoft.com 1;spf=pass smtp.mailfrom=ericsson.com;dmarc=pass action=none header.from=ericsson.com;dkim=pass header.d=ericsson.com;arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ericsson.com; s=selector2; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=oHusE5s48/RUxfaorid1+sFXXf8MjHECdJyzrTzuJ5o=; b=PX3hlwqflal5WveTmExiAXYkhXzNODYJsKcSaywgQrG02l1gZ3HW2AcfJivGPUDxebYH+V0w7zj1lQ7ZWJ9xjFqGF87zoBBYho9Kv1lNIQ6znYbGeoJwXW7rpevLa627QN8T1Nlx9GIZJfJAbaCjzhGn+OQf8YIQABm/eJpsgl8= Received: from CH2PR15MB3575.namprd15.prod.outlook.com (10.255.156.17) by CH2PR15MB3541.namprd15.prod.outlook.com (10.255.156.30) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.2073.10; Thu, 11 Jul 2019 12:55:12 +0000 Received: from CH2PR15MB3575.namprd15.prod.outlook.com ([fe80::ecc4:bffd:8512:a8b6]) by CH2PR15MB3575.namprd15.prod.outlook.com ([fe80::ecc4:bffd:8512:a8b6%2]) with mapi id 15.20.2073.008; Thu, 11 Jul 2019 12:55:12 +0000 From: Jon Maloy To: Chris Packham , Eric Dumazet , "ying.xue@windriver.com" , "davem@davemloft.net" CC: "netdev@vger.kernel.org" , "tipc-discussion@lists.sourceforge.net" , "linux-kernel@vger.kernel.org" Subject: RE: [PATCH] tipc: ensure skb->lock is initialised Thread-Topic: [PATCH] tipc: ensure skb->lock is initialised Thread-Index: AQHVNRbZCg2+IkEFUEKEsAEksjW2W6bFYzhw Date: Thu, 11 Jul 2019 12:55:12 +0000 Message-ID: References: <4d2ac0ce7f974184ac43b71f19aee7a3@svr-chch-ex1.atlnz.lc> In-Reply-To: <4d2ac0ce7f974184ac43b71f19aee7a3@svr-chch-ex1.atlnz.lc> Accept-Language: en-US Content-Language: en-US X-MS-Has-Attach: X-MS-TNEF-Correlator: authentication-results: spf=none (sender IP is ) smtp.mailfrom=jon.maloy@ericsson.com; x-originating-ip: [24.225.233.31] x-ms-publictraffictype: Email x-ms-office365-filtering-correlation-id: 5edbd025-63ac-427e-1034-08d705ff0341 x-microsoft-antispam: BCL:0;PCL:0;RULEID:(2390118)(7020095)(4652040)(8989299)(4534185)(4627221)(201703031133081)(201702281549075)(8990200)(5600148)(711020)(4605104)(1401327)(2017052603328)(7193020);SRVR:CH2PR15MB3541; x-ms-traffictypediagnostic: CH2PR15MB3541: x-microsoft-antispam-prvs: x-ms-oob-tlc-oobclassifiers: OLM:8882; x-forefront-prvs: 0095BCF226 x-forefront-antispam-report: SFV:NSPM;SFS:(10009020)(4636009)(366004)(189003)(199004)(13464003)(81166006)(33656002)(498600001)(68736007)(55016002)(6246003)(256004)(229853002)(76176011)(54906003)(110136005)(6436002)(7696005)(81156014)(186003)(9686003)(26005)(8676002)(53936002)(6506007)(53546011)(25786009)(6116002)(3846002)(99286004)(7736002)(5660300002)(66066001)(8936002)(476003)(486006)(14454004)(71190400001)(446003)(66446008)(4326008)(102836004)(76116006)(11346002)(66946007)(66476007)(64756008)(14444005)(52536014)(2906002)(66556008)(305945005)(2501003)(86362001)(2201001)(44832011)(71200400001)(74316002);DIR:OUT;SFP:1101;SCL:1;SRVR:CH2PR15MB3541;H:CH2PR15MB3575.namprd15.prod.outlook.com;FPR:;SPF:None;LANG:en;PTR:InfoNoRecords;MX:1;A:1; received-spf: None (protection.outlook.com: ericsson.com does not designate permitted sender hosts) x-ms-exchange-senderadcheck: 1 x-microsoft-antispam-message-info: vQ1G1vIptql2053HrtulEvLcPkw0bO/A+fec8nlgvLcOGCZ3ENvI2T57C6AEhrOQLAb/vNL5BrOdZ6IjtON6ZWjiIiC31oS1Jn31tGADC9zgnkby8oLEeUaQFLCXN1h1MSK/hsXqW/BNbYQ4dabzoMUz4Q0084TM0Pg7mXRIHL/eeJmjVF2b4WtX/TXoM0d8RC9cX+6pBHyb5wbQgrAwoT8wO1tcqeGsrsAQR6UoZTCHyI4rSVJU1JTI3+4fcL7GfT5r5mWyTbO4DTKIehw0VaHwh4kR5IP4bUSEqdZlY+aYQTSWyimV6UymYsaVvJAFcBcxzR76HHPm2vNhztGGUZpb2j3yUjkR+sMQYTXmB599zD8RKbGeufbUheh+3ccXltrL8j8JvgaUWre/lFBisYOIsAUIybXzKUnxvPS+ci4= Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: quoted-printable MIME-Version: 1.0 X-OriginatorOrg: ericsson.com X-MS-Exchange-CrossTenant-Network-Message-Id: 5edbd025-63ac-427e-1034-08d705ff0341 X-MS-Exchange-CrossTenant-originalarrivaltime: 11 Jul 2019 12:55:12.4390 (UTC) X-MS-Exchange-CrossTenant-fromentityheader: Hosted X-MS-Exchange-CrossTenant-id: 92e84ceb-fbfd-47ab-be52-080c6b87953f X-MS-Exchange-CrossTenant-mailboxtype: HOSTED X-MS-Exchange-CrossTenant-userprincipalname: jon.maloy@ericsson.com X-MS-Exchange-Transport-CrossTenantHeadersStamped: CH2PR15MB3541 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org > -----Original Message----- > From: Chris Packham > Sent: 10-Jul-19 16:58 > To: Jon Maloy ; Eric Dumazet > ; ying.xue@windriver.com; > davem@davemloft.net > Cc: netdev@vger.kernel.org; tipc-discussion@lists.sourceforge.net; linux- > kernel@vger.kernel.org > Subject: Re: [PATCH] tipc: ensure skb->lock is initialised >=20 >=20 > On 11/07/19 1:10 AM, Jon Maloy wrote: > >> -----Original Message----- > >> From: Eric Dumazet > >> Sent: 10-Jul-19 04:00 > >> To: Jon Maloy ; Eric Dumazet > >> ; Chris Packham > >> ; ying.xue@windriver.com; > >> davem@davemloft.net > >> Cc: netdev@vger.kernel.org; tipc-discussion@lists.sourceforge.net; > >> linux- kernel@vger.kernel.org > >> Subject: Re: [PATCH] tipc: ensure skb->lock is initialised > >> > >> > >> > >> On 7/9/19 10:15 PM, Jon Maloy wrote: > >>> > >>> It is not only for lockdep purposes, -it is essential. But please > >>> provide details > >> about where you see that more fixes are needed. > >>> > >> > >> Simple fact that you detect a problem only when skb_queue_purge() is > >> called should talk by itself. > >> > >> As I stated, there are many places where the list is manipulated > >> _without_ its spinlock being held. > > > > Yes, and that is the way it should be on the send path. > > > >> > >> You want consistency, then > >> > >> - grab the spinlock all the time. > >> - Or do not ever use it. > > > > That is exactly what we are doing. > > - The send path doesn't need the spinlock, and never grabs it. > > - The receive path does need it, and always grabs it. > > > > However, since we don't know from the beginning which path a created > > message will follow, we initialize the queue spinlock "just in case" > > when it is created, even though it may never be used later. > > You can see this as a violation of the principle you are stating > > above, but it is a prize that is worth paying, given savings in code > > volume, complexity and performance. > > > >> > >> Do not initialize the spinlock just in case a path will use > >> skb_queue_purge() (instead of using __skb_queue_purge()) > > > > I am ok with that. I think we can agree that Chris goes for that > > solution, so we can get this bug fixed. >=20 > So would you like a v2 with an improved commit message? I note that I sai= d > skb->lock instead of head->lock in the subject line so at least that shou= ld be > corrected. Yes, unless Eric has any more objections.=20 I addition, I have realized that we can change from skb_queue_head_init() = to __skb_queue_head_init() at all the disputed locations in the socket code= . Then, we do a separate call to spin_lock_init(&list->lock) at the moment we= find that the message will follow the receive path, i.e., in tipc_node_xmi= t(). That should make everybody happy.=20 I will post a patch when net-next re-opens. BR ///jon