Message ID | 1452598370-28509-2-git-send-email-ldewangan@nvidia.com (mailing list archive) |
---|---|
State | Changes Requested |
Headers | show |
On Tue, Jan 12, 2016 at 05:02:50PM +0530, Laxman Dewangan wrote: > Add support from DT to name the gpio-keys driver to have > desired key name for this input system. > > This helps userspace code to get name and perform proper > event to key mapping in some of cases. In android, the > user space map the key code to application code using > key character layout and for this it uses the name of > input system. Why is specifying the key code not enough? > Signed-off-by: Laxman Dewangan <ldewangan@nvidia.com> > --- > Documentation/devicetree/bindings/input/gpio-keys.txt | 1 + > drivers/input/keyboard/gpio_keys.c | 2 ++ > 2 files changed, 3 insertions(+) > > diff --git a/Documentation/devicetree/bindings/input/gpio-keys.txt b/Documentation/devicetree/bindings/input/gpio-keys.txt > index cf1333d..2e6bcd2 100644 > --- a/Documentation/devicetree/bindings/input/gpio-keys.txt > +++ b/Documentation/devicetree/bindings/input/gpio-keys.txt > @@ -4,6 +4,7 @@ Required properties: > - compatible = "gpio-keys"; > > Optional properties: > + - gpio-keys,name: String, name of the gpio-keys input system. gpio-keys is not a vendor. Would "label" work for you instead? Either way, I'm concerned this doesn't work for other key bindings which have multiple keys. > - autorepeat: Boolean, Enable auto repeat feature of Linux input > subsystem. > -- To unsubscribe from this list: send the line "unsubscribe linux-input" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
On Tuesday 12 January 2016 08:13 PM, Rob Herring wrote: > On Tue, Jan 12, 2016 at 05:02:50PM +0530, Laxman Dewangan wrote: >> Add support from DT to name the gpio-keys driver to have >> desired key name for this input system. >> >> This helps userspace code to get name and perform proper >> event to key mapping in some of cases. In android, the >> user space map the key code to application code using >> key character layout and for this it uses the name of >> input system. > Why is specifying the key code not enough? This is the name for input system instead of individual keys. In android system, the key mapping is done in user space. By having name offers to specifying the customized key character layout instead of generic one form android which is fall-back. > >> Signed-off-by: Laxman Dewangan <ldewangan@nvidia.com> >> --- >> Documentation/devicetree/bindings/input/gpio-keys.txt | 1 + >> drivers/input/keyboard/gpio_keys.c | 2 ++ >> 2 files changed, 3 insertions(+) >> >> diff --git a/Documentation/devicetree/bindings/input/gpio-keys.txt b/Documentation/devicetree/bindings/input/gpio-keys.txt >> index cf1333d..2e6bcd2 100644 >> --- a/Documentation/devicetree/bindings/input/gpio-keys.txt >> +++ b/Documentation/devicetree/bindings/input/gpio-keys.txt >> @@ -4,6 +4,7 @@ Required properties: >> - compatible = "gpio-keys"; >> >> Optional properties: >> + - gpio-keys,name: String, name of the gpio-keys input system. > gpio-keys is not a vendor. > > Would "label" work for you instead? "label" means node name? > > Either way, I'm concerned this doesn't work for other key bindings > which have multiple keys. > > This is not for the individual keys, its for input system like /sys/class/input/input0/name. -- To unsubscribe from this list: send the line "unsubscribe linux-input" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
On Tue, Jan 12, 2016 at 8:55 AM, Laxman Dewangan <ldewangan@nvidia.com> wrote: > > On Tuesday 12 January 2016 08:13 PM, Rob Herring wrote: >> >> On Tue, Jan 12, 2016 at 05:02:50PM +0530, Laxman Dewangan wrote: >>> >>> Add support from DT to name the gpio-keys driver to have >>> desired key name for this input system. >>> >>> This helps userspace code to get name and perform proper >>> event to key mapping in some of cases. In android, the >>> user space map the key code to application code using >>> key character layout and for this it uses the name of >>> input system. >> >> Why is specifying the key code not enough? > > > This is the name for input system instead of individual keys. > In android system, the key mapping is done in user space. By having name > offers to specifying the customized key character layout instead of generic > one form android which is fall-back. Okay, got it. >>> Signed-off-by: Laxman Dewangan <ldewangan@nvidia.com> >>> --- >>> Documentation/devicetree/bindings/input/gpio-keys.txt | 1 + >>> drivers/input/keyboard/gpio_keys.c | 2 ++ >>> 2 files changed, 3 insertions(+) >>> >>> diff --git a/Documentation/devicetree/bindings/input/gpio-keys.txt >>> b/Documentation/devicetree/bindings/input/gpio-keys.txt >>> index cf1333d..2e6bcd2 100644 >>> --- a/Documentation/devicetree/bindings/input/gpio-keys.txt >>> +++ b/Documentation/devicetree/bindings/input/gpio-keys.txt >>> @@ -4,6 +4,7 @@ Required properties: >>> - compatible = "gpio-keys"; >>> Optional properties: >>> + - gpio-keys,name: String, name of the gpio-keys input system. >> >> gpio-keys is not a vendor. >> >> Would "label" work for you instead? > > > "label" means node name? No, the standard label property. See gpio-leds for an example. >> Either way, I'm concerned this doesn't work for other key bindings >> which have multiple keys. >> >> > > This is not for the individual keys, its for input system like > /sys/class/input/input0/name. So label is exactly for this purpose of defining user meaningful names. Rob -- To unsubscribe from this list: send the line "unsubscribe linux-input" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
On Tuesday 12 January 2016 08:53 PM, Rob Herring wrote: > On Tue, Jan 12, 2016 at 8:55 AM, Laxman Dewangan <ldewangan@nvidia.com> wrote: >> On Tuesday 12 January 2016 08:13 PM, Rob Herring wrote: >>> On Tue, Jan 12, 2016 at 05:02:50PM +0530, Laxman Dewangan wrote: > So label is exactly for this purpose of defining user meaningful names. > Yes, I can use the label for name. I will update the patch. Just for understanding, is "label" is better property name to pass the specific name? -- To unsubscribe from this list: send the line "unsubscribe linux-input" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
On Tue, Jan 12, 2016 at 4:24 PM, Laxman Dewangan <ldewangan@nvidia.com> wrote: > On Tuesday 12 January 2016 08:53 PM, Rob Herring wrote: >> On Tue, Jan 12, 2016 at 8:55 AM, Laxman Dewangan <ldewangan@nvidia.com> >> wrote: >>> >>> On Tuesday 12 January 2016 08:13 PM, Rob Herring wrote: >>>> >>>> On Tue, Jan 12, 2016 at 05:02:50PM +0530, Laxman Dewangan wrote: > > >> So label is exactly for this purpose of defining user meaningful names. >> > Yes, I can use the label for name. I will update the patch. > > Just for understanding, is "label" is better property name to pass the > specific name? Yes, look at this from arch/arm64/boot/dts/arm/juno-motherboard.dtsi: gpio_keys { compatible = "gpio-keys"; #address-cells = <1>; #size-cells = <0>; button@1 { debounce_interval = <50>; wakeup-source; linux,code = <116>; label = "POWER"; gpios = <&iofpga_gpio0 0 0x4>; }; button@2 { debounce_interval = <50>; wakeup-source; linux,code = <102>; label = "HOME"; gpios = <&iofpga_gpio0 1 0x4>; }; (...) Currently these names (POWER, HOME etc) appear nicely in /proc/interrupts, so I guess the same should be used for input? Yours, Linus Walleij -- To unsubscribe from this list: send the line "unsubscribe linux-input" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
diff --git a/Documentation/devicetree/bindings/input/gpio-keys.txt b/Documentation/devicetree/bindings/input/gpio-keys.txt index cf1333d..2e6bcd2 100644 --- a/Documentation/devicetree/bindings/input/gpio-keys.txt +++ b/Documentation/devicetree/bindings/input/gpio-keys.txt @@ -4,6 +4,7 @@ Required properties: - compatible = "gpio-keys"; Optional properties: + - gpio-keys,name: String, name of the gpio-keys input system. - autorepeat: Boolean, Enable auto repeat feature of Linux input subsystem. diff --git a/drivers/input/keyboard/gpio_keys.c b/drivers/input/keyboard/gpio_keys.c index cf068cb..c95dc3b 100644 --- a/drivers/input/keyboard/gpio_keys.c +++ b/drivers/input/keyboard/gpio_keys.c @@ -628,6 +628,8 @@ gpio_keys_get_devtree_pdata(struct device *dev) pdata->rep = !!of_get_property(node, "autorepeat", NULL); + of_property_read_string(node, "gpio-keys,name", &pdata->name); + i = 0; for_each_child_of_node(node, pp) { enum of_gpio_flags flags;
Add support from DT to name the gpio-keys driver to have desired key name for this input system. This helps userspace code to get name and perform proper event to key mapping in some of cases. In android, the user space map the key code to application code using key character layout and for this it uses the name of input system. Signed-off-by: Laxman Dewangan <ldewangan@nvidia.com> --- Documentation/devicetree/bindings/input/gpio-keys.txt | 1 + drivers/input/keyboard/gpio_keys.c | 2 ++ 2 files changed, 3 insertions(+)