c789522
From ab8e0d4bf544b708f5afa4cc56e6bd16789f2f1e Mon Sep 17 00:00:00 2001
bc092b9
From: Andrei Borzenkov <arvidjaar@gmail.com>
bc092b9
Date: Tue, 21 Jun 2016 16:44:17 +0000
63f1a98
Subject: [PATCH 180/250] Fallback to old subvol name scheme to support old
bc092b9
 snapshot config
bc092b9
bc092b9
Ref: bsc#953538
bc092b9
---
bc092b9
 grub-core/fs/btrfs.c | 32 +++++++++++++++++++++++++++++++-
bc092b9
 1 file changed, 31 insertions(+), 1 deletion(-)
bc092b9
bc092b9
diff --git a/grub-core/fs/btrfs.c b/grub-core/fs/btrfs.c
ec4acbb
index d111147e836..a5c000805a7 100644
bc092b9
--- a/grub-core/fs/btrfs.c
bc092b9
+++ b/grub-core/fs/btrfs.c
da63b36
@@ -924,11 +924,41 @@ lookup_root_by_name(struct grub_btrfs_data *data, const char *path)
da63b36
   return GRUB_ERR_NONE;
bc092b9
 }
bc092b9
 
da63b36
+static grub_err_t
bc092b9
+lookup_root_by_name_fallback(struct grub_btrfs_data *data, const char *path)
bc092b9
+{
bc092b9
+  grub_err_t err;
bc092b9
+  grub_uint64_t tree = 0;
bc092b9
+  grub_uint8_t type;
bc092b9
+  struct grub_btrfs_key key;
bc092b9
+
bc092b9
+  err = find_path (data, path, &key, &tree, &type);
bc092b9
+  if (err)
bc092b9
+      return grub_error(GRUB_ERR_FILE_NOT_FOUND, "couldn't locate %s\n", path);
bc092b9
+
bc092b9
+  if (key.object_id != grub_cpu_to_le64_compile_time (GRUB_BTRFS_OBJECT_ID_CHUNK) || tree == 0)
bc092b9
+    return grub_error(GRUB_ERR_BAD_FILE_TYPE, "%s: not a subvolume\n", path);
bc092b9
+
bc092b9
+  data->fs_tree = tree;
bc092b9
+  return GRUB_ERR_NONE;
bc092b9
+}
bc092b9
+
da63b36
 static grub_err_t
bc092b9
 btrfs_handle_subvol(struct grub_btrfs_data *data __attribute__ ((unused)))
bc092b9
 {
bc092b9
   if (btrfs_default_subvol)
bc092b9
-    return lookup_root_by_name(data, btrfs_default_subvol);
bc092b9
+    {
bc092b9
+      grub_err_t err;
bc092b9
+      err = lookup_root_by_name(data, btrfs_default_subvol);
bc092b9
+
bc092b9
+      /* Fallback to old schemes */
bc092b9
+      if (err == GRUB_ERR_FILE_NOT_FOUND)
bc092b9
+	{
bc092b9
+	  err = GRUB_ERR_NONE;
bc092b9
+	  return lookup_root_by_name_fallback(data, btrfs_default_subvol);
bc092b9
+	}
bc092b9
+      return err;
bc092b9
+    }
bc092b9
 
bc092b9
   if (btrfs_default_subvolid)
bc092b9
     return lookup_root_by_id(data, btrfs_default_subvolid);
bc092b9
-- 
63f1a98
2.14.3
bc092b9