ASoC: dt-bindings: nau8824: Convert to dtschema
Convert the NAU8824 audio CODEC bindings to DT schema. Signed-off-by: David Lin <CTLIN0@nuvoton.com Reviewed-by: Krzysztof Kozlowski <krzysztof.kozlowski@linaro.org Link: https://lore.kernel.org/r/20230515065557.614125-1-CTLIN0@nuvoton.com Signed-off-by: Mark Brown <broonie@kernel.org
This commit is contained in:
parent
20ef7f2139
commit
518a1742f4
@ -1,88 +0,0 @@
|
|||||||
Nuvoton NAU8824 audio codec
|
|
||||||
|
|
||||||
This device supports I2C only.
|
|
||||||
|
|
||||||
Required properties:
|
|
||||||
- compatible : Must be "nuvoton,nau8824"
|
|
||||||
|
|
||||||
- reg : the I2C address of the device. This is either 0x1a (CSB=0) or 0x1b (CSB=1).
|
|
||||||
|
|
||||||
Optional properties:
|
|
||||||
- nuvoton,jkdet-polarity: JKDET pin polarity. 0 - active high, 1 - active low.
|
|
||||||
|
|
||||||
- nuvoton,vref-impedance: VREF Impedance selection
|
|
||||||
0 - Open
|
|
||||||
1 - 25 kOhm
|
|
||||||
2 - 125 kOhm
|
|
||||||
3 - 2.5 kOhm
|
|
||||||
|
|
||||||
- nuvoton,micbias-voltage: Micbias voltage level.
|
|
||||||
0 - VDDA
|
|
||||||
1 - VDDA
|
|
||||||
2 - VDDA * 1.1
|
|
||||||
3 - VDDA * 1.2
|
|
||||||
4 - VDDA * 1.3
|
|
||||||
5 - VDDA * 1.4
|
|
||||||
6 - VDDA * 1.53
|
|
||||||
7 - VDDA * 1.53
|
|
||||||
|
|
||||||
- nuvoton,sar-threshold-num: Number of buttons supported
|
|
||||||
- nuvoton,sar-threshold: Impedance threshold for each button. Array that contains up to 8 buttons configuration. SAR value is calculated as
|
|
||||||
SAR = 255 * MICBIAS / SAR_VOLTAGE * R / (2000 + R)
|
|
||||||
where MICBIAS is configured by 'nuvoton,micbias-voltage', SAR_VOLTAGE is configured by 'nuvoton,sar-voltage', R - button impedance.
|
|
||||||
Refer datasheet section 10.2 for more information about threshold calculation.
|
|
||||||
|
|
||||||
- nuvoton,sar-hysteresis: Button impedance measurement hysteresis.
|
|
||||||
|
|
||||||
- nuvoton,sar-voltage: Reference voltage for button impedance measurement.
|
|
||||||
0 - VDDA
|
|
||||||
1 - VDDA
|
|
||||||
2 - VDDA * 1.1
|
|
||||||
3 - VDDA * 1.2
|
|
||||||
4 - VDDA * 1.3
|
|
||||||
5 - VDDA * 1.4
|
|
||||||
6 - VDDA * 1.53
|
|
||||||
7 - VDDA * 1.53
|
|
||||||
|
|
||||||
- nuvoton,sar-compare-time: SAR compare time
|
|
||||||
0 - 500 ns
|
|
||||||
1 - 1 us
|
|
||||||
2 - 2 us
|
|
||||||
3 - 4 us
|
|
||||||
|
|
||||||
- nuvoton,sar-sampling-time: SAR sampling time
|
|
||||||
0 - 2 us
|
|
||||||
1 - 4 us
|
|
||||||
2 - 8 us
|
|
||||||
3 - 16 us
|
|
||||||
|
|
||||||
- nuvoton,short-key-debounce: Button short key press debounce time.
|
|
||||||
0 - 30 ms
|
|
||||||
1 - 50 ms
|
|
||||||
2 - 100 ms
|
|
||||||
|
|
||||||
- nuvoton,jack-eject-debounce: Jack ejection debounce time.
|
|
||||||
0 - 0 ms
|
|
||||||
1 - 1 ms
|
|
||||||
2 - 10 ms
|
|
||||||
|
|
||||||
|
|
||||||
Example:
|
|
||||||
|
|
||||||
headset: nau8824@1a {
|
|
||||||
compatible = "nuvoton,nau8824";
|
|
||||||
reg = <0x1a>;
|
|
||||||
interrupt-parent = <&gpio>;
|
|
||||||
interrupts = <TEGRA_GPIO(E, 6) IRQ_TYPE_LEVEL_LOW>;
|
|
||||||
nuvoton,vref-impedance = <2>;
|
|
||||||
nuvoton,micbias-voltage = <6>;
|
|
||||||
// Setup 4 buttons impedance according to Android specification
|
|
||||||
nuvoton,sar-threshold-num = <4>;
|
|
||||||
nuvoton,sar-threshold = <0xc 0x1e 0x38 0x60>;
|
|
||||||
nuvoton,sar-hysteresis = <0>;
|
|
||||||
nuvoton,sar-voltage = <6>;
|
|
||||||
nuvoton,sar-compare-time = <1>;
|
|
||||||
nuvoton,sar-sampling-time = <1>;
|
|
||||||
nuvoton,short-key-debounce = <0>;
|
|
||||||
nuvoton,jack-eject-debounce = <1>;
|
|
||||||
};
|
|
182
Documentation/devicetree/bindings/sound/nuvoton,nau8824.yaml
Normal file
182
Documentation/devicetree/bindings/sound/nuvoton,nau8824.yaml
Normal file
@ -0,0 +1,182 @@
|
|||||||
|
# SPDX-License-Identifier: GPL-2.0-only OR BSD-2-Clause
|
||||||
|
%YAML 1.2
|
||||||
|
---
|
||||||
|
$id: http://devicetree.org/schemas/sound/nuvoton,nau8824.yaml#
|
||||||
|
$schema: http://devicetree.org/meta-schemas/core.yaml#
|
||||||
|
|
||||||
|
title: NAU8824 audio CODEC
|
||||||
|
|
||||||
|
maintainers:
|
||||||
|
- John Hsu <KCHSU0@nuvoton.com>
|
||||||
|
|
||||||
|
allOf:
|
||||||
|
- $ref: dai-common.yaml#
|
||||||
|
|
||||||
|
properties:
|
||||||
|
compatible:
|
||||||
|
enum:
|
||||||
|
- nuvoton,nau8824
|
||||||
|
|
||||||
|
reg:
|
||||||
|
maxItems: 1
|
||||||
|
|
||||||
|
'#sound-dai-cells':
|
||||||
|
const: 0
|
||||||
|
|
||||||
|
interrupts:
|
||||||
|
maxItems: 1
|
||||||
|
|
||||||
|
nuvoton,jkdet-polarity:
|
||||||
|
$ref: /schemas/types.yaml#/definitions/uint32
|
||||||
|
description:
|
||||||
|
JKDET pin polarity.
|
||||||
|
enum:
|
||||||
|
- 0 # active high
|
||||||
|
- 1 # active low
|
||||||
|
default: 1
|
||||||
|
|
||||||
|
nuvoton,vref-impedance:
|
||||||
|
$ref: /schemas/types.yaml#/definitions/uint32
|
||||||
|
description:
|
||||||
|
VREF Impedance selection.
|
||||||
|
enum:
|
||||||
|
- 0 # Open
|
||||||
|
- 1 # 25 kOhm
|
||||||
|
- 2 # 125 kOhm
|
||||||
|
- 3 # 2.5 kOhm
|
||||||
|
default: 2
|
||||||
|
|
||||||
|
nuvoton,micbias-voltage:
|
||||||
|
$ref: /schemas/types.yaml#/definitions/uint32
|
||||||
|
description:
|
||||||
|
Micbias voltage level.
|
||||||
|
enum:
|
||||||
|
- 0 # VDDA
|
||||||
|
- 1 # VDDA
|
||||||
|
- 2 # VDDA * 1.1
|
||||||
|
- 3 # VDDA * 1.2
|
||||||
|
- 4 # VDDA * 1.3
|
||||||
|
- 5 # VDDA * 1.4
|
||||||
|
- 6 # VDDA * 1.53
|
||||||
|
- 7 # VDDA * 1.53
|
||||||
|
default: 6
|
||||||
|
|
||||||
|
nuvoton,sar-threshold-num:
|
||||||
|
$ref: /schemas/types.yaml#/definitions/uint32
|
||||||
|
description:
|
||||||
|
Number of buttons supported.
|
||||||
|
minimum: 1
|
||||||
|
maximum: 8
|
||||||
|
default: 4
|
||||||
|
|
||||||
|
nuvoton,sar-threshold:
|
||||||
|
$ref: /schemas/types.yaml#/definitions/uint32-array
|
||||||
|
description:
|
||||||
|
Impedance threshold for each button. Array that contains up to 8 buttons
|
||||||
|
configuration. SAR value is calculated as
|
||||||
|
SAR = 255 * MICBIAS / SAR_VOLTAGE * R / (2000 + R) where MICBIAS is
|
||||||
|
configured by 'nuvoton,micbias-voltage', SAR_VOLTAGE is configured by
|
||||||
|
'nuvoton,sar-voltage', R - button impedance.
|
||||||
|
Refer datasheet section 10.2 for more information about threshold
|
||||||
|
calculation.
|
||||||
|
minItems: 1
|
||||||
|
maxItems: 8
|
||||||
|
items:
|
||||||
|
minimum: 0
|
||||||
|
maximum: 255
|
||||||
|
|
||||||
|
nuvoton,sar-hysteresis:
|
||||||
|
$ref: /schemas/types.yaml#/definitions/uint32
|
||||||
|
description:
|
||||||
|
Button impedance measurement hysteresis.
|
||||||
|
default: 0
|
||||||
|
|
||||||
|
nuvoton,sar-voltage:
|
||||||
|
$ref: /schemas/types.yaml#/definitions/uint32
|
||||||
|
description:
|
||||||
|
Reference voltage for button impedance measurement.
|
||||||
|
enum:
|
||||||
|
- 0 # VDDA
|
||||||
|
- 1 # VDDA
|
||||||
|
- 2 # VDDA * 1.1
|
||||||
|
- 3 # VDDA * 1.2
|
||||||
|
- 4 # VDDA * 1.3
|
||||||
|
- 5 # VDDA * 1.4
|
||||||
|
- 6 # VDDA * 1.53
|
||||||
|
- 7 # VDDA * 1.53
|
||||||
|
default: 6
|
||||||
|
|
||||||
|
nuvoton,sar-compare-time:
|
||||||
|
$ref: /schemas/types.yaml#/definitions/uint32
|
||||||
|
description:
|
||||||
|
SAR compare time.
|
||||||
|
enum:
|
||||||
|
- 0 # 500ns
|
||||||
|
- 1 # 1us
|
||||||
|
- 2 # 2us
|
||||||
|
- 3 # 4us
|
||||||
|
default: 1
|
||||||
|
|
||||||
|
nuvoton,sar-sampling-time:
|
||||||
|
$ref: /schemas/types.yaml#/definitions/uint32
|
||||||
|
description:
|
||||||
|
SAR sampling time.
|
||||||
|
enum:
|
||||||
|
- 0 # 2us
|
||||||
|
- 1 # 4us
|
||||||
|
- 2 # 8us
|
||||||
|
- 3 # 16us
|
||||||
|
default: 1
|
||||||
|
|
||||||
|
nuvoton,short-key-debounce:
|
||||||
|
$ref: /schemas/types.yaml#/definitions/uint32
|
||||||
|
description:
|
||||||
|
Button short key press debounce time.
|
||||||
|
enum:
|
||||||
|
- 0 # 30 ms
|
||||||
|
- 1 # 50 ms
|
||||||
|
- 2 # 100 ms
|
||||||
|
default: 0
|
||||||
|
|
||||||
|
nuvoton,jack-eject-debounce:
|
||||||
|
$ref: /schemas/types.yaml#/definitions/uint32
|
||||||
|
description:
|
||||||
|
Jack ejection debounce time.
|
||||||
|
enum:
|
||||||
|
- 0 # 0 ms
|
||||||
|
- 1 # 1 ms
|
||||||
|
- 2 # 10 ms
|
||||||
|
default: 1
|
||||||
|
|
||||||
|
required:
|
||||||
|
- compatible
|
||||||
|
- reg
|
||||||
|
|
||||||
|
unevaluatedProperties: false
|
||||||
|
|
||||||
|
examples:
|
||||||
|
- |
|
||||||
|
#include <dt-bindings/gpio/gpio.h>
|
||||||
|
#include <dt-bindings/interrupt-controller/irq.h>
|
||||||
|
i2c {
|
||||||
|
#address-cells = <1>;
|
||||||
|
#size-cells = <0>;
|
||||||
|
codec@1a {
|
||||||
|
#sound-dai-cells = <0>;
|
||||||
|
compatible = "nuvoton,nau8824";
|
||||||
|
reg = <0x1a>;
|
||||||
|
interrupt-parent = <&gpio>;
|
||||||
|
interrupts = <38 IRQ_TYPE_LEVEL_LOW>;
|
||||||
|
nuvoton,vref-impedance = <2>;
|
||||||
|
nuvoton,micbias-voltage = <6>;
|
||||||
|
nuvoton,sar-threshold-num = <4>;
|
||||||
|
// Setup 4 buttons impedance according to Android specification
|
||||||
|
nuvoton,sar-threshold = <0xc 0x1e 0x38 0x60>;
|
||||||
|
nuvoton,sar-hysteresis = <0>;
|
||||||
|
nuvoton,sar-voltage = <6>;
|
||||||
|
nuvoton,sar-compare-time = <1>;
|
||||||
|
nuvoton,sar-sampling-time = <1>;
|
||||||
|
nuvoton,short-key-debounce = <0>;
|
||||||
|
nuvoton,jack-eject-debounce = <1>;
|
||||||
|
};
|
||||||
|
};
|
Loading…
x
Reference in New Issue
Block a user