Skip site navigation (1)Skip section navigation (2)
Date:      Wed, 18 May 2016 11:23:53 -0700
From:      Mark Johnston <markj@FreeBSD.org>
To:        NGie Cooper <yaneurabeya@gmail.com>
Cc:        src-committers@freebsd.org, svn-src-all@freebsd.org, svn-src-head@freebsd.org
Subject:   Re: svn commit: r300110 - head/sys/kern
Message-ID:  <20160518182353.GB26863@wkstn-mjohnston.west.isilon.com>
In-Reply-To: <7D442C5C-E059-40A5-887C-55840BE94425@gmail.com>
References:  <201605180355.u4I3tskK012821@repo.freebsd.org> <7D442C5C-E059-40A5-887C-55840BE94425@gmail.com>

next in thread | previous in thread | raw e-mail | index | archive | help
On Tue, May 17, 2016 at 10:22:18PM -0700, NGie Cooper wrote:
> 
> > On May 17, 2016, at 20:55, Mark Johnston <markj@FreeBSD.org> wrote:
> > 
> > Author: markj
> > Date: Wed May 18 03:55:54 2016
> > New Revision: 300110
> > URL: https://svnweb.freebsd.org/changeset/base/300110
> > 
> > Log:
> >  Do not acquire the thread lock in hardclock_cnt() unless needed.
> > 
> >  This function only sets thread flags if a SIGPROF or SIGVTALRM timer
> >  has fired, which is almost never the case.
> > 
> >  MFC after:    2 weeks
> > 
> > Modified:
> >  head/sys/kern/kern_clock.c
> > 
> > Modified: head/sys/kern/kern_clock.c
> > ==============================================================================
> > --- head/sys/kern/kern_clock.c    Wed May 18 03:50:21 2016    (r300109)
> > +++ head/sys/kern/kern_clock.c    Wed May 18 03:55:54 2016    (r300110)
> > @@ -570,9 +570,11 @@ hardclock_cnt(int cnt, int usermode)
> >            flags |= TDF_PROFPEND | TDF_ASTPENDING;
> >        PROC_ITIMUNLOCK(p);
> >    }
> > -    thread_lock(td);
> > -    td->td_flags |= flags;
> > -    thread_unlock(td);
> > +    if (flags != 0) {
> > +        thread_lock(td);
> > +        td->td_flags |= flags;
> > +        thread_unlock(td);
> > +    }
> 
> Use predict_false?

I don't think that's really warranted here. A __predict_false could
become incorrect after a future change elsewhere in this function, and
this isn't enough of a hot path for such a change to make a measurable
difference on its own.

> > 
> > #ifdef    HWPMC_HOOKS
> >    if (PMC_CPU_HAS_SAMPLES(PCPU_GET(cpuid)))
> > 



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