On Sat, Dec 27, 2008 at 02:06:29PM +0500, Alexander E. Patrakov wrote:elantech.c: Elantech version query result 0x00, 0x01, 0x64.
elantech.c: assuming hardware version 1, firmware version 0.100
elantech.c: Synaptics capabilities query result 0x00, 0x02, 0x64.
However, all version query results I have seen from Elantech touchpads have
a non-zero first byte and a zero second byte. So we could test for that to
prevent this mouse from being detected as a touchpad.
Dmitry, do you think something like this is sufficient?
--- elantech.c.ORIG 2008-12-29 19:35:01.000000000 +0100
+++ elantech.c.NEW 2008-12-29 19:38:59.000000000 +0100
@@ -618,6 +618,10 @@ int elantech_init(struct psmouse *psmous
}
pr_info("elantech.c: Elantech version query result 0x%02x, 0x%02x, 0x%02x.\n",
param[0], param[1], param[2]);
+ if (param[0] == 0 || param[1] != 0) {
+ pr_info("elantech.c: Probably not a real Elantech touchpad. Aborting.\n");
+ goto init_fail;
+ }
etd->fw_version_maj = param[0];
etd->fw_version_min = param[2];