Received: by 10.223.185.116 with SMTP id b49csp1101423wrg; Sat, 3 Mar 2018 15:35:36 -0800 (PST) X-Google-Smtp-Source: AG47ELsdJSBp6UdqywruogN2UoGXUmhFBCTcMTPL1IqDYwfA5R9rYVka5h5gkqKHRTfKSQ8cZSK0 X-Received: by 10.98.69.76 with SMTP id s73mr10541871pfa.31.1520120136619; Sat, 03 Mar 2018 15:35:36 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1520120136; cv=none; d=google.com; s=arc-20160816; b=fZvKADnGR7mal+33AlPyeTphFa0FsFXXDjRKAkV7T7go16Ukec1vX/PG1RJkNi7kxZ jAM47+NfYr23xVYJCXz95pjj0fUo6jLkDnKn7E0jC9f+27ikOeMAG9YUxLg9RQNbarVf kFNMVruSzMIBDcG1ZqcpDGjeKLWQksrWrB/1MB2vm5epyeI0/9PtNfjRu49Cpp2UZa/M 23V7Bl2Tp8aF1VEcAOBfrue6ENVw1yuBsVvAx1knHxiLdSz1KTrkyFh8ybxLbHfC+mto 90fTfI/mCrT7E+HCaD1LMd0IvWs81bFrcPWmgFiEH/FkoRng3VRtBqQwIP0/Mjj9v/iU ulAw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:content-transfer-encoding :spamdiagnosticmetadata:spamdiagnosticoutput:content-language :accept-language:in-reply-to:references:message-id:date:thread-index :thread-topic:subject:cc:to:from:dkim-signature :arc-authentication-results; bh=4ga8oeVdBwLe98n5aHG7kjzGegEveYoZvua6OXoUy2k=; b=vcIt47V99kTimMxWGt06AAAKPxLwOf0DFcu7Qrqd1d4+j302KLNgQU3hGbYEy2ae3C 5zHLHOdfW8Cvp7IpdllNYt3Xh0xtsOeJzq/RJzXz4G/7pv/dtBYRaDgGEGO3TiuaOvYb O0Xs1UD1fbCVDvqyDc5OAXBhp2Ll5d6ZTMjYnko9kxMJl7qAGIIvN/Zm7GJReEWjgsSW PvAXhltmvvAK0nTzIPO3amN8p2pngDW8O9+LJblNEWn3Q8BrWD3vf+N4zQKFM4CEzjxZ d3tyFMBfS/m8TXAu/smA7PTkF8ST4+CiRwdGkoDsbB4L6UZIwold0Wf/s2gWpmtX2+Ry KuFQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@microsoft.com header.s=selector1 header.b=SRDquE9o; 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=REJECT sp=REJECT dis=NONE) header.from=microsoft.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id o6-v6si6796630plk.820.2018.03.03.15.35.22; Sat, 03 Mar 2018 15:35:36 -0800 (PST) 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=@microsoft.com header.s=selector1 header.b=SRDquE9o; 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=REJECT sp=REJECT dis=NONE) header.from=microsoft.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752478AbeCCXdi (ORCPT + 99 others); Sat, 3 Mar 2018 18:33:38 -0500 Received: from mail-bn3nam01on0139.outbound.protection.outlook.com ([104.47.33.139]:45280 "EHLO NAM01-BN3-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S933950AbeCCWgF (ORCPT ); Sat, 3 Mar 2018 17:36:05 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version; bh=4ga8oeVdBwLe98n5aHG7kjzGegEveYoZvua6OXoUy2k=; b=SRDquE9ooPsWW60ptqcoAU9/yx8LKw0mURRr0zURwd0HK0XNQaYdUvlBykKchMZb3ICWOgLNwt+EeXwd7tQY9HwB/VFOg8bZstCeMmQOMG6Z0hifsrSsuu/AC/LFYuiXgIbZeLJCPAYtPfMMfHYO0WTMtyUzg8DSaKWgUqBs+h0= Received: from MW2PR2101MB1034.namprd21.prod.outlook.com (52.132.149.10) by MW2PR2101MB1034.namprd21.prod.outlook.com (52.132.149.10) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.567.3; Sat, 3 Mar 2018 22:35:47 +0000 Received: from MW2PR2101MB1034.namprd21.prod.outlook.com ([fe80::1d56:338f:e2b:cec0]) by MW2PR2101MB1034.namprd21.prod.outlook.com ([fe80::1d56:338f:e2b:cec0%3]) with mapi id 15.20.0567.006; Sat, 3 Mar 2018 22:35:47 +0000 From: Sasha Levin To: "linux-kernel@vger.kernel.org" , "stable@vger.kernel.org" CC: Michael Scott , Marcel Holtmann , Sasha Levin Subject: [PATCH AUTOSEL for 4.9 164/219] Bluetooth: 6lowpan: fix delay work init in add_peer_chan() Thread-Topic: [PATCH AUTOSEL for 4.9 164/219] Bluetooth: 6lowpan: fix delay work init in add_peer_chan() Thread-Index: AQHTsz8aSGewpgldmUmM5u3GZ5VDjg== Date: Sat, 3 Mar 2018 22:29:32 +0000 Message-ID: <20180303222716.26640-164-alexander.levin@microsoft.com> References: <20180303222716.26640-1-alexander.levin@microsoft.com> In-Reply-To: <20180303222716.26640-1-alexander.levin@microsoft.com> Accept-Language: en-US Content-Language: en-US X-MS-Has-Attach: X-MS-TNEF-Correlator: x-originating-ip: [52.168.54.252] x-ms-publictraffictype: Email x-microsoft-exchange-diagnostics: 1;MW2PR2101MB1034;7:J1xesqNJ3TfhzJeYqvq9DFWOrWirglW5czAH2fHFBjzlz1SC44O6Ll/gs5zZKMuCE2sTHXfR2zCBcumXpF2bDmbqV02oe5sPFFIQGAcXSYp0L44U6pnNpO6Fj1qXX13xkmi3KkltTF5c5TnGOwbZ9ORkIR26ZYd8x4Jhcvw/JFNBNPPrpJ5u+ekL7gcNhfJcq3InuX6P/gHAM2nerHmEBKGf4JtOSNkYVkzl+ppTeWTLoknyAaa33RVnM+SwX0F0 x-ms-office365-filtering-ht: Tenant x-ms-office365-filtering-correlation-id: 1aa422d2-50e1-4adb-d10d-08d581571c10 x-microsoft-antispam: UriScan:;BCL:0;PCL:0;RULEID:(7020095)(4652020)(4534165)(4627221)(201703031133081)(201702281549075)(48565401081)(5600026)(4604075)(3008032)(2017052603307)(7193020);SRVR:MW2PR2101MB1034; x-ms-traffictypediagnostic: MW2PR2101MB1034: authentication-results: spf=none (sender IP is ) smtp.mailfrom=Alexander.Levin@microsoft.com; x-microsoft-antispam-prvs: x-exchange-antispam-report-test: UriScan:(28532068793085)(89211679590171)(228905959029699); x-exchange-antispam-report-cfa-test: BCL:0;PCL:0;RULEID:(8211001083)(61425038)(6040501)(2401047)(5005006)(8121501046)(3231220)(944501244)(52105095)(93006095)(93001095)(10201501046)(3002001)(6055026)(61426038)(61427038)(6041288)(20161123562045)(201703131423095)(201702281528075)(20161123555045)(201703061421075)(201703061406153)(20161123564045)(20161123558120)(20161123560045)(6072148)(201708071742011);SRVR:MW2PR2101MB1034;BCL:0;PCL:0;RULEID:;SRVR:MW2PR2101MB1034; x-forefront-prvs: 0600F93FE1 x-forefront-antispam-report: SFV:NSPM;SFS:(10019020)(376002)(346002)(39860400002)(39380400002)(366004)(396003)(199004)(189003)(99286004)(22452003)(72206003)(316002)(3846002)(6116002)(186003)(26005)(478600001)(76176011)(54906003)(110136005)(102836004)(97736004)(1076002)(2501003)(3660700001)(66066001)(5250100002)(5660300001)(86362001)(10090500001)(10290500003)(86612001)(6506007)(68736007)(106356001)(25786009)(8676002)(4326008)(59450400001)(6512007)(305945005)(2906002)(14454004)(107886003)(8936002)(7736002)(81166006)(3280700002)(53936002)(105586002)(81156014)(6666003)(6486002)(36756003)(2900100001)(6436002)(2950100002)(22906009)(217873001);DIR:OUT;SFP:1102;SCL:1;SRVR:MW2PR2101MB1034;H:MW2PR2101MB1034.namprd21.prod.outlook.com;FPR:;SPF:None;PTR:InfoNoRecords;A:1;MX:1;LANG:en; received-spf: None (protection.outlook.com: microsoft.com does not designate permitted sender hosts) x-microsoft-antispam-message-info: XUeB9TEkgMlElbHgwFRktjCDzEVmWJqqo1cdXrm7V83EHkVUuXselyOJ/SAsmfLlSpmoFzswVAL/IjcJVNiu2sxLuXyd383T/6U0K8iHNIG9eJnia5RJOwfbW03IeewITHD1cSBZRjr7Z+Vs2lCjRODp0/JW5POnLoGDf9G/CuU= spamdiagnosticoutput: 1:99 spamdiagnosticmetadata: NSPM Content-Type: text/plain; charset="iso-8859-1" Content-Transfer-Encoding: quoted-printable MIME-Version: 1.0 X-OriginatorOrg: microsoft.com X-MS-Exchange-CrossTenant-Network-Message-Id: 1aa422d2-50e1-4adb-d10d-08d581571c10 X-MS-Exchange-CrossTenant-originalarrivaltime: 03 Mar 2018 22:29:32.6507 (UTC) X-MS-Exchange-CrossTenant-fromentityheader: Hosted X-MS-Exchange-CrossTenant-id: 72f988bf-86f1-41af-91ab-2d7cd011db47 X-MS-Exchange-Transport-CrossTenantHeadersStamped: MW2PR2101MB1034 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Michael Scott [ Upstream commit d2891c4d071d807f01cc911dc42a68f4568d65cf ] When adding 6lowpan devices very rapidly we sometimes see a crash: [23122.306615] CPU: 2 PID: 0 Comm: swapper/2 Not tainted 4.9.0-43-arm64 #1 = Debian 4.9.9.linaro.43-1 [23122.315400] Hardware name: HiKey Development Board (DT) [23122.320623] task: ffff800075443080 task.stack: ffff800075484000 [23122.326551] PC is at expire_timers+0x70/0x150 [23122.330907] LR is at run_timer_softirq+0xa0/0x1a0 [23122.335616] pc : [] lr : [] pstate: = 600001c5 This was due to add_peer_chan() unconditionally initializing the lowpan_btle_dev->notify_peers delayed work structure, even if the lowpan_btle_dev passed into add_peer_chan() had previously been initialized. Normally, this would go unnoticed as the delayed work timer is set for 100 msec, however when calling add_peer_chan() faster than 100 msec it clears out a previously queued delay work causing the crash above. To fix this, let add_peer_chan() know when a new lowpan_btle_dev is passed in so that it only performs the delay work initialization when needed. Signed-off-by: Michael Scott Acked-by: Jukka Rissanen Signed-off-by: Marcel Holtmann Signed-off-by: Sasha Levin --- net/bluetooth/6lowpan.c | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/net/bluetooth/6lowpan.c b/net/bluetooth/6lowpan.c index 1904a93f47d5..de7b82ece499 100644 --- a/net/bluetooth/6lowpan.c +++ b/net/bluetooth/6lowpan.c @@ -755,7 +755,8 @@ static void set_ip_addr_bits(u8 addr_type, u8 *addr) } =20 static struct l2cap_chan *add_peer_chan(struct l2cap_chan *chan, - struct lowpan_btle_dev *dev) + struct lowpan_btle_dev *dev, + bool new_netdev) { struct lowpan_peer *peer; =20 @@ -786,7 +787,8 @@ static struct l2cap_chan *add_peer_chan(struct l2cap_ch= an *chan, spin_unlock(&devices_lock); =20 /* Notifying peers about us needs to be done without locks held */ - INIT_DELAYED_WORK(&dev->notify_peers, do_notify_peers); + if (new_netdev) + INIT_DELAYED_WORK(&dev->notify_peers, do_notify_peers); schedule_delayed_work(&dev->notify_peers, msecs_to_jiffies(100)); =20 return peer->chan; @@ -843,6 +845,7 @@ out: static inline void chan_ready_cb(struct l2cap_chan *chan) { struct lowpan_btle_dev *dev; + bool new_netdev =3D false; =20 dev =3D lookup_dev(chan->conn); =20 @@ -853,12 +856,13 @@ static inline void chan_ready_cb(struct l2cap_chan *c= han) l2cap_chan_del(chan, -ENOENT); return; } + new_netdev =3D true; } =20 if (!try_module_get(THIS_MODULE)) return; =20 - add_peer_chan(chan, dev); + add_peer_chan(chan, dev, new_netdev); ifup(dev->netdev); } =20 --=20 2.14.1