From dbd400d930ccd790c2918f6382c0efaeb353c282 Mon Sep 17 00:00:00 2001 From: Jakob Unterwurzacher Date: Wed, 15 Aug 2018 17:14:24 +0200 Subject: fusefrontend: truncateGrowFile: pass zeroPad error to caller Errors from zeroPad were ignored until now, as discovered using xfstests generic/083. --- internal/fusefrontend/file_allocate_truncate.go | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) (limited to 'internal') diff --git a/internal/fusefrontend/file_allocate_truncate.go b/internal/fusefrontend/file_allocate_truncate.go index 34fe2c0..e735d79 100644 --- a/internal/fusefrontend/file_allocate_truncate.go +++ b/internal/fusefrontend/file_allocate_truncate.go @@ -198,7 +198,10 @@ func (f *File) truncateGrowFile(oldPlainSz uint64, newPlainSz uint64) fuse.Statu // // Make sure the old last block is padded to the block boundary. This call // is a no-op if it is already block-aligned. - f.zeroPad(oldPlainSz) + status := f.zeroPad(oldPlainSz) + if !status.Ok() { + return status + } // The new size is block-aligned. In this case we can do everything ourselves // and avoid the call to doWrite. if newPlainSz%f.contentEnc.PlainBS() == 0 { @@ -220,6 +223,6 @@ func (f *File) truncateGrowFile(oldPlainSz uint64, newPlainSz uint64) fuse.Statu // The new size is NOT aligned, so we need to write a partial block. // Write a single zero to the last byte and let doWrite figure it out. buf := make([]byte, 1) - _, status := f.doWrite(buf, int64(newEOFOffset)) + _, status = f.doWrite(buf, int64(newEOFOffset)) return status } -- cgit v1.2.3