Re: [PATCH 4/4] nfsd: filecache: change garbage collection to a timer.

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Thu, 23 Jan 2025, Jeff Layton wrote:

> > @@ -854,7 +855,9 @@ nfsd_alloc_fcache_disposal(void)
> >  	if (!l)
> >  		return NULL;
> >  	spin_lock_init(&l->lock);
> > -	INIT_DELAYED_WORK(&l->filecache_laundrette, nfsd_file_gc_worker);
> > +	timer_setup(&l->timer, nfsd_file_gc_worker, 0);
> > +	INIT_LIST_HEAD(&l->recent);
> > +	INIT_LIST_HEAD(&l->older);
> >  	INIT_LIST_HEAD(&l->recent);
> >  	INIT_LIST_HEAD(&l->older);
> 
> No need to do the list initializations twice. ^^^

Thanks.  I fixed up a few other merge-errors too.

> 
> It does seem like this is lightweight enough now that we can do the GC
> in interrupt context. I'm not certain that's best for latency, but it's
> worth experimenting.

What sort of latency are you thinking of?  By avoiding a scheduler
switch into the workqueue task we should be reducing overhead.
In the old code a timer would wake a thread which would need to be
scheduled to do the work.  In the new thread and identical time will do
the work directly.

Thanks,
NeilBrown


> -- 
> Jeff Layton <jlayton@xxxxxxxxxx>
> 
> 





[Index of Archives]     [Linux Filesystem Development]     [Linux USB Development]     [Linux Media Development]     [Video for Linux]     [Linux NILFS]     [Linux Audio Users]     [Yosemite Info]     [Linux SCSI]

  Powered by Linux