From ad8ce08d1146f0b2b26bd422e4421bc2cf085eb0 Mon Sep 17 00:00:00 2001 From: Serge Hallyn Date: Mon, 22 Jan 2024 13:23:20 -0600 Subject: [PATCH] avoid failing when lgetxattr has no data to give Signed-off-by: Serge Hallyn --- oci/layer/tar_generate.go | 12 ++++++++---- 1 file changed, 8 insertions(+), 4 deletions(-) diff --git a/oci/layer/tar_generate.go b/oci/layer/tar_generate.go index 76b35ca3..77620346 100644 --- a/oci/layer/tar_generate.go +++ b/oci/layer/tar_generate.go @@ -219,10 +219,14 @@ func (tg *tarGenerator) AddFile(name, path string) error { // (we'd need to use libcap to parse it). value, err := tg.fsEval.Lgetxattr(path, name) if err != nil { - // XXX: I'm not sure if we're unprivileged whether Lgetxattr can - // fail with EPERM. If it can, we should ignore it (like when - // we try to clear xattrs). - return errors.Wrapf(err, "get xattr: %s", name) + v := errors.Cause(err) + log.Debugf("failure reading xattr from list on %q: %q", name, v) + if v != unix.EOPNOTSUPP && v != unix.ENODATA { + // XXX: I'm not sure if we're unprivileged whether Lgetxattr can + // fail with EPERM. If it can, we should ignore it (like when + // we try to clear xattrs). + return errors.Wrapf(err, "get xattr: %s", name) + } } // https://golang.org/issues/20698 -- We don't just error out here // because it's not _really_ a fatal error. Currently it's unclear