> I understand the usefulness of this functionality, but I also worry > about proliferating the number of properties for devices (there are > only 32 bits we can use, IIRC). I see four options off the top of my > head: > > * Don't do anything, leave it as SEMI_MT. Obviously this would suck, > but it is an option. > > * Make the trackpad advertise itself as *not* SEMI_MT. This would be > broken, however, if the user performs a rotation where the touches > cross in the Y axis. I feel this is plain wrong according to the > stated protocol documentation and previous behavior, so I don't want > to do this. > > * Add a new device property (INVALID_Y_AXIS_CROSSING?) that > describes the exact behavior of this device. I would be ok with this > if everyone else is, but only because proper clickpad behavior > (which I consider very importand) is broken without this knowledge. > > * Leave the device as SEMI_MT, but provide the real locations, and > allow userspace to determine the device vendor/model/etc. If > userspace knows that a specific device behaves in a specific way, it > can do its own quirking handling. Given the specificity of this > behavior to only some devices of one brand, this would be my > suggested resolution to the issue. A fifth option is to quirk the driver to remove the pulling effect from the reported bounding box, such that the simple userspace scheme for determining the position of the moving finger actually works. For instance, consider the simple algorithm "the slowest corner is the stationary finger". As long as this is true, the behavior will be smooth. If the sensor data clutters this behavior, it shows up in the driver as a mismatch between the point as computed above and the better estimate available in the driver. For frames where this happens, one can simply alter the bounding box slightly so that the algorithm works. It should be possible to formulate such a scheme in a couple of lines. Henrik -- To unsubscribe from this list: send the line "unsubscribe linux-input" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html