Hello,
could you please re-send the patch? I for some reason have yet to see it ...
here it is again, adressing also the comments from Dmitry. Sincerely, Thomas Rohwer
--- linux-2.6.23-rc7/drivers/input/mouse/appletouch.c 2007-09-20 01:01:13.000000000 +0200 +++ linux/drivers/input/mouse/appletouch.c 2007-09-24 15:15:56.000000000 +0200 @@ -328,6 +328,7 @@ { int x, y, x_z, y_z, x_f, y_f; int retval, i, j; + int key; struct atp *dev = urb->context; switch (urb->status) { @@ -469,6 +470,9 @@ y = atp_calculate_abs(dev->xy_acc + ATP_XSENSORS, ATP_YSENSORS, ATP_YFACT, &y_z, &y_f); + key= dev->data[dev->datalen - 1] & 1; + input_report_key(dev->input, BTN_LEFT, key); + if (x && y) { if (dev->x_old != -1) { x = (dev->x_old * 3 + x) >> 2; @@ -505,7 +509,7 @@ the first touch unless reinitialised. Do so if it's been idle for a while in order to avoid waking the kernel up several hundred times a second */ - if (atp_is_geyser_3(dev)) { + if (atp_is_geyser_3(dev) && (!key)) { dev->idlecount++; if (dev->idlecount == 10) { dev->valid = 0; @@ -514,7 +518,6 @@ } } - input_report_key(dev->input, BTN_LEFT, dev->data[dev->datalen - 1] & 1); input_sync(dev->input); exit: