From 7be21dee4d0823dd2fe127c7a13254f960e5386a Mon Sep 17 00:00:00 2001 From: Colin Walters Date: Tue, 10 Jan 2017 22:24:12 -0500 Subject: [PATCH] xattrs: Handle ERANGE This is symmetric with an earlier commit which handled a transition from `size != 0` -> `size = 0`. Now if xattrs are added we retry. --- glnx-xattrs.c | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/glnx-xattrs.c b/glnx-xattrs.c index c52cd0f8..eadb6b15 100644 --- a/glnx-xattrs.c +++ b/glnx-xattrs.c @@ -155,6 +155,7 @@ get_xattrs_impl (const char *path, g_variant_builder_init (&builder, G_VARIANT_TYPE ("a(ayay)")); builder_initialized = TRUE; + again: if (path) bytes_read = llistxattr (path, NULL, 0); else @@ -177,6 +178,11 @@ get_xattrs_impl (const char *path, real_size = flistxattr (fd, xattr_names, bytes_read); if (real_size < 0) { + if (errno == ERANGE) + { + g_free (xattr_names); + goto again; + } glnx_set_prefix_error_from_errno (error, "%s", "llistxattr"); goto out; }