From: Lee Jones <lee.jones@linaro.org>
To: Hans de Goede <hdegoede@redhat.com>
Cc: Mauro Carvalho Chehab <mchehab+huawei@kernel.org>,
linuxarm@huawei.com, mauro.chehab@huawei.com,
linux-kernel@vger.kernel.org
Subject: Re: [PATCH] mfd: Kconfig: change INTEL_SOC_PMIC_CHTDC_TI to bool
Date: Mon, 29 Nov 2021 13:01:08 +0000 [thread overview]
Message-ID: <YaTPFEXmAEduJ916@google.com> (raw)
In-Reply-To: <ed1e0e2f-25a0-91a9-9f0b-a41b391ee869@redhat.com>
On Wed, 24 Nov 2021, Hans de Goede wrote:
> Hi,
>
> On 11/24/21 16:40, Lee Jones wrote:
> > On Fri, 29 Oct 2021, Mauro Carvalho Chehab wrote:
> >
> >> The INTEL_SOC_PMIC_CHTDC_TI should be initialized early, before
> >> loading the fbcon driver, as otherwise the i915 driver will
> >> fail to configure pwm:
> >>
> >> [ 13.674287] fb0: switching to inteldrmfb from EFI VGA
> >> [ 13.682380] Console: switching to colour dummy device 80x25
> >> [ 13.682468] i915 0000:00:02.0: vgaarb: deactivate vga console
> >> [ 13.682686] [drm] Supports vblank timestamp caching Rev 2 (21.10.2013).
> >> [ 13.685773] i915 0000:00:02.0: vgaarb: changed VGA decodes: olddecodes=io+mem,decodes=io+mem:owns=io+mem
> >> [ 13.686219] i915 0000:00:02.0: [drm] *ERROR* Failed to configure the pwm chip
> >> [ 13.699572] [drm] Initialized i915 1.6.0 20200313 for 0000:00:02.0 on minor 0
> >> [ 13.739044] fbcon: i915drmfb (fb0) is primary device
> >> [ 14.037792] intel_soc_pmic_exec_mipi_pmic_seq_element: No PMIC registered
> >> ...
> >> [ 24.621403] intel_pmic_install_opregion_handler: Ask to register OpRegion for bus ID=PMI2, HID=INT33F5
> >> [ 24.630540] intel_pmic_install_opregion_handler: OpRegion registered
> >>
> >> (some extra debug printk's were added to the above)
> >>
> >> As suggested by Hans, this patch also addresses an issue with
> >> the dependencies, as, for this driver to be a bool, it also
> >> need the I2C core and the I2C_DESIGNWARE driver to be builtin.
> >>
> >> Suggested-by: Hans de Goede <hdegoede@redhat.com>
> >> Signed-off-by: Mauro Carvalho Chehab <mchehab+huawei@kernel.org>
> >> ---
> >> drivers/mfd/Kconfig | 6 +++++-
> >> 1 file changed, 5 insertions(+), 1 deletion(-)
> >>
> >> diff --git a/drivers/mfd/Kconfig b/drivers/mfd/Kconfig
> >> index ca0edab91aeb..f9092c79c4e8 100644
> >> --- a/drivers/mfd/Kconfig
> >> +++ b/drivers/mfd/Kconfig
> >> @@ -632,7 +632,7 @@ config INTEL_SOC_PMIC_CHTWC
> >> config INTEL_SOC_PMIC_CHTDC_TI
> >> tristate "Support for Intel Cherry Trail Dollar Cove TI PMIC"
> >> depends on GPIOLIB
> >> - depends on I2C
> >> + depends on I2C = y && I2C_DESIGNWARE_PLATFORM=y
> >
> > The lack of formatting consistency here is eating me up inside!
> >
> >> depends on ACPI
> >> depends on X86
> >> select MFD_CORE
> >> @@ -642,6 +642,10 @@ config INTEL_SOC_PMIC_CHTDC_TI
> >> Select this option for supporting Dollar Cove (TI version) PMIC
> >> device that is found on some Intel Cherry Trail systems.
> >>
> >> + This option is a bool as it provides an ACPI OpRegion which must be
> >> + available before any devices using it are probed. This option also
> >> + needs the designware-i2c driver to be builtin for the same reason.
> >
> > Is there no way around this?
>
> No unfortunately not, the ACPI device-scan is done really early,
> and in ACPI everything is a function, including e.g. _HID,
> so I've seen _HID method-s reading e.g. GPIOs. So while the
> initial ACPI scan is figuring out what sort of devices it
> is dealing with, we already need working GPIOs (for example).
>
> Various early ACPI code (AML / the DSDT) tends to access the
> PMICs OpRegion and various problems happen when it is not
> available. For the same reason the other BYT/CHT related
> INTEL_SOC_PMIC_FOO options are already bools.
>
> I guess that the DSDTs for other Intel SoCs then the BYT/CHT
> SoCs might be a bit cleaner. BYT/CHT was Intel's first serious
> attempt at standard x86 tablet SoC and this shows in various
> places.
Thanks for the explanation.
--
Lee Jones [李琼斯]
Senior Technical Lead - Developer Services
Linaro.org │ Open source software for Arm SoCs
Follow Linaro: Facebook | Twitter | Blog
next prev parent reply other threads:[~2021-11-29 14:21 UTC|newest]
Thread overview: 6+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-10-29 7:02 [PATCH] mfd: Kconfig: change INTEL_SOC_PMIC_CHTDC_TI to bool Mauro Carvalho Chehab
2021-10-29 7:40 ` Hans de Goede
2021-11-24 15:40 ` Lee Jones
2021-11-24 16:25 ` Hans de Goede
2021-11-29 13:01 ` Lee Jones [this message]
2021-11-29 13:24 ` Mauro Carvalho Chehab
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=YaTPFEXmAEduJ916@google.com \
--to=lee.jones@linaro.org \
--cc=hdegoede@redhat.com \
--cc=linux-kernel@vger.kernel.org \
--cc=linuxarm@huawei.com \
--cc=mauro.chehab@huawei.com \
--cc=mchehab+huawei@kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox