Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp1372764imu; Fri, 21 Dec 2018 19:01:56 -0800 (PST) X-Google-Smtp-Source: ALg8bN7gyERo2+WnyIpXBmeA6Thztg0fN7R+7ck8frTXi3LcPRVwBwxp9TwTnRQ/wOsDP3cz2gkM X-Received: by 2002:a17:902:2c03:: with SMTP id m3mr5170060plb.125.1545447716457; Fri, 21 Dec 2018 19:01:56 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1545447716; cv=none; d=google.com; s=arc-20160816; b=IWK/WPrWzFAkk3Or34wIRu+2zCvYsQBt5YKCLFyWDE6EI79/TMYHyy3nvjsg8w+NMN oXZazzi5IrVKye9DRskrUdJkUSd6LwNt8rEb0oksQUr1pfagAJVjTQnyUuQdpf5lLH4/ j7r/h+373NoK4J65T7XZQ7K/9/ZWEJvnKYB1kpOivVPntq90kM1fzv771RAUK2gvSXv9 PTMbAn61XxobXumkVU0a/JhzUHiSvZ9BjG8v3M+k2mXEo5EUeXGRMMKyuTvICrJX0qKw 7LCnJGhYLydiWirn2AsZwBjqLSrhAjvIbZaIwIb56XoFJdjMP2xQWXdoYMtUvmYRmUPM BSqg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date; bh=UcmfGNB1v17BUGleGedbUJFpr9Nac0nnerxAN3NEFAM=; b=MYiKQwZrXCsGsntyj+OwsO1qERpaCW/LOTSABO9262zh4+uMmIFeTWWCG9y1yQOlMN ZH2VJ5kh2XDqCZ0ehLIGSloywwp6fmTMDQwJyaPRAQ6QIiMDYWxMZyi3HG7IWYs/Mr7J HG03fUrT1taisJ190dmNJ6SxwTNMYZMD2CV4oMaDS7Gr81BA/F/ouA+HdrOE3AIfAal+ i53F0WfcHSn4c7C3KpPBfC536GwlmjS1t7ZxGbw2p/yh7OWeJZrS6i/ju2WPdMGtVG6a vBUfjE7UhjQsbw3zYWcVAWsy1T2RR44VUhd3PKnWQacPoHJ/DiFXlX8XaN7oOo74FJz2 yMeA== ARC-Authentication-Results: i=1; mx.google.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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id x23si21927780pln.100.2018.12.21.19.01.41; Fri, 21 Dec 2018 19:01:56 -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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1733006AbeLUPz1 (ORCPT + 99 others); Fri, 21 Dec 2018 10:55:27 -0500 Received: from mail1.windriver.com ([147.11.146.13]:65529 "EHLO mail1.windriver.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725790AbeLUPz0 (ORCPT ); Fri, 21 Dec 2018 10:55:26 -0500 Received: from ALA-HCB.corp.ad.wrs.com ([147.11.189.41]) by mail1.windriver.com (8.15.2/8.15.1) with ESMTPS id wBLFtHbh012544 (version=TLSv1 cipher=AES128-SHA bits=128 verify=FAIL); Fri, 21 Dec 2018 07:55:18 -0800 (PST) Received: from yow-pgortmak-d1.corp.ad.wrs.com (128.224.56.57) by ALA-HCB.corp.ad.wrs.com (147.11.189.41) with Microsoft SMTP Server id 14.3.408.0; Fri, 21 Dec 2018 07:55:17 -0800 Received: by yow-pgortmak-d1.corp.ad.wrs.com (Postfix, from userid 1000) id 0F4072E07C2; Fri, 21 Dec 2018 10:55:16 -0500 (EST) Date: Fri, 21 Dec 2018 10:55:16 -0500 From: Paul Gortmaker To: Charles Keepax CC: Lee Jones , , Mark Brown , , Linus Walleij Subject: Re: [PATCH 18/18] mfd: wm8400-core: Make it explicitly non-modular Message-ID: <20181221155516.GP4292@windriver.com> References: <1545078688-21217-1-git-send-email-paul.gortmaker@windriver.com> <1545078688-21217-19-git-send-email-paul.gortmaker@windriver.com> <20181219091742.GA16508@imbe.wolfsonmicro.main> MIME-Version: 1.0 Content-Type: text/plain; charset="us-ascii" Content-Disposition: inline In-Reply-To: <20181219091742.GA16508@imbe.wolfsonmicro.main> User-Agent: Mutt/1.5.24 (2015-08-30) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org [Re: [PATCH 18/18] mfd: wm8400-core: Make it explicitly non-modular] On 19/12/2018 (Wed 09:17) Charles Keepax wrote: > On Mon, Dec 17, 2018 at 03:31:28PM -0500, Paul Gortmaker wrote: > > The Kconfig currently controlling compilation of this code is: > > > > drivers/mfd/Kconfig:config MFD_WM8400 > > drivers/mfd/Kconfig: bool "Wolfson Microelectronics WM8400" > > > > ...meaning that it currently is not being built as a module by anyone. > > > > Lets remove the modular code that is essentially orphaned, so that > > when reading the driver there is no doubt it is builtin-only. > > > > Since module_init was not in use by this code, the init ordering > > remains unchanged with this commit. > > > > A trivial function rename from wm8400_module_init to the name > > wm8400_driver_init is also done to reduce possible confusion. > > > > Also note that MODULE_DEVICE_TABLE is a no-op for non-modular code. > > > > We also delete the MODULE_LICENSE tag etc. since all that information > > is already contained at the top of the file in the comments. > > > > Cc: Lee Jones > > Cc: Mark Brown > > Cc: patches@opensource.cirrus.com > > Signed-off-by: Paul Gortmaker > > Acked-by: Linus Walleij > > --- > > -MODULE_DEVICE_TABLE(i2c, wm8400_i2c_id); > > > > static struct i2c_driver wm8400_i2c_driver = { > > .driver = { > > @@ -161,7 +160,7 @@ static struct i2c_driver wm8400_i2c_driver = { > > }; > > #endif > > Do we not want to add suppress_bind_attrs into the i2c_driver > struct here? We can add one if you/maintainers want one, but if you look at the original patch, this driver was using the more classic/legacy case of subsys_init() vs. platform_driver_register() used in other drivers. Not adding a suppress_bind_attrs here was intentional, since I'd decided to put in the unbind entries for code that used platform_driver_register() where the author had created the .remove code, on the assumption that they had put some thought into the process of unbind/remove - to make it explicit that unbind is now disabled. To be clear, using the subsys_init() doesn't implicitly disable unbind. However, there are lots of non-modular drivers out there; ones I've not even touched, and to start a project to add an unbind disable to them all is beyond the scope of the goals I've listed in the 00/18 preamble. I'd hope maybe we can revisit the global default setting for non-modular code someday - to make non-modules opt-in instead of opt-out, and achieve better consistency from one driver to the next, without having to add a new .driver sub-struct to each file for the suppress entry. I think LinusW hinted at in an earlier email in this ongoing review, that the default setting didn't quite make sense to him either. But in any case, that is a separate discussion for another time and place. Let me know if you explicitly want one added, otherwise I'll just leave the .remove + .suppress_bind_attrs pairing as described above. Thanks, Paul. -- > > Thanks, Charles