* grub-core/fs/zfs/zfs.c (nvlist_next_nvpair): Error is encode_size

<= 0.
This commit is contained in:
Massimo Maggi 2013-07-14 14:22:02 +02:00 committed by Vladimir 'phcoder' Serbinenko
parent 6d0ddff3d9
commit 0036f02d7b
2 changed files with 15 additions and 0 deletions

View file

@ -1,3 +1,8 @@
2013-07-14 Massimo Maggi <me@massimo-maggi.eu>
* grub-core/fs/zfs/zfs.c (nvlist_next_nvpair): Error is encode_size
<= 0.
2013-07-14 Massimo Maggi <me@massimo-maggi.eu> 2013-07-14 Massimo Maggi <me@massimo-maggi.eu>
* grub-core/fs/zfs/zfs.c: Split nvpair iterators into separate * grub-core/fs/zfs/zfs.c: Split nvpair iterators into separate

View file

@ -827,6 +827,16 @@ nvlist_next_nvpair(const char *nvl, const char *nvpair)
/* skip to the next nvpair */ /* skip to the next nvpair */
encode_size = grub_be_to_cpu32 (grub_get_unaligned32(nvpair)); encode_size = grub_be_to_cpu32 (grub_get_unaligned32(nvpair));
nvpair += encode_size; nvpair += encode_size;
/*If encode_size equals 0 nvlist_next_nvpair would return
* the same pair received in input, leading to an infinite loop.
* If encode_size is less than 0, this will move the pointer
* backwards, *possibly* examinining two times the same nvpair
* and potentially getting into an infinite loop. */
if(encode_size <= 0) {
grub_dprintf ("zfs", "nvpair with size <= 0\n");
grub_error (GRUB_ERR_BAD_FS, "incorrect nvlist");
return NULL;
}
} }
/* 8 bytes of 0 marks the end of the list */ /* 8 bytes of 0 marks the end of the list */
if (*(grub_uint64_t*)nvpair == 0) if (*(grub_uint64_t*)nvpair == 0)