public inbox for linux-btrfs@vger.kernel.org
 help / color / mirror / Atom feed
From: Sidong Yang <realwakka@gmail.com>
To: Nikolay Borisov <nborisov@suse.com>
Cc: Graham Cobb <g.btrfs@cobb.uk.net>,
	linux-btrfs <linux-btrfs@vger.kernel.org>,
	David Sterba <dsterba@suse.com>
Subject: Re: [PATCH v2] btrfs-progs: filesystem: du: skip file that permission denied
Date: Mon, 22 Nov 2021 15:10:27 +0000	[thread overview]
Message-ID: <20211122151027.GA10523@realwakka> (raw)
In-Reply-To: <0a7ce0b1-300c-233b-d844-012dfc771efe@suse.com>

On Mon, Nov 22, 2021 at 12:57:18PM +0200, Nikolay Borisov wrote:
> 
> 
> On 22.11.21 г. 11:53, Graham Cobb wrote:
> > 
> > On 22/11/2021 09:32, Nikolay Borisov wrote:
> >>
> >>
> >> On 22.11.21 г. 10:32, Sidong Yang wrote:
> >>> On Mon, Nov 22, 2021 at 09:20:00AM +0200, Nikolay Borisov wrote:
> >>>>
> >>>>
> >>>> On 21.11.21 г. 17:15, Sidong Yang wrote:
> >>>>> This patch handles issue #421. Filesystem du command fails and exit
> >>>>> when it access file that has permission denied. But it can continue the
> >>>>> command except the files. This patch recovers ret value when permission
> >>>>> denied.
> >>>>>
> >>>>> Signed-off-by: Sidong Yang <realwakka@gmail.com>
> >>>>
> >>>>
> >>>> The code itself is fine so :
> >>>>
> >>>>
> >>>> Reviewed-by: Nikolay Borisov <nborisov@suse.com>
> >>>>
> >>>>
> >>>> OTOH when I looked at the code rather than just the patch I can't help
> >>>> but wonder shouldn't we actually structure this the way you initially
> >>>> proposed but also add a debug output along the lines of "skipping
> >>>> file/dir XXXX due to permission denied", otherwise users might not be
> >>>> able to account for some space and they can possibly wonder that
> >>>> something is wrong with btrfs fi du command.
> >>>
> >>> You mean that it would be better that print some debug message than
> >>> skipping silently. I agree. So I would add this code in condition.
> >>>
> >>> fprintf(stderr, "skipping file/dir: %s : %m\n", entry->d_name);
> >>>
> >>> I think it's okay that it prints when ENOTTY occurs. Is this code what
> >>> you meant?
> >>
> >>
> >> I meant to print only if we have EACCESS, but now that I think about it,
> >> printing something when we have a non-fatal error and simply skipping
> >> some dirs/files makes sense. OTOH printing it by default might be too
> >> verbose so perhaps usuing a pr_verbose call would be more appropriate.
> >>
> >> This is one of those things which don't have a clear-cut answers so it's
> >> useful to get as many perspective as possible to arrive at some workable
> >> solution to a wider number of people.
> > 
> > I must admit I just assumed it worked the same way as /bin/du. I have
> > just created an inaccessible directory and got:
> > 
> > $ du -sh ~
> > du: cannot read directory '/home/cobb/permtest': Permission denied
> > 61G	/home/cobb
> > 
> > And when the directory was accessible but the file in it was not, I got:
> > 
> > $ du -sh ~
> > du: cannot access '/home/cobb/permtest/file': Permission denied
> > 61G	/home/cobb
> > 
> > In other words, I think any error should be printed but the error is
> > then skipped and the du continues. No need to tell people the file is
> > being skipped - that is obvious. But the error must be printed by
> > default (if there are really cases where the error should not be printed
> > but reasons not to redirect stderr to /dev/null then add an option to
> > suppress printing it).
> > 
> > Just my opinion.
> 
> 
> That actually works for me, I'd rather btrfs be as consistent as
> possible and not give surprises to users. So just mimicking what an
> omnipresent tool does is as good as it gets :)

Yeah, I understood that any error should be printed but no need to print
that it is skipped. I agree. If so, I think the code that print error
message should like below.

fprintf(stderr, "failed to walk dir/file: %s: %m\n", entry->d_name);

I agreed that btrfs command should be like "du" command that familiar
with users. I wonder if I understood it well.

If so, I think it would be better that use switch-case than if-else.
> 
> 
> > 
> > Graham
> > 

  reply	other threads:[~2021-11-22 15:10 UTC|newest]

Thread overview: 9+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2021-11-21 15:15 [PATCH v2] btrfs-progs: filesystem: du: skip file that permission denied Sidong Yang
2021-11-22  7:20 ` Nikolay Borisov
2021-11-22  8:32   ` Sidong Yang
2021-11-22  9:32     ` Nikolay Borisov
2021-11-22  9:53       ` Graham Cobb
2021-11-22 10:57         ` Nikolay Borisov
2021-11-22 15:10           ` Sidong Yang [this message]
2021-11-22 15:20             ` Nikolay Borisov
2021-11-22 15:51               ` Sidong Yang

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20211122151027.GA10523@realwakka \
    --to=realwakka@gmail.com \
    --cc=dsterba@suse.com \
    --cc=g.btrfs@cobb.uk.net \
    --cc=linux-btrfs@vger.kernel.org \
    --cc=nborisov@suse.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox