Without further ado, here's what happened when we ran our test apps with the default Windows 7 scheduler threading—i.e., with no awareness of modules or sharing—and with our two different affinity masks.
These results couldn't be much more definitive. In every case but one, distributing the threads one per module, and thus avoiding sharing, produces roughly 10-20% higher performance than packing the threads together on two modules. (And that one case, the FDom function in picCOLOR, shows little difference between the three affinity options.) At least for this handful of workloads, the benefits of avoiding resource sharing between two cores on a module are pretty tangible. Even though the packed config enables a higher Turbo Core frequency of 4.2GHz, the shared config is faster.
Our test apps, obviously, are not your typical desktop applications, and they may not be a perfect indicator of what to expect elsewhere. However, since many games and other apps are lightly threaded, with three or four threads handling the bulk of the work, we wouldn't be surprised if one-per-module thread affinities were generally a win on Bulldozer-based processors.
Naturally, some folks who have been disappointed with Bulldozer performance to date may find solace in this outcome. With proper scheduling, as may come in Windows 8, future AMD processors derived from this architecture may be able to perform more competitively. Unfortunately, Windows 8 probably won't ship during the model run of the current FX processors.
At the same time, these results take some of the air out of AMD's rhetoric about the pitfalls of Intel's Hyper-threading scheme. The truth is that both major x86 CPU makers now offer flagship desktop CPU architectures with a measure of resource sharing between threads, and proper scheduling is needed in order to extract the best performance from them both. (This situation mirrors what's happened in 2P servers in recent years, where applictions must be NUMA-aware on current x86 systems in order to achieve optimal throughput.) A gain of up to 20% on a CPU this quick is certainly worthy of note.
Trouble is, right now, Intel has much better OS and application support for Hyper-Threading than AMD does for Bulldozer. In fact, we're a little surprised AMD hasn't attempted to piggyback on Intel's Hyper-Threading infrastructure by making Bulldozer processors present themselves to the OS as four physical cores with eight logical threads. One would think that might be a nice BIOS menu option, at least. (Hmm. Mobo makers, are you listening?)
At any rate, application developers who want to make the most of Bulldozer are free to affinitize threads in upcoming revisions of their software packages anytime. If AMD can persuade some key developers to help out, it's possible the next round of desktop applications could benefit very soon.
106 comments — Last by format_C at 11:59 AM on 12/15/11
|Intel's Atom Z3000 'Bay Trail' SoC revealedA first look at its architecture and performance||95|
|Inside Intel's Atom C2000-series 'Avoton' processorsAn SoC for microservers, storage, and communications||83|
|Intel's Core i7-4960X processor reviewedIvy Bridge Extreme finally arrives||206|
|Intel aims to reinvent the data centerAn aggressive strategy marks the beginning of an new era||21|
|An intro to all things ARMHow ARM created an ecosystem that upended the market||58|
|AMD's A10-6800K and A10-6700 'Richland' APUs reviewedDesktop quad-core takes a modest step forward||132|
|Haswell overclocked: the Core i7-4770K at 4.7GHzMoar power requires moar cooling||130|
|Intel's Core i7-4770K and 4950HQ 'Haswell' processors reviewedA revamped CPU architecture, better graphics, and a few surprises||320|
|Race the Sun is on Steam, and you should play it||9|
|An update on Radeon R9 290X variance||55|
|Ubisoft's Snowdrop engine makes The Division look incredible||86|
|No Man's Sky has procedurally generated planets, looks amazing||54|
|Samsung brings 840 EVO to mSATA, drops new firmware for 2.5'' version||16|
|Next Windows release could be more desktop-friendly||154|
|Asus teases custom Radeon R9 290X with DirectCU II cooler||67|
|Report: NSA put agents in World of Warcraft, Second Life||84|
|Bay Trail could power $99 Android tablets||31|