ARM: omap: pmic-cpcap: do not mess around without CPCAP or OMAP4
commit 7397daf1029d5bfd3415ec8622f5179603d5702d upstream.
The late init call just writes to omap4 registers as soon as
CONFIG_MFD_CPCAP is enabled without checking whether the
cpcap driver is actually there or the SoC is indeed an
OMAP4.
Rather do these things only with the right device combination.
Fixes booting the BT200 with said configuration enabled and non-factory
X-Loader and probably also some surprising behavior on other devices.
Fixes: c145649bf2
("ARM: OMAP2+: Configure voltage controller for cpcap to low-speed")
CC: stable@vger.kernel.org
Signed-off-by: Andreas Kemnade <andreas@kemnade.info>
Reivewed-by: Tony Lindgren <tony@atomide.com>
Link: https://lore.kernel.org/r/20250331144439.769697-1-andreas@kemnade.info
Signed-off-by: Kevin Hilman <khilman@baylibre.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
committed by
Greg Kroah-Hartman
parent
c592d3ceca
commit
838d63de34
@@ -264,7 +264,11 @@ int __init omap4_cpcap_init(void)
|
|||||||
|
|
||||||
static int __init cpcap_late_init(void)
|
static int __init cpcap_late_init(void)
|
||||||
{
|
{
|
||||||
omap4_vc_set_pmic_signaling(PWRDM_POWER_RET);
|
if (!of_find_compatible_node(NULL, NULL, "motorola,cpcap"))
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
if (soc_is_omap443x() || soc_is_omap446x() || soc_is_omap447x())
|
||||||
|
omap4_vc_set_pmic_signaling(PWRDM_POWER_RET);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user