a new hard-drive in a 2y/o laptop
Ian Smith
smithi at nimnet.asn.au
Wed Jan 5 05:44:26 UTC 2011
On Tue, 4 Jan 2011, Warren Block wrote:
> On Tue, 4 Jan 2011, Chris Brennan wrote:
>
> > On Tue, Jan 4, 2011 at 3:56 AM, Ian Smith <smithi at nimnet.asn.au> wrote:
> >
> > > On Mon, 3 Jan 2011 16:31:17 -0500, Chris Brennan wrote:
> > > [.. trimming ccs, selectively quoting and de-gmailing a bit ..]
> > >
> >
> > Trimmings! Oh nevermind. I don't know what possessed me to go and look
> > at the debug window. But I do and I see the following.
> >
> > GEOM: ad4: the primary GPT table is corrupt or invalid.
> > GEOM: ad4: using the secondary instead -- recovery strongly advised.
> >
> > This is even after zero the beginning and the end of the drive ....
> > Something is hinky!
Indeed. Well Chris attached the following to his prior email, which
made it to the list being text, dmesg didn't, application/octet-stream:
http://lists.freebsd.org/pipermail/freebsd-questions/attachments/20110104/c370dd77/dmesg-0001.obj
But confirming the GEOM messages shown above, here's the 'smoking gun':
00000000 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 |................|
*
00004000 45 46 49 20 50 41 52 54 00 00 01 00 5c 00 00 00 |EFI PART....\...|
00004010 2b b3 b7 fa 00 00 00 00 ef 66 54 57 00 00 00 00 |+........fTW....|
00004020 01 00 00 00 00 00 00 00 22 00 00 00 00 00 00 00 |........".......|
00004030 ce 66 54 57 00 00 00 00 45 51 13 4c 0e 0e e0 11 |.fTW....EQ.L....|
00004040 95 6e 00 1d 72 5b f5 d6 cf 66 54 57 00 00 00 00 |.n..r[...fTW....|
00004050 80 00 00 00 80 00 00 00 86 d2 54 ab 00 00 00 00 |..........T.....|
00004060 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 |................|
*
00004200
So that is really the last 33 sectors of the disk (0x4200 = 16896d, /
512 = 33) and the last sector does indeed have the 'GPT EFI' signature
(ref: http://en.wikipedia.org/wiki/GUID_Partition_Table), so the seek
and count looks right, matching the read command I'd suggested:
> dd if=/dev/ad4 iseek=1465149135 count=33 | hd
Seems odd that it hasn't been zeroed, but all the sectors before it are
(ie there's just the header, no actual 128-byte partition entries if I'm
interpreting this correctly), so maybe there's still some off-by-one in
counting from the end of the disk for writing, not knowing the actual dd
command used .. you're not wrong that negative offsets can be tricky!
> Today I also found that zeroing the beginning and end of the drive didn't
> seem to be enough. I had the start of a huffy email about how hard it was to
> calculate the end of a drive in blocks, and how dd didn't have a negative
> oseek to seek backwards from the end. But then I checked gpart(8)... and it
> turns out that
>
> # gpart destroy -F da0
>
> works. Be very careful that you've got the right drive there, of course.
Saw Chris' later message that -F isn't there for him, but here's what
should be, on the data, the sure-fire way to clobber that last sector:
dd if=/dev/zero of=/dev/ad4 oseek=1465149167
which command SHOULD report just 512 bytes written (we're sure it can't
write past the end of the disk with no count specified), after which:
dd if=/dev/ad4 iseek=1465149167 | hd
SHOULD show zeroes from 00000000 to 000001ff (ie next block 00000200)
If not, there really must be some hardware issue with writing?
Hopefully getting there!
cheers, Ian
More information about the freebsd-questions
mailing list