From: Colin Watson <cjwatson@ubuntu.com>
To: "Vladimir 'φ-coder/phcoder' Serbinenko" <phcoder@gmail.com>
Cc: grub-devel@gnu.org, Mario Limonciello <mario_limonciello@dell.com>
Subject: Re: [PATCH] grub-setup Modify the conditionality of the copy of the partition table
Date: Fri, 25 Mar 2011 23:31:23 +0000 [thread overview]
Message-ID: <20110325233122.GC9163@riva.ucam.org> (raw)
In-Reply-To: <4D8D1D64.2040801@gmail.com>
On Fri, Mar 25, 2011 at 11:55:32PM +0100, Vladimir 'φ-coder/phcoder' Serbinenko wrote:
> On 25.03.2011 23:13, Mario Limonciello wrote:
> > + * util/grub-setup.c: Conditionalize the partition map copy on floppy
> > + support, not on whether the target contains partitions.
> > +
> > + Otherwise, the BIOS on Dell Latitude E series laptops will freeze
> > + during POST if an invalid partition table is contained in the PBR
> > + of the active partition when GRUB is installed to a partition.
>
> It's wrong to assume that no floppies contain partition tables. Also
> --allow-floppy is usually used for USB sticks which sometimes appear as
> floppies on some BIOSes and they pretty much contain the partition
> table. Bottom line is: if you see a partition table: preserve it.
Reading from floppies requires the floppy_probe function in boot.S,
doesn't it, which collides with the partition table? But it makes sense
to keep dest_partmap in the condition for safety anyway (and it saves a
call to grub_util_biosdisk_is_floppy), so we'd end up with:
if (dest_partmap ||
(!allow_floppy && !grub_util_biosdisk_is_floppy (dest_dev->disk)))
memcpy (boot_img + GRUB_BOOT_MACHINE_WINDOWS_NT_MAGIC,
tmp_img + GRUB_BOOT_MACHINE_WINDOWS_NT_MAGIC,
GRUB_BOOT_MACHINE_PART_END - GRUB_BOOT_MACHINE_WINDOWS_NT_MAGIC);
?
> But it's ok to preserve this contents if floppy support is disabled
> even if no partition table is discovered.
In the case Mario discovered, there was indeed no partition table (all
zeroes). Writing the floppy-probing code into that area caused it to
fail.
> A small logic lecture:
>
> Floppy support is: allow_floppy || grub_util_biosdisk_is_floppy (dest_dev->disk)
> Negation of it is either !(allow_floppy || grub_util_biosdisk_is_floppy (dest_dev->disk)) or !allow_floppy && !grub_util_biosdisk_is_floppy (dest_dev->disk), not what you wrote.
Agreed. The latter form is found elsewhere in grub-setup.
> Please don't move around unrelated parts.
The parts Mario moved around weren't unrelated. Since the case at hand
is that of installing to a partition boot record, this if block will
run:
if (! dest_partmap)
{
grub_util_warn (_("Attempting to install GRUB to a partitionless disk or to a partition. This is a BAD idea."));
goto unable_to_embed;
}
In order to preserve the partition table (or lack thereof) in this case,
it was necessary to move the memcpy up above that test.
Cheers,
--
Colin Watson [cjwatson@ubuntu.com]
next prev parent reply other threads:[~2011-03-25 23:31 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2011-03-25 22:13 [PATCH] grub-setup Modify the conditionality of the copy of the partition table Mario Limonciello
2011-03-25 22:55 ` Vladimir 'φ-coder/phcoder' Serbinenko
2011-03-25 23:31 ` Colin Watson [this message]
2011-03-26 0:37 ` Mario Limonciello
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20110325233122.GC9163@riva.ucam.org \
--to=cjwatson@ubuntu.com \
--cc=grub-devel@gnu.org \
--cc=mario_limonciello@dell.com \
--cc=phcoder@gmail.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.