Skip to content

Commit

Permalink
ARM: mach-shmobile: ap4evb: Add ts_get_pendown_state for tsc2007
Browse files Browse the repository at this point in the history
This function is necessary to ensure the detection of pen-down.
This patch support both QHD / WVGA pannel.

Tested-by: Tony SIM <chinyeow.sim.xt@renesas.com>
Signed-off-by: Kuninori Morimoto <kuninori.morimoto.gx@renesas.com>
Signed-off-by: Paul Mundt <lethal@linux-sh.org>
  • Loading branch information
Kuninori Morimoto authored and Paul Mundt committed Aug 4, 2010
1 parent dba6f38 commit 71c3ba9
Showing 1 changed file with 62 additions and 16 deletions.
78 changes: 62 additions & 16 deletions arch/arm/mach-shmobile/board-ap4evb.c
Original file line number Diff line number Diff line change
Expand Up @@ -576,12 +576,74 @@ static struct platform_device *ap4evb_devices[] __initdata = {
&sh_mmcif_device
};

/*
* FIXME !!
*
* gpio_no_direction
* gpio_pull_up
* are quick_hack.
*
* current gpio frame work doesn't have
* the method to control only pull up/down/free.
* this function should be replaced by correct gpio function
*/
static void __init gpio_no_direction(u32 addr)
{
__raw_writeb(0x00, addr);
}

static void __init gpio_pull_up(u32 addr)
{
u8 data = __raw_readb(addr);

data &= 0x0F;
data |= 0xC0;
__raw_writeb(data, addr);
}

/* TouchScreen */
#define IRQ28 evt2irq(0x3380) /* IRQ28A */
#define IRQ7 evt2irq(0x02e0) /* IRQ7A */
static int ts_get_pendown_state(void)
{
int val1, val2;

gpio_free(GPIO_FN_IRQ28_123);
gpio_free(GPIO_FN_IRQ7_40);

gpio_request(GPIO_PORT123, NULL);
gpio_request(GPIO_PORT40, NULL);

gpio_direction_input(GPIO_PORT123);
gpio_direction_input(GPIO_PORT40);

val1 = gpio_get_value(GPIO_PORT123);
val2 = gpio_get_value(GPIO_PORT40);

gpio_request(GPIO_FN_IRQ28_123, NULL); /* for QHD */
gpio_request(GPIO_FN_IRQ7_40, NULL); /* for WVGA */

return val1 ^ val2;
}

#define PORT40CR 0xE6051028
#define PORT123CR 0xE605007B
static int ts_init(void)
{
gpio_request(GPIO_FN_IRQ28_123, NULL); /* for QHD */
gpio_request(GPIO_FN_IRQ7_40, NULL); /* for WVGA */

gpio_pull_up(PORT40CR);
gpio_pull_up(PORT123CR);

return 0;
}

static struct tsc2007_platform_data tsc2007_info = {
.model = 2007,
.x_plate_ohms = 180,
.get_pendown_state = ts_get_pendown_state,
.init_platform_hw = ts_init,
};

static struct i2c_board_info tsc_device = {
Expand Down Expand Up @@ -625,20 +687,6 @@ static void __init ap4evb_map_io(void)
shmobile_setup_console();
}

/*
* FIXME !!
*
* gpio_no_direction is quick_hack.
*
* current gpio frame work doesn't have
* the method to control only pull up/down/free.
* this function should be replaced by correct gpio function
*/
static void __init gpio_no_direction(u32 addr)
{
__raw_writeb(0x00, addr);
}

#define GPIO_PORT9CR 0xE6051009
#define GPIO_PORT10CR 0xE605100A

Expand Down Expand Up @@ -784,7 +832,6 @@ static void __init ap4evb_init(void)
gpio_request(GPIO_FN_KEYIN4, NULL);

/* enable TouchScreen */
gpio_request(GPIO_FN_IRQ28_123, NULL);
set_irq_type(IRQ28, IRQ_TYPE_LEVEL_LOW);

tsc_device.irq = IRQ28;
Expand Down Expand Up @@ -860,7 +907,6 @@ static void __init ap4evb_init(void)
lcdc_info.ch[0].lcd_size_cfg.height = 91;

/* enable TouchScreen */
gpio_request(GPIO_FN_IRQ7_40, NULL);
set_irq_type(IRQ7, IRQ_TYPE_LEVEL_LOW);

tsc_device.irq = IRQ7;
Expand Down

0 comments on commit 71c3ba9

Please sign in to comment.