Hi Morimoto-san,
On 01/23/2017 08:33 AM, Kuninori Morimoto wrote:
Hi Rob, Mark
I created OF-graph base simple sound card. I want to post this patch-set, but it depends many things. Thus, before posting patch-set, I would like to know OF-graph sound DT binding was OK or not. Can you give me comments ?
.../bindings/sound/simple-graph-card.txt | 140 +++++++++++++++++++++ 1 file changed, 140 insertions(+) create mode 100644 Documentation/devicetree/bindings/sound/simple-graph-card.txt
diff --git a/Documentation/devicetree/bindings/sound/simple-graph-card.txt b/Documentation/devicetree/bindings/sound/simple-graph-card.txt new file mode 100644 index 0000000..4b29284 --- /dev/null +++ b/Documentation/devicetree/bindings/sound/simple-graph-card.txt @@ -0,0 +1,140 @@ +Simple-Graph-Card:
This binding is likely going to cover most of existing sound system configuration, at least it looks as it has a potential to be scalable enough. So perhaps we could treat is as a more generic binding and could drop the "Simple" word now? I'm not 100% sure it's a good idea, but maybe we could make it "Generic Sound Card DT Binding"?
+Simple-Graph-Card specifies audio DAI connections of SoC <-> codec. +It is based on common bindings for device graphs. +see ${LINUX}/Documentation/devicetree/bindings/graph.txt
The DT bindings should be OS agnostic, I think we should drop the "${LINUX}/" part here and elsewhere in this documentation.
+Basically, Simple-Graph-Card property is same as Simple-Card. +see ${LINUX}/Documentation/devicetree/bindings/sound/simple-card.txt
+Below are same as Simple-Card.
+- simple-audio-card,name +- simple-audio-card,format +- simple-audio-card,frame-master +- simple-audio-card,bitclock-master +- simple-audio-card,bitclock-inversion +- simple-audio-card,frame-inversion +- simple-audio-card,dai-tdm-slot-num +- simple-audio-card,dai-tdm-slot-width +- clocks / system-clock-frequency
+These should be implemented +- simple-audio-card,widgets +- simple-audio-card,routing +- simple-audio-card,mclk-fs +- simple-audio-card,hp-det-gpio +- simple-audio-card,mic-det-gpio
+Required properties:
+- compatible : "asoc-simple-graph-card";
"asoc" is Linux related, we shouldn't be putting this in the compatible string. Perhaps "generic-sound-card" ? Again, I'm sure if it is expected to have such a generic kind of DT binding.
+Optional properties:
+- dais : Sound DAI phandle list if Card has
multi DAI. see Example
+Each ports
+- port@0 : CPU setting +- port@1 : Codec setting
+Example: Single DAI case
- sound_card: sound {
compatible = "asoc-simple-graph-card";
ports {
#address-cells = <1>;
#size-cells = <0>;
port@0 {
sound0_in: endpoint {
remote-endpoint = <&rsnd_port0>;
simple-audio-card,format = "left_j";
simple-audio-card,bitclock-master = <&rsnd_port0>;
simple-audio-card,frame-master = <&rsnd_port0>;
};
};
port@1 {
sound0_out: endpoint {
remote-endpoint = <&ak4613_port>;
};
};
};
- };
I wouldn't be making a separate case for single DAI. The 'ports' node can be omitted, port@0, port@1 nodes could be put under respective device nodes and in the 'sound' node we would have 'dais' property pointing to the CPU DAI port, not the endpoint. The endpoint is supposed to describe one of possible configurations of the port. I think we want phandles to the 'port' nodes, not phandles to the 'endpoint' nodes in the 'sound' node.
+Example: Multi DAI case
- sound_dai0: sound_dai@0 {
ports {
#address-cells = <1>;
#size-cells = <0>;
port@0 {
sound0_in: endpoint {
remote-endpoint = <&rsnd_port0>;
simple-audio-card,format = "left_j";
simple-audio-card,bitclock-master = <&rsnd_port0>;
simple-audio-card,frame-master = <&rsnd_port0>;
};
};
port@1 {
sound0_out: endpoint {
remote-endpoint = <&ak4613_port>;
};
};
};
- };
- sound_dai1: sound_dai@1 {
ports {
#address-cells = <1>;
#size-cells = <0>;
port@0 {
sound1_in: endpoint {
remote-endpoint = <&rsnd_port1>;
simple-audio-card,format = "i2s";
simple-audio-card,bitclock-master = <&rsnd_port1>;
simple-audio-card,frame-master = <&rsnd_port1>;
};
};
port@1 {
sound1_out: endpoint {
remote-endpoint = <&rcar_dw_hdmi0_snd_in>;
};
};
};
- };
- rsnd_ak4613: sound {
compatible = "asoc-simple-graph-card";
dais = <&sound_dai0
&sound_dai1
&sound_dai2>;
- };