public inbox for linux-btrfs@vger.kernel.org
 help / color / mirror / Atom feed
From: Wang Shilong <wangsl.fnst@cn.fujitsu.com>
To: David Sterba <dsterba@suse.cz>
Cc: linux-btrfs@vger.kernel.org, Stefan Behrens <sbehrens@giantdisaster.de>
Subject: Re: [PATCH] btrfs-progs: enclose uuid tree compat code with ifdefs
Date: Thu, 23 Jan 2014 15:42:37 +0800	[thread overview]
Message-ID: <52E0C7ED.3000709@cn.fujitsu.com> (raw)
In-Reply-To: <1390319767-11201-1-git-send-email-dsterba@suse.cz>

Hi David,

On 01/21/2014 11:56 PM, David Sterba wrote:
> Commit "Btrfs-progs: make send/receive compatible with older kernels"
> adds code that will become deprecated, let's clearly mark it in the
> sources.
>
> CC: Stefan Behrens <sbehrens@giantdisaster.de>
> CC: Wang Shilong <wangsl.fnst@cn.fujitsu.com>
> Signed-off-by: David Sterba <dsterba@suse.cz>
> ---
>   send-utils.c |   28 ++++++++++++++++++++++++++++
>   send-utils.h |   10 ++++++++++
>   2 files changed, 38 insertions(+), 0 deletions(-)
>
> diff --git a/send-utils.c b/send-utils.c
> index 1772d2c5c0f3..8d4f46e3dd04 100644
> --- a/send-utils.c
> +++ b/send-utils.c
> @@ -159,6 +159,7 @@ static int btrfs_read_root_item(int mnt_fd, u64 root_id,
>   	return 0;
>   }
>   
> +#ifdef BTRFS_COMPAT_SEND_NO_UUID_TREE
>   static struct rb_node *tree_insert(struct rb_root *root,
>   				   struct subvol_info *si,
>   				   enum subvol_search_type type)
> @@ -223,6 +224,7 @@ static struct rb_node *tree_insert(struct rb_root *root,
>   	}
>   	return NULL;
>   }
> +#endif
>   
>   int btrfs_subvolid_resolve(int fd, char *path, size_t path_len, u64 subvol_id)
>   {
> @@ -320,6 +322,7 @@ static int btrfs_subvolid_resolve_sub(int fd, char *path, size_t *path_len,
>   	return 0;
>   }
>   
> +#ifdef BTRFS_COMPAT_SEND_NO_UUID_TREE
>   static int count_bytes(void *buf, int len, char b)
>   {
>   	int cnt = 0;
> @@ -416,6 +419,16 @@ static struct subvol_info *subvol_uuid_search_old(struct subvol_uuid_search *s,
>   		return NULL;
>   	return tree_search(root, root_id, uuid, transid, path, type);
>   }
> +#else
> +void subvol_uuid_search_add(struct subvol_uuid_search *s,
> +			    struct subvol_info *si)
> +{
> +	if (si) {
> +		free(si->path);
> +		free(si);
> +	}
> +}
> +#endif
I noticed subvol_uuid_search_add() function before, anyway
it is not called anywhere before, aslo IMO it is a little strange that 
we free
memory here.

Thanks,
Wang
>   
>   struct subvol_info *subvol_uuid_search(struct subvol_uuid_search *s,
>   				       u64 root_id, const u8 *uuid, u64 transid,
> @@ -426,9 +439,11 @@ struct subvol_info *subvol_uuid_search(struct subvol_uuid_search *s,
>   	struct btrfs_root_item root_item;
>   	struct subvol_info *info = NULL;
>   
> +#ifdef BTRFS_COMPAT_SEND_NO_UUID_TREE
>   	if (!s->uuid_tree_existed)
>   		return subvol_uuid_search_old(s, root_id, uuid, transid,
>   					     path, type);
> +#endif
>   	switch (type) {
>   	case subvol_search_by_received_uuid:
>   		ret = btrfs_lookup_uuid_received_subvol_item(s->mnt_fd, uuid,
> @@ -481,6 +496,7 @@ out:
>   	return info;
>   }
>   
> +#ifdef BTRFS_COMPAT_SEND_NO_UUID_TREE
>   static int is_uuid_tree_supported(int fd)
>   {
>   	int ret;
> @@ -679,6 +695,18 @@ void subvol_uuid_search_finit(struct subvol_uuid_search *s)
>   	s->received_subvols = RB_ROOT;
>   	s->path_subvols = RB_ROOT;
>   }
> +#else
> +int subvol_uuid_search_init(int mnt_fd, struct subvol_uuid_search *s)
> +{
> +	s->mnt_fd = mnt_fd;
> +
> +	return 0;
> +}
> +
> +void subvol_uuid_search_finit(struct subvol_uuid_search *s)
> +{
> +}
> +#endif
>   
>   char *path_cat(const char *p1, const char *p2)
>   {
> diff --git a/send-utils.h b/send-utils.h
> index 943b0277cf7e..f451c1cb6071 100644
> --- a/send-utils.h
> +++ b/send-utils.h
> @@ -30,6 +30,12 @@
>   extern "C" {
>   #endif
>   
> +/*
> + * Compatibility code for kernels < 3.12; the UUID tree is not available there
> + * and we have to do the slow search. This should be deprecated someday.
> + */
> +#define BTRFS_COMPAT_SEND_NO_UUID_TREE 1
> +
>   enum subvol_search_type {
>   	subvol_search_by_root_id,
>   	subvol_search_by_uuid,
> @@ -38,10 +44,12 @@ enum subvol_search_type {
>   };
>   
>   struct subvol_info {
> +#ifdef BTRFS_COMPAT_SEND_NO_UUID_TREE
>   	struct rb_node rb_root_id_node;
>   	struct rb_node rb_local_node;
>   	struct rb_node rb_received_node;
>   	struct rb_node rb_path_node;
> +#endif
>   
>   	u64 root_id;
>   	u8 uuid[BTRFS_UUID_SIZE];
> @@ -57,12 +65,14 @@ struct subvol_info {
>   
>   struct subvol_uuid_search {
>   	int mnt_fd;
> +#ifdef BTRFS_COMPAT_SEND_NO_UUID_TREE
>   	int uuid_tree_existed;
>   
>   	struct rb_root root_id_subvols;
>   	struct rb_root local_subvols;
>   	struct rb_root received_subvols;
>   	struct rb_root path_subvols;
> +#endif
>   };
>   
>   int subvol_uuid_search_init(int mnt_fd, struct subvol_uuid_search *s);


  reply	other threads:[~2014-01-23  7:43 UTC|newest]

Thread overview: 3+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2014-01-21 15:56 [PATCH] btrfs-progs: enclose uuid tree compat code with ifdefs David Sterba
2014-01-23  7:42 ` Wang Shilong [this message]
2014-01-23  8:20   ` Stefan Behrens

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=52E0C7ED.3000709@cn.fujitsu.com \
    --to=wangsl.fnst@cn.fujitsu.com \
    --cc=dsterba@suse.cz \
    --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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox