Hand on gmirror (Was: Re: gmirror bugs, how many?)

Pawel Jakub Dawidek pjd at FreeBSD.org
Sun Nov 28 12:28:02 PST 2004


On Fri, Nov 26, 2004 at 05:55:51PM -0200, Jo?o Carlos Mendes Luís wrote:
+> Pawel Jakub Dawidek wrote:
[...]
+> >What error do you get when you try to do this?
+> 
+>     Step by step:
+> 
+> - The system has started with a preloaded geom_mirror:
[...]
+> - There is a running mirror partition:
[...]
+> - Now let's try to remove (disable was my intention, a bad idea):
+> 
+> sigesc::root jcmendes [524] gmirror unload
+> Could not unload module: Device not configured.
+> sigesc::root jcmendes [525] gmirror list
+> sigesc::root jcmendes [526] gmirror load
+> Command 'load' not available.
+> sigesc::root jcmendes [527] gmirror list
+> sigesc::root jcmendes [528] kldstat
+> Id Refs Address    Size     Name
+>  1   13 0xc0400000 3126c4   kernel
+>  2    1 0xc0713000 10be8    geom_mirror.ko
+>  3   14 0xc0724000 59340    acpi.ko
+>  4    1 0xc106a000 6000     linprocfs.ko
+>  5    1 0xc1070000 18000    linux.ko
+>  6    1 0xc1183000 2000     fade_saver.ko
+> sigesc::root jcmendes [529] ls -l /dev/mirror/
+> total 1
+> dr-xr-xr-x  2 root  wheel  512 Nov 26 12:19 .
+> dr-xr-xr-x  5 root  wheel  512 Nov 26 12:19 ..
+> sigesc::root jcmendes [530]
+> 
+> - Well, something not good happened.  The device did not unload, and do 
+> not list any device anymore.  Trying to "reload" it has no effect.
+> - This used to work before preloading it in loader.conf, but then I 
+> would not be able to boot a mirror partition.
[...]

Not working 'unload' command is because of bug in GEOM. Now, to avoid
deadlock you get an error (ENXIO), but mirror will be destroyed.
The next 'unload' should be ok. To avoid those errors, you should first
stop all mirrors (unsing 'stop' command) and then unload kernel module.
BTW. There is no 'reload' command.

+>     Indeed, the -h option is what I wanted and the "bug" is in the 
+> manual. What would happen if I change the disc ID in this case?

Your disk will not be detected as a mirror component, because hardcoded
name is different.

+> sigesc::root jcmendes [553] disklabel mirror/vol0
+> # /dev/mirror/vol0:
+> 8 partitions:
+> #        size   offset    fstype   [fsize bsize bps/cpg]
+>   a: 16498864       16    unused        0     0
+>   c: 16498880        0    unused        0     0         # "raw" part, 
+> don't edit
+> sigesc::root jcmendes [554]
+> 
+>   Seems good until now.  Except for the offset 16 of the "a" partition. 
+>  Is this necessary?  The man page says that the only sector reserved 
+> for metadata is the provider's last one.

Ehh, "blame" disklabel(8). First 16 sectors are reserved for boot code.

-- 
Pawel Jakub Dawidek                       http://www.FreeBSD.org
pjd at FreeBSD.org                           http://garage.freebsd.pl
FreeBSD committer                         Am I Evil? Yes, I Am!
-------------- next part --------------
A non-text attachment was scrubbed...
Name: not available
Type: application/pgp-signature
Size: 187 bytes
Desc: not available
Url : http://lists.freebsd.org/pipermail/freebsd-hackers/attachments/20041128/cdfa2b3e/attachment.bin


More information about the freebsd-hackers mailing list