| # SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) |
| %YAML 1.2 |
| --- |
| $id: http://devicetree.org/schemas/input/touchscreen/ti,am3359-tsc.yaml# |
| $schema: http://devicetree.org/meta-schemas/core.yaml# |
| |
| title: TI AM3359 Touchscreen controller |
| |
| maintainers: |
| - Miquel Raynal <miquel.raynal@bootlin.com> |
| |
| properties: |
| compatible: |
| const: ti,am3359-tsc |
| |
| ti,wires: |
| description: Wires refer to application modes i.e. 4/5/8 wire touchscreen |
| support on the platform. |
| $ref: /schemas/types.yaml#/definitions/uint32 |
| enum: [4, 5, 8] |
| |
| ti,x-plate-resistance: |
| description: X plate resistance |
| $ref: /schemas/types.yaml#/definitions/uint32 |
| |
| ti,coordinate-readouts: |
| description: The sequencer supports a total of 16 programmable steps. Each |
| step is used to read a single coordinate. A single readout is enough but |
| multiple reads can increase the quality. A value of 5 means, 5 reads for |
| X, 5 for Y and 2 for Z (always). This utilises 12 of the 16 software steps |
| available. The remaining 4 can be used by the ADC. |
| $ref: /schemas/types.yaml#/definitions/uint32 |
| minimum: 1 |
| maximum: 6 |
| |
| ti,wire-config: |
| description: Different boards could have a different order for connecting |
| wires on touchscreen. We need to provide an 8-bit number where the |
| first four bits represent the analog lines and the next 4 bits represent |
| positive/negative terminal on that input line. Notations to represent the |
| input lines and terminals respectively are as follows, AIN0 = 0, AIN1 = 1 |
| and so on until AIN7 = 7. XP = 0, XN = 1, YP = 2, YN = 3. |
| $ref: /schemas/types.yaml#/definitions/uint32-array |
| minItems: 4 |
| maxItems: 8 |
| |
| ti,charge-delay: |
| description: Length of touch screen charge delay step in terms of ADC clock |
| cycles. Charge delay value should be large in order to avoid false pen-up |
| events. This value effects the overall sampling speed, hence need to be |
| kept as low as possible, while avoiding false pen-up event. Start from a |
| lower value, say 0x400, and increase value until false pen-up events are |
| avoided. The pen-up detection happens immediately after the charge step, |
| so this does in fact function as a hardware knob for adjusting the amount |
| of "settling time". |
| $ref: /schemas/types.yaml#/definitions/uint32 |
| |
| required: |
| - compatible |
| - ti,wires |
| - ti,x-plate-resistance |
| - ti,coordinate-readouts |
| - ti,wire-config |
| |
| additionalProperties: false |
| |
| examples: |
| - | |
| tsc { |
| compatible = "ti,am3359-tsc"; |
| ti,wires = <4>; |
| ti,x-plate-resistance = <200>; |
| ti,coordinate-readouts = <5>; |
| ti,wire-config = <0x00 0x11 0x22 0x33>; |
| ti,charge-delay = <0x400>; |
| }; |