Received: by 2002:a25:c205:0:0:0:0:0 with SMTP id s5csp56607ybf; Thu, 27 Feb 2020 16:00:27 -0800 (PST) X-Google-Smtp-Source: APXvYqz+5208tY4WQnHaNIyZTX9+h2xygMD0Bn6kR0rqMXMPZSheU0K8ltJeM4NX8B/nF85QwI7D X-Received: by 2002:a9d:6b06:: with SMTP id g6mr1144141otp.93.1582848027604; Thu, 27 Feb 2020 16:00:27 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1582848027; cv=none; d=google.com; s=arc-20160816; b=PE4OwvJrs4G8MkV6HaJuYiWB55R/4clEo0HoMZCGAEu1VzGGkYlt3haohXVjbbHYWT HWHkqTNKQWzmaJ1x75WgqufXmLJieqRMR41IZcEpL+3/tXjBQSWMNCYJuMospoWpv9nP ddilXJXI/JDA4beCQhHppeQ+Q6sydNMtBaIHhQdpXOMFS2lez6hsNPBXAF7PczmeIQqD 9KmiDUN25KBxsz34fiBQsWDaOzwM/0N1a2AHA7uxxYbrm+GzIp3ImaF+aOcxqNhZz6GV vvH7ppfE9WgENC2HAyf2nkavU6Fx1+rTUlB7+FgAC+hUmP8487ZLyzJsg3NkML95YoCu 5u0g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:from:subject:mime-version :message-id:date:dkim-signature; bh=UnGEUXFlTBCBPshIVdS6XExVwEXBFybs+wps5bqBFfU=; b=pwCyWuyE7l3NuhqCiCh8Q1+g1K4A9/ZfpLj5h/TFTBDhpFrE0jDYjpifI/Y1kfkzDU tMiQ5a/7MFNn24dGj4nYF6P5q6CBdHjFxF/yHlkAaQBFf+KK/a9rOJfgjqd6a50nQS4c AzDXn1W4tOuS5hk9VEKHMwDqmEOsorcJQkaeTQrjYQat3UuHPzv6ksRfjjk6TgGskplQ ZeSPiiRUck9Skbj93mgRMtDP526OeeO80LlTMCKhAZD8Zn6pLkc1dSu6zR4nK8/P2F76 6Ftf7zc4YefRqXK3X/fYCfgq8/O9Q/+84ofIZKPnItUekVghjaETlDjxanSP+JiGpSI+ 6mbg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=ZqA9ZpZ5; 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=google.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id l13si494333otq.30.2020.02.27.16.00.14; Thu, 27 Feb 2020 16:00:27 -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=@google.com header.s=20161025 header.b=ZqA9ZpZ5; 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=google.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729930AbgB1AAJ (ORCPT + 99 others); Thu, 27 Feb 2020 19:00:09 -0500 Received: from mail-qk1-f202.google.com ([209.85.222.202]:43897 "EHLO mail-qk1-f202.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728993AbgB1AAJ (ORCPT ); Thu, 27 Feb 2020 19:00:09 -0500 Received: by mail-qk1-f202.google.com with SMTP id k194so1203575qke.10 for ; Thu, 27 Feb 2020 16:00:08 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20161025; h=date:message-id:mime-version:subject:from:to:cc; bh=UnGEUXFlTBCBPshIVdS6XExVwEXBFybs+wps5bqBFfU=; b=ZqA9ZpZ5GnZovgjwmeGhGPDca2UmvTs4hRN0ST7NikKc3qUD+KGMpwtKGyW5QGxv1A lMgbp0lPx36sq+iGlJCBX+ZgfX/+pQ71BCHn95YwwY8PkFF9+SgDGCV9GpWCLzMVxm3X 9s1drcGlA1wahwzNdlnI06QggAm/iY30ymefmOZ0pe7tM8TZ0kjKkaJaCVmpCpCINUWR rKiPs9QLiVGoq78pNXfAit5PURw9miOeDwuG4eaepkqq0sL2WPdjpwWHjl0Uj1GOKzvl kOszvSTFEstsDOVZytiBj2/q+bJe0iTFKwN2619P4qYhXPRu/a1GMVTv/RKcJn5WVdGd xlDQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:message-id:mime-version:subject:from:to:cc; bh=UnGEUXFlTBCBPshIVdS6XExVwEXBFybs+wps5bqBFfU=; b=Z7JmRJgM5/tUJL8IsaQ6eHxsofWlrOu7GiVnAJeqxFBkR21UxZy0MpYCNLyAhifRD2 k3oEp5bGaIf6GqjTs1lZBEVDMMyYRgc8ByklOsSKpTmALcxmGzgr5FvF/Zt4maZkuzIi 8CpDBM+q+5jCwtXmWa3TfsyyglpzjluHIoI3KuhmuxpOgocQg3yIIgXUq8c+yottpmEi yjofSChQRuDcBf7hY5DE3MdVPahYcCCdAjXIPCsMHyxBwRTOMY7IX69AVfHggYtw/Qfm 3TUcEmnl37Yuu/QHbLQ92xvZdrau61jbsQYeknQ5b0g1G8DILKZyggEr89/Vrgw/4rKi u3mA== X-Gm-Message-State: APjAAAXvV9kUs6HrQ3ImvPnJmdtOMKw/o2LogO/o1Y3jxkCJeM05ZJNT bF/XrpBECUtedaXBCLhTlrtvVugDioWBmwF3LvasBA== X-Received: by 2002:a37:4f51:: with SMTP id d78mr2117183qkb.28.1582848007962; Thu, 27 Feb 2020 16:00:07 -0800 (PST) Date: Thu, 27 Feb 2020 16:00:01 -0800 Message-Id: <20200228000001.240428-1-brendanhiggins@google.com> Mime-Version: 1.0 X-Mailer: git-send-email 2.25.1.481.gfbce0eb801-goog Subject: [PATCH v1] Revert "software node: Simplify software_node_release() function" From: Brendan Higgins To: gregkh@linuxfoundation.org, rafael@kernel.org Cc: linux-kernel@vger.kernel.org, davidgow@google.com, Brendan Higgins , Heidi Fahim , Heikki Krogerus , Hans de Goede , "Rafael J . Wysocki" 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 This reverts commit 3df85a1ae51f6b256982fe9d17c2dc5bfb4cc402. The reverted commit says "It's possible to release the node ID immediately when fwnode_remove_software_node() is called, no need to wait for software_node_release() with that." However, releasing the node ID before waiting for software_node_release() to be called causes the node ID to be released before the kobject and the underlying sysfs entry; this means there is a period of time where a sysfs entry exists that is associated with an unallocated node ID. Once consequence of this is that there is a race condition where it is possible to call fwnode_create_software_node() with no parent node specified (NULL) and have it fail with -EEXIST because the node ID that was assigned is still associated with a stale sysfs entry that hasn't been cleaned up yet. Although it is difficult to reproduce this race condition under normal conditions, it can be deterministically reproduced with the following minconfig on UML: CONFIG_KUNIT_DRIVER_PE_TEST=y CONFIG_DEBUG_KERNEL=y CONFIG_DEBUG_OBJECTS=y CONFIG_DEBUG_OBJECTS_TIMERS=y CONFIG_DEBUG_KOBJECT_RELEASE=y CONFIG_KUNIT=y Running the tests with this configuration causes the following failure: kobject: 'node0' ((____ptrval____)): kobject_release, parent (____ptrval____) (delayed 400) ok 1 - pe_test_uints sysfs: cannot create duplicate filename '/kernel/software_nodes/node0' CPU: 0 PID: 28 Comm: kunit_try_catch Not tainted 5.6.0-rc3-next-20200227 #14 kobject_add_internal failed for node0 with -EEXIST, don't try to register things with the same name in the same directory. kobject: 'node0' ((____ptrval____)): kobject_release, parent (____ptrval____) (delayed 100) # pe_test_uint_arrays: ASSERTION FAILED at drivers/base/test/property-entry-test.c:123 Expected node is not error, but is: -17 not ok 2 - pe_test_uint_arrays Reported-by: Heidi Fahim Signed-off-by: Brendan Higgins Cc: Heikki Krogerus Cc: Hans de Goede Cc: Rafael J. Wysocki --- drivers/base/swnode.c | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/drivers/base/swnode.c b/drivers/base/swnode.c index 0b081dee1e95c..de8d3543e8fe3 100644 --- a/drivers/base/swnode.c +++ b/drivers/base/swnode.c @@ -608,6 +608,13 @@ static void software_node_release(struct kobject *kobj) { struct swnode *swnode = kobj_to_swnode(kobj); + if (swnode->parent) { + ida_simple_remove(&swnode->parent->child_ids, swnode->id); + list_del(&swnode->entry); + } else { + ida_simple_remove(&swnode_root_ids, swnode->id); + } + if (swnode->allocated) { property_entries_free(swnode->node->properties); kfree(swnode->node); @@ -773,13 +780,6 @@ void fwnode_remove_software_node(struct fwnode_handle *fwnode) if (!swnode) return; - if (swnode->parent) { - ida_simple_remove(&swnode->parent->child_ids, swnode->id); - list_del(&swnode->entry); - } else { - ida_simple_remove(&swnode_root_ids, swnode->id); - } - kobject_put(&swnode->kobj); } EXPORT_SYMBOL_GPL(fwnode_remove_software_node); -- 2.25.1.481.gfbce0eb801-goog