Commit d79360eb authored by Takashi Sakamoto's avatar Takashi Sakamoto Committed by Takashi Iwai

ALSA: firewire-digi00x: code refactoring for initialization/destruction of AMDTP stream

This commit is a preparation to support AMDTP domain.
Signed-off-by: default avatarTakashi Sakamoto <o-takashi@sakamocchi.jp>
Signed-off-by: default avatarTakashi Iwai <tiwai@suse.de>
parent 7eb7b18e
...@@ -218,43 +218,62 @@ static int keep_resources(struct snd_dg00x *dg00x, struct amdtp_stream *stream, ...@@ -218,43 +218,62 @@ static int keep_resources(struct snd_dg00x *dg00x, struct amdtp_stream *stream,
fw_parent_device(dg00x->unit)->max_speed); fw_parent_device(dg00x->unit)->max_speed);
} }
int snd_dg00x_stream_init_duplex(struct snd_dg00x *dg00x) static int init_stream(struct snd_dg00x *dg00x, struct amdtp_stream *s)
{ {
struct fw_iso_resources *resources;
enum amdtp_stream_direction dir;
int err; int err;
/* For out-stream. */ if (s == &dg00x->tx_stream) {
err = fw_iso_resources_init(&dg00x->rx_resources, dg00x->unit); resources = &dg00x->tx_resources;
dir = AMDTP_IN_STREAM;
} else {
resources = &dg00x->rx_resources;
dir = AMDTP_OUT_STREAM;
}
err = fw_iso_resources_init(resources, dg00x->unit);
if (err < 0) if (err < 0)
goto error; return err;
err = amdtp_dot_init(&dg00x->rx_stream, dg00x->unit, AMDTP_OUT_STREAM);
err = amdtp_dot_init(s, dg00x->unit, dir);
if (err < 0) if (err < 0)
goto error; fw_iso_resources_destroy(resources);
return err;
}
/* For in-stream. */ static void destroy_stream(struct snd_dg00x *dg00x, struct amdtp_stream *s)
err = fw_iso_resources_init(&dg00x->tx_resources, dg00x->unit); {
amdtp_stream_destroy(s);
if (s == &dg00x->tx_stream)
fw_iso_resources_destroy(&dg00x->tx_resources);
else
fw_iso_resources_destroy(&dg00x->rx_resources);
}
int snd_dg00x_stream_init_duplex(struct snd_dg00x *dg00x)
{
int err;
err = init_stream(dg00x, &dg00x->rx_stream);
if (err < 0) if (err < 0)
goto error; return err;
err = amdtp_dot_init(&dg00x->tx_stream, dg00x->unit, AMDTP_IN_STREAM);
err = init_stream(dg00x, &dg00x->tx_stream);
if (err < 0) if (err < 0)
goto error; destroy_stream(dg00x, &dg00x->rx_stream);
return 0;
error:
snd_dg00x_stream_destroy_duplex(dg00x);
return err; return err;
} }
/* // This function should be called before starting streams or after stopping
* This function should be called before starting streams or after stopping // streams.
* streams.
*/
void snd_dg00x_stream_destroy_duplex(struct snd_dg00x *dg00x) void snd_dg00x_stream_destroy_duplex(struct snd_dg00x *dg00x)
{ {
amdtp_stream_destroy(&dg00x->rx_stream); destroy_stream(dg00x, &dg00x->rx_stream);
fw_iso_resources_destroy(&dg00x->rx_resources); destroy_stream(dg00x, &dg00x->tx_stream);
amdtp_stream_destroy(&dg00x->tx_stream);
fw_iso_resources_destroy(&dg00x->tx_resources);
} }
int snd_dg00x_stream_reserve_duplex(struct snd_dg00x *dg00x, unsigned int rate) int snd_dg00x_stream_reserve_duplex(struct snd_dg00x *dg00x, unsigned int rate)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment