All of lore.kernel.org
 help / color / mirror / Atom feed
From: Wang Shilong <wangsl-fnst@cn.fujitsu.com>
To: Stefan Behrens <sbehrens@giantdisaster.de>
Cc: linux-btrfs@vger.kernel.org
Subject: Re: [PATCH v3 3/4] Btrfs-progs: add more subvol fields to btrfs-list
Date: Fri, 12 Apr 2013 17:33:54 +0800	[thread overview]
Message-ID: <5167D502.8060901@cn.fujitsu.com> (raw)
In-Reply-To: <5167CE55.6040309@giantdisaster.de>

Hello,

> On Fri, 12 Apr 2013 16:39:55 +0800, Wang Shilong wrote:
> [...]
>>> +	if (ritem && !is_v0) {
>>> +		rinfo->cgen = btrfs_root_ctransid(ritem);
>>> +		rinfo->ogen = btrfs_root_otransid(ritem);
>>> +		rinfo->sgen = btrfs_root_stransid(ritem);
>>> +		rinfo->rgen = btrfs_root_rtransid(ritem);
>>> +		rinfo->ctime = btrfs_stack_timespec_sec(&ritem->ctime);
>>> +		rinfo->otime = btrfs_stack_timespec_sec(&ritem->otime);
>>> +		rinfo->stime = btrfs_stack_timespec_sec(&ritem->stime);
>>> +		rinfo->rtime = btrfs_stack_timespec_sec(&ritem->rtime);
>>> +		memcpy(rinfo->uuid, ritem->uuid, BTRFS_UUID_SIZE);
>>> +		memcpy(rinfo->puuid, ritem->parent_uuid, BTRFS_UUID_SIZE);
>>> +		memcpy(rinfo->ruuid, ritem->received_uuid, BTRFS_UUID_SIZE);
>>> +	} else if (ritem && is_v0 && root_offset) {
>>> +		/*
>>> +		 * old style (v0) root items don't contain an otransid field.
>>> +		 * But for snapshots, root_offset equals to its original
>>> +		 * generation.
>>> +		 */
>>> +		rinfo->ogen = root_offset;
>>> +	}
>>
>> 	We set it rinfo->ogen = root_offset only if:
>> 	1> for root_item_v0
>> 	2> it is a snapshot.
>>
>> 	Besides for a snapshot it's root_offset is always none zero.
>> 	so we do not need (is_v0 && root_offset) both.
>> 	Actually, Patch V2 doses the correct thing.
>>
> 
> Patch V2 was accessing the otransid field also for root_item_v0 which
> does not have this field. This was not correct.
> 
> That root_offset != 0 thing is because add_root() and therefore
> set_root_info() is called twice, once for BTRFS_ROOT_BACKREF_KEY and
> once for BTRFS_ROOT_ITEM_KEY. In both cases, the arguments to add_root()
> are only partially supplied and those values that are not available are
> set to zero. The old code everywhere had this ... != 0 else don't set
> the value, to handle this double call to add_root(), and I replaced most
> of it by passing a root_item pointer of NULL in the BACKREF case (where
> the old code just set gen=0, time=0, uuid=0 ...), and reading the values
> of the root_item down in set_root_info() in the ROOT_ITEM case. Only
> root_offset remains which is set to 0 in the BACKREF case and to the
> key's offset value in the ROOT_ITEM case. One could now argue that in
> the first case where root_offset is not valid, ritem is set to NULL and
> therefore the equation (ritem && is_v0 && root_offset) is equal to
> (ritem && is_v0), but IMHO a deep subfunction should not make use of too
> much information that is part of the functions that call the subfunction.
> 
> Summary: Patch V3 does the correct thing.
> 


After reading carefully, i agree patch V3 is correct~~, thanks
for so detailed illustration^_^

Thanks,
Wang

> --
> To unsubscribe from this list: send the line "unsubscribe linux-btrfs" in
> the body of a message to majordomo@vger.kernel.org
> More majordomo info at  http://vger.kernel.org/majordomo-info.html
> 
> 




      reply	other threads:[~2013-04-12  9:30 UTC|newest]

Thread overview: 16+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2013-04-11 16:22 [PATCH v2 0/4] Btrfs-progs: add --fields option to subvol list Stefan Behrens
2013-04-11 16:22 ` [PATCH v2 1/4] Btrfs-progs: cleanup in btrfs-list.c Stefan Behrens
2013-04-11 16:22 ` [PATCH v2 2/4] Btrfs-progs: make the btrfs-list output more compact Stefan Behrens
2013-04-11 16:22 ` [PATCH v2 3/4] Btrfs-progs: add more subvol fields to btrfs-list Stefan Behrens
2013-04-12  1:34   ` Wang Shilong
2013-04-12  1:42   ` Wang Shilong
2013-04-12  8:18     ` Stefan Behrens
2013-04-11 16:22 ` [PATCH v2 4/4] Btrfs-progs: enhance 'btrfs subvolume list' Stefan Behrens
2013-04-12  0:58   ` Wang Shilong
2013-04-12  7:44     ` Stefan Behrens
2013-04-18 16:28       ` David Sterba
2013-04-18 16:42   ` David Sterba
2013-04-12  8:26 ` [PATCH v3 3/4] Btrfs-progs: add more subvol fields to btrfs-list Stefan Behrens
2013-04-12  8:39   ` Wang Shilong
2013-04-12  9:05     ` Stefan Behrens
2013-04-12  9:33       ` Wang Shilong [this message]

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=5167D502.8060901@cn.fujitsu.com \
    --to=wangsl-fnst@cn.fujitsu.com \
    --cc=linux-btrfs@vger.kernel.org \
    --cc=sbehrens@giantdisaster.de \
    /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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.