mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/chenhuacai/linux-loongson
synced 2025-09-02 08:32:55 +00:00

This is a very big release due to a combination of some big new work, mainly new drivers and generic SoundWire support, and some wide ranging cleanup work that made small changes to a lot of drivers. - Morimoto-san has completed the conversion to use modern terminology for the clocking configuration, and several other cleanups with narrower impact. - All the power management operation configuration was updated to use current idioms by Takashi Iwai. - Clarification of the control operations from Charles Keepax. - Prepartory work for more generic SoundWire SCDA controls from Charles Keepax. - Support for AMD ACP 7.x, AWINC WM88166, Everest ES8388, Intel AVS PEAKVOL and GAIN DSP modules Mediatek MT8188 DMIC, NXP i.MX95, nVidia Tegra interconnects, Rockchip RK3588 S/PDIF, Texas Instruments SN012776 and TAS5770L, and Wolfson WM8904 DMICs, Some changes from the tip tree adding APIs needed by the AMD code are included, these were unfortunately rebased in the tip tree after being pulled in. There's also some regmap changes supporting the SCDA work and some devres refactoring that was pulled in to support other changes. -----BEGIN PGP SIGNATURE----- iQEzBAABCgAdFiEEreZoqmdXGLWf4p/qJNaLcl1Uh9AFAmfhZEUACgkQJNaLcl1U h9DQjgf9FxqmX7qAbT3tV06lX6UJ79KtCGquvVpToxP3nMFa05h/HSJlQAnqEFkL AUdAr/bfH6noDIqL08j+DMHs85lz6fP06PubCmQCHEk+yAEPOZ19OUsTKbhdXcG2 GTObvLEjnz8MDnUW99SwoB52y3DX/7F09uhcbv+xiLIZo0EmQOcTsLKx79XwuzgU q52mQBXYi7CDhVTlnITeapcLj7G+6r2m7zLsQRWa897bKp/nRVq08GhWu0SHBNtP m/RwBvwPZEgCDxH+aHOWvc6S7yQpotC9EIvTUchxFGkcHh9OKoLUoWLH7p+d99B2 ydVWgOz72GwRhAjp9FHH7X49A5UMmg== =xZD3 -----END PGP SIGNATURE----- Merge tag 'asoc-v6.15' of https://git.kernel.org/pub/scm/linux/kernel/git/broonie/sound into for-next ASoC: Updates for v6.15 This is a very big release due to a combination of some big new work, mainly new drivers and generic SoundWire support, and some wide ranging cleanup work that made small changes to a lot of drivers. - Morimoto-san has completed the conversion to use modern terminology for the clocking configuration, and several other cleanups with narrower impact. - All the power management operation configuration was updated to use current idioms by Takashi Iwai. - Clarification of the control operations from Charles Keepax. - Prepartory work for more generic SoundWire SCDA controls from Charles Keepax. - Support for AMD ACP 7.x, AWINC WM88166, Everest ES8388, Intel AVS PEAKVOL and GAIN DSP modules Mediatek MT8188 DMIC, NXP i.MX95, nVidia Tegra interconnects, Rockchip RK3588 S/PDIF, Texas Instruments SN012776 and TAS5770L, and Wolfson WM8904 DMICs, Some changes from the tip tree adding APIs needed by the AMD code are included, these were unfortunately rebased in the tip tree after being pulled in. There's also some regmap changes supporting the SCDA work and some devres refactoring that was pulled in to support other changes.
263 lines
7.1 KiB
YAML
263 lines
7.1 KiB
YAML
# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
|
|
%YAML 1.2
|
|
---
|
|
$id: http://devicetree.org/schemas/sound/fsl,sai.yaml#
|
|
$schema: http://devicetree.org/meta-schemas/core.yaml#
|
|
|
|
title: Freescale Synchronous Audio Interface (SAI).
|
|
|
|
maintainers:
|
|
- Shengjiu Wang <shengjiu.wang@nxp.com>
|
|
|
|
description: |
|
|
The SAI is based on I2S module that used communicating with audio codecs,
|
|
which provides a synchronous audio interface that supports fullduplex
|
|
serial interfaces with frame synchronization such as I2S, AC97, TDM, and
|
|
codec/DSP interfaces.
|
|
|
|
properties:
|
|
compatible:
|
|
oneOf:
|
|
- items:
|
|
- enum:
|
|
- fsl,imx6ul-sai
|
|
- fsl,imx7d-sai
|
|
- const: fsl,imx6sx-sai
|
|
|
|
- items:
|
|
- enum:
|
|
- fsl,imx8mm-sai
|
|
- fsl,imx8mn-sai
|
|
- fsl,imx8mp-sai
|
|
- const: fsl,imx8mq-sai
|
|
|
|
- items:
|
|
- enum:
|
|
- fsl,imx6sx-sai
|
|
- fsl,imx7ulp-sai
|
|
- fsl,imx8mq-sai
|
|
- fsl,imx8qm-sai
|
|
- fsl,imx8ulp-sai
|
|
- fsl,imx93-sai
|
|
- fsl,imx95-sai
|
|
- fsl,vf610-sai
|
|
- items:
|
|
- enum:
|
|
- fsl,imx94-sai
|
|
- const: fsl,imx95-sai
|
|
|
|
reg:
|
|
maxItems: 1
|
|
|
|
clocks:
|
|
items:
|
|
- description: The ipg clock for register access
|
|
- description: master clock source 0 (obsoleted)
|
|
- description: master clock source 1
|
|
- description: master clock source 2
|
|
- description: master clock source 3
|
|
- description: PLL clock source for 8kHz series
|
|
- description: PLL clock source for 11kHz series
|
|
minItems: 4
|
|
|
|
clock-names:
|
|
oneOf:
|
|
- items:
|
|
- const: bus
|
|
- const: mclk0
|
|
- const: mclk1
|
|
- const: mclk2
|
|
- const: mclk3
|
|
- const: pll8k
|
|
- const: pll11k
|
|
minItems: 5
|
|
- items:
|
|
- const: bus
|
|
- const: mclk1
|
|
- const: mclk2
|
|
- const: mclk3
|
|
- const: pll8k
|
|
- const: pll11k
|
|
minItems: 4
|
|
|
|
power-domains:
|
|
maxItems: 1
|
|
|
|
dmas:
|
|
minItems: 1
|
|
maxItems: 2
|
|
|
|
dma-names:
|
|
minItems: 1
|
|
items:
|
|
- enum: [ rx, tx ]
|
|
- const: tx
|
|
|
|
interrupts:
|
|
items:
|
|
- description: receive and transmit interrupt
|
|
|
|
ports:
|
|
$ref: /schemas/graph.yaml#/properties/ports
|
|
properties:
|
|
port@0:
|
|
$ref: audio-graph-port.yaml#
|
|
unevaluatedProperties: false
|
|
description: port for TX and RX
|
|
|
|
port@1:
|
|
$ref: audio-graph-port.yaml#
|
|
unevaluatedProperties: false
|
|
description: port for TX only
|
|
|
|
port@2:
|
|
$ref: audio-graph-port.yaml#
|
|
unevaluatedProperties: false
|
|
description: port for RX only
|
|
|
|
big-endian:
|
|
description: |
|
|
required if all the SAI registers are big-endian rather than little-endian.
|
|
type: boolean
|
|
|
|
fsl,dataline:
|
|
$ref: /schemas/types.yaml#/definitions/uint32-matrix
|
|
description: |
|
|
Configure the dataline. It has 3 value for each configuration
|
|
maxItems: 16
|
|
items:
|
|
items:
|
|
- description: format Default(0), I2S(1) or PDM(2)
|
|
enum: [0, 1, 2]
|
|
- description: dataline mask for 'rx'
|
|
- description: dataline mask for 'tx'
|
|
|
|
fsl,sai-mclk-direction-output:
|
|
description: SAI will output the SAI MCLK clock.
|
|
type: boolean
|
|
|
|
fsl,sai-synchronous-rx:
|
|
description: |
|
|
SAI will work in the synchronous mode (sync Tx with Rx) which means
|
|
both the transmitter and the receiver will send and receive data by
|
|
following receiver's bit clocks and frame sync clocks.
|
|
type: boolean
|
|
|
|
fsl,sai-asynchronous:
|
|
description: |
|
|
SAI will work in the asynchronous mode, which means both transmitter
|
|
and receiver will send and receive data by following their own bit clocks
|
|
and frame sync clocks separately.
|
|
If both fsl,sai-asynchronous and fsl,sai-synchronous-rx are absent, the
|
|
default synchronous mode (sync Rx with Tx) will be used, which means both
|
|
transmitter and receiver will send and receive data by following clocks
|
|
of transmitter.
|
|
type: boolean
|
|
|
|
fsl,shared-interrupt:
|
|
description: Interrupt is shared with other modules.
|
|
type: boolean
|
|
|
|
lsb-first:
|
|
description: |
|
|
Configures whether the LSB or the MSB is transmitted
|
|
first for the fifo data. If this property is absent,
|
|
the MSB is transmitted first as default, or the LSB
|
|
is transmitted first.
|
|
type: boolean
|
|
|
|
"#sound-dai-cells":
|
|
const: 0
|
|
description: optional, some dts node didn't add it.
|
|
|
|
allOf:
|
|
- $ref: dai-common.yaml#
|
|
- if:
|
|
required:
|
|
- fsl,sai-asynchronous
|
|
then:
|
|
properties:
|
|
fsl,sai-synchronous-rx: false
|
|
|
|
required:
|
|
- compatible
|
|
- reg
|
|
- clocks
|
|
- clock-names
|
|
- dmas
|
|
- dma-names
|
|
- interrupts
|
|
|
|
unevaluatedProperties: false
|
|
|
|
examples:
|
|
- |
|
|
#include <dt-bindings/interrupt-controller/arm-gic.h>
|
|
#include <dt-bindings/clock/vf610-clock.h>
|
|
sai2: sai@40031000 {
|
|
compatible = "fsl,vf610-sai";
|
|
reg = <0x40031000 0x1000>;
|
|
interrupts = <86 IRQ_TYPE_LEVEL_HIGH>;
|
|
pinctrl-names = "default";
|
|
pinctrl-0 = <&pinctrl_sai2_1>;
|
|
clocks = <&clks VF610_CLK_PLATFORM_BUS>,
|
|
<&clks VF610_CLK_SAI2>,
|
|
<&clks 0>, <&clks 0>;
|
|
clock-names = "bus", "mclk1", "mclk2", "mclk3";
|
|
dma-names = "rx", "tx";
|
|
dmas = <&edma0 0 20>, <&edma0 0 21>;
|
|
big-endian;
|
|
lsb-first;
|
|
};
|
|
|
|
- |
|
|
#include <dt-bindings/interrupt-controller/arm-gic.h>
|
|
#include <dt-bindings/clock/imx8mm-clock.h>
|
|
sai1: sai@30010000 {
|
|
compatible = "fsl,imx8mm-sai", "fsl,imx8mq-sai";
|
|
reg = <0x30010000 0x10000>;
|
|
interrupts = <GIC_SPI 95 IRQ_TYPE_LEVEL_HIGH>;
|
|
clocks = <&clk IMX8MM_CLK_SAI1_IPG>,
|
|
<&clk IMX8MM_CLK_DUMMY>,
|
|
<&clk IMX8MM_CLK_SAI1_ROOT>,
|
|
<&clk IMX8MM_CLK_DUMMY>, <&clk IMX8MM_CLK_DUMMY>;
|
|
clock-names = "bus", "mclk0", "mclk1", "mclk2", "mclk3";
|
|
dmas = <&sdma2 0 2 0>, <&sdma2 1 2 0>;
|
|
dma-names = "rx", "tx";
|
|
fsl,dataline = <1 0xff 0xff 2 0xff 0x11>;
|
|
#sound-dai-cells = <0>;
|
|
|
|
ports {
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
|
|
port@1 {
|
|
reg = <1>;
|
|
playback-only;
|
|
|
|
sai1_endpoint0: endpoint {
|
|
dai-tdm-slot-num = <8>;
|
|
dai-tdm-slot-width = <32>;
|
|
dai-tdm-slot-width-map = <32 8 32>;
|
|
dai-format = "dsp_a";
|
|
bitclock-master;
|
|
frame-master;
|
|
remote-endpoint = <&mcodec01_ep>;
|
|
};
|
|
};
|
|
|
|
port@2 {
|
|
reg = <2>;
|
|
capture-only;
|
|
|
|
sai1_endpoint1: endpoint {
|
|
dai-tdm-slot-num = <8>;
|
|
dai-tdm-slot-width = <32>;
|
|
dai-tdm-slot-width-map = <32 8 32>;
|
|
dai-format = "dsp_a";
|
|
remote-endpoint = <&fe02_ep>;
|
|
};
|
|
};
|
|
};
|
|
};
|