On Tue, 2011-01-04 at 17:12 +1100, Dave Chinner wrote: > From: Dave Chinner <dchinner@xxxxxxxxxx> > > When checking large filesystems, xfs_repair makes an estimate of how > much RAM it will need to execute effectively. If the amount of RAM > is less than this, it reduces the bhash size and turns of > prefetching, which will substantially slow down the repair process. > Add a warning that indicates this is happening, along with a > recommendation of how much RAM repair calculates it needs to run > with prefetching enabled. This looks good. If someone specifies a maximum memory amount using -m, but that amount exceeds the memory available and/or the process' address space rlimit, it is silently reduced to the maximum possible. That may then be followed by the "...please increase it..." message, which might be confusing and possibly annoying. Maybe a single message that was a bit more informative would suffice, whether or not max_mem was specified. Just a thought. Your change looks fine. Reviewed-by: Alex Elder <aelder@xxxxxxx> > Signed-off-by: Dave Chinner <dchinner@xxxxxxxxxx> > --- > repair/xfs_repair.c | 10 +++++++++- > 1 files changed, 9 insertions(+), 1 deletions(-) > > diff --git a/repair/xfs_repair.c b/repair/xfs_repair.c > index e36eeae..eea1b34 100644 > --- a/repair/xfs_repair.c > +++ b/repair/xfs_repair.c > @@ -650,12 +650,20 @@ main(int argc, char **argv) > * Turn off prefetch and minimise libxfs cache if > * physical memory is deemed insufficient > */ > - if (max_mem_specified) > + if (max_mem_specified) { > do_abort(_("Required memory for repair is " > "greater that the maximum specified " > "with the -m option. Please increase " > "it to at least %lu.\n"), > mem_used / 1024); > + } else { > + do_warn(_("Not enough RAM available for repair " > + "to enable prefetching. This will be " > + "_slow_.\n" > + "You need at least %luMB RAM to run " > + "with prefetching enabled."), > + mem_used * 1280 / (1024 * 1024)); > + } > do_prefetch = 0; > libxfs_bhash_size = 64; > } else { _______________________________________________ xfs mailing list xfs@xxxxxxxxxxx http://oss.sgi.com/mailman/listinfo/xfs