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>