Re: [PATCH] new driver for ITM Touch touchscreen
From: Paulo Marques
Date: Tue Mar 08 2005 - 13:27:20 EST
Hans-Christian Egtvedt wrote:
[...]
Any tips are welcome. Is this done before with a touchscreen?
Just a minor nitpick, not really related to the mouse problem. More of
coding style problem.
IMHO the UCP and UCOM macros just obfuscate the code. If you do not want
to write "((unsigned char *) urb->transfer_buffer)[0]" every time (I can
perfectly understand that), maybe using a local "u8 *" var would do the
trick.
Something like this:
static void itmtouch_irq(struct urb *urb, struct pt_regs *regs)
{
struct itmtouch_dev * itmtouch = urb->context;
int retval;
u8 *tbuf;
....
input_regs(&itmtouch->inputdev, regs);
tbuf = (u8 *)(urb->transfer_buffer);
/* if pressure has been released, then don't report X/Y */
if (!(tbuf[7] & 0x20)) {
input_report_abs(&itmtouch->inputdev, ABS_X,
(tbuf[0] & 0x1F) << 7 | (tbuf[3] & 0x7F));
input_report_abs(&itmtouch->inputdev, ABS_Y,
(tbuf[1] & 0x1F) << 7 | (tbuf[4] & 0x7F));
}
input_report_abs(&itmtouch->inputdev, ABS_PRESSURE,
(tbuf[2] & 0x1) << 7 | (tbuf[5] & 0x7F));
input_report_key(&itmtouch->inputdev, BTN_TOUCH, !(tbuf[7] & 0x20));
/* TODO: Do we need to use input_sync() ? */
/* input_sync(&itmtouch->inputdev); */
......
This is perfectly readable without one having to find out what those
macros mean, and it is even easier for the compiler to optimize (even
though gcc will probably optimize both versions just fine).
--
Paulo Marques - www.grupopie.com
All that is necessary for the triumph of evil is that good men do nothing.
Edmund Burke (1729 - 1797)
-
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/