Received: by 10.192.165.148 with SMTP id m20csp873866imm; Wed, 25 Apr 2018 08:59:11 -0700 (PDT) X-Google-Smtp-Source: AIpwx4/O4z4jZiSrTXNhALl52/AHwQUuenjM3QXoSDPAV+HeDkCh/AihdLOpkRPt/7Xq6usp3mU7 X-Received: by 10.101.101.71 with SMTP id a7mr10985620pgw.216.1524671951713; Wed, 25 Apr 2018 08:59:11 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1524671951; cv=none; d=google.com; s=arc-20160816; b=yfspdmq6q0+MIl4RBakOv+t4IvBZalm4deSgeqrDdnPdm/7yKSumDjxeeEoxnLsA1y zRqgSKHsQYpHsnEXb8djY2rK97GCP8DBi0hNbndoVgz+7VS2bLktZVVbNkKVkBL7VOs3 4VWODlAvO+tGbplB+l3/S+BsaQ/Xtn/H+vrc+iFcdztov6HgIOP64PbafN7uZ+GJ18GP EDbUvkAwfZ1YFrvr8wYjUGSFjLblLMfqmOijTbQq3ZJiB5jamyjvFBJV3Frl1I1IifBg c/348wHQRwm4YeiXUBDJsz3p/ILg+5ml6OVVK3Fv7xi7khL8q5+Aggg1XcZokBELK9ZN qXmw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:subject:message-id:date:from :references:in-reply-to:mime-version:dkim-signature :arc-authentication-results; bh=3+FdJP1qLXrXsMILF6YY4ciuj+34BbYQhRH801gUGwA=; b=QvXokz2dltDi9H+JArAO712XswfcK3KrPZry08pl/9K0zri0HGjQVbfFkDZacXzz+y rPyyDNh3MtwHdXy4l11zmYN399B8Gi+W9am8kW+YIxsQvcmWJ3aHQUxFWCcpORcsShQB ca5pMYGvH5YXniTivQfA8OsBjzTMFIREdfN8SiYrp7HIBeG+BVVy5m9SO9x6UTi2PzY5 e5HrHvdB5xr67/CNvZgqK1DqyouevASQqzEluKXu10fl7G5TUuNR1uIFG5cc11vhGn1A 3VqCMnqSw3uYPc0zFF8mrnSUVp6ZL+EtV0sjelZssygcBn6mzxhBVjJkmtzQ7Rlz9s0P zS8A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@android.com header.s=20161025 header.b=rydZ5Woj; 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=android.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 29si16126656pfj.6.2018.04.25.08.58.56; Wed, 25 Apr 2018 08:59:11 -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=@android.com header.s=20161025 header.b=rydZ5Woj; 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=android.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S932087AbeDYP4Q (ORCPT + 99 others); Wed, 25 Apr 2018 11:56:16 -0400 Received: from mail-vk0-f68.google.com ([209.85.213.68]:41849 "EHLO mail-vk0-f68.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1755510AbeDYP4K (ORCPT ); Wed, 25 Apr 2018 11:56:10 -0400 Received: by mail-vk0-f68.google.com with SMTP id 131so9354384vkf.8 for ; Wed, 25 Apr 2018 08:56:10 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=android.com; s=20161025; h=mime-version:in-reply-to:references:from:date:message-id:subject:to :cc; bh=3+FdJP1qLXrXsMILF6YY4ciuj+34BbYQhRH801gUGwA=; b=rydZ5WojFKsP/WQFverfp2ihsqzlejLGu4dV3MYKPJBvlrt6E8ZwmdInt0ledeH6fr 3HBh96om1xTNrYHjeb0WLOHixhGuFzASDhymBxCOIcEcg8su+ulVpjvrI6YESNy/mi3Z 9VW0qsVIe4weFp1JayZhd12dQtnbzYvs58rDNE/O91CLzULSojknYjdb+OPXtWnyPSqA Y7GoiNMo6oGzIqtBhqGTgTV7td/GgdBw6wFHnCENl6SLrQZ2HhVud9hu2tOsbWQzUY1/ qc/gv+7ITf9FPRtEgcYOpzvHuJU2pCark0BC76gl5HQjXUlDfvyu/PA2u0uF7mDoD/TM 9uJQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:in-reply-to:references:from:date :message-id:subject:to:cc; bh=3+FdJP1qLXrXsMILF6YY4ciuj+34BbYQhRH801gUGwA=; b=JvlDtsnjOnKusuRi7WnOlnPlK8vIor4jN3buBHuJhu0BspP8M0+lXG2mONmsjsko/m 08I9g84XFKuh7FF3Wpb+5qwrVQrsihIldSYcBg6/E8bkluUiq9inTwkOvE3OXU8Abiad RU6awFbZ3DkvW/tOuYrfiYuiFQAii/cwI9BQzFIMFcDdKE/Z7K1UQYnDH0prWFYw6J0z M7sox4pP7ZYMIUMW9P6m/9uhTSlCuAo/UjfsVHbwDLznQVlfFfdv5syILAmnadplsCbj zCJG3Goy/VOMIrPkQQaEd/WwkvgGCRLPMSIYYDQj6IxzT7ikdtO/O3v+ju9CTTwMi8Fd LRfg== X-Gm-Message-State: ALQs6tAxjXr8KXYBdsGvo6pJNIt+DhlFP0rsR02yNoRB673l/LrP/GUx 5+KAN2YKZ5HLBgwYn5hJdWqEw1xupPWDzCbDjHfCbQ== X-Received: by 10.31.52.203 with SMTP id b194mr21792769vka.100.1524671769892; Wed, 25 Apr 2018 08:56:09 -0700 (PDT) MIME-Version: 1.0 Received: by 10.103.56.8 with HTTP; Wed, 25 Apr 2018 08:56:09 -0700 (PDT) In-Reply-To: <1523366506-19832-3-git-send-email-geert+renesas@glider.be> References: <1523366506-19832-1-git-send-email-geert+renesas@glider.be> <1523366506-19832-3-git-send-email-geert+renesas@glider.be> From: Todd Kjos Date: Wed, 25 Apr 2018 08:56:09 -0700 Message-ID: Subject: Re: [PATCH v2 2/4] ARM: amba: Fix race condition with driver_override To: Geert Uytterhoeven Cc: Greg Kroah-Hartman , Russell King , Adrian Salido , Nicolai Stange , Sasha Levin , LKML Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Reviewed-by: Todd Kjos On Tue, Apr 10, 2018 at 6:21 AM, Geert Uytterhoeven wrote: > The driver_override implementation is susceptible to a race condition > when different threads are reading vs storing a different driver > override. Add locking to avoid this race condition. > > Cfr. commits 6265539776a0810b ("driver core: platform: fix race > condition with driver_override") and 9561475db680f714 ("PCI: Fix race > condition with driver_override"). > > Fixes: 3cf385713460eb2b ("ARM: 8256/1: driver coamba: add device binding path 'driver_override'") > Signed-off-by: Geert Uytterhoeven > --- > drivers/amba/bus.c | 11 +++++++++-- > 1 file changed, 9 insertions(+), 2 deletions(-) > > diff --git a/drivers/amba/bus.c b/drivers/amba/bus.c > index 6ffd778352e6d953..36c5653ced5742b7 100644 > --- a/drivers/amba/bus.c > +++ b/drivers/amba/bus.c > @@ -69,8 +69,12 @@ static ssize_t driver_override_show(struct device *_dev, > struct device_attribute *attr, char *buf) > { > struct amba_device *dev = to_amba_device(_dev); > + ssize_t len; > > - return sprintf(buf, "%s\n", dev->driver_override); > + device_lock(_dev); > + len = sprintf(buf, "%s\n", dev->driver_override); > + device_unlock(_dev); > + return len; > } > > static ssize_t driver_override_store(struct device *_dev, > @@ -78,7 +82,7 @@ static ssize_t driver_override_store(struct device *_dev, > const char *buf, size_t count) > { > struct amba_device *dev = to_amba_device(_dev); > - char *driver_override, *old = dev->driver_override, *cp; > + char *driver_override, *old, *cp; > > if (count > PATH_MAX) > return -EINVAL; > @@ -91,12 +95,15 @@ static ssize_t driver_override_store(struct device *_dev, > if (cp) > *cp = '\0'; > > + device_lock(_dev); > + old = dev->driver_override; > if (strlen(driver_override)) { > dev->driver_override = driver_override; > } else { > kfree(driver_override); > dev->driver_override = NULL; > } > + device_unlock(_dev); > > kfree(old); > > -- > 2.7.4 >