Skip site navigation (1)Skip section navigation (2)
Date:      Wed, 25 Jul 2007 17:39:22 +0100
From:      Doug Rabson <dfr@rabson.org>
To:        Mark Powell <M.S.Powell@salford.ac.uk>
Cc:        freebsd-fs@freebsd.org
Subject:   Re: ZfS & GEOM with many odd drive sizes
Message-ID:  <77814562-8B5E-4E3C-9018-59F7E8FBF8C8@rabson.org>
In-Reply-To: <20070725171343.M61339@rust.salford.ac.uk>
References:  <20070719102302.R1534@rust.salford.ac.uk> <20070719135510.GE1194@garage.freebsd.pl> <20070719181313.G4923@rust.salford.ac.uk> <20070721065204.GA2044@garage.freebsd.pl> <20070725095723.T57231@rust.salford.ac.uk> <1185355848.3698.7.camel@herring.rabson.org> <20070725103746.N57231@rust.salford.ac.uk> <3A5D89E1-A7B1-4B10-ADB8-F58332306691@rabson.org> <20070725120913.A57231@rust.salford.ac.uk> <6FF8729F-B449-4EFA-B3C6-8B9A9E6F6C4F@rabson.org> <20070725171343.M61339@rust.salford.ac.uk>

next in thread | previous in thread | raw e-mail | index | archive | help

On 25 Jul 2007, at 17:20, Mark Powell wrote:

> On Wed, 25 Jul 2007, Doug Rabson wrote:
>
>> On 25 Jul 2007, at 12:17, Mark Powell wrote:
>>> Great work. That will be zfs mirror only right?
>>
>> The code is close to being able to support collections of mirrors.  
>> No raidz or raidz2 for now though.
>
> That's great news.
>   So that would mean, if a raidz vdev was required on a system  
> another pool would have to be created with only a mirror vdev in  
> it, to have / on zfs too?
>   Considering the work involved, is raidz / support really worth  
> it? Of course, it's fantastic if you plan to tackle it, but I don't  
> envy you the task :(

In theory supporting raidz isn't that hard although the layout policy  
is undocumented. I've looked at the code and I could probably borrow  
some code from the 'real' zfs to figure out the layout and support  
non-degraded raidz and raidz2. Supported degraded configurations is  
more effort because of the extra code to re-generate the date from  
the parity.

The biggest problem here is space. The wretched PC platform requires  
us to bootstrap the system starting from a single sector's worth of  
code (512 bytes). That code runs in stone-age 16bit mode and loads  
the second stage from a fixed disk location. To keep my sanity, I'm  
currently trying to limit the code size of the second stage to 16k.  
This second stage has to understand ZFS well enough to load the third  
stage /boot/loader code from the pool. I currently have exactly 171  
bytes of free space in boot2.

I could probably squeeze another 4k into the second stage bootstrap  
by re-writing boot1 again. I will probably have to do that to support  
collections of disks/mirrors anyway. Doing that will mean permanently  
giving up the idea of booting ZFS on systems that don't support LBA  
addressing. Tthis already disabled in my boot1 code but could be  
resurrected after some hair pulling - increasing the size of boot2  
would make supporting legacy (>10hys old) BIOS machines impossible.




Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?77814562-8B5E-4E3C-9018-59F7E8FBF8C8>