On Tue, 8 Aug 2023 15:22:52 +0800 Wenhua Lin <Wenhua.Lin@xxxxxxxxxx> wrote: > Add keypad driver ducumentation. documentation Though naming convention for dt-bindings patches does not look like this. Take a look at what has been accepted as bindings recently. Also you aren't going to get much review of this without cc'ing the dt list and maintainers. > > Signed-off-by: Wenhua Lin <Wenhua.Lin@xxxxxxxxxx> > --- > .../bindings/input/sprd-keypad.yaml | 76 +++++++++++++++++++ > 1 file changed, 76 insertions(+) > create mode 100644 Documentation/devicetree/bindings/input/sprd-keypad.yaml > > diff --git a/Documentation/devicetree/bindings/input/sprd-keypad.yaml b/Documentation/devicetree/bindings/input/sprd-keypad.yaml > new file mode 100644 > index 000000000000..51710e1eb389 > --- /dev/null > +++ b/Documentation/devicetree/bindings/input/sprd-keypad.yaml > @@ -0,0 +1,76 @@ > +# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) > +# Copyright 2023 Unisoc Inc. > +%YAML 1.2 > +--- > +$id: http://devicetree.org/schemas/input/sprd-keypad.yaml# > +$schema: http://devicetree.org/meta-schemas/core.yaml# > + > +title: Device-Tree bindings for GPIO attached keys Seems rather more specific than that! > + > +maintainers: > + - Orson Zhai <orsonzhai@xxxxxxxxx> > + - Baolin Wang <baolin.wang7@xxxxxxxxx> > + - Chunyan Zhang <zhang.lyra@xxxxxxxxx> > + > +description: | > + Keypad controller is used to interface a SoC with a matrix-keypad device. > + The keypad controller supports multiple row and column lines. > + A key can be placed at each intersection of a unique row and a unique column. > + The keypad controller can sense a key-press and key-release and report the > + event using a interrupt to the cpu. CPU > + > +properties: > + compatible: > + const: sprd,sc9860-keypad Make sure you follow the guidance on test building your binding and example. See Documentation/devicetree/bindings/writing-bindings.rst and submitting-patches.rst This has a lot of issues covered by that document. > + > + reg: > + maxItems: 1 > + > + interrupts: > + maxItems: 1 > + > + keypad,num-rows: > + description: Number of row lines connected to the keypad controller. > + > + keypad,num-columns: > + description: Number of column lines connected to the keypad. > + > + debounce-interval: > + description: > + Debouncing interval time in milliseconds. If not specified defaults to 5. > + $ref: /schemas/types.yaml#/definitions/uint32 > + > + default: 5 > + > + linux,keymap: > + description: An array of packed 1-cell entries containing the equivalent > + of row, column and linux key-code. The 32-bit big endian cell is packed. > + > +required: > + - compatible > + - reg > + - keypad,num-rows > + - keypad,num-columns > + - linux,keymap > + > +unevaluatedProperties: false > + > + > +examples: > + - | > + keypad@40250000 { > + compatible = "sprd,sc9860-keypad"; > + reg = <0x40250000 0x1000>; > + interrupts = <GIC_SPI 36 IRQ_TYPE_LEVEL_HIGH>; > + clocks = <&aonapb_gate CLK_KPD_EB>, > + <&aonapb_gate CLK_KPD_RTC_EB>; > + clock-names = "enable", "rtc"; > + keypad,num-rows= <3>; > + keypad,num-columns = <3>; > + debounce-interval = <5>; > + linux,keymap = < 0x00000001 > + 0x01000002 > + 0x00020003>; > + status = "okay"; Status shouldn't be in an example. Formatting wrong. IF your binding example doesn't build (this won't) then it won't be accepted by the dt-binding maintainers and their review is needed for it to be merged. Jonathan > + }; > +...