Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp921563pxb; Tue, 9 Feb 2021 16:46:31 -0800 (PST) X-Google-Smtp-Source: ABdhPJwoU4e/pV7HtjlVaFplmpCNVzU/tQbVRRk4GDNTM+oITlhQn7bQYooH1rf5wVR3GVV+rrdb X-Received: by 2002:a17:906:c413:: with SMTP id u19mr351745ejz.147.1612917991519; Tue, 09 Feb 2021 16:46:31 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1612917991; cv=none; d=google.com; s=arc-20160816; b=v/oA6Qv7qWVz3sV5JHIy2K+bvdS5LXE77/niaU/ZkOa58o+FDF6LjP+Tdr7UUmjUIX xMord5HHXDyabEn1IiV+DLogLqLxs3ZagiXJgbveWbgaDIP8Ya9eycivDA0c06U9/Cpo 37K92LtXjWDzqpRtocKPL2kMIdFsQ3PkZLN+veSMApOM+4/h1vmGzTp/GKVlWRLErU/U N/VJNet8n92MIixQu1aJJfQ5/yc5pACdV/NxsjEvZM1Fz9rEkdPbD8LD0dQUtgrs9zJ3 zxn/4raaThMAwmLWOXRKjBhef83cQr4I0dKFhTKP3mRfhRIS3W7g/dT1VRrTD1tq+S1V yGsg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=/b1pq71warZLMI2oEgNGwKzGLH0EOvUgdq9nRsXw6vQ=; b=KK4oBOMSu1nI0fNTZCeQxOByV8db9MDq0ZKAm2Ro8YPChSIiwFMJlZaAAIK/Tw+qKm FyX2B2RZ69X+bd9iN8jwLhCbIyzZbj6mqMrncBAoutARPlPy/7Hj9QTr8ns1pQ1Pq2QW 0LiCBgfOpuidCgY6BX4ENuZ0bChmFO+qqOEL1J86flVRWjC6KDGVHd4lpgAhcnJHtxLZ L3lmBzhbiyDpBtGV42xZOP0kPZcN8ViSpx7JYocAVi9EgwmYrbI3bNGxLUEJ5suCt/84 u+89eaJHdStdocc29yOhb4mmAoOFVLbhMIWIY12L4/fDnOfUCUqYqVOnpbDBaLTYsqPu pB1w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=WDknU+XK; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id v12si178899ejb.566.2021.02.09.16.46.08; Tue, 09 Feb 2021 16:46:31 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=WDknU+XK; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233994AbhBJAmL (ORCPT + 99 others); Tue, 9 Feb 2021 19:42:11 -0500 Received: from mail.kernel.org ([198.145.29.99]:45738 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233954AbhBIVHv (ORCPT ); Tue, 9 Feb 2021 16:07:51 -0500 Received: by mail.kernel.org (Postfix) with ESMTPSA id 3A06F64EC5; Tue, 9 Feb 2021 19:14:27 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1612898067; bh=yAyfaqHOOoS3R3ANty1E7nUADcg6ondxQvzykZeBYKU=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=WDknU+XKb8Qc0LPzkWkZCNGotV3bBcB5QvrxbYmSON5THjTYIwGlVNbo8TvnEAMi8 0rlCHH7URvfgJvNx0TuWi6ZpYW9mucKCNC7+CaDgxbs3SNNLJvIYiX7yCxFU46nARS kPQexvAtvJvXLKs5PZks3a2lXM+8BoZ1CfNpmykg= Date: Tue, 9 Feb 2021 20:14:25 +0100 From: Greg KH To: Dave Jiang Cc: Jacob Pan , Dave Ertman , Dan Williams , rafael@kernel.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH] driver core: auxiliary bus: Fix calling stage for auxiliary bus init Message-ID: References: <161289750572.1086235.9903492973331406876.stgit@djiang5-desk3.ch.intel.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <161289750572.1086235.9903492973331406876.stgit@djiang5-desk3.ch.intel.com> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, Feb 09, 2021 at 12:05:05PM -0700, Dave Jiang wrote: > When the auxiliary device code is built into the kernel, it can be executed > before the auxiliary bus is registered. This causes bus->p to be not > allocated and triggers a NULL pointer dereference when the auxiliary bus > device gets added with bus_add_device(). Change the init of auxiliary bus > to subsys_initcall() from module_init() to ensure the bus is registered > before devices. > > Below is the kernel splat for the bug: > [ 1.948215] BUG: kernel NULL pointer dereference, address: 0000000000000060 > [ 1.950670] #PF: supervisor read access in kernel mode > [ 1.950670] #PF: error_code(0x0000) - not-present page > [ 1.950670] PGD 0 > [ 1.950670] Oops: 0000 1 SMP NOPTI > [ 1.950670] CPU: 0 PID: 1 Comm: swapper/0 Not tainted 5.10.0-intel-nextsvmtest+ #2205 > [ 1.950670] Hardware name: QEMU Standard PC (Q35 + ICH9, 2009), BIOS rel-1.14.0-0-g155821a1990b-prebuilt.qemu.org 04/01/2014 > [ 1.950670] RIP: 0010:bus_add_device+0x64/0x140 > [ 1.950670] Code: 00 49 8b 75 20 48 89 df e8 59 a1 ff ff 41 89 c4 85 c0 75 7b 48 8b 53 50 48 85 d2 75 03 48 8b 13 49 8b 85 a0 00 00 00 48 89 de <48> 8 > 78 60 48 83 c7 18 e8 ef d9 a9 ff 41 89 c4 85 c0 75 45 48 8b > [ 1.950670] RSP: 0000:ff46032ac001baf8 EFLAGS: 00010246 > [ 1.950670] RAX: 0000000000000000 RBX: ff4597f7414aa680 RCX: 0000000000000000 > [ 1.950670] RDX: ff4597f74142bbc0 RSI: ff4597f7414aa680 RDI: ff4597f7414aa680 > [ 1.950670] RBP: ff46032ac001bb10 R08: 0000000000000044 R09: 0000000000000228 > [ 1.950670] R10: ff4597f741141b30 R11: ff4597f740182a90 R12: 0000000000000000 > [ 1.950670] R13: ffffffffa5e936c0 R14: 0000000000000000 R15: 0000000000000000 > [ 1.950670] FS: 0000000000000000(0000) GS:ff4597f7bba00000(0000) knlGS:0000000000000000 > [ 1.950670] CS: 0010 DS: 0000 ES: 0000 CR0: 0000000080050033 > [ 1.950670] CR2: 0000000000000060 CR3: 000000002140c001 CR4: 0000000000f71ef0 > [ 1.950670] DR0: 0000000000000000 DR1: 0000000000000000 DR2: 0000000000000000 > [ 1.950670] DR3: 0000000000000000 DR6: 00000000fffe07f0 DR7: 0000000000000400 > [ 1.950670] PKRU: 55555554 > [ 1.950670] Call Trace: > [ 1.950670] device_add+0x3ee/0x850 > [ 1.950670] __auxiliary_device_add+0x47/0x60 > [ 1.950670] idxd_pci_probe+0xf77/0x1180 > [ 1.950670] local_pci_probe+0x4a/0x90 > [ 1.950670] pci_device_probe+0xff/0x1b0 > [ 1.950670] really_probe+0x1cf/0x440 > [ 1.950670] ? rdinit_setup+0x31/0x31 > [ 1.950670] driver_probe_device+0xe8/0x150 > [ 1.950670] device_driver_attach+0x58/0x60 > [ 1.950670] __driver_attach+0x8f/0x150 > [ 1.950670] ? device_driver_attach+0x60/0x60 > [ 1.950670] ? device_driver_attach+0x60/0x60 > [ 1.950670] bus_for_each_dev+0x79/0xc0 > [ 1.950670] ? kmem_cache_alloc_trace+0x323/0x430 > [ 1.950670] driver_attach+0x1e/0x20 > [ 1.950670] bus_add_driver+0x154/0x1f0 > [ 1.950670] driver_register+0x70/0xc0 > [ 1.950670] __pci_register_driver+0x54/0x60 > [ 1.950670] idxd_init_module+0xe2/0xfc > [ 1.950670] ? idma64_platform_driver_init+0x19/0x19 > [ 1.950670] do_one_initcall+0x4a/0x1e0 > [ 1.950670] kernel_init_freeable+0x1fc/0x25c > [ 1.950670] ? rest_init+0xba/0xba > [ 1.950670] kernel_init+0xe/0x116 > [ 1.950670] ret_from_fork+0x1f/0x30 > [ 1.950670] Modules linked in: > [ 1.950670] CR2: 0000000000000060 > [ 1.950670] --[ end trace cd7d1b226d3ca901 ]-- > > Fixes: 7de3697e9cbd ("Add auxiliary bus support") > Reported-by: Jacob Pan > Acked-by: Dave Ertman > Reviewed-by: Dan Williams > Signed-off-by: Dave Jiang > --- > drivers/base/auxiliary.c | 2 +- > 1 file changed, 1 insertion(+), 1 deletion(-) > > diff --git a/drivers/base/auxiliary.c b/drivers/base/auxiliary.c > index 8336535f1e11..53f93a506626 100644 > --- a/drivers/base/auxiliary.c > +++ b/drivers/base/auxiliary.c > @@ -270,7 +270,7 @@ static void __exit auxiliary_bus_exit(void) > bus_unregister(&auxiliary_bus_type); > } > > -module_init(auxiliary_bus_init); > +subsys_initcall(auxiliary_bus_init); Ah, the linker priority dance. Are you _SURE_ this will solve this? Why not just call this explicitly in driver_init() so that you know it will be ok? Just like we do for the platform bus? thanks, greg k-h