ALSA: firewire-digi00x: simplify error path to begin streaming session
This commit is a part of preparation to perform allocation/release of isochronous resources in pcm.hw_params/hw_free callbacks. The caller of begin_session() calls finish_session() in its error path, thus no need to call finish_session() in error path of begin_session(). This commit simplifies error path of begin_session(). Signed-off-by: Takashi Sakamoto <o-takashi@sakamocchi.jp> Signed-off-by: Takashi Iwai <tiwai@suse.de>
This commit is contained in:
parent
d18b0a6e42
commit
638e19fc46
@ -159,13 +159,13 @@ static int begin_session(struct snd_dg00x *dg00x)
|
|||||||
DG00X_ADDR_BASE + DG00X_OFFSET_ISOC_CHANNELS,
|
DG00X_ADDR_BASE + DG00X_OFFSET_ISOC_CHANNELS,
|
||||||
&data, sizeof(data), 0);
|
&data, sizeof(data), 0);
|
||||||
if (err < 0)
|
if (err < 0)
|
||||||
goto error;
|
return err;
|
||||||
|
|
||||||
err = snd_fw_transaction(dg00x->unit, TCODE_READ_QUADLET_REQUEST,
|
err = snd_fw_transaction(dg00x->unit, TCODE_READ_QUADLET_REQUEST,
|
||||||
DG00X_ADDR_BASE + DG00X_OFFSET_STREAMING_STATE,
|
DG00X_ADDR_BASE + DG00X_OFFSET_STREAMING_STATE,
|
||||||
&data, sizeof(data), 0);
|
&data, sizeof(data), 0);
|
||||||
if (err < 0)
|
if (err < 0)
|
||||||
goto error;
|
return err;
|
||||||
curr = be32_to_cpu(data);
|
curr = be32_to_cpu(data);
|
||||||
|
|
||||||
if (curr == 0)
|
if (curr == 0)
|
||||||
@ -180,15 +180,12 @@ static int begin_session(struct snd_dg00x *dg00x)
|
|||||||
DG00X_OFFSET_STREAMING_SET,
|
DG00X_OFFSET_STREAMING_SET,
|
||||||
&data, sizeof(data), 0);
|
&data, sizeof(data), 0);
|
||||||
if (err < 0)
|
if (err < 0)
|
||||||
goto error;
|
break;
|
||||||
|
|
||||||
msleep(20);
|
msleep(20);
|
||||||
curr--;
|
curr--;
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
|
||||||
error:
|
|
||||||
finish_session(dg00x);
|
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user