[alsa-devel] [PATCH] aplay: Introduce and use xwrite helper
Takashi Iwai
tiwai at suse.de
Fri Apr 7 20:41:08 CEST 2017
On Fri, 07 Apr 2017 17:35:40 +0200,
Daniel Baluta wrote:
>
> Write can return less then requested bytes, but we treat this as
> an error thus ending up with confusing error messages.
>
> Fix this by introducing xwrite helper, which makes sure all bytes
> are written or an error is returned.
>
> With this patch an usecase where disk is filled by recording will
> print:
> $ /mnt/msc/audio.wav: No space left on device
>
> instead of random messages like:
>
> $/mnt/msc/audio.wav: No such file or directory
>
> Signed-off-by: Daniel Baluta <daniel.baluta at nxp.com>
> ---
> This is a follow up of:
>
> http://mailman.alsa-project.org/pipermail/alsa-devel/2017-April/119632.html
>
> where I tried to fix the error message instead of write :).
>
> aplay/aplay.c | 55 +++++++++++++++++++++++++++++++++++++------------------
> 1 file changed, 37 insertions(+), 18 deletions(-)
>
> diff --git a/aplay/aplay.c b/aplay/aplay.c
> index ee480f2..74d3d37 100644
> --- a/aplay/aplay.c
> +++ b/aplay/aplay.c
> @@ -429,6 +429,25 @@ enum {
> OPT_FATAL_ERRORS,
> };
>
> +/*
> + * make sure we write all bytes or return an error
> + */
> +static ssize_t xwrite(int fd, const void *buf, size_t count)
> +{
> + ssize_t written;
> + size_t offset = 0;
> +
> + while (offset < count) {
> + written = write(fd, buf + offset, count - offset);
> + if (written <= 0)
> + return written;
> +
> + offset += written;
> + };
> +
> + return written;
This will return a partial written size.
Return "offset" instead.
thanks,
Takashi
More information about the Alsa-devel
mailing list