Re: [PATCH 3/6 v2] input: Add support for VIA VT8500 and compatiblesin i8042

From: Alexey Charkov
Date: Fri Nov 12 2010 - 17:54:21 EST


2010/11/7 Alexey Charkov <alchark@xxxxxxxxx>:
> VIA and WonderMedia Systems-on-Chip feature a standard i8042-compatible
> keyboard and mouse controller. This adds necessary glue to enable use
> of the standard driver with these systems.
>
> Signed-off-by: Alexey Charkov <alchark@xxxxxxxxx>
> ---
>
> Please review and (if appropriate) commit to a relevant git tree for
> further integration in 2.6.38.
>
> Previous version of this code was 'Acked-by: Dmitry Torokhov <dtor@xxxxxxx>'
> This one only differs by using runtime-selected IRQ definitions instead
> of static compile-time preprocessor macros.
>
> Relevant register and interrupt definitions are provided by PATCH 1/6 in
> this series, so one would need that to make use of this code.
>
> Âdrivers/input/serio/Kconfig    Â|  Â3 +-
> Âdrivers/input/serio/i8042-vt8500.h | Â 74 ++++++++++++++++++++++++++++++++++++
> Âdrivers/input/serio/i8042.h    Â|  Â2 +
> Â3 files changed, 78 insertions(+), 1 deletions(-)
> Âcreate mode 100644 drivers/input/serio/i8042-vt8500.h
>
> diff --git a/drivers/input/serio/Kconfig b/drivers/input/serio/Kconfig
> index 6256233..ff799f3 100644
> --- a/drivers/input/serio/Kconfig
> +++ b/drivers/input/serio/Kconfig
> @@ -21,7 +21,8 @@ if SERIO
> Âconfig SERIO_I8042
> Â Â Â Âtristate "i8042 PC Keyboard controller" if EMBEDDED || !X86
> Â Â Â Âdefault y
> - Â Â Â depends on !PARISC && (!ARM || ARCH_SHARK || FOOTBRIDGE_HOST) && \
> + Â Â Â depends on !PARISC && \
> + Â Â Â Â Â Â Â Â (!ARM || ARCH_SHARK || ARCH_VT8500 || FOOTBRIDGE_HOST) && \
> Â Â Â Â Â Â Â Â Â (!SUPERH || SH_CAYMAN) && !M68K && !BLACKFIN
> Â Â Â Âhelp
> Â Â Â Â Âi8042 is the chip over which the standard AT keyboard and PS/2
> diff --git a/drivers/input/serio/i8042-vt8500.h b/drivers/input/serio/i8042-vt8500.h
> new file mode 100644
> index 0000000..4ff9e1c
> --- /dev/null
> +++ b/drivers/input/serio/i8042-vt8500.h
> @@ -0,0 +1,74 @@
> +#ifndef _I8042_VT8500_H
> +#define _I8042_VT8500_H
> +
> +#include <mach/mmio_regs.h>
> +#include <mach/irq_defs.h>
> +
> +/*
> + * This program is free software; you can redistribute it and/or modify it
> + * under the terms of the GNU General Public License version 2 as published by
> + * the Free Software Foundation.
> + */
> +
> +static void __iomem *regbase;
> +
> +/*
> + * Names.
> + */
> +
> +#define I8042_KBD_PHYS_DESC "vt8500ps2/serio0"
> +#define I8042_AUX_PHYS_DESC "vt8500ps2/serio1"
> +#define I8042_MUX_PHYS_DESC "vt8500ps2/serio%d"
> +
> +/*
> + * IRQs.
> + */
> +
> +#define I8042_KBD_IRQ Â(wmt_current_irqs->ps2kbd)
> +#define I8042_AUX_IRQ Â(wmt_current_irqs->ps2mouse)
> +
> +
> +/*
> + * Register numbers.
> + */
> +
> +#define I8042_COMMAND_REG Â Â Â(regbase + 0x4)
> +#define I8042_STATUS_REG Â Â Â (regbase + 0x4)
> +#define I8042_DATA_REG Â Â Â Â (regbase + 0x0)
> +
> +static inline int i8042_read_data(void)
> +{
> + Â Â Â return readl(I8042_DATA_REG);
> +}
> +
> +static inline int i8042_read_status(void)
> +{
> + Â Â Â return readl(I8042_STATUS_REG);
> +}
> +
> +static inline void i8042_write_data(int val)
> +{
> + Â Â Â writel(val, I8042_DATA_REG);
> +}
> +
> +static inline void i8042_write_command(int val)
> +{
> + Â Â Â writel(val, I8042_COMMAND_REG);
> +}
> +
> +static inline int i8042_platform_init(void)
> +{
> + Â Â Â i8042_reset = true;
> + Â Â Â regbase = ioremap(wmt_current_regs->ps2, SZ_1K);
> + Â Â Â if (!regbase)
> + Â Â Â Â Â Â Â return -ENODEV;
> +
> + Â Â Â return 0;
> +}
> +
> +static inline void i8042_platform_exit(void)
> +{
> + Â Â Â iounmap(regbase);
> +}
> +
> +#endif /* _I8042_VT8500_H */
> diff --git a/drivers/input/serio/i8042.h b/drivers/input/serio/i8042.h
> index cbc1beb..bdb2aeb 100644
> --- a/drivers/input/serio/i8042.h
> +++ b/drivers/input/serio/i8042.h
> @@ -16,6 +16,8 @@
>
> Â#if defined(CONFIG_MACH_JAZZ)
> Â#include "i8042-jazzio.h"
> +#elif defined(CONFIG_ARCH_VT8500)
> +#include "i8042-vt8500.h"
> Â#elif defined(CONFIG_SGI_HAS_I8042)
> Â#include "i8042-ip22io.h"
> Â#elif defined(CONFIG_SNI_RM)
> --
> 1.7.3.2
>
>

Any comments about this?

Thanks,
Alexey
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/