ARM: mach-omap2: omap3: Fix GPIO clocking in SPL

OMAP3_GPIO_x is needed to enable each GPIO bank on the OMAP3
boards. At one point, the #ifdef's were replaced with
if CONFIG_IS_ENABLED but this won't work for people who need
OMAP3_GPIO_x in SPL since the SPL prefix for this option isn't
used in Kconfig.  This patch moves the check to #if defined and
also makes Kconfig select the banks if CMD_GPIO is used which
makes the checks in the code less cumbersome.

Fixes: bd8a9c14c9 ("arm: mach-omap2/omap3/clock.c: Enable
all GPIO with CMD_GPIO")

Reported-by: Liam O'Shaughnessy <liam.o.shaughnessy@gumstix.com>
Signed-off-by: Adam Ford <aford173@gmail.com>
[trini: Migrate omap3_igep00x0.h]
Signed-off-by: Tom Rini <trini@konsulko.com>
This commit is contained in:
Adam Ford 2018-12-14 16:28:30 -06:00 committed by Tom Rini
parent 5766a27176
commit a1702746df
3 changed files with 10 additions and 9 deletions

View File

@ -3,18 +3,23 @@ if OMAP34XX
# We only enable the clocks for the GPIO banks that a given board requies. # We only enable the clocks for the GPIO banks that a given board requies.
config OMAP3_GPIO_2 config OMAP3_GPIO_2
bool bool
default y if CMD_GPIO
config OMAP3_GPIO_3 config OMAP3_GPIO_3
bool bool
default y if CMD_GPIO
config OMAP3_GPIO_4 config OMAP3_GPIO_4
bool bool
default y if CMD_GPIO
config OMAP3_GPIO_5 config OMAP3_GPIO_5
bool bool
default y if CMD_GPIO
config OMAP3_GPIO_6 config OMAP3_GPIO_6
bool bool
default y if CMD_GPIO
choice choice
prompt "OMAP3 board select" prompt "OMAP3 board select"

View File

@ -750,23 +750,23 @@ void per_clocks_enable(void)
setbits_le32(&prcm_base->iclken_per, 0x00000800); setbits_le32(&prcm_base->iclken_per, 0x00000800);
#endif #endif
#if (CONFIG_IS_ENABLED(OMAP3_GPIO_2) || CONFIG_IS_ENABLED(CMD_GPIO)) #if defined(CONFIG_OMAP3_GPIO_2)
setbits_le32(&prcm_base->fclken_per, 0x00002000); setbits_le32(&prcm_base->fclken_per, 0x00002000);
setbits_le32(&prcm_base->iclken_per, 0x00002000); setbits_le32(&prcm_base->iclken_per, 0x00002000);
#endif #endif
#if (CONFIG_IS_ENABLED(OMAP3_GPIO_3) || CONFIG_IS_ENABLED(CMD_GPIO)) #if defined(CONFIG_OMAP3_GPIO_3)
setbits_le32(&prcm_base->fclken_per, 0x00004000); setbits_le32(&prcm_base->fclken_per, 0x00004000);
setbits_le32(&prcm_base->iclken_per, 0x00004000); setbits_le32(&prcm_base->iclken_per, 0x00004000);
#endif #endif
#if (CONFIG_IS_ENABLED(OMAP3_GPIO_4) || CONFIG_IS_ENABLED(CMD_GPIO)) #if defined(CONFIG_OMAP3_GPIO_4)
setbits_le32(&prcm_base->fclken_per, 0x00008000); setbits_le32(&prcm_base->fclken_per, 0x00008000);
setbits_le32(&prcm_base->iclken_per, 0x00008000); setbits_le32(&prcm_base->iclken_per, 0x00008000);
#endif #endif
#if (CONFIG_IS_ENABLED(OMAP3_GPIO_5) || CONFIG_IS_ENABLED(CMD_GPIO)) #if defined(CONFIG_OMAP3_GPIO_5)
setbits_le32(&prcm_base->fclken_per, 0x00010000); setbits_le32(&prcm_base->fclken_per, 0x00010000);
setbits_le32(&prcm_base->iclken_per, 0x00010000); setbits_le32(&prcm_base->iclken_per, 0x00010000);
#endif #endif
#if (CONFIG_IS_ENABLED(OMAP3_GPIO_6) || CONFIG_IS_ENABLED(CMD_GPIO)) #if defined(CONFIG_OMAP3_GPIO_6)
setbits_le32(&prcm_base->fclken_per, 0x00020000); setbits_le32(&prcm_base->fclken_per, 0x00020000);
setbits_le32(&prcm_base->iclken_per, 0x00020000); setbits_le32(&prcm_base->iclken_per, 0x00020000);
#endif #endif

View File

@ -20,10 +20,6 @@
#define CONFIG_REVISION_TAG 1 #define CONFIG_REVISION_TAG 1
/* GPIO banks */
#define CONFIG_OMAP3_GPIO_2 /* GPIO32..63 is in GPIO bank 2 */
#define CONFIG_OMAP3_GPIO_4 /* GPIO96..127 is in GPIO bank 4 */
/* TPS65950 */ /* TPS65950 */
#define PBIASLITEVMODE1 (1 << 8) #define PBIASLITEVMODE1 (1 << 8)