mirror of
https://github.com/torvalds/linux.git
synced 2026-04-28 03:22:27 -04:00
This swaps the descriptions of the 0 and 1 values to match
what the driver actually does with this property.
The background here is somewhat confusing. The codec has two
invert bits for the tip sense. The DT property should have been
for the TIP_SENSE_INV bit, which is the one that controls the
detect block. Due to some misunderstanding of the hardware the
driver actually implemented setting of the TS_INV bit, which is
only for swapping the sense of the interrupt bits. The description
was taken from the datasheet and refers to TIP_SENSE_INV but
unfortunately TS_INV has a different purpose and the net effect
of changing it is the reverse of what was intended (this is not
clearly described in the datasheet). So the ts-inv settings have
always done the exact opposite of what the description said.
Given the age of the driver, it's too late now to swap the meanings
of the values, so the description is changed to match the behaviour.
They have been annotated with the terminology used in the datasheet
to avoid the confusion of which one corresponds to what the datasheet
calls "inverted tip sense".
Signed-off-by: Richard Fitzgerald <rf@opensource.cirrus.com>
Fixes: da16c55793 ("ASoC: cs42l42: Add devicetree bindings for CS42L42")
Link: https://lore.kernel.org/r/20211028140902.11786-2-rf@opensource.cirrus.com
Signed-off-by: Mark Brown <broonie@kernel.org>
116 lines
3.7 KiB
Plaintext
116 lines
3.7 KiB
Plaintext
CS42L42 audio CODEC
|
|
|
|
Required properties:
|
|
|
|
- compatible : "cirrus,cs42l42"
|
|
|
|
- reg : the I2C address of the device for I2C.
|
|
|
|
- VP-supply, VCP-supply, VD_FILT-supply, VL-supply, VA-supply :
|
|
power supplies for the device, as covered in
|
|
Documentation/devicetree/bindings/regulator/regulator.txt.
|
|
|
|
Optional properties:
|
|
|
|
- reset-gpios : a GPIO spec for the reset pin. If specified, it will be
|
|
deasserted before communication to the codec starts.
|
|
|
|
- interrupts : IRQ line info CS42L42.
|
|
(See Documentation/devicetree/bindings/interrupt-controller/interrupts.txt
|
|
for further information relating to interrupt properties)
|
|
|
|
- cirrus,ts-inv : Boolean property. Sets the behaviour of the jack plug
|
|
detect switch.
|
|
|
|
0 = (Default) Shorted to tip when unplugged, open when plugged.
|
|
This is "inverted tip sense (ITS)" in the datasheet.
|
|
|
|
1 = Open when unplugged, shorted to tip when plugged.
|
|
This is "normal tip sense (TS)" in the datasheet.
|
|
|
|
- cirrus,ts-dbnc-rise : Debounce the rising edge of TIP_SENSE_PLUG. With no
|
|
debounce, the tip sense pin might be noisy on a plug event.
|
|
|
|
0 - 0ms,
|
|
1 - 125ms,
|
|
2 - 250ms,
|
|
3 - 500ms,
|
|
4 - 750ms,
|
|
5 - (Default) 1s,
|
|
6 - 1.25s,
|
|
7 - 1.5s,
|
|
|
|
- cirrus,ts-dbnc-fall : Debounce the falling edge of TIP_SENSE_UNPLUG.
|
|
With no debounce, the tip sense pin might be noisy on an unplug event.
|
|
|
|
0 - 0ms,
|
|
1 - 125ms,
|
|
2 - 250ms,
|
|
3 - 500ms,
|
|
4 - 750ms,
|
|
5 - (Default) 1s,
|
|
6 - 1.25s,
|
|
7 - 1.5s,
|
|
|
|
- cirrus,btn-det-init-dbnce : This sets how long the driver sleeps after
|
|
enabling button detection interrupts. After auto-detection and before
|
|
servicing button interrupts, the HS bias needs time to settle. If you
|
|
don't wait, there is possibility for erroneous button interrupt.
|
|
|
|
0ms - 200ms,
|
|
Default = 100ms
|
|
|
|
- cirrus,btn-det-event-dbnce : This sets how long the driver delays after
|
|
receiving a button press interrupt. With level detect interrupts, you want
|
|
to wait a small amount of time to make sure the button press is making a
|
|
clean connection with the bias resistors.
|
|
|
|
0ms - 20ms,
|
|
Default = 10ms
|
|
|
|
- cirrus,bias-lvls : For a level-detect headset button scheme, each button
|
|
will bias the mic pin to a certain voltage. To determine which button was
|
|
pressed, the driver will compare this biased voltage to sequential,
|
|
decreasing voltages and will stop when a comparator is tripped,
|
|
indicating a comparator voltage < bias voltage. This value represents a
|
|
percentage of the internally generated HS bias voltage. For different
|
|
hardware setups, a designer might want to tweak this. This is an array of
|
|
descending values for the comparator voltage.
|
|
|
|
Array of 4 values
|
|
Each 0-63
|
|
< x1 x2 x3 x4 >
|
|
Default = < 15 8 4 1>
|
|
|
|
- cirrus,hs-bias-sense-disable: This is boolean property. If present the
|
|
HSBIAS sense is disabled. Configures HSBIAS output current sense through
|
|
the external 2.21-k resistor. HSBIAS_SENSE is hardware feature to reduce
|
|
the potential pop noise during the headset plug out slowly. But on some
|
|
platforms ESD voltage will affect it causing test to fail, especially
|
|
with CTIA headset type. For different hardware setups, a designer might
|
|
want to tweak default behavior.
|
|
|
|
Example:
|
|
|
|
cs42l42: cs42l42@48 {
|
|
compatible = "cirrus,cs42l42";
|
|
reg = <0x48>;
|
|
VA-supply = <&dummy_vreg>;
|
|
VP-supply = <&dummy_vreg>;
|
|
VCP-supply = <&dummy_vreg>;
|
|
VD_FILT-supply = <&dummy_vreg>;
|
|
VL-supply = <&dummy_vreg>;
|
|
|
|
reset-gpios = <&axi_gpio_0 1 0>;
|
|
interrupt-parent = <&gpio0>;
|
|
interrupts = <55 8>
|
|
|
|
cirrus,ts-inv = <0x00>;
|
|
cirrus,ts-dbnc-rise = <0x05>;
|
|
cirrus,ts-dbnc-fall = <0x00>;
|
|
cirrus,btn-det-init-dbnce = <100>;
|
|
cirrus,btn-det-event-dbnce = <10>;
|
|
cirrus,bias-lvls = <0x0F 0x08 0x04 0x01>;
|
|
cirrus,hs-bias-ramp-rate = <0x02>;
|
|
};
|