# 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>; };