Geom question

Chad J. Milios milios at ccsys.com
Fri Oct 2 21:31:00 UTC 2015


On 10/2/2015 5:00 PM, William A. Mahaffey III wrote:
> On 10/02/15 15:31, Chad J. Milios wrote:
>>> On Oct 2, 2015, at 3:41 PM, William A. Mahaffey III <wam at hiwaay.net> 
>>> wrote:
>>>
>>> I am prepping to provision 2 boxen w/ FreeBSD 9.3R, preferably from 
>>> a thumb drive. I would like to add a 'utils' directory w/ some 
>>> scripts I wrote to automate the partitioning/slicing of the HDD's 
>>> (2X on 1 box, 8X on the other), & also accumulate output from the 
>>> install process in case questions arise. To that end, I am planning 
>>> on partitioning/slicing a thumb drive, prepping it to be bootable 
>>> following examples on the gpart man page, & copying verbatim stuff 
>>> from the memstick.img for 9.3R that I downloaded a while back, as 
>>> well as adding my utils directory. Reading up on gpart & geom raises 
>>> 1 question: can I do all these preps on a disk image file I create 
>>> w/ dd, or do i do them in place on the target memstick, then dd the 
>>> results onto an on-disk image for safekeeping ? Put another way, can 
>>> a disk image created by dd be a 'geom' for gpart ? TIA & have a good 
>>> one.
>>>
>>> -- 
>>>
>>>     William A. Mahaffey III
>> In a way, yes. `mdconfig -f filename` will make your file accessible 
>> as a virtual device.
>>
>
> Thanks for the info. I proceeded w/ trying to setup /dev/md0 as a 
> bootable disk image as follows:
>
> [root at kabini1, /etc, 3:54:31pm] 758 % dd if=/dev/zero 
> of=/home/memstick.img count=3699 bs=1m
> 3699+0 records in
> 3699+0 records out
> 3878682624 bytes transferred in 8.324621 secs (465929036 bytes/sec)
FYI, check out `man truncate` next time to save some time/space. Most 
file systems support what are known as "sparse" files. That dd command 
works just fine for this though.
> [root at kabini1, /etc, 3:55:23pm] 759 % cat 
> ~wam/FreeBSD/9.3/README.createBootableMBR-SD.txt
>
>      MBR:   Master Boot Record is used on PCs and removable media. 
> Requires
>             the GEOM_PART_MBR kernel option.  The GEOM_PART_EBR option 
> adds
>             support for the Extended Boot Record (EBR), which is used to
>             define a logical partition.  The GEOM_PART_EBR_COMPAT option
>             enables backward compatibility for partition names in the EBR
>             scheme.  It also prevents any type of actions on such 
> partitions.
>
>      Create an MBR scheme on ada0, then create a 30GB-sized FreeBSD 
> slice, mark it active and install the boot0 boot manager:
>
>            /sbin/gpart create -s MBR ada0
>            /sbin/gpart add -t freebsd -s 30G ada0
>            /sbin/gpart set -a active -i 1 ada0
>            /sbin/gpart bootcode -b /boot/boot0 ada0
>
>      Now create a BSD scheme (BSD label) with space for up to 20 
> partitions:
>
>            /sbin/gpart create -s BSD -n 20 ada0s1
>
>      Create a 1GB-sized UFS partition and a 4GB-sized swap partition:
>
>            /sbin/gpart add -t freebsd-ufs -s 1G ada0s1
>            /sbin/gpart add -t freebsd-swap -s 4G ada0s1
>
>      Install bootstrap code for the BSD label:
>
>            /sbin/gpart bootcode -b /boot/boot ada0s1
>
> [root at kabini1, /etc, 3:55:50pm] 760 % mdconfig -f /home/memstick.img
> md0
> [root at kabini1, /etc, 3:56:26pm] 761 % /sbin/gpart create -s MBR md0
> md0 created
> [root at kabini1, /etc, 3:58:45pm] 762 % /sbin/gpart add -t freebsd -s 
> 3698M md0
> md0s1 added
If you leave off the -s $SIZE option gpart will simply use up every 
available byte for you
> [root at kabini1, /etc, 3:59:14pm] 763 % /sbin/gpart set -a active -i 1 md0
> active set on md0s1
> [root at kabini1, /etc, 3:59:25pm] 764 % /sbin/gpart bootcode -b 
> /boot/boot0 md0
> bootcode written to md0
> [root at kabini1, /etc, 3:59:44pm] 765 % /sbin/gpart create -s BSD md0s1
> md0s1 created
> [root at kabini1, /etc, 3:59:57pm] 766 % /sbin/gpart add -t freebsd-ufs 
> md0s1
> md0s1a added
> [root at kabini1, /etc, DING!] 767 % /sbin/gpart bootcode -b /boot/boot 
> md0s1
> bootcode written to md0s1
> [root at kabini1, /etc, 4:00:25pm] 768 % lltr /dev/md0*; date
> crw-r-----  1 root  operator  0xd2 Oct  2 15:56 /dev/md0
> crw-r-----  1 root  operator  0xd5 Oct  2 15:59 /dev/md0s1
> crw-r-----  1 root  operator  0xd6 Oct  2 16:00 /dev/md0s1a
> Fri Oct  2 16:00:44 MCDT 2015
> [root at kabini1, /etc, 4:00:44pm] 769 % mount /dev/md0s1  /media/sd/
> mount: /dev/md0s1: Invalid argument
> [root at kabini1, /etc, 4:01:16pm] 770 % mount -t ufs /dev/md0s1 /media/sd/
> mount: /dev/md0s1: Invalid argument
> [root at kabini1, /etc, 4:01:34pm] 771 % mount -t ufs /dev/md0s1a /media/sd/
> mount: /dev/md0s1a: Invalid argument
> [root at kabini1, /etc, 4:01:41pm] 772 %
>
> & I appear to be stuck trying to mount the /dev/md0 device so I can 
> copy stuff to it :-/. Any clues appreciated. TIA & have a good one.

you need to `newfs /dev/md0s1a` first before attempting to mount it, as 
`gpart add -t freebsd-ufs $GEOM` only marks the meta info in the 
outerlying structure (the front few blocks of /dev/md0s1 in your case) 
and doesn't actually do what you're expecting. `man newfs` to decide 
that you probably want the -U flag with that and might want the -J flag 
as well.

Cheers,
-Chad


More information about the freebsd-questions mailing list