162306a36Sopenharmony_ci# SPDX-License-Identifier: GPL-2.0 262306a36Sopenharmony_ci%YAML 1.2 362306a36Sopenharmony_ci--- 462306a36Sopenharmony_ci$id: http://devicetree.org/schemas/iio/adc/samsung,exynos-adc.yaml# 562306a36Sopenharmony_ci$schema: http://devicetree.org/meta-schemas/core.yaml# 662306a36Sopenharmony_ci 762306a36Sopenharmony_cititle: Samsung Exynos Analog to Digital Converter (ADC) 862306a36Sopenharmony_ci 962306a36Sopenharmony_cimaintainers: 1062306a36Sopenharmony_ci - Krzysztof Kozlowski <krzk@kernel.org> 1162306a36Sopenharmony_ci 1262306a36Sopenharmony_ciproperties: 1362306a36Sopenharmony_ci compatible: 1462306a36Sopenharmony_ci enum: 1562306a36Sopenharmony_ci - samsung,exynos-adc-v1 # Exynos5250 1662306a36Sopenharmony_ci - samsung,exynos-adc-v2 1762306a36Sopenharmony_ci - samsung,exynos3250-adc 1862306a36Sopenharmony_ci - samsung,exynos4212-adc # Exynos4212 and Exynos4412 1962306a36Sopenharmony_ci - samsung,exynos7-adc 2062306a36Sopenharmony_ci - samsung,s3c2410-adc 2162306a36Sopenharmony_ci - samsung,s3c2416-adc 2262306a36Sopenharmony_ci - samsung,s3c2440-adc 2362306a36Sopenharmony_ci - samsung,s3c2443-adc 2462306a36Sopenharmony_ci - samsung,s3c6410-adc 2562306a36Sopenharmony_ci - samsung,s5pv210-adc 2662306a36Sopenharmony_ci 2762306a36Sopenharmony_ci reg: 2862306a36Sopenharmony_ci maxItems: 1 2962306a36Sopenharmony_ci 3062306a36Sopenharmony_ci clocks: 3162306a36Sopenharmony_ci description: 3262306a36Sopenharmony_ci Phandle to ADC bus clock. For Exynos3250 additional clock is needed. 3362306a36Sopenharmony_ci minItems: 1 3462306a36Sopenharmony_ci maxItems: 2 3562306a36Sopenharmony_ci 3662306a36Sopenharmony_ci clock-names: 3762306a36Sopenharmony_ci description: 3862306a36Sopenharmony_ci Must contain clock names (adc, sclk) matching phandles in clocks 3962306a36Sopenharmony_ci property. 4062306a36Sopenharmony_ci minItems: 1 4162306a36Sopenharmony_ci maxItems: 2 4262306a36Sopenharmony_ci 4362306a36Sopenharmony_ci interrupts: 4462306a36Sopenharmony_ci description: 4562306a36Sopenharmony_ci ADC interrupt followed by optional touchscreen interrupt. 4662306a36Sopenharmony_ci minItems: 1 4762306a36Sopenharmony_ci maxItems: 2 4862306a36Sopenharmony_ci 4962306a36Sopenharmony_ci "#io-channel-cells": 5062306a36Sopenharmony_ci const: 1 5162306a36Sopenharmony_ci 5262306a36Sopenharmony_ci vdd-supply: true 5362306a36Sopenharmony_ci 5462306a36Sopenharmony_ci samsung,syscon-phandle: 5562306a36Sopenharmony_ci $ref: /schemas/types.yaml#/definitions/phandle 5662306a36Sopenharmony_ci description: 5762306a36Sopenharmony_ci Phandle to the PMU system controller node (to access the ADC_PHY 5862306a36Sopenharmony_ci register on Exynos3250/4x12/5250/5420/5800). 5962306a36Sopenharmony_ci 6062306a36Sopenharmony_ci has-touchscreen: 6162306a36Sopenharmony_ci description: 6262306a36Sopenharmony_ci If present, indicates that a touchscreen is connected and usable. 6362306a36Sopenharmony_ci type: boolean 6462306a36Sopenharmony_ci 6562306a36Sopenharmony_cirequired: 6662306a36Sopenharmony_ci - compatible 6762306a36Sopenharmony_ci - reg 6862306a36Sopenharmony_ci - clocks 6962306a36Sopenharmony_ci - clock-names 7062306a36Sopenharmony_ci - interrupts 7162306a36Sopenharmony_ci - "#io-channel-cells" 7262306a36Sopenharmony_ci - vdd-supply 7362306a36Sopenharmony_ci 7462306a36Sopenharmony_ciadditionalProperties: 7562306a36Sopenharmony_ci type: object 7662306a36Sopenharmony_ci 7762306a36Sopenharmony_ciallOf: 7862306a36Sopenharmony_ci - if: 7962306a36Sopenharmony_ci properties: 8062306a36Sopenharmony_ci compatible: 8162306a36Sopenharmony_ci contains: 8262306a36Sopenharmony_ci enum: 8362306a36Sopenharmony_ci - samsung,exynos-adc-v1 8462306a36Sopenharmony_ci - samsung,exynos-adc-v2 8562306a36Sopenharmony_ci - samsung,exynos3250-adc 8662306a36Sopenharmony_ci - samsung,exynos4212-adc 8762306a36Sopenharmony_ci then: 8862306a36Sopenharmony_ci required: 8962306a36Sopenharmony_ci - samsung,syscon-phandle 9062306a36Sopenharmony_ci 9162306a36Sopenharmony_ci - if: 9262306a36Sopenharmony_ci properties: 9362306a36Sopenharmony_ci compatible: 9462306a36Sopenharmony_ci contains: 9562306a36Sopenharmony_ci enum: 9662306a36Sopenharmony_ci - samsung,exynos3250-adc 9762306a36Sopenharmony_ci then: 9862306a36Sopenharmony_ci properties: 9962306a36Sopenharmony_ci clocks: 10062306a36Sopenharmony_ci minItems: 2 10162306a36Sopenharmony_ci maxItems: 2 10262306a36Sopenharmony_ci clock-names: 10362306a36Sopenharmony_ci items: 10462306a36Sopenharmony_ci - const: adc 10562306a36Sopenharmony_ci - const: sclk 10662306a36Sopenharmony_ci else: 10762306a36Sopenharmony_ci properties: 10862306a36Sopenharmony_ci clocks: 10962306a36Sopenharmony_ci minItems: 1 11062306a36Sopenharmony_ci maxItems: 1 11162306a36Sopenharmony_ci clock-names: 11262306a36Sopenharmony_ci items: 11362306a36Sopenharmony_ci - const: adc 11462306a36Sopenharmony_ci 11562306a36Sopenharmony_ci - if: 11662306a36Sopenharmony_ci required: 11762306a36Sopenharmony_ci - has-touchscreen 11862306a36Sopenharmony_ci then: 11962306a36Sopenharmony_ci properties: 12062306a36Sopenharmony_ci interrupts: 12162306a36Sopenharmony_ci minItems: 2 12262306a36Sopenharmony_ci maxItems: 2 12362306a36Sopenharmony_ci 12462306a36Sopenharmony_ciexamples: 12562306a36Sopenharmony_ci - | 12662306a36Sopenharmony_ci adc: adc@12d10000 { 12762306a36Sopenharmony_ci compatible = "samsung,exynos-adc-v1"; 12862306a36Sopenharmony_ci reg = <0x12d10000 0x100>; 12962306a36Sopenharmony_ci interrupts = <0 106 0>; 13062306a36Sopenharmony_ci #io-channel-cells = <1>; 13162306a36Sopenharmony_ci 13262306a36Sopenharmony_ci clocks = <&clock 303>; 13362306a36Sopenharmony_ci clock-names = "adc"; 13462306a36Sopenharmony_ci 13562306a36Sopenharmony_ci vdd-supply = <&buck5_reg>; 13662306a36Sopenharmony_ci samsung,syscon-phandle = <&pmu_system_controller>; 13762306a36Sopenharmony_ci 13862306a36Sopenharmony_ci /* NTC thermistor is a hwmon device */ 13962306a36Sopenharmony_ci thermistor { 14062306a36Sopenharmony_ci compatible = "murata,ncp15wb473"; 14162306a36Sopenharmony_ci pullup-uv = <1800000>; 14262306a36Sopenharmony_ci pullup-ohm = <47000>; 14362306a36Sopenharmony_ci pulldown-ohm = <0>; 14462306a36Sopenharmony_ci io-channels = <&adc 4>; 14562306a36Sopenharmony_ci }; 14662306a36Sopenharmony_ci }; 14762306a36Sopenharmony_ci 14862306a36Sopenharmony_ci - | 14962306a36Sopenharmony_ci #include <dt-bindings/clock/exynos3250.h> 15062306a36Sopenharmony_ci 15162306a36Sopenharmony_ci adc@126c0000 { 15262306a36Sopenharmony_ci compatible = "samsung,exynos3250-adc"; 15362306a36Sopenharmony_ci reg = <0x126c0000 0x100>; 15462306a36Sopenharmony_ci interrupts = <0 137 0>; 15562306a36Sopenharmony_ci #io-channel-cells = <1>; 15662306a36Sopenharmony_ci 15762306a36Sopenharmony_ci clocks = <&cmu CLK_TSADC>, 15862306a36Sopenharmony_ci <&cmu CLK_SCLK_TSADC>; 15962306a36Sopenharmony_ci clock-names = "adc", "sclk"; 16062306a36Sopenharmony_ci 16162306a36Sopenharmony_ci vdd-supply = <&buck5_reg>; 16262306a36Sopenharmony_ci samsung,syscon-phandle = <&pmu_system_controller>; 16362306a36Sopenharmony_ci }; 164