svn commit: r304244 - head/sys/kern

Bryan Drewery bdrewery at FreeBSD.org
Sat Aug 20 17:18:20 UTC 2016


On 8/16/2016 2:55 PM, Gleb Smirnoff wrote:
> Author: glebius
> Date: Tue Aug 16 21:55:34 2016
> New Revision: 304244
> URL: https://svnweb.freebsd.org/changeset/base/304244
> 
> Log:
>   We should not be allowing a timeout to reset when a drain is in progress on
>   it (either async or sync drain).
>   
>   At this moment the only user of drain is TCP, but TCP wouldn't reschedule a
>   callout after it has drained it, since it drains only when a tcpcb is closed.
>   This for now the problem isn't observed.
>   
>   Submitted by:	rrs

Should this be MFC'd into 11.0?

> 
> Modified:
>   head/sys/kern/kern_timeout.c
> 
> Modified: head/sys/kern/kern_timeout.c
> ==============================================================================
> --- head/sys/kern/kern_timeout.c	Tue Aug 16 21:32:05 2016	(r304243)
> +++ head/sys/kern/kern_timeout.c	Tue Aug 16 21:55:34 2016	(r304244)
> @@ -1061,7 +1061,7 @@ callout_reset_sbt_on(struct callout *c, 
>  		 */
>  		if (c->c_lock != NULL && !cc_exec_cancel(cc, direct))
>  			cancelled = cc_exec_cancel(cc, direct) = true;
> -		if (cc_exec_waiting(cc, direct)) {
> +		if (cc_exec_waiting(cc, direct) || cc_exec_drain(cc, dir)) {
>  			/*
>  			 * Someone has called callout_drain to kill this
>  			 * callout.  Don't reschedule.
> 


-- 
Regards,
Bryan Drewery

-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 473 bytes
Desc: OpenPGP digital signature
URL: <http://lists.freebsd.org/pipermail/svn-src-head/attachments/20160820/a5c00574/attachment.sig>


More information about the svn-src-head mailing list