Home | History | Annotate | Download | only in raidframe
History log of /src/sys/dev/raidframe/rf_diskqueue.c
RevisionDateAuthorComments
 1.64  17-Sep-2023  oster Implement hot removal of spares and components. From manu@.

Implement a long desired feature of automatically incorporating
a used spare into the array after a reconstruct.

Given the configuration:
Components:
/dev/wd0e: failed
/dev/wd1e: optimal
/dev/wd2e: optimal
Spares:
/dev/wd3e: spare

Running 'raidctl -F /dev/wd0e raid0' will now result in the
following configuration after a successful rebuild:
Components:
/dev/wd3e: optimal
/dev/wd1e: optimal
/dev/wd2e: optimal
No spares.

Thanks to manu@ for the development of the initial set of changes
which allowed the changes to automatically incorporate a used spare
to come to fruition. Thanks also to manu@ for useful discussions
about and additional testing of these changes.
 1.63  14-Dec-2021  mrg branches: 1.63.4;
call buf_destroy() after buf_init(). hopefully fixes the lockdebug
problem shown here:

http://mail-index.netbsd.org/tech-kern/2021/12/10/msg027851.html

but seems unlikely to fix the original problem.

tested on i386/anita. ok oster@

XXX: pullup-9 (netbsd-8 uses old APIs.)
 1.62  27-Jul-2021  oster rf_CreateDiskQueueData() no longer uses waitflag, and will always succeed.
Cleanup the error path for the (no longer needed) PR_NOWAIT cases.
 1.61  23-Jul-2021  oster Various disk queue "peek" routines were only ever used in the simulator
version of RAIDFrame. Remove them from here.
 1.60  23-Jul-2021  oster Extensive mechanical changes to the pools used in RAIDframe.

Alloclist remains not per-RAID, so initialize that pool
separately/differently than the rest.

The remainder of pools in RF_Pools_s are now per-RAID pools. Mostly
mechanical changes to functions to allocate/destroy per-RAID pools.
Needed to make raidPtr available in certain cases to be able to find
the per-RAID pools.

Extend rf_pool_init() to now populate a per-RAID wchan value that is
unique to each pool for a given RAID device.

TODO: Complete the analysis of the minimum number of items that are
required for each pool to allow IO to progress (i.e. so that a request
for pool resources can always be satisfied), and dynamically scale
minimum pool sizes based on RAID configuration.
 1.59  23-Jul-2021  oster getiobuf() can return NULL if there are no IO buffers available.
RAIDframe can't deal with that, so create a dedicated pool of buffers
to use for IO. PR_WAITOK is fine here, as we pre-allocate more than
we need to guarantee IO can make progress. Tuning of pool still to
come.
 1.58  19-Jun-2020  jdolecek branches: 1.58.6;
remove unnnecessary splbio() in rf_FreeDiskQueueData()
 1.57  19-Jun-2020  jdolecek pass down b_flags B_PHYS|B_RAW|B_MEDIA_FLAGS from bio subsystem
to component I/O

fixes the xbd(4) KASSERT() triggered by raidframe, noted in PR kern/55397
by Frank Kardel
 1.56  10-Oct-2019  christos fix the function pointer and callback mess:
- callback functions return 0 and their result is not checked; make them void.
- there are two types of callbacks and they used to overload their parameters
and the callback structure; separate them into "function" and "value"
callbacks.
- make the wait function signature consistent.
 1.55  10-Feb-2019  christos branches: 1.55.4;
Introduce PR_ZERO to avoid open-coding memset()s everywhere. OK riastradh@.
 1.54  09-Feb-2019  christos - Change the allocation macros to be more like function calls
- Change sizeof(type) -> sizeof(*variable)
- Use macros for the long buffer length allocations
- Remove "bit polishing" memsets() -- do them only once
- Remove unnecessary casts

Thanks to oster@ for finding bugs and testing.
 1.53  05-May-2011  mrg branches: 1.53.56;
convert the diskqueue mutex into a kmutex
 1.52  23-Mar-2009  oster branches: 1.52.4; 1.52.6;
Rework/simplify the disk queuing code. A bunch of this was still
holdovers from the simulator and would never be seen/used in-kernel.
 1.51  17-Jun-2008  reinoud branches: 1.51.4; 1.51.6; 1.51.10; 1.51.14;
Mark a buffer `busy` in getnewbuf() when it came from the pool_cache since
its not on a free list.

