Date: Wed, 14 Jan 2004 14:08:11 -0500 (EST) From: Robert Watson <rwatson@freebsd.org> To: "Andrew Edwards (Olympic Shaver Centre)" <andrew@shavers.co.uk> Cc: freebsd-current@freebsd.org Subject: Re: Hyperthreading with SMP in 5.2 Message-ID: <Pine.NEB.3.96L.1040114140430.49872C-100000@fledge.watson.org> In-Reply-To: <003c01c3da8f$c022a3e0$0b00a8c0@laptop>
next in thread | previous in thread | raw e-mail | index | archive | help
On Wed, 14 Jan 2004, Andrew Edwards (Olympic Shaver Centre) wrote: > Could anyone clarify the level of support for Pentium 4 hyperthreading > in 5.2? I understand that the kernel is now smp aware by default but > does it handle the logical cpu's of hyperthreading in the same manner as > it would a physical cpu? > > I ask as for the best part my machine rarely goes above 50% cpu > utilisation. However using -j2 when building the kernel or world for > example will give me nearer full use, which I can appreciate as it > generates concurrent processes that likely get divided over the two > logical cpu. > > Not being fully aware of the technical bits to hyperthreading is the > above scenario as good as it can be and is making good use of the cpu, > i.e if I run a single cpu heavy process, whereas without hyperthreading > I would see 100% usage now I only see around 50%. Part of the problem here is actually in the measurement -- when one hyperthreaded virtual CPU is idle, the other virtual CPU has more computational resources, and so will actually run faster. The FreeBSD kernel can only measure the utilization in terms of wall clock time, not underlying computational units, so it reports you have two CPU's, one idle, and one at 100% (i.e., 50%). In practice, you could easily be using 75% or more of the resources of the total silicon with your program. You might well not be able to utilize the full resources of the CPU without paralellism in your program, which would require writing the program to use parallelism (threading or multiple processes). Depending on the task, this may or may not be more efficient, since you may blow out shared cache resources with a larger working set, as well as paying the costs of synchronization. The real question is: do you get your work done faster from a wall clock perspective, and that depends on the workload and the efficiency of the FreeBSD kernel. We're working on making the FreeBSD kernel more efficient with SMP (one of the big goals for the 5.x branch), but it's definitely still a work in progress. If you just want to see 100%, you can disable hyperthreading so that the virtual CPU is simply kept idle the same as it might be now, but FreeBSD won't count it towards accounting. :-) Robert N M Watson FreeBSD Core Team, TrustedBSD Projects robert@fledge.watson.org Senior Research Scientist, McAfee Research
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?Pine.NEB.3.96L.1040114140430.49872C-100000>