zfs: Fix disk-matching logic.
Reported by: Tim Chase <dweeezil>
This commit is contained in:
parent
68cf24376c
commit
12a9c52e51
1 changed files with 6 additions and 8 deletions
|
@ -252,7 +252,6 @@ struct grub_zfs_data
|
||||||
|
|
||||||
uberblock_t current_uberblock;
|
uberblock_t current_uberblock;
|
||||||
|
|
||||||
int mounted;
|
|
||||||
grub_uint64_t guid;
|
grub_uint64_t guid;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -957,7 +956,7 @@ nvpair_value (const char *nvp,char **val,
|
||||||
static grub_err_t
|
static grub_err_t
|
||||||
check_pool_label (struct grub_zfs_data *data,
|
check_pool_label (struct grub_zfs_data *data,
|
||||||
struct grub_zfs_device_desc *diskdesc,
|
struct grub_zfs_device_desc *diskdesc,
|
||||||
int *inserted)
|
int *inserted, int original)
|
||||||
{
|
{
|
||||||
grub_uint64_t pool_state, txg = 0;
|
grub_uint64_t pool_state, txg = 0;
|
||||||
char *nvlist,*features;
|
char *nvlist,*features;
|
||||||
|
@ -1081,11 +1080,12 @@ check_pool_label (struct grub_zfs_data *data,
|
||||||
|
|
||||||
grub_dprintf ("zfs", "check 11 passed\n");
|
grub_dprintf ("zfs", "check 11 passed\n");
|
||||||
|
|
||||||
if (data->mounted && data->guid != poolguid)
|
if (original)
|
||||||
return grub_error (GRUB_ERR_BAD_FS, "another zpool");
|
|
||||||
else
|
|
||||||
data->guid = poolguid;
|
data->guid = poolguid;
|
||||||
|
|
||||||
|
if (data->guid != poolguid)
|
||||||
|
return grub_error (GRUB_ERR_BAD_FS, "another zpool");
|
||||||
|
|
||||||
{
|
{
|
||||||
char *nv;
|
char *nv;
|
||||||
nv = grub_zfs_nvlist_lookup_nvlist (nvlist, ZPOOL_CONFIG_VDEV_TREE);
|
nv = grub_zfs_nvlist_lookup_nvlist (nvlist, ZPOOL_CONFIG_VDEV_TREE);
|
||||||
|
@ -1186,7 +1186,7 @@ scan_disk (grub_device_t dev, struct grub_zfs_data *data,
|
||||||
}
|
}
|
||||||
grub_dprintf ("zfs", "label ok %d\n", label);
|
grub_dprintf ("zfs", "label ok %d\n", label);
|
||||||
|
|
||||||
err = check_pool_label (data, &desc, inserted);
|
err = check_pool_label (data, &desc, inserted, original);
|
||||||
if (err || !*inserted)
|
if (err || !*inserted)
|
||||||
{
|
{
|
||||||
grub_errno = GRUB_ERR_NONE;
|
grub_errno = GRUB_ERR_NONE;
|
||||||
|
@ -3612,8 +3612,6 @@ zfs_mount (grub_device_t dev)
|
||||||
ub_endian) >> 63) & 1;
|
ub_endian) >> 63) & 1;
|
||||||
grub_free (osp);
|
grub_free (osp);
|
||||||
|
|
||||||
data->mounted = 1;
|
|
||||||
|
|
||||||
return data;
|
return data;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue