svn commit: r267029 - head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs

Bjoern A. Zeeb bz at FreeBSD.org
Tue Jun 3 23:45:19 UTC 2014


On 03 Jun 2014, at 21:06 , Alexander Motin <mav at FreeBSD.org> wrote:

> Author: mav
> Date: Tue Jun  3 21:06:03 2014
> New Revision: 267029
> URL: http://svnweb.freebsd.org/changeset/base/267029
> 
> Log:
>  Replace gethrtime() with cpu_ticks(), as source of random for the taskqueue
>  selection.  gethrtime() in our port updated with HZ rate, so unusable for
>  this specific purpose, completely draining benefit of multiple taskqueues.
> 
>  MFC after:	2 weeks
> 

I am seeing this now for all buildworld targets:

/storage/head/obj//arm.armeb/scratch/tmp/bz/head.svn/tmp/usr/lib/libzpool.so: undefined reference to `cpu_ticks'


> Modified:
>  head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/spa.c
> 
> Modified: head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/spa.c
> ==============================================================================
> --- head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/spa.c	Tue Jun  3 21:02:19 2014	(r267028)
> +++ head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/spa.c	Tue Jun  3 21:06:03 2014	(r267029)
> @@ -953,7 +953,7 @@ spa_taskq_dispatch_ent(spa_t *spa, zio_t
> 	if (tqs->stqs_count == 1) {
> 		tq = tqs->stqs_taskq[0];
> 	} else {
> -		tq = tqs->stqs_taskq[gethrtime() % tqs->stqs_count];
> +		tq = tqs->stqs_taskq[cpu_ticks() % tqs->stqs_count];
> 	}
> 
> 	taskq_dispatch_ent(tq, func, arg, flags, ent);
> 

— 
Bjoern A. Zeeb             "Come on. Learn, goddamn it.", WarGames, 1983



More information about the svn-src-all mailing list