@@ -648,4 +648,15 @@ config TOUCHSCREEN_STMPE
To compile this driver as a module, choose M here: the
module will be called stmpe-ts.
+config TOUCHSCREEN_MCHPAR1XXX
+ tristate "Microchip AR1XXX touchscreen"
+ select SERIO
+ help
+ Say Y here if you have a Microchip AR1XXX Controller and
+ want to enable support for the built-in touchscreen.
+
+ To compile this driver as a module, choose M here: the
+ module will be called mchipar1xxx.
endif
+
+
@@ -53,3 +53,4 @@ obj-$(CONFIG_TOUCHSCREEN_WM97XX_MAINSTONE) += mainstone-wm97xx.o
obj-$(CONFIG_TOUCHSCREEN_WM97XX_ZYLONITE) += zylonite-wm97xx.o
obj-$(CONFIG_TOUCHSCREEN_W90X900) += w90p910_ts.o
obj-$(CONFIG_TOUCHSCREEN_TPS6507X) += tps6507x-ts.o
+obj-$(CONFIG_TOUCHSCREEN_MCHPAR1XXX) += mchpar1xxx.o
@@ -2,7 +2,7 @@
* Microchip Serial Touchscreen Driver
*
* Copyright (c) 2010 Microchip Technology, Inc.
- *
+ *
* http://www.microchip.com/mtouch
*/
@@ -13,7 +13,8 @@
*/
/*
- * This driver can handle serial Microchip controllers using the AR1XXX 5-byte protocol
+ * This driver can handle serial Microchip controllers using the AR1XXX 5-byte
+ * protocol
*/
#include <linux/errno.h>
@@ -57,57 +58,46 @@ static void mchpar1xxx_process_data(struct mchip *mchip, unsigned char data)
mchip->data[mchip->index] = data;
/****************************************************
-
Data format, 5 bytes: SYNC, DATA1, DATA2, DATA3, DATA4
-
SYNC [7:0]: 1,0,0,0,0,TOUCHSTATUS[0:0]
DATA1[7:0]: 0,X-LOW[6:0]
DATA2[7:0]: 0,X-HIGH[4:0]
DATA3[7:0]: 0,Y-LOW[6:0]
DATA4[7:0]: 0,Y-HIGH[4:0]
-
TOUCHSTATUS: 0 = Touch up, 1 = Touch down
-
- ****************************************************/
-
+ ****************************************************/
switch (mchip->index++) {
- case 0:
- if (!(0x80 & data))
- {
-/* printk(KERN_ERR "mchip: Sync bit not set\n"); */
- mchip->index = 0;
- }
- break;
-
- case (MCHIP_MAX_LENGTH - 1):
- /* verify byte is valid for current index */
- if (0x80 & data)
- {
- /* byte not valid */
- mchip->data[0]=data;
- mchip->index = 1;
- break;
- }
-
+ case 0:
+ /* Verify sync bit on first byte of packet */
+ if (!(0x80 & data))
mchip->index = 0;
-
-/* printk(KERN_ERR "mchip: %d %d %d\n",((mchip->data[2] & 0x1f) << 7) | (mchip->data[1] & 0x7f), ((mchip->data[4] & 0x1f) << 7) | (mchip->data[3] & 0x7f), 0 != (mchip->data[0] & 7)); */
-
- input_report_abs(dev, ABS_X, ((mchip->data[2] & 0x1f) << 7) | (mchip->data[1] & 0x7f));
- input_report_abs(dev, ABS_Y, ((mchip->data[4] & 0x1f) << 7) | (mchip->data[3] & 0x7f));
- input_report_key(dev, BTN_TOUCH, 0 != (mchip->data[0] & 1) );
- input_sync(dev);
- break;
- default:
- /* verify byte is valid for current index */
- if (0x80 & data)
- {
- /* byte not valid */
- mchip->data[0]=data;
- mchip->index = 1;
- }
+ break;
+
+ case (MCHIP_MAX_LENGTH - 1):
+ /* verify byte is valid for current index */
+ if (0x80 & data) {
+ /* byte not valid */
+ mchip->data[0] = data;
+ mchip->index = 1;
break;
-
+ }
+
+ mchip->index = 0;
+ input_report_abs(dev, ABS_X, \
+ ((mchip->data[2] & 0x1f) << 7) | (mchip->data[1] & 0x7f));
+ input_report_abs(dev, ABS_Y, \
+ ((mchip->data[4] & 0x1f) << 7) | (mchip->data[3] & 0x7f));
+ input_report_key(dev, BTN_TOUCH, 0 != (mchip->data[0] & 1));
+ input_sync(dev);
+ break;
+ default:
+ /* verify byte is valid for current index */
+ if (0x80 & data) {
+ /* byte not valid */
+ mchip->data[0] = data;
+ mchip->index = 1;
+ }
+ break;
}
}
@@ -115,11 +105,11 @@ static void mchpar1xxx_process_data(struct mchip *mchip, unsigned char data)
static irqreturn_t mchpar1xxx_interrupt(struct serio *serio,
unsigned char data, unsigned int flags)
{
- struct mchip *mchip = serio_get_drvdata(serio);
+ struct mchip *mchip = serio_get_drvdata(serio);
- mchpar1xxx_process_data(mchip, data);
+ mchpar1xxx_process_data(mchip, data);
- return IRQ_HANDLED;
+ return IRQ_HANDLED;
}
static int mchpar1xxx_setup(struct mchip *mchip)
@@ -196,9 +186,9 @@ static int mchpar1xxx_connect(struct serio *serio, struct serio_driver *drv)
return 0;
- fail3: serio_close(serio);
- fail2: serio_set_drvdata(serio, NULL);
- fail1: input_free_device(input_dev);
+fail3: serio_close(serio);
+fail2: serio_set_drvdata(serio, NULL);
+fail1: input_free_device(input_dev);
kfree(mchip);
return err;
}
@@ -197,5 +197,6 @@ static inline void serio_continue_rx(struct serio *serio)
#define SERIO_W8001 0x39
#define SERIO_DYNAPRO 0x3a
#define SERIO_HAMPSHIRE 0x3b
+#define SERIO_MCHPAR1XXX 0x3c
#endif