Also change buf_init() to not automatically mark buffers `busy' since this
only makes sense for bufcache buffers.

Mark all buf_init'd buffers 'busy' on the places where they ought to be
flagged as such to not confuse the buffer cache.

Fixes PR 38923.
 1.50  02-Jan-2008  ad branches: 1.50.6; 1.50.10; 1.50.12; 1.50.14;
Merge vmlocking2 to head.
 1.49  04-Mar-2007  christos branches: 1.49.2; 1.49.16; 1.49.22; 1.49.24; 1.49.28;
Kill caddr_t; there will be some MI fallout, but it will be fixed shortly.
 1.48  16-Nov-2006  christos branches: 1.48.4;
__unused removal on arguments; approved by core.
 1.47  12-Oct-2006  christos - sprinkle __unused on function decls.
- fix a couple of unused bugs
- no more -Wno-unused for i386
 1.46  05-Oct-2006  tls Protect calls to pool_put/pool_get that may occur in interrupt context
with spl used to protect other allocations and frees, or datastructure
element insertion and removal, in adjacent code.

It is almost unquestionably the case that some of the spl()/splx() calls
added here are superfluous, but it really seems wrong to see:

s=splfoo();
/* frob data structure */
splx(s);
pool_put(x);

and if we think we need to protect the first operation, then it is hard
to see why we should not think we need to protect the next. "Better
safe than sorry".

It is also almost unquestionably the case that I missed some pool
gets/puts from interrupt context with my strategy for finding these
calls; use of PR_NOWAIT is a strong hint that a pool may be used from
interrupt context but many callers in the kernel pass a "can wait/can't
wait" flag down such that my searches might not have found them. One
notable area that needs to be looked at is pf.

See also:

http://mail-index.netbsd.org/tech-kern/2006/07/19/0003.html
http://mail-index.netbsd.org/tech-kern/2006/07/19/0009.html
 1.45  08-Jan-2006  oster branches: 1.45.18; 1.45.20;
Cleanup the initialization of buffers a bit, and remove some old code
that works around a bug that no longer exists. From yamt. Thanks!
(a bit more cleanup to follow)
 1.44  06-Jan-2006  yamt initialize necessary members of struct buf. PR/32462 from Reinoud Zandijk.
 1.43  04-Jan-2006  yamt - add simple functions to allocate/free a buffer for i/o.
- make bufpool static.
 1.42  11-Dec-2005  christos branches: 1.42.2;
merge ktrace-lwp.
 1.41  29-May-2005  christos branches: 1.41.2;
- avoid variable shadowing
- add a lot of const
- remove parameters from functin declarations
 1.40  27-Feb-2005  perry branches: 1.40.2;
nuke trailing whitespace
 1.39  12-Feb-2005  oster The 'next' argument to rf_CreateDiskQueueData is always NULL. Since
there is no particular reason to pass an extra NULL argument, turf it,
and initialize p->next to NULL within the function.
 1.38  12-Feb-2005  oster Add a 'waitflag' argument to rf_CreateDiskQueueData() and use it to
determine if we are willing to wait for memory to come from the
diskqueuedata (dqd) and bufpool pools. Cleanup the mess related to
code calling rf_CreateDiskQueueData() with different expectations
(and/or blatent disregard) of what might happen if there were
insufficient pool resources.
 1.37  05-Feb-2005  oster CreateDiskQueueData() doesn't need to use void * for raidPtr.
RF_Raid_t is well known in RF, and there's no reason not to use it here.
 1.36  24-Nov-2004  oster branches: 1.36.4; 1.36.6;
Only touch bufpool whilst in splbio(). (That should be the case
already, but this makes it explicit and safer in the case where
that changes for some reason.)
 1.35  23-Mar-2004  oster branches: 1.35.4;
bufpool must be accessed at splbio().
 1.34  21-Mar-2004  oster Doesn't hurt much to zero this before we start mucking with it.
 1.33  07-Mar-2004  oster - Introduce rf_pools which contains all of the various global pools used
by RAIDframe. Convert all other RAIDframe global pools to use pools
defined within this new structure.
- Introduce rf_pool_init(), used for initializing a single pool in
RAIDframe. Teach each of the configuration routines to use
rf_pool_init().
- Cleanup a few pool-related comments.
- Cleanup revent initialization and #defines.
- Add a missing pool_destroy() for the reconbuffer pool.

(Saves another 1K off of an i386 GENERIC kernel, and makes
stuff a lot more readable)
 1.32  07-Mar-2004  oster - Introduce rf_pools which contains all of the various global pools used
by RAIDframe. Convert all other RAIDframe global pools to use pools
defined within this new structure.
- Introduce rf_pool_init(), used for initializing a single pool in
RAIDframe. Teach each of the configuration routines to use
rf_pool_init().
- Cleanup a few pool-related comments.
- Cleanup revent initialization and #defines.
- Add a missing pool_destroy() for the reconbuffer pool.

(Saves another 1K off of an i386 GENERIC kernel, and makes
stuff a lot more readable)
 1.31  05-Mar-2004  oster - remove the RF_*_INC's, as necessary. They are not needed any more.
- introduce RF_MIN_*'s, as necessary. These will indicate the
low-water mark for pools as well as the pool_prime() value.
- add pool_setlowat() for the critical pools.
- pool_prime() and pool_setlowat() the raidframe_cbufpool.
- re-order some pool_prime()'s and pool_sethiwat()'s for clarity.
 1.30  29-Feb-2004  oster Adjust _rf_ShutdownCreate() so that it is willing to wait for more
memory. Since we only now ever "return(0)", just return (void)
instead.

Cleanup all uses of rf_ShutdownCreate() to not worry about
it ever failing. Shaves another 600 bytes off of an i386 GENERIC kernel.
 1.29  01-Jan-2004  oster Nuke a bunch of unused variables:
- node_queue_cond
- quiescent_cond
- eq_cond
- desc->cond
- desc->head
- diskqueue->numWaiting

Nuke rf_print_unable_to_init_cond().
Nuke rf_TerminateDiskQueues prototype from rf_diskqueue.h.
 1.28  31-Dec-2003  oster init_dqd and clean_dqd don't do enough to be their own functions,
and just serve to cause confusion. Back-merge their contents to their
(only) calling spots and nuke them.
 1.27  30-Dec-2003  oster Some days you wonder if some of the function declaration consistency
was just an accident in the first place. Cleanup function decls and
a few comments. [ok.. so I wasn't going to fix this many.. but once
you're on a roll....]
 1.26  29-Dec-2003  oster _rf_create_managed_cond() is now left doing nothing. Convert callers.
Mash DO_RAID_COND in rf_driver.c out of existance.

- Nuke (already #if 0'ed) _rf_create_managed_lkmgr_mutex() while we're
busy here.

simplify DO_INIT in rf_engine.c
 1.25  29-Dec-2003  oster _rf_create_managed_mutex() is doing just a simple:

rf_mutex_init(m)

now. The rest of the fluff is no longer needed.
It also cannot fail, so error checking on rf_create_managed_mutex()
is just wasting space.

Nuke the #define's associated with rf_create_managed_mutex().
Convert rf_create_managed_mutex(listp,m) to just rf_mutex_init(m).
Remove wasteful "error checking" and simplify all instances where this
is called. (another 0.3K saved in the binary, but the real savings
is in code readability!)
 1.24  29-Dec-2003  oster - first kick at a major reworking of RAIDframe's memory allocation code:
- all freelists converted to pools
- initialization of structure members in certain cases where
code was relying on specific allocation and usage properties
to keep structures in a "known state" (that doesn't work with
pools!).
- make most pool_get() be "PR_WAITOK" until they can be analyzed
further, and/or have proper error handling added.
- all RF_Mallocs zero the space returned, so there is no difference
between RF_Calloc and RF_Malloc. In fact, all the RF_Calloc()'s
do is tend to do is get things horribly confused.
Make RF_Malloc() the "general memory allocator", with
RF_MallocAndAdd() the "general memory allocator with
allocation list".
- some of these RF_Malloc's et al. are destined to disappear.
- remove rf_rdp_freelist entirely (it's not used anywhere!)
- remove: #include "rf_freelist.h"
- to the files that were relying on the above, add: #include "rf_general.h"
- add: #include "rf_debugMem.h" to rf_shutdown.h to make it happy
about the loss of: #include "rf_freelist.h".

This shrinks an i386 GENERIC kernel by approx 5K. RAIDframe now
weighs in at about 162K on i386.
 1.23  29-Dec-2003  oster [Having received a definite lack of strenuous objection, a small amount
of strenuous agreement, and some general agreement, this commit is
going ahead because it's now starting to block some other changes I
wish to make.]

Remove most of the support for the concept of "rows" from RAIDframe.
While the "row" interface has been exported to the world, RAIDframe
internals have really only supported a single row, even though they
have feigned support of multiple rows.

Nothing changes in configuration land -- config files still need to
specify a single row, etc. All auto-config structures remain fully
forward/backwards compatible.

The only visible difference to the average user should be a
reduction in the size of a GENERIC kernel (i386) by 4.5K. For those
of us trolling through RAIDframe kernel code, a lot of the driver
configuration code has become a LOT easier to read.
 1.22  09-Feb-2003  jdolecek branches: 1.22.2;
constify some
 1.21  17-Sep-2002  oster Use RF_DEBUG_DISKQUEUE to eliminate more debuggin printfs that the
vast majority of the world will never see much less care about.
 1.20  15-Sep-2002  oster Nuke unlockingOp -- it was only used for the userland version of the
code.
 1.19  15-Sep-2002  oster 'buf2' is unused. Nuke it.
 1.18  14-Sep-2002  oster Everyone and their dog was using RF_ERRORMSG3 to print out the same
sort of error message, over and over again, in different files.
Rather than having the same text repeated in multiple .o files,
create a couple of little functions to do the printing, and save a
bundle of space. Also improves readability of code.
 1.17  02-Aug-2002  oster - AuxFunc is no longer used.
- cleanup function prototypes in rf_diskqueue.h
 1.16  02-Aug-2002  oster It appears that nothing is using rf_CreateDiskQueueDataFull. Make it even
harder to do so by removing it.
 1.15  13-Nov-2001  lukem branches: 1.15.8;
add RCSIDs
 1.14  04-Oct-2001  oster Step 2 of the disentanglement. We now look to <dev/raidframe/*> for
the stuff that used to live in rf_types.h, rf_raidframe.h, rf_layout.h,
rf_netbsd.h, rf_raid.h, rf_decluster,h, and a few other places.
Believe it or not, when this is all done, things will be cleaner.

No functional changes to RAIDframe.
 1.13  04-Mar-2000  oster branches: 1.13.6; 1.13.8; 1.13.10;
Reorganize some comments.
 1.12  04-Mar-2000  oster Garbage collect the (already disabled) "random" queue type.
 1.11  24-Feb-2000  oster Garbage collect some unused stuff. Include rf_kintf.h for a
function prototype.
 1.10  24-Feb-2000  oster - record the pointer to the DiskQueueSW so we can use that when
we hot-add a spare.
- use the above info when adding a spare.
 1.9  13-Feb-2000  oster Get recent changes into the tree:
- make component_label variables more consistent (==> clabel)
- re-work incorrect component configuration code
- re-work disk configuration code
- cleanup initial configuration of raidPtr info
- add auto-detection of components and RAID sets (Disabled, for now)
- allow / on RAID sets (Disabled, for now)
- rename "config_disk_queue" to "rf_ConfigureDiskQueue" and properly prototype
in rf_diskqueue.h
- protect some headers with #if _KERNEL (XXX this needs to be fixed properly)
and cleanup header formatting.
- expand the component labels (yes, they should be backward/forward compatible)
- other bits and pieces (some function names are still bogus, and will get
changed soon)
 1.8  07-Jan-2000  oster Nuke: #include "rf_threadid.h" and call to rf_get_threadid().
 1.7  04-Jun-1999  oster branches: 1.7.2;
At config time, initialize a small amount of space for the disk queues
corresponding to the hot spares. We'll need that space when a spare is
actually added. Huge Thanks to Martin Laubach for helping track this down.
 1.6  05-Feb-1999  oster branches: 1.6.2; 1.6.4; 1.6.6;
Phase 2 of the RAIDframe cleanup. The source is now closer to KNF
and is much easier to read. No functionality changes.
 1.5  26-Jan-1999  oster RAIDframe cleanup, phase 1. Nuke simulator support, user-land driver,
out-dated comments, and other unneeded stuff. This helps prepare
for cleaning up the rest of the code, and adding new functionality.

No functional changes to the kernel code in this commit.
 1.4  14-Jan-1999  thorpej Use M_RAIDFRAME.
 1.3  14-Jan-1999  oster Duh... check that malloc() hasn't returned a NULL *before* we zero the buffer,
not after. Pointed out by Michael Graff.
 1.2  03-Dec-1998  oster Fix (potential) referencing of null pointer in (verbose) debugging mode.
 1.1  13-Nov-1998  oster RAIDframe, version 1.1, from the Parallel Data Laboratory at
Carnegie Mellon University. Full RAID implementation, including
levels 0, 1, 4, 5, 6, parity logging, and a few other goodies.
Ported to NetBSD by Greg Oster.
 1.6.6.1  30-Nov-1999  itojun bring in latest KAME (as of 19991130, KAME/NetBSD141) into kame branch
just for reference purposes.
This commit includes 1.4 -> 1.4.1 sync for kame branch.

The branch does not compile at all (due to the lack of ALTQ and some other
source code). Please do not try to modify the branch, this is just for
referenre purposes.

synchronization to latest KAME will take place on HEAD branch soon.
 1.6.4.1  21-Jun-1999  thorpej Sync w/ -current.
 1.6.2.1  23-Jun-1999  perry pullup 1.6->1.7 (oster)
 1.7.2.1  20-Nov-2000  bouyer Update thorpej_scsipi to -current as of a month ago
A i386 GENERIC kernel compiles without the siop, ahc and bha drivers
(will be updated later). i386 IDE/ATAPI and ncr work, as well as
sparc/esp_sbus. alpha should work as well (untested yet).
siop, ahc and bha will be updated once I've updated the branch to current
-current, as well as machine-dependant code.
 1.13.10.2  11-Oct-2001  fvdl Catch up with -current. Fix some bogons in the sparc64 kbd/ms
attach code. cd18xx conversion provided by mrg.
 1.13.10.1  07-Sep-2001  thorpej Commit my "devvp" changes to the thorpej-devvp branch. This
replaces the use of dev_t in most places with a struct vnode *.

This will form the basic infrastructure for real cloning device
support (besides being architecurally cleaner -- it'll be good
to get away from using numbers to represent objects).
 1.13.8.3  10-Oct-2002  jdolecek sync kqueue with -current; this includes merge of gehenna-devsw branch,
merge of i386 MP branch, and part of autoconf rototil work
 1.13.8.2  06-Sep-2002  jdolecek sync kqueue branch with HEAD
 1.13.8.1  10-Jan-2002  thorpej Sync kqueue branch with -current.
 1.13.6.5  18-Oct-2002  nathanw Catch up to -current.
 1.13.6.4  17-Sep-2002  nathanw Catch up to -current.
 1.13.6.3  13-Aug-2002  nathanw Catch up to -current.
 1.13.6.2  14-Nov-2001  nathanw Catch up to -current.
 1.13.6.1  22-Oct-2001  nathanw Catch up to -current.
 1.15.8.1  29-Aug-2002  gehenna catch up with -current.
 1.22.2.8  10-Nov-2005  skrll Sync with HEAD. Here we go again...
 1.22.2.7  04-Mar-2005  skrll Sync with HEAD.

Hi Perry!
 1.22.2.6  15-Feb-2005  skrll Sync with HEAD.
 1.22.2.5  06-Feb-2005  skrll Sync with HEAD.
 1.22.2.4  29-Nov-2004  skrll Sync with HEAD.
 1.22.2.3  21-Sep-2004  skrll Fix the sync with head I botched.
 1.22.2.2  18-Sep-2004  skrll Sync with HEAD.
 1.22.2.1  03-Aug-2004  skrll Sync with HEAD
 1.35.4.1  06-Apr-2005  tron Pull up revision 1.36 (requested by oster in ticket #1041):
Only touch bufpool whilst in splbio(). (That should be the case
already, but this makes it explicit and safer in the case where
that changes for some reason.)
 1.36.6.2  19-Mar-2005  yamt sync with head. xen and whitespace. xen part is not finished.
 1.36.6.1  12-Feb-2005  yamt sync with head.
 1.36.4.1  29-Apr-2005  kent sync with -current
 1.40.2.1  17-Jun-2005  tron Pull up revision 1.41 (requested by oster in ticket #472):
- avoid variable shadowing
- add a lot of const
- remove parameters from function declarations
 1.41.2.4  21-Jan-2008  yamt sync with head
 1.41.2.3  03-Sep-2007  yamt sync with head.
 1.41.2.2  30-Dec-2006  yamt sync with head.
 1.41.2.1  21-Jun-2006  yamt sync with head.
 1.42.2.1  15-Jan-2006  yamt sync with head.
 1.45.20.2  10-Dec-2006  yamt sync with head.
 1.45.20.1  22-Oct-2006  yamt sync with head
 1.45.18.1  18-Nov-2006  ad Sync with head.
 1.48.4.1  12-Mar-2007  rmind Sync with HEAD.
 1.49.28.1  02-Jan-2008  bouyer Sync with HEAD
 1.49.24.1  04-Dec-2007  ad Pull the vmlocking changes into a new branch.
 1.49.22.1  18-Feb-2008  mjf Sync with HEAD.
 1.49.16.1  09-Jan-2008  matt sync with HEAD
 1.49.2.1  24-Aug-2007  ad Sync with buffer cache locking changes. See buf.h/vfs_bio.c for details.
Some minor portions are incomplete and needs to be verified as a whole.
 1.50.14.1  18-Jun-2008  simonb Sync with head.
 1.50.12.1  23-Jun-2008  wrstuden Sync w/ -current. 34 merge conflicts to follow.
 1.50.10.1  04-May-2009  yamt sync with head.
 1.50.6.1  29-Jun-2008  mjf Sync with HEAD.
 1.51.14.1  21-Apr-2010  matt sync to netbsd-5
 1.51.10.1  13-May-2009  jym Sync with HEAD.

Commit is split, to avoid a "too many arguments" protocol error.
 1.51.6.1  01-May-2009  snj Pull up following revision(s) (requested by oster in ticket #607):
sys/dev/raidframe/rf_dagfuncs.c: revision 1.30
sys/dev/raidframe/rf_diskqueue.c: revision 1.52
sys/dev/raidframe/rf_diskqueue.h: revision 1.23
Rework/simplify the disk queuing code. A bunch of this was still
holdovers from the simulator and would never be seen/used in-kernel.
 1.51.4.1  28-Apr-2009  skrll Sync with HEAD.
 1.52.6.1  06-Jun-2011  jruoho Sync with HEAD.
 1.52.4.1  31-May-2011  rmind sync with head
 1.53.56.2  13-Apr-2020  martin Mostly merge changes from HEAD upto 20200411
 1.53.56.1  10-Jun-2019  christos Sync with HEAD
 1.55.4.2  19-Dec-2021  martin Pull up following revision(s) (requested by mrg in ticket #1394):

sys/dev/raidframe/rf_diskqueue.c: revision 1.63 (patch)

call buf_destroy() after buf_init(). hopefully fixes the lockdebug
problem shown here:

http://mail-index.netbsd.org/tech-kern/2021/12/10/msg027851.html

but seems unlikely to fix the original problem.

tested on i386/anita. ok oster@

XXX: pullup-9 (netbsd-8 uses old APIs.)
 1.55.4.1  19-Oct-2021  martin Pull up following revision(s) (requested by oster in ticket #1361):

sys/dev/raidframe/rf_netbsd.h: revision 1.36 (via patch)
sys/dev/raidframe/rf_diskqueue.c: revision 1.58
sys/dev/raidframe/rf_diskqueue.c: revision 1.59

remove unnnecessary splbio() in rf_FreeDiskQueueData()

getiobuf() can return NULL if there are no IO buffers available.
RAIDframe can't deal with that, so create a dedicated pool of buffers
to use for IO. PR_WAITOK is fine here, as we pre-allocate more than
we need to guarantee IO can make progress. Tuning of pool still to
come.
 1.58.6.1  01-Aug-2021  thorpej Sync with HEAD.
 1.63.4.1  28-Apr-2024  martin Pull up following revision(s) (requested by oster in ticket #674):

sys/dev/raidframe/rf_raid.h: revision 1.52
sbin/raidctl/raidctl.8: revision 1.80
sys/dev/raidframe/rf_driver.c: revision 1.141
sys/dev/raidframe/rf_disks.c: revision 1.94
sys/dev/raidframe/rf_diskqueue.c: revision 1.64
sys/dev/raidframe/rf_diskqueue.h: revision 1.30
sys/dev/raidframe/rf_disks.h: revision 1.15
sys/dev/raidframe/rf_netbsdkintf.c: revision 1.414
sys/dev/raidframe/rf_reconstruct.c: revision 1.129
sys/dev/raidframe/raidframeio.h: revision 1.12
sbin/raidctl/raidctl.c: revision 1.79

Implement hot removal of spares and components. From manu@.

Implement a long desired feature of automatically incorporating
a used spare into the array after a reconstruct.

Given the configuration:

Components:
/dev/wd0e: failed
/dev/wd1e: optimal
/dev/wd2e: optimal
Spares:
/dev/wd3e: spare

Running 'raidctl -F /dev/wd0e raid0' will now result in the
following configuration after a successful rebuild:

Components:
/dev/wd3e: optimal
/dev/wd1e: optimal
/dev/wd2e: optimal
No spares.

Thanks to manu@ for the development of the initial set of changes
which allowed the changes to automatically incorporate a used spare
to come to fruition. Thanks also to manu@ for useful discussions
about and additional testing of these changes.

RSS XML Feed