On 5 November 2010 19:47, Ping Cheng <pinglinux@xxxxxxxxx> wrote: > Recent changes and discussion about MT support at LKML, UDS, and > xorg-devel encouraged me to migrate Wacom MT devices to the slot-based > MT protocol (introduced in kernel 2.6.36). Since Wacom supports both > digitizer and touch devices, I need to decide how to report touch data > when the pen is in proximity. > > My goal is to understand how X server would like the MT data to be > reported from the kernel. I hope to keep kernel and X server driver MT > support in sync so we can avoid unnecessary confusion or extra work in > the userland. > > The existing solution for single touch events is to arbitrate touch > when pen is in prox. This is based on the assumption that we do not > want to have two cursors competing on the screen. As a tablet user, not X developer I don't think it is desirable and expected to register pen touch and finger touch together as a multitouch. That is, if I wanted to trigger a multitouch feature I would use fingers, not pen and finger. While it would be technically possible to use the pen touch and finger touch together to trigger multitouch I don't think it makes much sense. Also it is a good idea to turn off (single) touch when pen is in proximity because it is quite easy to accidentally touch the surface while moving the pen. This means that the protocol that sends abs events from pen when in proximity and from finger otherwise would work well. However, there is one feature that makes sort of sense and does not work when touch is completely off. It might be possible to use touch for button and pen for moving the cursor. I tried to use the pad button on my Bamboo together with pen motion for right drags and it seems somewhat easier than using the pen button. So I would say that protocol that allows events from both pen and touch at the same time is desirable in the long run but with some options to filter the events when both pen and touch are used together. This gives basically three options 1) leave as is, turn off touch when pen is in proximity 2) report everything by kernel, put some filter on the touch events in the X driver (which defaults to killing most touch stuff when pen is in proximity) 3) the same as above but put the filter in the kernel driver 2 or 3 is more flexible as people with some special uses can just turn off the filter and get all events. WRT X ease of development I would suggest that the same device should never report different events based on pen proximity. Either the device is in some "compatibility mode" and reports only one pointer as per 1 or there are two separate pointers and they are just reported out of proximity when the pointer positioning is not desirable (ie when pen is out or when touch is off due to pen being in). If somebody wants to have multitouch combining two different pointers there is nothing stopping them, either with P&T pen and touch pointers or completely unrelated devices. Thanks Michal -- 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