mirror of
https://github.com/torvalds/linux.git
synced 2026-04-28 11:32:28 -04:00
Merge series from Srinivas Kandagatla <srinivas.kandagatla@oss.qualcomm.com>: This patch series fixes SM6115 lpass codec macro support and adding missing dt-bindings to complete support for SM6115. SM6115 lpass codec macro support is added partially and broken to some extent, Fix this broken support and add complete lpass macro support for this SoC.
158 lines
3.5 KiB
YAML
158 lines
3.5 KiB
YAML
# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
|
|
%YAML 1.2
|
|
---
|
|
$id: http://devicetree.org/schemas/sound/qcom,lpass-rx-macro.yaml#
|
|
$schema: http://devicetree.org/meta-schemas/core.yaml#
|
|
|
|
title: LPASS(Low Power Audio Subsystem) RX Macro audio codec
|
|
|
|
maintainers:
|
|
- Srinivas Kandagatla <srinivas.kandagatla@linaro.org>
|
|
|
|
properties:
|
|
compatible:
|
|
oneOf:
|
|
- enum:
|
|
- qcom,sc7280-lpass-rx-macro
|
|
- qcom,sm6115-lpass-rx-macro
|
|
- qcom,sm8250-lpass-rx-macro
|
|
- qcom,sm8450-lpass-rx-macro
|
|
- qcom,sm8550-lpass-rx-macro
|
|
- qcom,sc8280xp-lpass-rx-macro
|
|
- items:
|
|
- enum:
|
|
- qcom,kaanapali-lpass-rx-macro
|
|
- qcom,sm8650-lpass-rx-macro
|
|
- qcom,sm8750-lpass-rx-macro
|
|
- qcom,x1e80100-lpass-rx-macro
|
|
- const: qcom,sm8550-lpass-rx-macro
|
|
|
|
reg:
|
|
maxItems: 1
|
|
|
|
"#sound-dai-cells":
|
|
const: 1
|
|
|
|
'#clock-cells':
|
|
const: 0
|
|
|
|
clocks:
|
|
minItems: 3
|
|
maxItems: 5
|
|
|
|
clock-names:
|
|
minItems: 3
|
|
maxItems: 5
|
|
|
|
clock-output-names:
|
|
maxItems: 1
|
|
|
|
power-domains:
|
|
maxItems: 2
|
|
|
|
power-domain-names:
|
|
items:
|
|
- const: macro
|
|
- const: dcodec
|
|
|
|
required:
|
|
- compatible
|
|
- reg
|
|
- "#sound-dai-cells"
|
|
|
|
allOf:
|
|
- $ref: dai-common.yaml#
|
|
- if:
|
|
properties:
|
|
compatible:
|
|
enum:
|
|
- qcom,sc7280-lpass-rx-macro
|
|
then:
|
|
properties:
|
|
clock-names:
|
|
oneOf:
|
|
- items: # for ADSP based platforms
|
|
- const: mclk
|
|
- const: npl
|
|
- const: macro
|
|
- const: dcodec
|
|
- const: fsgen
|
|
- items: # for ADSP bypass based platforms
|
|
- const: mclk
|
|
- const: npl
|
|
- const: fsgen
|
|
|
|
- if:
|
|
properties:
|
|
compatible:
|
|
enum:
|
|
- qcom,sm6115-lpass-rx-macro
|
|
then:
|
|
properties:
|
|
clocks:
|
|
minItems: 4
|
|
maxItems: 4
|
|
clock-names:
|
|
items:
|
|
- const: mclk
|
|
- const: npl
|
|
- const: dcodec
|
|
- const: fsgen
|
|
|
|
- if:
|
|
properties:
|
|
compatible:
|
|
enum:
|
|
- qcom,sc8280xp-lpass-rx-macro
|
|
- qcom,sm8250-lpass-rx-macro
|
|
- qcom,sm8450-lpass-rx-macro
|
|
then:
|
|
properties:
|
|
clocks:
|
|
minItems: 5
|
|
maxItems: 5
|
|
clock-names:
|
|
items:
|
|
- const: mclk
|
|
- const: npl
|
|
- const: macro
|
|
- const: dcodec
|
|
- const: fsgen
|
|
|
|
- if:
|
|
properties:
|
|
compatible:
|
|
contains:
|
|
enum:
|
|
- qcom,sm8550-lpass-rx-macro
|
|
then:
|
|
properties:
|
|
clocks:
|
|
minItems: 4
|
|
maxItems: 4
|
|
clock-names:
|
|
items:
|
|
- const: mclk
|
|
- const: macro
|
|
- const: dcodec
|
|
- const: fsgen
|
|
|
|
unevaluatedProperties: false
|
|
|
|
examples:
|
|
- |
|
|
#include <dt-bindings/sound/qcom,q6afe.h>
|
|
codec@3200000 {
|
|
compatible = "qcom,sm8250-lpass-rx-macro";
|
|
reg = <0x3200000 0x1000>;
|
|
#sound-dai-cells = <1>;
|
|
#clock-cells = <0>;
|
|
clocks = <&audiocc 0>,
|
|
<&audiocc 1>,
|
|
<&q6afecc LPASS_HW_MACRO_VOTE LPASS_CLK_ATTRIBUTE_COUPLE_NO>,
|
|
<&q6afecc LPASS_HW_DCODEC_VOTE LPASS_CLK_ATTRIBUTE_COUPLE_NO>,
|
|
<&vamacro>;
|
|
clock-names = "mclk", "npl", "macro", "dcodec", "fsgen";
|
|
clock-output-names = "mclk";
|
|
};
|