devicetree.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: Stephen Warren <swarren@nvidia.com>
To: Linux Input Mailing List <linux-input@vger.kernel.org>,
	Devicetree Discuss <devicetree-discuss@lists.ozlabs.org>,
	Dmitry Torokhov <dmitry.torokhov@gmail.com>
Cc: Simon Glass <sjg@chromium.org>, Rakesh Iyer <riyer@nvidia.com>
Subject: Keyboard device tree bindings, and modifier mapping representation
Date: Mon, 12 Dec 2011 11:55:45 -0700	[thread overview]
Message-ID: <4EE64E31.3030602@nvidia.com> (raw)

Simon Glass is attempting to define a device tree binding for the Tegra
KBC controller, for use in U-Boot. I raised some issues re: how to
represent modifier mappings. We'd like the ask for any insight from the
Linux input people regarding this.

Tegra's KBC is a matrix keyboard controller. The original binding that
Simon is attempting to upstream contains four tables:

kbc@7000e200 {
    keycode-plain = [00  00  'w' 's' 'a' 'z' ... ];
    keycode-fn =    [00  00  00  00  00  00  ... ];
    keycode-shift = [00  00  'W' 'S' 'A' 'Z' ... ];
    keycode-ctrl =  [00  00  17  13  01  1a  ... ];
};

keycode-plain lists the keycode generated by each matrix position when
no modifier is held.

keycode-fn is the same thing, but when the "Fn" key is pressed. It seems
reasonable to represent this "Fn" feature directly in the device tree,
since in non-matrix keyboards, "Fn" is generally implemented in the
keyboard hardware and invisible to software.

My main question is about keycode-shift and keycode-ctrl, which deal
with modifiers.

My assertion is that those aren't really hardware features; most
keyboard emit explicit keycodes for modifiers, and these are handled
purely in software at a higher level than the keyboard driver. Hence,
shift/ctrl shouldn't be represented in the same way as the plain/fn tables.

I believe the definition of keycode-shift/ctrl should be written such
that those properties could be re-used across any keyboard, rather than
being something custom for the Tegra KBC binding.

I imagine that if keycode-shift/ctrl were present in the device tree,
the kernel would simply ignore them and just use its standard keyboard
mapping mechanisms. Could keycode-shift/ctrl be used to initialize the
default mapping in the Linux kernel? I guess that would only affect the
console and not X, and it might be confusing to not use all the existing
mapping mechanisms.

In the binding above, the four tables both use the matrix position as
input, and give a keycode as output. I think that keycode-shift/ctrl
should take keycodes (from the plain/fn table output) and map them to
other keycodes. This would be more in line with typical keyboards, where
the modifier mapping operates at that level.

Note that U-Boot (where this binding is headed first) has no separate
input layer above the keyboard driver, and hence no generic shift/ctrl
modifier handling. At least initially, the Tegra KBC driver would have
to implement all 4 of those tables, irrespective of how the tables are
represented (as above, or as a generic keycode->keycode mapping table).
However, I'd like to come up with a binding now that's workable for both
U-Boot and the Linux kernel, and indeed any other SW.

What's the thinking of the linux-input maintainers here?

Thanks for reading.

-- 
nvpublic

                 reply	other threads:[~2011-12-12 18:55 UTC|newest]

Thread overview: [no followups] expand[flat|nested]  mbox.gz  Atom feed

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=4EE64E31.3030602@nvidia.com \
    --to=swarren@nvidia.com \
    --cc=devicetree-discuss@lists.ozlabs.org \
    --cc=dmitry.torokhov@gmail.com \
    --cc=linux-input@vger.kernel.org \
    --cc=riyer@nvidia.com \
    --cc=sjg@chromium.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
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).