162306a36Sopenharmony_ci# SPDX-License-Identifier: (GPL-2.0 OR BSD-2-Clause) 262306a36Sopenharmony_ci%YAML 1.2 362306a36Sopenharmony_ci--- 462306a36Sopenharmony_ci 562306a36Sopenharmony_ci$id: http://devicetree.org/schemas/input/google,cros-ec-keyb.yaml# 662306a36Sopenharmony_ci$schema: http://devicetree.org/meta-schemas/core.yaml# 762306a36Sopenharmony_ci 862306a36Sopenharmony_cititle: ChromeOS EC Keyboard 962306a36Sopenharmony_ci 1062306a36Sopenharmony_cimaintainers: 1162306a36Sopenharmony_ci - Simon Glass <sjg@chromium.org> 1262306a36Sopenharmony_ci - Benson Leung <bleung@chromium.org> 1362306a36Sopenharmony_ci 1462306a36Sopenharmony_cidescription: | 1562306a36Sopenharmony_ci Google's ChromeOS EC Keyboard is a simple matrix keyboard 1662306a36Sopenharmony_ci implemented on a separate EC (Embedded Controller) device. It provides 1762306a36Sopenharmony_ci a message for reading key scans from the EC. These are then converted 1862306a36Sopenharmony_ci into keycodes for processing by the kernel. This device also supports 1962306a36Sopenharmony_ci switches/buttons like power and volume buttons. 2062306a36Sopenharmony_ci 2162306a36Sopenharmony_ciproperties: 2262306a36Sopenharmony_ci compatible: 2362306a36Sopenharmony_ci oneOf: 2462306a36Sopenharmony_ci - description: ChromeOS EC with only buttons/switches 2562306a36Sopenharmony_ci const: google,cros-ec-keyb-switches 2662306a36Sopenharmony_ci - description: ChromeOS EC with keyboard and possibly buttons/switches 2762306a36Sopenharmony_ci const: google,cros-ec-keyb 2862306a36Sopenharmony_ci 2962306a36Sopenharmony_ci google,needs-ghost-filter: 3062306a36Sopenharmony_ci description: 3162306a36Sopenharmony_ci Enable a ghost filter for the matrix keyboard. This is recommended 3262306a36Sopenharmony_ci if the EC does not have its own logic or hardware for this. 3362306a36Sopenharmony_ci type: boolean 3462306a36Sopenharmony_ci 3562306a36Sopenharmony_ci function-row-physmap: 3662306a36Sopenharmony_ci $ref: /schemas/types.yaml#/definitions/uint32-array 3762306a36Sopenharmony_ci minItems: 1 3862306a36Sopenharmony_ci maxItems: 15 3962306a36Sopenharmony_ci description: | 4062306a36Sopenharmony_ci An ordered u32 array describing the rows/columns (in the scan matrix) 4162306a36Sopenharmony_ci of top row keys from physical left (KEY_F1) to right. Each entry 4262306a36Sopenharmony_ci encodes the row/column as: 4362306a36Sopenharmony_ci (((row) & 0xFF) << 24) | (((column) & 0xFF) << 16) 4462306a36Sopenharmony_ci where the lower 16 bits are reserved. This property is specified only 4562306a36Sopenharmony_ci when the keyboard has a custom design for the top row keys. 4662306a36Sopenharmony_ci 4762306a36Sopenharmony_cidependencies: 4862306a36Sopenharmony_ci function-row-physmap: [ 'linux,keymap' ] 4962306a36Sopenharmony_ci google,needs-ghost-filter: [ 'linux,keymap' ] 5062306a36Sopenharmony_ci 5162306a36Sopenharmony_cirequired: 5262306a36Sopenharmony_ci - compatible 5362306a36Sopenharmony_ci 5462306a36Sopenharmony_ciif: 5562306a36Sopenharmony_ci properties: 5662306a36Sopenharmony_ci compatible: 5762306a36Sopenharmony_ci contains: 5862306a36Sopenharmony_ci const: google,cros-ec-keyb 5962306a36Sopenharmony_cithen: 6062306a36Sopenharmony_ci $ref: /schemas/input/matrix-keymap.yaml# 6162306a36Sopenharmony_ci required: 6262306a36Sopenharmony_ci - keypad,num-rows 6362306a36Sopenharmony_ci - keypad,num-columns 6462306a36Sopenharmony_ci - linux,keymap 6562306a36Sopenharmony_ci 6662306a36Sopenharmony_ciunevaluatedProperties: false 6762306a36Sopenharmony_ci 6862306a36Sopenharmony_ciexamples: 6962306a36Sopenharmony_ci - | 7062306a36Sopenharmony_ci #include <dt-bindings/input/input.h> 7162306a36Sopenharmony_ci keyboard-controller { 7262306a36Sopenharmony_ci compatible = "google,cros-ec-keyb"; 7362306a36Sopenharmony_ci keypad,num-rows = <8>; 7462306a36Sopenharmony_ci keypad,num-columns = <13>; 7562306a36Sopenharmony_ci google,needs-ghost-filter; 7662306a36Sopenharmony_ci function-row-physmap = < 7762306a36Sopenharmony_ci MATRIX_KEY(0x00, 0x02, 0) /* T1 */ 7862306a36Sopenharmony_ci MATRIX_KEY(0x03, 0x02, 0) /* T2 */ 7962306a36Sopenharmony_ci MATRIX_KEY(0x02, 0x02, 0) /* T3 */ 8062306a36Sopenharmony_ci MATRIX_KEY(0x01, 0x02, 0) /* T4 */ 8162306a36Sopenharmony_ci MATRIX_KEY(0x03, 0x04, 0) /* T5 */ 8262306a36Sopenharmony_ci MATRIX_KEY(0x02, 0x04, 0) /* T6 */ 8362306a36Sopenharmony_ci MATRIX_KEY(0x01, 0x04, 0) /* T7 */ 8462306a36Sopenharmony_ci MATRIX_KEY(0x02, 0x09, 0) /* T8 */ 8562306a36Sopenharmony_ci MATRIX_KEY(0x01, 0x09, 0) /* T9 */ 8662306a36Sopenharmony_ci MATRIX_KEY(0x00, 0x04, 0) /* T10 */ 8762306a36Sopenharmony_ci >; 8862306a36Sopenharmony_ci /* 8962306a36Sopenharmony_ci * Keymap entries take the form of 0xRRCCKKKK where 9062306a36Sopenharmony_ci * RR=Row CC=Column KKKK=Key Code 9162306a36Sopenharmony_ci * The values below are for a US keyboard layout and 9262306a36Sopenharmony_ci * are taken from the Linux driver. Note that the 9362306a36Sopenharmony_ci * 102ND key is not used for US keyboards. 9462306a36Sopenharmony_ci */ 9562306a36Sopenharmony_ci linux,keymap = < 9662306a36Sopenharmony_ci /* CAPSLCK F1 B F10 */ 9762306a36Sopenharmony_ci 0x0001003a 0x0002003b 0x00030030 0x00040044 9862306a36Sopenharmony_ci /* N = R_ALT ESC */ 9962306a36Sopenharmony_ci 0x00060031 0x0008000d 0x000a0064 0x01010001 10062306a36Sopenharmony_ci /* F4 G F7 H */ 10162306a36Sopenharmony_ci 0x0102003e 0x01030022 0x01040041 0x01060023 10262306a36Sopenharmony_ci /* ' F9 BKSPACE L_CTRL */ 10362306a36Sopenharmony_ci 0x01080028 0x01090043 0x010b000e 0x0200001d 10462306a36Sopenharmony_ci /* TAB F3 T F6 */ 10562306a36Sopenharmony_ci 0x0201000f 0x0202003d 0x02030014 0x02040040 10662306a36Sopenharmony_ci /* ] Y 102ND [ */ 10762306a36Sopenharmony_ci 0x0205001b 0x02060015 0x02070056 0x0208001a 10862306a36Sopenharmony_ci /* F8 GRAVE F2 5 */ 10962306a36Sopenharmony_ci 0x02090042 0x03010029 0x0302003c 0x03030006 11062306a36Sopenharmony_ci /* F5 6 - \ */ 11162306a36Sopenharmony_ci 0x0304003f 0x03060007 0x0308000c 0x030b002b 11262306a36Sopenharmony_ci /* R_CTRL A D F */ 11362306a36Sopenharmony_ci 0x04000061 0x0401001e 0x04020020 0x04030021 11462306a36Sopenharmony_ci /* S K J ; */ 11562306a36Sopenharmony_ci 0x0404001f 0x04050025 0x04060024 0x04080027 11662306a36Sopenharmony_ci /* L ENTER Z C */ 11762306a36Sopenharmony_ci 0x04090026 0x040b001c 0x0501002c 0x0502002e 11862306a36Sopenharmony_ci /* V X , M */ 11962306a36Sopenharmony_ci 0x0503002f 0x0504002d 0x05050033 0x05060032 12062306a36Sopenharmony_ci /* L_SHIFT / . SPACE */ 12162306a36Sopenharmony_ci 0x0507002a 0x05080035 0x05090034 0x050B0039 12262306a36Sopenharmony_ci /* 1 3 4 2 */ 12362306a36Sopenharmony_ci 0x06010002 0x06020004 0x06030005 0x06040003 12462306a36Sopenharmony_ci /* 8 7 0 9 */ 12562306a36Sopenharmony_ci 0x06050009 0x06060008 0x0608000b 0x0609000a 12662306a36Sopenharmony_ci /* L_ALT DOWN RIGHT Q */ 12762306a36Sopenharmony_ci 0x060a0038 0x060b006c 0x060c006a 0x07010010 12862306a36Sopenharmony_ci /* E R W I */ 12962306a36Sopenharmony_ci 0x07020012 0x07030013 0x07040011 0x07050017 13062306a36Sopenharmony_ci /* U R_SHIFT P O */ 13162306a36Sopenharmony_ci 0x07060016 0x07070036 0x07080019 0x07090018 13262306a36Sopenharmony_ci /* UP LEFT */ 13362306a36Sopenharmony_ci 0x070b0067 0x070c0069>; 13462306a36Sopenharmony_ci }; 13562306a36Sopenharmony_ci - | 13662306a36Sopenharmony_ci /* No matrix keyboard, just buttons/switches */ 13762306a36Sopenharmony_ci keyboard-controller { 13862306a36Sopenharmony_ci compatible = "google,cros-ec-keyb-switches"; 13962306a36Sopenharmony_ci }; 14062306a36Sopenharmony_ci... 141