amd64/186515: Doesn't boot with GPT when # of entries over than 128.
John Baldwin
jhb at freebsd.org
Thu Feb 6 19:30:02 UTC 2014
The following reply was made to PR kern/186515; it has been noted by GNATS.
From: John Baldwin <jhb at freebsd.org>
To: freebsd-amd64 at freebsd.org
Cc: Yeong.Hun at freebsd.org,
Jo <jyhpsycho at gmail.com>,
freebsd-gnats-submit at freebsd.org
Subject: Re: amd64/186515: Doesn't boot with GPT when # of entries over than 128.
Date: Thu, 6 Feb 2014 13:41:04 -0500
On Thursday, February 06, 2014 12:43:48 pm Yeong.Hun at freebsd.org, Jo wrote:
>
> >Number: 186515
> >Category: amd64
> >Synopsis: Doesn't boot with GPT when # of entries over than 128.
> >Confidential: no
> >Severity: non-critical
> >Priority: low
> >Responsible: freebsd-amd64
> >State: open
> >Quarter:
> >Keywords:
> >Date-Required:
> >Class: sw-bug
> >Submitter-Id: current-users
> >Arrival-Date: Thu Feb 06 17:50:00 UTC 2014
> >Closed-Date:
> >Last-Modified:
> >Originator: Yeong Hun, Jo
> >Release: FreeBSD 10.0-RELEASE
> >Organization:
> -
> >Environment:
> FreeBSD localhost 10.0-RELEASE FreeBSD 10.0-RELEASE #0 r260789: Thu Jan 1
22:34:59 UTC 2014 root at snap.freebsd.org:/usr/obj/usr/src/sys/GENERIC
amd64
> >Description:
> I tried to making USB memory stick using GPT partition table scheme. I
usually use 152 entries to aligning 4KB boundary for data disk(start location)
and use 156 entries to aligning 4KB boundary for system disk(end location,
misalignment of start location is used for boot code and make 4KB aligned root
partition). I don't like that some "free" sectors on disk :-)
>
> But, it failed to boot when partition entry count is adjusted to more than
128.
>
> * WORKS : 128 entries GPT(1st usable sector = 34) with freebsd-boot
partition at sector 34, 40.
>
> * DOESN'T WORK : 152 entries GPT(1st usable sector = 40) with freebsd-boot
partition at sector 40, 156 entries GPT(1st usable sector = 41) with freebsd-
boot partition at sector 41.
>
>
>
> Yes, There's no problem with default size GPT partition table. "128 entires"
- minimum entry count by spec. - seems to be sufficient at most cases. But,
that can be arbitrary size and should be supported even that cases. I think
there's some issue on gpart or early-stage boot loader(/boot/pmbr).
>
> >How-To-Repeat:
> * For example, USB disk is da0 here.
>
> # gpart create -s gpt -n 152 da0
> # gpart add -t freebsd-boot -b 40 -s 32 -i 1 da0
> # gpart bootcode -b /boot/pmbr -p /boot/gptboot -i 1 da0
>
> and try to boot USB. It should be show "clockwise" loading screen even no
freebsd-ufs partition on USB, but it doesn't show anything and reboot
immediately. It(doesn't say anything and reboot) occurs with /boot populated
freebsd-ufs partition, too.
Using more entries to pad out the table isn't the normal way to handle 4k
alignment. You can just leave a gap before the start of freebsd-boot. Having
the sectors "free" vs having them contain zero'd GPT entries doesn't really
make a difference. One question is when does the boot break? Does it make it
into the loader and break trying to boot the kernel? Does it make it into
gptboot and break trying to load the loader?
--
John Baldwin
More information about the freebsd-fs
mailing list