ALSA: firewire-motu: update isochronous resources when starting packet streaming...
authorTakashi Sakamoto <o-takashi@sakamocchi.jp>
Mon, 17 Jun 2019 08:15:09 +0000 (17:15 +0900)
committerTakashi Iwai <tiwai@suse.de>
Tue, 18 Jun 2019 06:45:32 +0000 (08:45 +0200)
After bus reset, isochronous resource manager releases all of allocated
isochronous resources. The nodes to transfer isochronous packet should
request reallocation of the resources.

However, between the bus-reset and invocation of 'struct fw_driver.update'
handler, ALSA PCM application can detect this situation by XRUN because
the target device cancelled to transmit packets once bus-reset occurs.

Due to the above mechanism, ALSA fireface driver just stops packet
streaming in the update handler, thus pcm.prepare handler should
request the reallocation.

This commit requests the reallocation in pcm.prepare callback when
bus generation is changed.

Signed-off-by: Takashi Sakamoto <o-takashi@sakamocchi.jp>
Signed-off-by: Takashi Iwai <tiwai@suse.de>
sound/firewire/motu/motu-stream.c

index 5630a8f1f2f1b6a0c03fe45cf43ecc6d1a1239ff..82891583b7364286f737a2762bb249b5f2263582 100644 (file)
@@ -236,6 +236,7 @@ static int ensure_packet_formats(struct snd_motu *motu)
 
 int snd_motu_stream_start_duplex(struct snd_motu *motu)
 {
+       unsigned int generation = motu->rx_resources.generation;
        int err = 0;
 
        if (motu->substreams_counter == 0)
@@ -245,6 +246,16 @@ int snd_motu_stream_start_duplex(struct snd_motu *motu)
            amdtp_streaming_error(&motu->tx_stream))
                finish_session(motu);
 
+       if (generation != fw_parent_device(motu->unit)->card->generation) {
+               err = fw_iso_resources_update(&motu->rx_resources);
+               if (err < 0)
+                       return err;
+
+               err = fw_iso_resources_update(&motu->tx_resources);
+               if (err < 0)
+                       return err;
+       }
+
        if (!amdtp_stream_running(&motu->rx_stream)) {
                err = ensure_packet_formats(motu);
                if (err < 0)