On Mon, Nov 30, 2020 at 11:16:19PM -0600, Glenn Washburn wrote: > There is a hardcoded maximum disk size that can be read or written from, > currently set at 1EiB in grub_disk_adjust_range. Move the literal into a > macro in disk.h, so our assumptions are more visible. This hard coded limit > does not prevent using larger disks, just grub won't read/write past the > limit. The comment accompanying this restriction didn't quite make sense to > me, so its been modified. > > Signed-off-by: Glenn Washburn <developm...@efficientek.com>
Reviewed-by: Daniel Kiper <daniel.ki...@oracle.com> Except one nit... > --- > grub-core/kern/disk_common.c | 15 ++++++++------- > include/grub/disk.h | 6 ++++++ > 2 files changed, 14 insertions(+), 7 deletions(-) > > diff --git a/grub-core/kern/disk_common.c b/grub-core/kern/disk_common.c > index 2ca12b5f8..d43b927a4 100644 > --- a/grub-core/kern/disk_common.c > +++ b/grub-core/kern/disk_common.c > @@ -32,13 +32,14 @@ grub_disk_adjust_range (grub_disk_t disk, > grub_disk_addr_t *sector, > /* Transform total_sectors to number of 512B blocks. */ > total_sectors = disk->total_sectors << (disk->log_sector_size - > GRUB_DISK_SECTOR_BITS); > > - /* Some drivers have problems with disks above reasonable. > - Treat unknown as 1EiB disk. While on it, clamp the size to 1EiB. > - Just one condition is enough since GRUB_DISK_UNKNOWN_SIZE << ls is > always > - above 9EiB. > - */ > - if (total_sectors > (1ULL << 51)) > - total_sectors = (1ULL << 51); > + /* > + * Some drivers have problems with disks above reasonable sizes. > + * Clamp the size to GRUB_DISK_MAX_SECTORS. Just one condition is enough > + * since GRUB_DISK_UNKNOWN_SIZE is always above GRUB_DISK_MAX_SECTORS, s/GRUB_DISK_UNKNOWN_SIZE/GRUB_DISK_SIZE_UNKNOWN/ I can fix it before committing the patch. Daniel _______________________________________________ Grub-devel mailing list Grub-devel@gnu.org https://lists.gnu.org/mailman/listinfo/grub-devel