Skip site navigation (1)Skip section navigation (2)
Date:      Tue, 25 Sep 2007 21:43:39 +0200
From:      Rink Springer <rink@FreeBSD.org>
To:        Kostik Belousov <kostikbel@gmail.com>
Cc:        Rink Springer <rink@freebsd.org>, Alan Cox <alc@freebsd.org>, cvs-src@freebsd.org, Alan Cox <alc@cs.rice.edu>, cvs-all@freebsd.org, src-committers@freebsd.org
Subject:   Re: cvs commit: src/sys/amd64/include vmparam.h src/sys/arm/include vmparam.h src/sys/i386/include vmparam.h src/sys/ia64/include vmparam.h src/sys/kern kern_exec.c vfs_bio.c src/sys/powerpc/include vmparam.h src/sys/sparc64/include ...
Message-ID:  <20070925194339.GA91097@rink.nu>
In-Reply-To: <20070925171204.GJ87366@deviant.kiev.zoral.com.ua>
References:  <200709250625.l8P6P7w7082233@repoman.freebsd.org> <20070925110147.GC60963@rink.nu> <46F93B16.50102@cs.rice.edu> <20070925171204.GJ87366@deviant.kiev.zoral.com.ua>

next in thread | previous in thread | raw e-mail | index | archive | help
On Tue, Sep 25, 2007 at 08:12:04PM +0300, Kostik Belousov wrote:
> On Tue, Sep 25, 2007 at 11:45:10AM -0500, Alan Cox wrote:
> > Rink Springer wrote:
> > >Hi Alan,
> > >
> > >On Tue, Sep 25, 2007 at 06:25:07AM +0000, Alan Cox wrote:
> > >  
> > >>  Change the management of cached pages (PQ_CACHE) in two fundamental
> > >>  ways:
> > >>    
> > >
> > >With this change, KDE no longer starts up; the process 'kbuildsycoca'
> > >seems to wait forever in status 'madvpo'. Reverting this changeset fixes
> > >the problem.
> > >
> > >  
> > 
> > This is a problem with madvise(WILLNEED).  I believe that the attached 
> > patch will fix it.
> > 
> > Thanks,
> > Alan
> > 
> > 
> > 
> 
> > Index: vm/vm_object.c
> > ===================================================================
> > RCS file: /home/ncvs/src/sys/vm/vm_object.c,v
> > retrieving revision 1.383
> > diff -p -u -r1.383 vm_object.c
> > --- vm/vm_object.c	25 Sep 2007 06:25:06 -0000	1.383
> > +++ vm/vm_object.c	25 Sep 2007 16:17:40 -0000
> > @@ -1105,7 +1105,8 @@ shadowlookup:
> >  			/*
> >  			 * If the page is cached, reactivate it.
> >  			 */
> > -			m = vm_page_alloc(tobject, tpindex, VM_ALLOC_IFCACHED);
> > +			m = vm_page_alloc(tobject, tpindex, VM_ALLOC_IFCACHED |
> > +			    VM_ALLOC_NOBUSY);
> >  		}
> >  		if (m == NULL) {
> >  			/*
> 
> Yes, this indeed fixes the problem. Several minutes ago I suggested the
> same change to rdivacky@, and he reported that the problem is gone.

Same case here - feel free to get it committed, if you aren't already
working on this.

Alan, thanks for the quick response!

-- 
Rink P.W. Springer                                - http://rink.nu
"root is always right" -- the kernel



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20070925194339.GA91097>