* grub-core/disk/efi/efidisk.c: Handle partitions on non-512B disks.

Also-By: Vladimir Serbinenko <phcoder@gmail.com>
This commit is contained in:
Peter Jones 2013-04-04 10:35:50 +02:00 committed by Vladimir 'phcoder' Serbinenko
parent f75835bdad
commit efe0cddae8
2 changed files with 19 additions and 6 deletions

View file

@ -1,3 +1,8 @@
2013-04-04 Vladimir Serbinenko <phcoder@gmail.com>
2013-04-04 Peter Jones <pjones@redhat.com>
* grub-core/disk/efi/efidisk.c: Handle partitions on non-512B disks.
2013-04-04 Vladimir Serbinenko <phcoder@gmail.com> 2013-04-04 Vladimir Serbinenko <phcoder@gmail.com>
Use TSC as a possible time source on i386-ieee1275. Use TSC as a possible time source on i386-ieee1275.

View file

@ -659,9 +659,11 @@ grub_efidisk_get_device_handle (grub_disk_t disk)
&& (GRUB_EFI_DEVICE_PATH_SUBTYPE (c->last_device_path) && (GRUB_EFI_DEVICE_PATH_SUBTYPE (c->last_device_path)
== GRUB_EFI_HARD_DRIVE_DEVICE_PATH_SUBTYPE) == GRUB_EFI_HARD_DRIVE_DEVICE_PATH_SUBTYPE)
&& (grub_partition_get_start (disk->partition) && (grub_partition_get_start (disk->partition)
== hd.partition_start) == (hd.partition_start << (disk->log_sector_size
- GRUB_DISK_SECTOR_BITS)))
&& (grub_partition_get_len (disk->partition) && (grub_partition_get_len (disk->partition)
== hd.partition_size)) == (hd.partition_size << (disk->log_sector_size
- GRUB_DISK_SECTOR_BITS))))
{ {
handle = c->handle; handle = c->handle;
break; break;
@ -738,8 +740,12 @@ grub_efidisk_get_device_name_iter (grub_disk_t disk __attribute__ ((unused)),
{ {
struct grub_efidisk_get_device_name_ctx *ctx = data; struct grub_efidisk_get_device_name_ctx *ctx = data;
if (grub_partition_get_start (part) == ctx->hd.partition_start if (grub_partition_get_start (part)
&& grub_partition_get_len (part) == ctx->hd.partition_size) == (ctx->hd.partition_start << (disk->log_sector_size
- GRUB_DISK_SECTOR_BITS))
&& grub_partition_get_len (part)
== (ctx->hd.partition_size << (disk->log_sector_size
- GRUB_DISK_SECTOR_BITS)))
{ {
ctx->partition_name = grub_partition_get_name (part); ctx->partition_name = grub_partition_get_name (part);
return 1; return 1;
@ -798,7 +804,9 @@ grub_efidisk_get_device_name (grub_efi_handle_t *handle)
ctx.partition_name = NULL; ctx.partition_name = NULL;
grub_memcpy (&ctx.hd, ldp, sizeof (ctx.hd)); grub_memcpy (&ctx.hd, ldp, sizeof (ctx.hd));
if (ctx.hd.partition_start == 0 if (ctx.hd.partition_start == 0
&& ctx.hd.partition_size == grub_disk_get_size (parent)) && (ctx.hd.partition_size << (parent->log_sector_size
- GRUB_DISK_SECTOR_BITS))
== grub_disk_get_size (parent))
{ {
dev_name = grub_strdup (parent->name); dev_name = grub_strdup (parent->name);
} }