[alsa-devel] Question about OF-graph ports
Rob Herring
robh+dt at kernel.org
Thu Jan 19 15:58:13 CET 2017
On Thu, Jan 19, 2017 at 12:07 AM, Kuninori Morimoto
<kuninori.morimoto.gx at renesas.com> wrote:
>
> Hi Rob, Mark
> and ALSA SoC ML
>
> I'm working for OF-graph base sound card support.
> Now I want to know 1 things which can't solve by myself.
> It is OF-graph ports
>
> ALSA SoC needs CPU, Codec, and Sound Card.
> If CPU <-> Card <-> Codec case, OF-graph will be
>
> card {
> ports {
> port at 0 {
> card_in: endpoint {
> remote-endpoint = <&cpu_out>;
> };
> };
> port at 1 {
> card_out: endpoint {
> remote-endpoint = <&codec_in>;
> };
> };
> };
> };
>
> cpu {
> port {
> cpu_out: endpoint {
> remote-endpoint = <&card_in>;
> };
> };
> };
>
> codec {
> port {
> codec_in: endpoint {
> remote-endpoint = <&card_out>;
> };
> };
> };
>
> This is OK.
> If CPU has many ports, then ALSA SoC requests 1 Card which has many
> DAIs (= Digital Audio Interface).
> This case, cpu will have "ports" and many "port", this is OK.
>
> SoC.0 Codec0
> SoC.1 <-> Card <-> Codec1
> SoC.2 Codec2
This looks wrong to me. The card is just a container node to group
things. The card should not be the middle of the graph. There is no
data flow thru the card as it's not a hardware thing. Start with the
codec's port connected to the node controlling the audio port on the
SOC (In the simple case, that's an SSI controller) and expand the
graph from there.
> In "card", CPU/Codec pair is indicated by "ports" now
> (= port0 is CPU, port1 is Codec, etc)
>
> My question is in this case, how to know CPU/Codec pair on "card" ?
The card should only have the entry (or exit) points of the graph.
That may not even need to be graph nodes. It could just be a list of
CPU DAI phandles (which then have graph nodes).
Look at the display side use of OF graph. We have display subsystem
nodes (like a card) with a poorly named ports property (nothing to do
with OF graph) listing display channels. Each phandle there is the
entry point to the graph and is typically the front end display
controller (perhaps a CSC and scaling unit). The graph then goes to a
backend controller (for display timing), then to interface PHY
(DSI/HDMI), then possibly and external bridge chip, then to a
connector or panel node. That's a complex example. In simple cases, we
just have a display controller connected to a panel.
> Can we have *multi ports*, like this ?
>
> card {
> ports {
> ports at 0 {
> port at 0 { /* SoC.0 */ };
This is not the OF graph binding, so don't do this. OF graph is
flexible enough already to describe any topology. If you feel you need
to extend it, then something is wrong.
> port at 1 { /* Codec0*/ };
> };
> ports at 1 {
> port at 0 { /* SoC.1 */ };
> port at 1 { /* Codec1*/ };
> };
> ports at 2 {
> port at 0 { /* SoC.2 */ };
> port at 1 { /* Codec2*/ };
> };
> };
> };
>
> Or can I use grouping, like this ?
>
> card {
> group = <port at 0 port at 1>,
> <port at 2 port at 3>,
> <port at 4 port at 5>;
If it's not clear by now, the graph is supposed to define the
connections. You are defining connections here in your own custom way.
> ports {
> port at 0 { /* SoC.0 */ };
> port at 1 { /* SoC.1 */ };
> port at 2 { /* SoC.2 */ };
> port at 3 { /* Codec0*/ };
> port at 4 { /* Codec1*/ };
> port at 5 { /* Codec2*/ };
> };
> };
>
> Best regards
> ---
> Kuninori Morimoto
More information about the Alsa-devel
mailing list