Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp2731818ybt; Mon, 22 Jun 2020 05:47:32 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxvzVxEB16JTzfNJz/iOJtLSXv6xwBik9IIE06HeD1P6aQv26z2HEDj2oLIJTM44jz98oNN X-Received: by 2002:a50:e08c:: with SMTP id f12mr16700793edl.233.1592830052223; Mon, 22 Jun 2020 05:47:32 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1592830052; cv=none; d=google.com; s=arc-20160816; b=spX2WXWQAiDiRFXCEyeIxiGRqfbUWlFFbJlc5sf0XH2t8r8zNDCOW3Gxj3NTOeS2+D j7e22Sinszpg2NK6hS4ppiQSVA7M2iZNlc8faM1vnTOv9LiC6uFVnHF2qCYKMovF3XXx aDQsYRoxiWu9myu1xDkcN+MjwDaiGV2Ko7R8+oJRunB6b4qr8+gWjNNz6tpd8rCM/JUs wZfB8ViTrNe3jLU0j9jDGmnzM0BFVW5x6rHjRR+r2xDPMpCYmPAPNL+T1Z/jsPZXmw2E 2vI2Wd/KYA6rCYILxjA3pCaZcS5Xw0mI/BQX6GBLS2RU7i120jiy7I/EdwDZLaG6GCoG qPAQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:references:cc:to:from:subject:dkim-signature; bh=mu6VeqCASEiuhRz0q1C6CUsALhu2QbWsAKX0g1pGGUU=; b=0xX0u3tzoZwaMIW4uuCh4wbnovfx5JddFiUVG3eCRDO5Y2S4P9/Ev65RGqcOYUKgb3 EkArJPs7VKMckHULijGFj+CIcXShQIi0L6YQRf6miVI2UZh/KdxNb6p1soQdOxR4nap2 izO9CCmgIXbySZfosWnf68zZkYfMqMrI/fZEAbN/iBgHtkG0e+LJNHsoAaJnzFzM8WZm Qsgo3bdL2h8wQzeSMJwLNrvw54SaFCYFVoICe2Ty++2H0WsmdVYHgQhS6VaWxb69KH8U wAf1x2kOCId+uyiN+eTr8VUq+z1PMd5cCGbntDTtL7DpHPB7L45dNElStX5J8cTVACLk dtQg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=jvZM8CIu; 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=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id h19si9237058edq.313.2020.06.22.05.47.08; Mon, 22 Jun 2020 05:47:32 -0700 (PDT) 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=@gmail.com header.s=20161025 header.b=jvZM8CIu; 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=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728002AbgFVMmS (ORCPT + 99 others); Mon, 22 Jun 2020 08:42:18 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:40498 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727865AbgFVMmR (ORCPT ); Mon, 22 Jun 2020 08:42:17 -0400 Received: from mail-ed1-x544.google.com (mail-ed1-x544.google.com [IPv6:2a00:1450:4864:20::544]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 1573FC061794; Mon, 22 Jun 2020 05:42:17 -0700 (PDT) Received: by mail-ed1-x544.google.com with SMTP id m21so13478990eds.13; Mon, 22 Jun 2020 05:42:17 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=subject:from:to:cc:references:message-id:date:user-agent :mime-version:in-reply-to:content-language:content-transfer-encoding; bh=mu6VeqCASEiuhRz0q1C6CUsALhu2QbWsAKX0g1pGGUU=; b=jvZM8CIuqTfTr4MeZm6B1/AEogjayZusgd+hj7/qJouomAjYB3w3DrtDzyAKVPIYg3 3p6mWhZaFR6e7FvOTdA3U3vaQnonCUUIGQOrkyFN8R6TuNVrJUDBvdVLYKOtOophsrhw tTNc/yOkawmCdm6Xq9Xk/adjXBZsf838sp6sYtay6OB6/5ixJqfGqaOS1YH6OKfFZPqq PM6Pd5cQZOQ2NcYPld+51Pht/9zFRIj0ATJXm6rrAf1pD/3vNo559mhA6jxVa3rd7Ndz aq6OmgkDGcB8h+0khpz5nNjhIYgrq5M2W0iFeO2R2x0FE30V34M7lPZe8YtafWhQm3hk whlw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:from:to:cc:references:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=mu6VeqCASEiuhRz0q1C6CUsALhu2QbWsAKX0g1pGGUU=; b=duINeSkjh7X56o78AqghEHjWNcfFapDwVDF3o8F80nZ/IxG1VAExaMGTmO6Y3UMcok Y1iZ/b3tt1EA1NrAPiJVNssdggAJZfzRdHuwso4DwZ5KO9LyoB754cLR2gPhRhCqQJLP 7CnPyFANrIzvO+LRawLfKafo+1AnxR/koeXT/WyiNNQAGiatDq02GesJDFe2+DDW1bXJ MVw4UAW3b7C/p4frLEuLk13bgeJypCAlDM8jPQE2Db+30ly73VE8zgghz5T9Z8OzqmGV mZLKJ10WfegfVsfNJEjik730IV6mYh9/3Ja3qHtXWvBdati2/jF5tcijsYcAxeTGvrgP F7Rw== X-Gm-Message-State: AOAM53277/R36RJ9PX+ld8KXgIxHifHO3DbQEin51IzVM0H5SrgZdgxd Mz4DXqqz+milS+TKFORdXKksiYlz X-Received: by 2002:a50:e047:: with SMTP id g7mr2599254edl.290.1592829735416; Mon, 22 Jun 2020 05:42:15 -0700 (PDT) Received: from ?IPv6:2a01:110f:b59:fd00:a1e8:1586:8683:3d86? ([2a01:110f:b59:fd00:a1e8:1586:8683:3d86]) by smtp.gmail.com with ESMTPSA id kt4sm2006231ejb.48.2020.06.22.05.42.13 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Mon, 22 Jun 2020 05:42:14 -0700 (PDT) Subject: Re: [RESEND PATCH v27 11/15] leds: lp55xx: Add multicolor framework support to lp55xx From: Jacek Anaszewski To: Dan Murphy , pavel@ucw.cz, robh@kernel.org Cc: kbuild-all@lists.01.org, devicetree@vger.kernel.org, linux-leds@vger.kernel.org, linux-kernel@vger.kernel.org References: <20200615201522.19677-12-dmurphy@ti.com> <202006180032.JW0i39C6%lkp@intel.com> <0a8a6f57-678d-b1b9-41e5-5e58c15cfe6b@ti.com> <58ad7723-131f-6930-00d7-1144c993110c@gmail.com> <56823113-4875-4813-8627-84b0d1792391@ti.com> <04473d1d-5cd8-7d1f-7c5d-8d8b582df464@ti.com> <1f5dd2f9-01c7-1f74-9b93-0ae2a6dac915@gmail.com> <69c01524-c4a4-55c8-578e-24b26bc863b8@ti.com> <52d2c06a-d4ab-b9b2-b1d3-d5f81780cd7f@gmail.com> Message-ID: <9a396176-c6e8-c403-df10-ee94ff5f0ebd@gmail.com> Date: Mon, 22 Jun 2020 14:42:11 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.9.0 MIME-Version: 1.0 In-Reply-To: <52d2c06a-d4ab-b9b2-b1d3-d5f81780cd7f@gmail.com> Content-Type: text/plain; charset=windows-1252; format=flowed Content-Language: en-US Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Dan, On 6/21/20 10:24 PM, Jacek Anaszewski wrote: > Dan, > > On 6/21/20 4:12 PM, Dan Murphy wrote: >> Jacek >> >> On 6/19/20 5:10 PM, Jacek Anaszewski wrote: >>> Dan, >>> >>> On 6/19/20 6:35 PM, Dan Murphy wrote: >>>> Jacek >>>> >>>> On 6/18/20 6:26 PM, Jacek Anaszewski wrote: >>>>> On 6/19/20 12:09 AM, Jacek Anaszewski wrote: >>>>>> Dan, >>>>>> >>>>>> On 6/18/20 11:44 PM, Dan Murphy wrote: >>>>>>> Jacek >>>>>>> >>>>>>> On 6/18/20 4:21 PM, Jacek Anaszewski wrote: >>>>>>>> Dan, >>>>>>>> >>>>>>>> On 6/18/20 12:33 AM, Dan Murphy wrote: >>>>>>>>> Jacek >>>>>>>>> >>>>>>>>> On 6/17/20 4:41 PM, Jacek Anaszewski wrote: >>>>>>>>>> Dan, >>>>>>>>>> >>>>>>>>>> On 6/17/20 9:22 PM, Dan Murphy wrote: >>>>>>>>>>> Pavel/Jacek >>>>>>>>>>> >>>>>>>>>>> On 6/17/20 11:28 AM, kernel test robot wrote: >>>>>>>>>>>> Hi Dan, >>>>>>>>>>>> >>>>>>>>>>>> I love your patch! Yet something to improve: >>>>>>>>>>>> >>>>>>>>>>>> [auto build test ERROR on pavel-linux-leds/for-next] >>>>>>>>>>>> [cannot apply to j.anaszewski-leds/for-next] >>>>>>>>>>>> [if your patch is applied to the wrong git tree, please drop >>>>>>>>>>>> us a note to help >>>>>>>>>>>> improve the system. BTW, we also suggest to use '--base' >>>>>>>>>>>> option to specify the >>>>>>>>>>>> base tree in git format-patch, please see >>>>>>>>>>>> https://stackoverflow.com/a/37406982] >>>>>>>>>>>> >>>>>>>>>>>> url: >>>>>>>>>>>> https://github.com/0day-ci/linux/commits/Dan-Murphy/Multicolor-Framework-v27/20200616-042217 >>>>>>>>>>>> >>>>>>>>>>>> base: >>>>>>>>>>>> git://git.kernel.org/pub/scm/linux/kernel/git/pavel/linux-leds.git >>>>>>>>>>>> for-next >>>>>>>>>>>> config: ia64-randconfig-r015-20200617 (attached as .config) >>>>>>>>>>>> compiler: ia64-linux-gcc (GCC) 9.3.0 >>>>>>>>>>>> reproduce (this is a W=1 build): >>>>>>>>>>>> ???????? wget >>>>>>>>>>>> https://raw.githubusercontent.com/intel/lkp-tests/master/sbin/make.cross >>>>>>>>>>>> -O ~/bin/make.cross >>>>>>>>>>>> ???????? chmod +x ~/bin/make.cross >>>>>>>>>>>> ???????? # save the attached .config to linux build tree >>>>>>>>>>>> ???????? COMPILER_INSTALL_PATH=$HOME/0day COMPILER=gcc-9.3.0 >>>>>>>>>>>> make.cross ARCH=ia64 >>>>>>>>>>>> >>>>>>>>>>>> If you fix the issue, kindly add following tag as appropriate >>>>>>>>>>>> Reported-by: kernel test robot >>>>>>>>>>>> >>>>>>>>>>>> All errors (new ones prefixed by >>, old ones prefixed by <<): >>>>>>>>>>>> >>>>>>>>>>>> ia64-linux-ld: drivers/leds/leds-lp55xx-common.o: in >>>>>>>>>>>> function `lp55xx_set_mc_brightness': >>>>>>>>>>>>>> drivers/leds/leds-lp55xx-common.c:146: undefined reference >>>>>>>>>>>>>> to `led_mc_calc_color_components' >>>>>>>>>>>> ia64-linux-ld: drivers/leds/leds-lp55xx-common.o: in >>>>>>>>>>>> function `devm_led_classdev_multicolor_register': >>>>>>>>>>>>>> include/linux/led-class-multicolor.h:74: undefined >>>>>>>>>>>>>> reference to `devm_led_classdev_multicolor_register_ext' >>>>>>>>>>>> vim +146 drivers/leds/leds-lp55xx-common.c >>>>>>>>>>>> >>>>>>>>>>>> ??? 138 >>>>>>>>>>>> ??? 139??? static int lp55xx_set_mc_brightness(struct >>>>>>>>>>>> led_classdev *cdev, >>>>>>>>>>>> ??? 140??????????????????????? enum led_brightness brightness) >>>>>>>>>>>> ??? 141??? { >>>>>>>>>>>> ??? 142??????? struct led_classdev_mc *mc_dev = >>>>>>>>>>>> lcdev_to_mccdev(cdev); >>>>>>>>>>>> ??? 143??????? struct lp55xx_led *led = >>>>>>>>>>>> mcled_cdev_to_led(mc_dev); >>>>>>>>>>>> ??? 144??????? struct lp55xx_device_config *cfg = >>>>>>>>>>>> led->chip->cfg; >>>>>>>>>>>> ??? 145 >>>>>>>>>>>> ? > 146 led_mc_calc_color_components(&led->mc_cdev, >>>>>>>>>>>> brightness); >>>>>>>>>>>> ??? 147??????? return cfg->multicolor_brightness_fn(led); >>>>>>>>>>>> ??? 148 >>>>>>>>>>> >>>>>>>>>>> Well this was a mess to figure out. >>>>>>>>>>> >>>>>>>>>>> The only fix I can figure out here is to remove the >>>>>>>>>>> >>>>>>>>>>> ???? depends on LEDS_CLASS_MULTI_COLOR || >>>>>>>>>>> !LEDS_CLASS_MULTI_COLOR >>>>>>>>>>> >>>>>>>>>>> from each child device and add >>>>>>>>>>> >>>>>>>>>>> ???? select LEDS_CLASS_MULTI_COLOR >>>>>>>>>>> >>>>>>>>>>> to the LP55XX_COMMON >>>>>>>>>>> >>>>>>>>>>> This way the Multi color framework will inherit the symbol >>>>>>>>>>> that was set by the COMMON flag which is inherited by >>>>>>>>>>> majority from the child flags. >>>>>>>>>> >>>>>>>>>> Did you try this? >>>>>>>>>> >>>>>>>>>> --- a/drivers/leds/Kconfig >>>>>>>>>> +++ b/drivers/leds/Kconfig >>>>>>>>>> @@ -398,6 +398,7 @@ config LEDS_LP50XX >>>>>>>>>> ?config LEDS_LP55XX_COMMON >>>>>>>>>> ??????? tristate "Common Driver for TI/National >>>>>>>>>> LP5521/5523/55231/5562/8501" >>>>>>>>>> ??????? depends on LEDS_LP5521 || LEDS_LP5523 || LEDS_LP5562 >>>>>>>>>> || LEDS_LP8501 >>>>>>>>>> +?????? depends on LEDS_CLASS_MULTI_COLOR || >>>>>>>>>> !LEDS_CLASS_MULTI_COLOR >>>>>>>>>> ??????? depends on OF >>>>>>>>>> ??????? select FW_LOADER >>>>>>>>>> ??????? select FW_LOADER_USER_HELPER >>>>>>>>>> >>>>>>>>>> >>>>>>>>> Yes I did >>>>>>>>> >>>>>>>>> That gave unmet dependencies. >>>>>>>>> >>>>>>>>> WARNING: unmet direct dependencies detected for LEDS_LP55XX_COMMON >>>>>>>>> ?? Depends on [m]: NEW_LEDS [=y] && (LEDS_LP5521 [=n] || >>>>>>>>> LEDS_LP5523 [=m] || LEDS_LP5562 [=y] || LEDS_LP8501 [=y]) && >>>>>>>>> (LEDS_CLASS_MULTI_COLOR [=m] || !LEDS_CLASS_MULTI_COLOR [=m]) >>>>>>>>> && OF [=y] >>>>>>>>> ?? Selected by [y]: >>>>>>>>> ?? - LEDS_LP5562 [=y] && NEW_LEDS [=y] && LEDS_CLASS [=y] && >>>>>>>>> I2C [=y] >>>>>>>>> ?? - LEDS_LP8501 [=y] && NEW_LEDS [=y] && LEDS_CLASS [=y] && >>>>>>>>> I2C [=y] >>>>>>>>> ?? Selected by [m]: >>>>>>>>> ?? - LEDS_LP5523 [=m] && NEW_LEDS [=y] && LEDS_CLASS [=y] && >>>>>>>>> I2C [=y] && (LEDS_CLASS_MULTI_COLOR [=m] || >>>>>>>>> !LEDS_CLASS_MULTI_COLOR [=m]) >>>>>>>>> >>>>>>>> >>>>>>>> When I was testing that yesterday I also had the same warning at >>>>>>>> some >>>>>>>> point of testing different Kconfig setups, but with what I >>>>>>>> showed above >>>>>>>> it ceased to appear. Now every time I am doing "make oldconfig" the >>>>>>>> CONFIG_LEDS_LP55XX_COMMON=y entry gets changed to =m with the >>>>>>>> config >>>>>>>> from the test bot. >>>>>>>> >>>>>>> That is not what I saw in my testing especially after doing a >>>>>>> distclean >>>>>> >>>>>> Could you please give your exact steps after "make distclean" and >>>>>> copying test bot config to the kernel root directory? >>>>>> >>>>>> Also, please share the toolchain you're using for tests. >>>>> >>>>> Actually at this stage the toolchain is of lesser relevance. >>>>> >>>>> I've tried once more and indeed the problem shows up. >>>>> >>>>> It is caused by the driver entries doing >>>>> >>>>> "select LEDS_LP55XX_COMMON". >>>>> >>>>> Select sets config to "y" so it conflicts with >>>>> "depends on LEDS_CLASS_MULTI_COLOR || !LEDS_CLASS_MULTI_COLOR" >>>>> in the "config LEDS_LP55XX_COMMON". >>>>> >>>>> Your proposed fix will block the possibility of building >>>>> LED_CLASS_MULTI_COLOR as a module when LP55XX drivers >>>>> are enabled so this is also not an option. >>>>> >>>>> Solving this riddle will require some more thinking. >>>>> I haven't analyzed it in detail but maybe "imply" statement from >>>>> kconfig-language.rst could help somehow here. >>>> >>>> The multicolor framework will build as a module if the LED_CLASS is >>>> defined as a module. >>>> >>>> See attached test_defconfig >>> >>> But it will be impossible to enable CONFIG_LEDS_LP50XX without >>> CONFIG_LEDS_CLASS_MULTI_COLOR if you will remove >>> >>> depends on LEDS_CLASS_MULTI_COLOR || !LEDS_CLASS_MULTI_COLOR. >>> >> I was not removing the dependency for the LP50xx only the LP55xx. > > It was my typo, I meant LP55XX. > >> >>> This is actually why the above entry was needed. >>> >>> LP55XX drivers have to work also without multicolor class. >>> >> Well I am not sure how else to resolve this problem.? Because the >> LP55xx has multi level dependencies. >> >> Only the LP55xx_common has the dependency on the MC framework. The >> device drivers do not. >> >> The issue is the mixing and matching of the MC fw as a module vs the >> LP55XX_COMMON as a built-in. > > The simplest solution is to avoid selecting LP55XX_COMMON in favor > of making child drivers depending on it. Of course, maybe there exists > some trickier option to keep the selection, but I would have to play > a bit more with it to be sure. Yep, this seems to be the only viable solution. My proposed change to the Kconfig: diff --git a/drivers/leds/Kconfig b/drivers/leds/Kconfig index adfa762cb291..10de7d237ffd 100644 --- a/drivers/leds/Kconfig +++ b/drivers/leds/Kconfig @@ -397,10 +397,10 @@ config LEDS_LP50XX config LEDS_LP55XX_COMMON tristate "Common Driver for TI/National LP5521/5523/55231/5562/8501" - depends on LEDS_LP5521 || LEDS_LP5523 || LEDS_LP5562 || LEDS_LP8501 depends on OF select FW_LOADER select FW_LOADER_USER_HELPER + depends on LEDS_CLASS_MULTI_COLOR || !LEDS_CLASS_MULTI_COLOR help This option supports common operations for LP5521/5523/55231/5562/8501 devices. @@ -408,8 +408,7 @@ config LEDS_LP55XX_COMMON config LEDS_LP5521 tristate "LED Support for N.S. LP5521 LED driver chip" depends on LEDS_CLASS && I2C - depends on LEDS_CLASS_MULTI_COLOR || !LEDS_CLASS_MULTI_COLOR - select LEDS_LP55XX_COMMON + depends on LEDS_LP55XX_COMMON help If you say yes here you get support for the National Semiconductor LP5521 LED driver. It is 3 channel chip with programmable engines. @@ -419,8 +418,7 @@ config LEDS_LP5521 config LEDS_LP5523 tristate "LED Support for TI/National LP5523/55231 LED driver chip" depends on LEDS_CLASS && I2C - depends on LEDS_CLASS_MULTI_COLOR || !LEDS_CLASS_MULTI_COLOR - select LEDS_LP55XX_COMMON + depends on LEDS_LP55XX_COMMON help If you say yes here you get support for TI/National Semiconductor LP5523/55231 LED driver. @@ -431,7 +429,7 @@ config LEDS_LP5523 config LEDS_LP5562 tristate "LED Support for TI LP5562 LED driver chip" depends on LEDS_CLASS && I2C - select LEDS_LP55XX_COMMON + depends on LEDS_LP55XX_COMMON help If you say yes here you get support for TI LP5562 LED driver. It is 4 channels chip with programmable engines. @@ -441,7 +439,7 @@ config LEDS_LP5562 config LEDS_LP8501 tristate "LED Support for TI LP8501 LED driver chip" depends on LEDS_CLASS && I2C - select LEDS_LP55XX_COMMON + depends on LEDS_LP55XX_COMMON help If you say yes here you get support for TI LP8501 LED driver. It is 9 channel chip with programmable engines. -- Best regards, Jacek Anaszewski