RE: [PATCH] arm: exynos4: fix incorrect pad configuration for keypad row lines

2011-09-14 Thread Kukjin Kim
Thomas Abraham wrote:
 
 The keypad controller requires a external pull-up for all the keypad
 row lines. Fix the incorrect pad configuration for keypad controller
 row lines by enabling the pad pull-up for the all row lines of the
 keypad controller.
 
 Signed-off-by: Thomas Abraham thomas.abra...@linaro.org
 ---
 SMDKV310 board does not have pull-up resistors populated for the keypad
 row lines (unlike the smdk boards for the previous Samsung SoC's). So
 the pad pull-up for all keypad row lines should be enabled for
 smdkv310 board.
 
 The default requirement for the keypad controller is to enable the
 pull-up for all the keypad row lines. If a exynos4 based board has
 on-board pull-up's populated for keypad row lines, this patch would
 cause no harm. And in such cases, if internal pad pull-up is to be
 disabled (to reduce some power consumption), an alternative gpio
 configuration function can be supplied that does not enable the
 internal pad pull-up.
 ---
  arch/arm/mach-exynos4/setup-keypad.c |   11 ++-
  1 files changed, 6 insertions(+), 5 deletions(-)
 
 diff --git a/arch/arm/mach-exynos4/setup-keypad.c b/arch/arm/mach-
 exynos4/setup-keypad.c
 index 1ee0ebf..7862bfb 100644
 --- a/arch/arm/mach-exynos4/setup-keypad.c
 +++ b/arch/arm/mach-exynos4/setup-keypad.c
 @@ -19,15 +19,16 @@ void samsung_keypad_cfg_gpio(unsigned int rows,
 unsigned int cols)
 
   if (rows  8) {
   /* Set all the necessary GPX2 pins: KP_ROW[0~7] */
 - s3c_gpio_cfgrange_nopull(EXYNOS4_GPX2(0), 8,
 S3C_GPIO_SFN(3));
 + s3c_gpio_cfgall_range(EXYNOS4_GPX2(0), 8,
 S3C_GPIO_SFN(3),
 + S3C_GPIO_PULL_UP);
 
   /* Set all the necessary GPX3 pins: KP_ROW[8~] */
 - s3c_gpio_cfgrange_nopull(EXYNOS4_GPX3(0), (rows - 8),
 -  S3C_GPIO_SFN(3));
 + s3c_gpio_cfgall_range(EXYNOS4_GPX3(0), (rows - 8),
 +  S3C_GPIO_SFN(3),
 S3C_GPIO_PULL_UP);
   } else {
   /* Set all the necessary GPX2 pins: KP_ROW[x] */
 - s3c_gpio_cfgrange_nopull(EXYNOS4_GPX2(0), rows,
 -  S3C_GPIO_SFN(3));
 + s3c_gpio_cfgall_range(EXYNOS4_GPX2(0), rows,
 S3C_GPIO_SFN(3),
 + S3C_GPIO_PULL_UP);
   }
 
   /* Set all the necessary GPX1 pins to special-function 3: KP_COL[x]
*/
 --
 1.6.6.rc2

Oops, you're right, applied.
Thanks.

Best regards,
Kgene.
--
Kukjin Kim kgene@samsung.com, Senior Engineer,
SW Solution Development Team, Samsung Electronics Co., Ltd.

--
To unsubscribe from this list: send the line unsubscribe linux-samsung-soc in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html


Re: [PATCH] arm: exynos4: fix incorrect pad configuration for keypad row lines

2011-09-04 Thread Alan Cox
 SMDKV310 board does not have pull-up resistors populated for the keypad
 row lines (unlike the smdk boards for the previous Samsung SoC's). So
 the pad pull-up for all keypad row lines should be enabled for
 smdkv310 board.

So does this change the behaviour of existing boards, and if so isn't it
the SMDKV310 that hould be providing the alternate gpio configuration
function ?

--
To unsubscribe from this list: send the line unsubscribe linux-samsung-soc in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html


Re: [PATCH] arm: exynos4: fix incorrect pad configuration for keypad row lines

2011-09-04 Thread Thomas Abraham
Hi Alan,

On 4 September 2011 15:23, Alan Cox a...@lxorguk.ukuu.org.uk wrote:
 SMDKV310 board does not have pull-up resistors populated for the keypad
 row lines (unlike the smdk boards for the previous Samsung SoC's). So
 the pad pull-up for all keypad row lines should be enabled for
 smdkv310 board.

 So does this change the behaviour of existing boards, and if so isn't it
 the SMDKV310 that hould be providing the alternate gpio configuration
 function ?

Among the boards based on the Exynos4 SoC, only the smdk boards use
the keypad controller for connecting the keys on the board. All other
boards either use gpio keys or use some other mechanism for keyboard
input. So this patch is applicable to only the existing exynos4 soc
based smdk boards.

A pull-up for all the row lines is the default requirement of the
keypad controller. So, in this patch, the default gpio and pad
configuration function for keypad controller enables the internal pad
pull-up. If a upcoming board based on exynos4 does populate pull-up
for row lines on the board of the keypad, this patch would still not
break anything. If required, such boards could provide another gpio
and pad configuration function that disables the internal pull-up.

This patch modifies only the exynos4 keypad gpio/pad configuration
setup function. All previous Samsung SoC's are not affected by this
patch.

Thanks,
Thomas.



--
To unsubscribe from this list: send the line unsubscribe linux-samsung-soc in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html