linux-input.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* Adding an interface to evdev for tablet orientation
@ 2015-08-06 13:19 Hans de Goede
  2015-08-16 19:58 ` Bastien Nocera
  0 siblings, 1 reply; 4+ messages in thread
From: Hans de Goede @ 2015-08-06 13:19 UTC (permalink / raw)
  To: linux-usb, Dmitry Torokhov; +Cc: Bastien Nocera

Hi All,

Many accelerometers used in tablets not only offer acceleration
data along 3 axis, but also have a notion of the orientation of
the tablet (right side up, upside down, rotated 90 degrees left/right),
currently there is no way to export this info via evdev.

I think we need to add an axis/switch/? to the linux/uapi/input.h
definitions to support this, as it is useful info to have, and the hw
is likely a more reliable source of this info then deducting it from
the accelerometer readings as is done in e.g. :

https://github.com/hadess/iio-sensor-proxy/blob/master/src/orientation.c#L60

3 questions:

1) Do people agree that it is a good idea to export the hardware's
notation of the orientation through evdev ?

2) What sort of evdev events should orientation changes send, events
on a new axis, or switch events, or ... ?

3) The accelerometer hardware I've been looking at sofar typically
generates a hw interrupt for orientation changes, where as reading
the actual acceleration axis typically is a contineous process
requiring polling. The current iio-sensor-proxy code (which also
handles evdev accelerometers) leaves the evdev node closed and
only opens it on a change kevent, which means that we need to
generate change kevents on orientation changes. Another approach
would be to have 2 separate evdev nodes, one for the orientation
function, and on opening that we enable the irq), and one for
reading accel values and on opening this one we start polling.

Regards,

Hans

^ permalink raw reply	[flat|nested] 4+ messages in thread

end of thread, other threads:[~2015-08-16 20:17 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2015-08-06 13:19 Adding an interface to evdev for tablet orientation Hans de Goede
2015-08-16 19:58 ` Bastien Nocera
2015-08-16 20:12   ` Hans de Goede
2015-08-16 20:17     ` Bastien Nocera

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).