[PATCH 1/4] input: touchscreen: Add generic touchscreen softbutton handling code

Dmitry Torokhov dmitry.torokhov at gmail.com
Mon Aug 1 10:41:54 PDT 2016


On Mon, Aug 01, 2016 at 11:54:30AM -0500, Rob Herring wrote:
> On Sun, Jul 31, 2016 at 05:23:07PM +0200, Hans de Goede wrote:
> > Some touchscreens extend over the display they cover and have a number
> > of capacative softbuttons outside of the display the cover.
> > 
> > With some hardware these softbuttons simply report touches with
> > coordinates outside of the normal coordinate space for touches on the
> > display.
> > 
> > This commit adds a devicetree binding for describing such buttons in
> > devicetree and a bunch of helper functions to easily add support for
> > these to existing touchscreen drivers.
> > 
> > Signed-off-by: Hans de Goede <hdegoede at redhat.com>
> > ---
> >  .../bindings/input/touchscreen/softbuttons.txt     |  58 +++++++++
> >  drivers/input/touchscreen/Makefile                 |   2 +-
> >  drivers/input/touchscreen/softbuttons.c            | 145 +++++++++++++++++++++
> >  include/linux/input/touchscreen.h                  |   9 ++
> >  4 files changed, 213 insertions(+), 1 deletion(-)
> >  create mode 100644 Documentation/devicetree/bindings/input/touchscreen/softbuttons.txt
> >  create mode 100644 drivers/input/touchscreen/softbuttons.c
> > 
> > diff --git a/Documentation/devicetree/bindings/input/touchscreen/softbuttons.txt b/Documentation/devicetree/bindings/input/touchscreen/softbuttons.txt
> > new file mode 100644
> > index 0000000..3eb6f4c
> > --- /dev/null
> > +++ b/Documentation/devicetree/bindings/input/touchscreen/softbuttons.txt
> > @@ -0,0 +1,58 @@
> > +General Touchscreen Softbutton Properties:
> > +
> > +Some touchscreens extend over the display they cover and have a number
> > +of capacative softbuttons outside of the display the cover.
> > +
> > +Some of these softbuttons simply report touches with coordinates outside of
> > +the normal coordinate space for touches on the display. This binding is for
> > +describing such buttons in devicetree.
> > +
> > +Each softkey is represented as a sub-node of the touchscreen node.
> > +
> > +Required subnode-properties:
> > + - label			: Descriptive name of the key.
> > + - linux,code			: Keycode to emit.
> > + - softbutton-min-x		: X start of the area the softbutton area covers
> > + - softbutton-max-x		: X end of the area the softbutton area covers
> > + - softbutton-min-y		: Y start of the area the softbutton area covers
> > + - softbutton-max-y		: Y end of the area the softbutton area covers
> 
> This generally looks fine to me, but I am wondering one thing. If the 
> buttons are located at the origin of an axis, can we handle that case? I 
> don't think you can unless you assume softbutton-max-? is 0 for the 
> touchscreen. To put it another way, you have a gap from 1024 to 1084 
> which you can't express for buttons at the origin unless you do negative 
> numbers.

I do not this this should be done in kernel: I do not see nay difference
in softbuttons or sliders or circular controls or... They are not
controller-specific and I think are better handled in userspace. We do
that for Synaptics touchpads with softbuttons, we can do that for other
controllers.

Also, what is or stance when there is no bezel and we sill want to have
the softbutons (i.e. all Nexus phones and tablets)?

Thanks.

-- 
Dmitry



More information about the linux-arm-kernel mailing list