iXBT Labs - Computer Hardware in Detail

Platform

Video

Multimedia

Mobile

Other

Detailed Platform Analysis in RightMark Memory Analyzer. Part 11: Dual Core Intel Pentium Extreme Edition 955 (Presler)




On January 5, 2006 Intel presented new dual core processors Pentium D 900, followed by Pentium Extreme Edition 955 a few days later (January 16). These processors are based on the new Presler core, which is the first processor core manufactured by the new 65-nm process technology. The history repeats itself — as in case with the transition from 130 nm to 90 nm process technology, the first solutions are desktop processors with NetBurst microarchitecture. Mobile platforms are announced only a tad later, based on processors manufactured by the new process technology. At the same time, there was a much longer period of time between the first 90 nm Prescott and Dothan than between the 65-nm Presler and Yonah (we have already reviewed them) — it's quite possible that the new 65 nm process technology will be easier to master. But let's not go into details and focus on the main objective of this article — low level analysis of the new 65 nm Presler core in comparison with its closest counterparts — Xtreme modifications of processors based on 90 nm Smithfield core and the latest revision of Prescott N0 core, which we reviewed earlier.

Testbed configuration

  • CPU: Intel Pentium Extreme Edition 955 (3.46 GHz, Presler core, Socket 775, FSB 266 MHz)
  • Motherboard: Gigabyte GA-G1975X, Intel 975X, BIOS F1 dated 2005/11/21
  • Memory: 2x512 MB Corsair XMS2-5400UL in DDR2-533 mode (3-3-3-9 timings)

CPUID Characteristics

Let's start the review of the new Presler core with the analysis of key characteristics, output by CPUID instruction with various input parameters.

Table 1. Pentium EE 840 (Smithfield A0) CPUID

CPUID function Value Comments
Processor signature 0F44h Family 15 , Model 4, Stepping 4
Brand ID 00h Not supported
Cache/TLB descriptors 50h
5Bh
60h
40h
70h
7Ch
I-TLB: full associativity, 64 entries
D-TLB: full associativity, 64 entries
L1 Cache: 16 KB, 8-way assoc., 64-byte line
L3 Cache is not available
Trace Cache: 12Kuops, 8-way assoc.
L2 Cache: 1 MB, 8-way assoc., 64-byte line
Number of logical processors 04h 4 logical processors
Number of cores 01h 2 cores
Basic Features, ECX 641Dh Bit 0, 3: SSE3 support, MONITOR/MWAIT
Bit 2: Unknown
Bit 4: Debug Store (DS-CPL) extension support
Bit 10: L1 Cache Context ID support
Bit 13: CMPXCHG16B support
Bit 14: Task Priority Messages support
Extended Features, EDX 20000000h Bit 29: Intel (R) EM64T support

Table 2. Pentium EE 955 (Presler B1) CPUID

CPUID function Value Comments
Processor signature 0F62h Family 15 , Model 6, Stepping 2
Brand ID 00h Not supported
Cache/TLB descriptors 50h
5Bh
60h
40h
70h
7Dh
I-TLB: full associativity, 64 entries
D-TLB: full associativity, 64 entries
L1 Cache: 16 KB, 8-way assoc., 64-byte line
L3 Cache is not available
Trace Cache: 12Kuops, 8-way assoc.
L2 Cache: 2 MB, 8-way assoc., 64-byte line
Number of logical processors 04h 4 logical processors
Number of cores 01h 2 cores
Basic Features, ECX E43Dh Bit 0, 3: SSE3 support, MONITOR/MWAIT
Bit 2: Unknown
Bit 4: Debug Store (DS-CPL) extension support
Bit 5: Unknown
Bit 10: L1 Cache Context ID support
Bit 13: CMPXCHG16B support
Bit 14: Task Priority Messages support
Bit 15: Unknown
Extended Features, EDX 20100000h Bit 20: XD bit support
Bit 29: Intel (R) EM64T support

Let's compare CPUID characteristics of the Pentium EE 955 processor (Table 2) with characteristics of its closest counterpart — former "extreme" processor Pentium EE 840 (Table 1). First of all the changes affected a CPU signature — the new Pentium EE 955 with Presler core got Model Number 6 and Core Stepping 2, retaining its Series 15. Official name of the core stepping, which corresponds to the signature 0F62h, is B1. Note that the previous "dual-core" cores of processors Pentium D 800 and Pentium Extreme Edition had Steppings A0 (which appears in our today's review) and B0. Thus, we can assume that the manufacturer sees the new 65 nm Presler core, which first stepping is called B1, as the next stage of the development of 90 nm "dual-core" Smithfield cores.

We can see no differences in Cache/TLB descriptors, except for the L2 Cache descriptor — its size in Presler is 2 MB (per a single core, that is 4 MB in total), that is Presler can be considered a 65 nm dual core modification of Prescott-2M core (while Smithfield is just a dual core modification of Prescott core). There are no differences in the number of physical cores (2) and logical processors (4) in this processor either. Remember that with the appearance of dual core processors, the number of logical processors has become a nominal notion — it would be correct to call it a total number of system processors in a given die. This very number of processors will be detected by an operating system (if it supports multiprocessing and Hyper-Threading), when installed and loaded on a given real processor. For example, all dual core processors have two logical processors, like all single-core processors supporting Hyper-Threading. But the former differ from the latter in a number of physical cores (2 and 1 correspondingly). But if it's a dual core processor supporting Hyper-Threading, the number of logical processors grows to four, which can be seen in Pentium Extreme Edition processors (840 and 955).

The most important changes were made to supported extensions (Basic Features, ECX, and Extended Features, EDX). The new Presler differs from Smithfield in two new unknown extensions (technologies), specified by Bits 5 and 15 in the ECX Basic Features register. Note that the same bits also appeared in CPUID of the recently reviewed first 65 nm mobile dual core processor Intel Core Duo (Yonah). In this connection, like in the Yonah review, we can assume that one of these bits corresponds to virtualization technology (VT), officially implemented in Core Solo/Duo as well as in Pentium D/Extreme Edition with the new Presler core. We should also note that formerly unknown Bit 13 of Basic Features, ECX, which we have seen from the latest revisions of Prescott core, is now officially known and corresponds to support for the CMPXCHG16B instruction. Among other differences between Presler and Smithfield we can mention Execute Disable technology in the former, designated by Bit 20 of the EDX register Extended Features.

Real Bandwidth of Data Cache/Memory

The overall situation with real bandwidth of L1/L2 D-Cache and memory (Picture 1) looks usual for Prescott successors. 16 KB L1 Cache, 2 MB L2 Cache, inclusive cache hierarchy. L2 Cache throughput goes down a little at 256 KB (as the specified area falls on L2 Cache), which has to do with depleted D-TLB resources. As before, L1 Cache is characterized by Write-Through mode. It shows as an equality of L1 and L2 Cache write bandwidths (in other words, no inflection at the area of L1 Cache size, that is 16 KÁ).




Picture 1. Real Bandwidth of Data Cache and Memory

Table 3

Level Average bandwidth, bytes/cycle (MB/sec)
Pentium 4 EE
(Prescott N0)
Pentium EE 840
(Smithfield A0)
Pentium EE 955
(Presler B1)
L1, reading, MMX
L1, reading, SSE2
L1, writing, MMX
L1, writing, SSE2
7.98
15.93
2.91
3.56
7.98
15.93
2.91
3.56
7.98
15.93
2.91
3.56
L2, reading, MMX
L2, reading, SSE2
L2, writing, MMX
L2, writing, SSE2
4.57
8.20
2.91
3.56
4.57
8.21
2.91
3.56
4.56
8.13
2.91
3.56
RAM, reading, MMX
RAM, reading, SSE2
RAM, writing, MMX
RAM, writing, SSE2
6003 MB/s
6540 MB/s
2217 MB/s
2218 MB/s
5361 MB/s
5650 MB/s
2409 MB/s
2431 MB/s
6100 MB/s
6604 MB/s
2145 MB/s
2157 MB/s

Quantitative bandwidth characteristics (Table 3) show that L1 and L2 Caches in Presler are practically identical in every respect to those in Prescott N0 and Smithfield. Real memory read bandwidth of a Presler-based system is noticeably higher compared to a Smithfield-based system due to the 266 MHz FSB (its theoretical bandwidth is 8.53 GB/s). But its write performance is not that high, it is even lower than on the platform with Pentium 4 Extreme Edition (Prescott N0, 266 MHz FSB as well).

Maximum Real Memory Bandwidth

As usual (for Pentium 4 processors), Software Prefetch method allows maximum memory bandwidth, while other methods are not so highly efficient.




Picture 2. Maximum Real Memory Bandwidth, Software Prefetch and Non-Temporal Store

The curves of real memory read and copy bandwidth versus software prefetch distance (Picture 2) look typical for Prescott cores (they look like the curves for Pentium 4 Extreme Edition 3.73 GHz).

Table 4

Access mode Maximum Real Memory Read Bandwidth, MB/s*
Pentium 4 EE
(Prescott N0)
Pentium EE 840
(Smithfield A0)
Pentium EE 955
(Presler B1)
Reading, MMX
Reading, SSE2
Reading, MMX, SW Prefetch
Reading, SSE2, SW Prefetch
Reading, MMX, Block Prefetch 1
Reading, SSE2, Block Prefetch 1
Reading, MMX, Block Prefetch 2
Reading, SSE2, Block Prefetch 2
Reading cache lines, forward
Reading cache lines, backward
6003 (70.3%)
6540 (76.6%)
8315 (97.4%)
8509 (99.7%)
5490 (64.3%)
6069 (71.1%)
5936 (69.6%)
6557 (76.8%)
7623 (89.3%)
7613 (89.2%)
5361 (83.8%)
5650 (88.3%)
6405 (100.1%)
6438 (100.6%)
4730 (73.9%)
5245 (82.0%)
5351 (83.6%)
5681 (88.8%)
6213 (97.1%)
6208 (97.0%)
6100 (71.5%)
6604 (77.4%)
8422 (98.7%)
8569 (100.4%)
5455 (63.9%)
6084 (71.3%)
5992 (70.2%)
6576 (77.1%)
7466 (87.5%)
7488 (87.8%)

*values relative to the theoretical memory bandwidth limit are given in parentheses
(6.4 GB/s for 200 MHz FSB, 8.53 GB/s for 266 MHz FSB)

The quantitative analysis of maximum real memory read bandwidth (Table 4) shows that memory bandwidth values obtained by various optimizations on Presler are very close to the values obtained on Pentium 4 Extreme Edition with Prescott core, Stepping N0. Thus we can assume that software prefetch in Presler is no different from that in Prescott N0.

Table 5

Access mode Maximum Real Memory Write Bandwidth, MB/s*
Pentium 4 EE
(Prescott N0)
Pentium EE 840
(Smithfield A0)
Pentium EE 955
(Presler B1)
Writing, MMX
Writing, SSE2
Writing, MMX, Non-Temporal
Writing, SSE2, Non-Temporal
Writing cache lines, forward
Writing cache lines, backward
2217 (26.0%)
2218 (26.0%)
5705 (66.9%)
5707 (66.9%)
2760 (32.3%)
2703 (31.7%)
2409 (37.6%)
2431 (38.0%)
4266 (66.6%)
4266 (66.6%)
3114 (48.7%)
3113 (48.6%)
2145 (25.1%)
2157 (25.3%)
5662 (66.4%)
5670 (66.4%)
2805 (32.9%)
2770 (32.5%)

*values relative to the theoretical memory bandwidth limit are given in parentheses
(6.4 GB/s for 200 MHz FSB, 8.53 GB/s for 266 MHz FSB)

In the same way, the values of maximum real memory read bandwidth (Table 5) obtained for Prescott N0 and Presler are close in all cases. As usual, the best result is achieved by non-temporal store method, which allows memory bandwidth to reach 2/3 of theoretical FSB throughput.

Data Cache/Memory Latency

The general picture of L1/L2 D-Cache and RAM latency (Picture 3) looks as usual. What concerns peculiarities, we should note very low latencies for forward and backward walks with the stride size of L1 Cache line (64 bytes — strictly speaking, that's not quite correct, because fetching data from memory into L2 Cache is done by whole L2 Cache lines; their effective length is 128 bytes in connection with a mandatory fetch of the adjacent 64-byte line) as well as smooth growth of the pseudo-random access latency for the block size of 256 KB and higher, which has to do with depleting D-TLB.




Picture 3. Data Cache/Memory Latency

What concerns the quantitative analysis (Table 6) of the average L1/L2 D-Cache and RAM latencies (RAM latencies are obtained by a "correct" walk at the 128-byte stride), we should mention considerable differences between our processors — the average L1 Cache latency amounts to 4 cycles in all cases, L2 — approximately to 28.5 cycles. The average memory latency depends on an access mode (due to hardware prefetch). It amounts to about 30-35 ns for linear walk, 50 ns — for pseudo-random walk, and 90-100 ns — for random walk. Presler's smaller average latencies do not allow us to see noticeable differences in hardware prefetch algorithm (you will see it below). They more likely have to do with memory proper (Corsair XMS2-5400UL modules and the newer Intel 975X chipset).

Table 6

Level, access Average latency, cycles (ns)
Pentium 4 EE
(Prescott N0)
Pentium EE 840
(Smithfield A0)
Pentium EE 955
(Presler B1)
L1 (all cases)
4
4
4
L2 (all cases)
~28.5
~28.5
~28.5
RAM*, forward
RAM, backward
RAM, random**
RAM, pseudo-random
30.3 ns
33.9 ns
101.4 ns
49.4 ns
32.3 ns
35.7 ns
100.9 ns
51.5 ns
30.0 ns
33.5 ns
90.0 ns
47.8 ns

*128-byte stride
**4 MB block size

Minimum Latency of Data Cache/Memory

The most interesting discoveries in Presler core await us in this very section. What concerns the minimum L1 Cache latency, we can see no differences from the average latency of this cache as well as from the other processor cores (so we don't publish these graphs) — it stays on the level of 4 cycles in all cases. It's much more interesting to see how Minimum L2 Cache latencies are reached by unloading the L1-L2 bus of the processor.




Picture 4. Minimum L2 Cache Latency, Method 1

We get an excellent result already in the first case (Picture 4) using the standard procedure to unload the bus, which is not very good for testing processors with pronounced speculative data loading.

Let's analyze L2 Cache walk modes in reverse order. So, a usual (for Prescott cores and their successors) look of the curves is preserved only in case of random walk of a 96 KB data block in L2 Cache — minimum latency is 24 cycles, the bus is not unloaded even with lots of NOPs. A pseudo-random walk gives a similar curve. But it's shifted 2 cycles down relative to the main curve. Thus, minimum latency in this case is 22 cycles. We don't know the reasons for the reduction of latency during a pseudo-random walk. But hardware prefetch has nothing to do with it, as we don't see that the bus is unloaded here. It happens only in case of forward and backward walks in L2 Cache — we can see a typical picture of unloaded bus with 5(!)-cycle L2 Cache latency for more than 21 NOPs (in a first approximation, each next NOP in the area from 0 to 21 decrements L2 Cache latency by one cycle).

What does it mean? Of course, it would have been absurd to speak of the true 5-cycle L2 Cache latency (for 4-cycle L1 Cache) — we'd rather speak of hardware prefetch on the level of L2 Cache! Unload curves for linear walks speak in favor of hardware prefetch, which is easily implemented for linear data access. In other cases we can see L2 Cache latency "practically in pure form", as in all other Prescott cores.

Well, hardware prefetch from L2 Cache is a good solution. It allows to cover up large latencies for accessing this cache at least partially.




Picture 5. Minimum L2 Cache Latency, Method 2

Differences in L2 Cache latency depending on a walk mode can also be seen in Minimum L2 Cache latency curves, obtained by an alternative method (Picture 5) for Prescott-like cores. In this case, pseudo-random and random walk curves show a distinct minimum L2 Cache latency of 22 cycles, typical of Prescott processors (inflection point for 22 single-cycle NOP operations, latency in this point also equals 22). This test proves our hypothesis that Presler's L2 Cache latency as such hasn't changed.

We proceed to minimum memory latency tests. In order to demonstrate the second significant Presler difference from the previous cores of this family, we published the unload curves for the memory bus, plotted for "wrong" 64-byte walk on Smithfield (Picture 6a) and Presler (Picture 6b) processors — in this very case we can see the most significant differences in hardware prefetch algorithms, but already on the memory level.




Picture 6a. Minimum Memory Latency, 64-byte stride, Smithfield



Picture 6b. Minimum Memory Latency, 64-byte stride, Presler

As in case of L2 Cache, pseudo-random and random walk curves (when hardware prefetch is practically idle) look identical on both processors. There are differences for forward and backward walks of a data chain in memory. In case of Smithfield, the curves are qualitatively identical to the two curves above, but with lower absolute values. In case of Presler, we can see quite a different unload situation, which resembles unloading L1-L2 bus in this processor as well as in AMD K8 processors. Thus, along with hardware prefetch on the level of L2 Cache, we can speak of Presler's improved hardware prefetch from memory.




Picture 7. Minimum memory latency, 128-byte stride

The L2-RAM bus unload curves for 128-byte stride (Picture 7) look totally different. To be more exact, they are practically identical to the curves, obtained on Prescott and Smithfield cores.

Table 7

Level, access Minimum latency, cycles (ns)
Pentium 4 EE
(Prescott N0)
Pentium EE 840
(Smithfield A0)
Pentium EE 955
(Presler B1)
L1 (all cases)
4
4
4
L2*, forward
L2, backward
L2, random
L2, pseudo-random
24 (22)
24 (22)
24 (22)
24 (22)
24 (22)
24 (22)
24 (22)
24 (22)
5 (22)
5 (22)
24 (22)
22 (22)
RAM**, forward
RAM, backward
RAM, random***
RAM, pseudo-random
27.0 ns
31.1 ns
105.4 ns
50.9 ns
24.6 ns
27.0 ns
98.9 ns
50.5 ns
23.4 ns
24.8 ns
90.3 ns
47.0 ns

*Values in brackets are obtained by Method 2
**128-byte stride
***4 MB block size

A summary of minimum L1/L2 D-Cache and memory latencies in processors with Prescott N0, Smithfield and Presler cores is published in Table 7. In case of all three processor cores, minimum memory latencies are practically no different at 128-byte stride, when the efficiency of hardware prefetch is very low.

Data Cache Associativity




Picture 8. Data Cache Associativity

The test of Presler L1/L2 D-Cache associativity (Picture 8) demonstrates a picture typical of Prescott processors — effective associativity of L1 D-Cache in this processor is equal to one, associativity of the L2 Cache for instructions/data is equal to eight.

Real L1-L2 Cache Bus Bandwidth

Typical relationship between an increase in L2 Cache size and a decrease in L1-L2 bus bandwidth, which we detected in our review of the Smithfield core, is confirmed by the Presler core (Table 8). Namely, its L1-L2 bus bandwidth is practically identical to the bandwidth of L1-L2 bus in Pentium 4 Extreme Edition processor with Prescott N0 core, 2 MB L2 Cache.

Table 8

Access mode Bandwidth, bytes/cycle*
Pentium 4 EE
(Prescott N0)
Pentium EE 840
(Smithfield A0)
Pentium EE 955
(Presler B1)
Reading (forward)
Reading (backward)
Writing (forward)
Writing (backward)
14.66 (45.8%)
14.60 (45.6%)
4.10 (12.8%)
4.10 (12.8%)
16.75 (52.3%)
16.58 (51.8%)
4.89 (15.3%)
4.85 (15.2%)
14.62 (45.7%)
14.55 (45.5%)
4.10 (12.8%)
4.10 (12.8%)
*values relative to the theoretical limit are given in parentheses

Trace Cache, Decode/Execute Efficiency

The most interesting component of the NetBurst micro architecture is a special cache for micro operations from the predecoder - Execution Trace Cache. Let's see what differences the new Presler core will offer.




Picture 9. Decode/execute efficiency

As usual, the most illustrative situation is in decode/execute efficiency for a series of large simple 6-byte CMP instructions. In this test, like in all the other tests of this type, there are no qualitative differences between Presler and previously reviewed Prescott and Smithfield. Let's proceed to quantitative tests.

Table 9. Decode/execute efficiency, Pentium 4 EE (Prescott N0)

Instruction type Effective size of Trace Cache, KB (Kuop) Decode efficiency, bytes/cycle (instructions/cycle)
Trace Cache L2 Cache
NOP
10.5 (10.5)
2.87 (2.87)
1.00 (1.00)
SUB
22.0 (11.0)
5.73 (2.87)
2.00 (1.00)
XOR
22.0 (11.0)
4.00 (2.00)
2.00 (1.00)
TEST
22.0 (11.0)
3.42 (1.71)
2.00 (1.00)
XOR/ADD
22.0 (11.0)
5.73 (2.87)
2.00 (1.00)
CMP 1
22.0 (11.0)
5.16 (2.58)
2.00 (1.00)
CMP 2
44.0 (11.0)
10.32 (2.58)
4.00 (1.00)
CMP 3
63.0 (10.5)
15.48 (2.58)
4.00 (0.67)
CMP 4
63.0 (10.5)
15.48 (2.58)
4.00 (0.67)
CMP 5
63.0 (10.5)
15.48 (2.58)
4.00 (0.67)
CMP 6*
32.0 (10.6)
8.67 (1.45)
4.00 (0.67)
Prefixed CMP 1
63.0 (7.9; 10.5**)
20.62 (2.58)
4.14 (0.52)
Prefixed CMP 2
63.0 (7.9; 10.5**)
20.60 (2.58)
4.14 (0.52)
Prefixed CMP 3
63.0 (7.9; 10.5**)
20.60 (2.58)
4.14 (0.52)
Prefixed CMP 4*
44.0 (11.0; 14.7**)
11.56 (1.45)
4.12 (0.52)

*2 micro-operations
**assuming that prefixes are truncated before they are placed into Trace Cache

As we know from our previous analyses of various NetBurst incarnations, the first cores with official support for EM64T, such as Nocona D0 and Prescott E0, have a tendency for worse execution efficiency of some commands — the simplest operations like TEST (test eax, eax) and CMP 1 (cmp eax, eax) in particular. This tendency progresses in Prescott/2M core Revision N0 (Table 9; those values that change in the next cores are given in bold for your convenience). First of all, this core has even lower execution efficiency of TEST and CMP 1. The second significant modification is the reduction of maximum execute speed for all CMP operations from L2 Cache to 4.0 bytes/cycle (1.0 or 0.67 instructions/cycle, depending on the command length) as well as prefixed CMP to 4.14 bytes/cycle (0.52 instructions/cycle).

Table 10. Decode/execute efficiency, Pentium EE 840 (Smithfield A0)

Instruction type Effective size of Trace Cache, KB (Kuop) Decode efficiency, bytes/cycle (instructions/cycle)
Trace Cache L2 Cache
NOP
10.5 (10.5)
2.87 (2.87)
1.00 (1.00)
SUB
22.0 (11.0)
5.73 (2.87)
2.00 (1.00)
XOR
22.0 (11.0)
3.99 (2.00)
2.00 (1.00)
TEST
22.0 (11.0)
3.42 (1.71)
2.00 (1.00)
XOR/ADD
22.0 (11.0)
5.73 (2.87)
2.00 (1.00)
CMP 1
22.0 (11.0)
5.16 (2.58)
2.00 (1.00)
CMP 2
44.0 (11.0)
10.32 (2.58)
3.99 (1.00)
CMP 3
63.0 (10.5)
15.48 (2.58)
4.26 (0.71)
CMP 4
63.0 (10.5)
15.48 (2.58)
4.26 (0.71)
CMP 5
63.0 (10.5)
15.48 (2.58)
4.26 (0.71)
CMP 6*
32.0 (10.6)
8.67 (1.45)
4.26 (0.71)
Prefixed CMP 1
63.0 (7.9; 10.5**)
20.60 (2.58)
4.45 (0.56)
Prefixed CMP 2
63.0 (7.9; 10.5**)
20.60 (2.58)
4.45 (0.56)
Prefixed CMP 3
63.0 (7.9; 10.5**)
20.60 (2.58)
4.45 (0.56)
Prefixed CMP 4*
44.0 (11.0; 14.7**)
11.55 (1.45)
4.45 (0.56)

*2 micro-operations
**assuming that prefixes are truncated before they are placed into Trace Cache

Further NetBurst evolution, manifested by the first dual core processor Pentium Extreme Edition 840 (and Pentium D 800) with Smithfield core (Table 10), brought no significant changes into execution efficiency of TEST and CMP 1 — it stays on the same level as in case of processors with Prescott/2M core. In return, the execute efficiency of CMP3-CMP6 as well as prefixed CMP1-CMP4 operations from L2 Cache again got higher. In our Smithfield review we assumed that it had to do with differences in L2 Cache size between Prescott N0 and Smithfield. It's high time to check up this assumption using test results of the new Presler core (Table 11).

Table 11. Decode/execute efficiency, Pentium EE 955 (Prescott B1)

Instruction type Effective size of Trace Cache, KB (Kuop) Decode efficiency, bytes/cycle (instructions/cycle)
Trace Cache L2 Cache
NOP
10.5 (10.5)
2.87 (2.87)
1.00 (1.00)
SUB
22.0 (11.0)
5.73 (2.87)
2.00 (1.00)
XOR
22.0 (11.0)
3.99 (2.00)
2.00 (1.00)
TEST
22.0 (11.0)
3.42 (1.71)
2.00 (1.00)
XOR/ADD
22.0 (11.0)
5.73 (2.87)
2.00 (1.00)
CMP 1
22.0 (11.0)
5.16 (2.58)
2.00 (1.00)
CMP 2
44.0 (11.0)
10.32 (2.58)
3.99 (1.00)
CMP 3
63.0 (10.5)
15.47 (2.58)
4.00 (0.67)
CMP 4
63.0 (10.5)
15.48 (2.58)
4.00 (0.67)
CMP 5
63.0 (10.5)
15.48 (2.58)
4.00 (0.67)
CMP 6*
32.0 (10.6)
8.66 (1.45)
4.00 (0.67)
Prefixed CMP 1
63.0 (7.9; 10.5**)
20.62 (2.58)
4.14 (0.52)
Prefixed CMP 2
63.0 (7.9; 10.5**)
20.62 (2.58)
4.14 (0.52)
Prefixed CMP 3
63.0 (7.9; 10.5**)
20.61 (2.58)
4.14 (0.52)
Prefixed CMP 4*
44.0 (11.0; 14.7**)
11.55 (1.45)
4.12 (0.52)

*2 micro-operations
**assuming that prefixes are truncated before they are placed into Trace Cache

Our assumption is confirmed — the increase in L2 Cache size to 2 MB is again accompanied by the reduction of maximum decode efficiency for large simple instructions to 4.0-4.14 bytes/cycle. This series of tests demonstrates no other differences between the new Presler core and Smithfield, Prescott N0.

The second noticeable change in the Prescott/Nocona decoder with the introduction of EM64T consisted in reduced efficiency of truncating meaningless prefixes in the test that executes instructions of the following type: [0x66]nNOP, n = 0..14.




Picture 10. Decode/execute efficiency for prefix instructions

Table 12

Number of
prefixes
Decode/execute efficiency, bytes/cycle
(instructions/cycle)
Pentium 4 660
(Prescott N0)
Pentium EE 840
(Smithfield A0)
Pentium EE 955
(Presler B1)
0
2.80 (2.80)
2.80 (2.80)
2.79 (2.79)
1
5.43 (2.72)
5.43 (2.72)
5.37 (2.69)
2
8.13 (2.71)
8.13 (2.71)
8.06 (2.69)
3
10.42 (2.61)
10.42 (2.61)
10.32 (2.58)
4
12.74 (2.55)
12.74 (2.55)
12.58 (2.52)
5
14.74 (2.46)
14.74 (2.46)
14.33 (2.38)
6
16.64 (2.38)
16.64 (2.38)
16.12 (2.30)
7
18.76 (2.35)
18.76 (2.35)
18.43 (2.30)
8
20.23 (2.25)
20.23 (2.25)
19.84 (2.20)
9
21.96 (2.20)
21.96 (2.20)
21.50 (2.15)
10
23.45 (2.13)
23.45 (2.13)
22.43 (2.04)
11
25.17 (2.10)
25.17 (2.10)
24.57 (2.05)
12
26.46 (2.04)
26.46 (2.04)
25.80 (1.98)
13
27.89 (1.99)
27.89 (1.99)
27.15 (1.94)
14
30.35 (2.02)
30.35 (2.02)
28.66 (1.91)

Remember that Prescott N0 and Smithfield cores did not suffer significant changes relative to the previous processor cores supporting EM64T. Nevertheless, Presler's results in this test (Picture 10, Table 12) indicate further reduction of efficiency of truncating meaningless prefixes.

Instruction Re-Order Buffer (I-ROB)




Picture 11. Instruction Re-Order Buffer Depth

Testing depth of the Instruction Re-Order Buffer in Presler (Picture 11) provides a similar situation as in case of Nocona core, Stepping D0. We can see an inflection at 120 NOPs, quite close to the true value, specified for Pentium 4 Prescott (126) processors. It would be reasonable to assume that the new dual core processors Pentium D/Extreme Edition 800 and 900 (based on Smithfield and Presler cores) have the same I-ROB depth.

TLB Characteristics

We shall not analyze D-TLB and I-TLB characteristics in detail, considering that they haven't changed (according to CPUID descriptors) since the first Prescott core.




Picture 12. D-TLB size



Picture 13. D-TLB associativity

D-TLB size (Picture 12) is 64 entries (we have already seen it in test results for L1/L2/RAM bandwidth and latency), a miss penalty (when the TLB size is used up) costs a processor 57 cycles minimum. Full associativity (Picture 13).




Picture 14. I-TLB size



Picture 15. I-TLB associativity

I-TLB size (Picture 14) — 64 entries, the miss penalty is 45 cycles (forward, backward walk) and higher (random walk), full associativity (Picture 15).

Conclusion

Our today's analysis of low-level characteristics of one of two independent cores of the new 65nm dual core processor Pentium Extreme Edition 955 (Presler) revealed that it's maximum close to the previous 90nm Prescott/2M, implemented in processors Pentium 4 600 and Pentium 4 Extreme Edition 3.73 GHz. Similarity manifests itself in the size and organization of D-Caches, their performance, L1-L2 bus bandwidth, as well as most characteristics of the predecoder and Execution Trace Cache.

At the same time, we revealed a number of serious differences, which positively distinguish the new Presler core. First of all, we mean a principally new element for x86 processors on the whole and for NetBurst architecture in particular — hardware prefetch on the level of L2 Cache. It allows to mask noticeable delays, which have to do with access to this relatively slow cache when reading data strictly forward or backward. Secondly, Presler has a significantly overhauled data prefetch from memory, which allows to reach even lower memory latencies (in the same cases of forward and backward access). Reduced efficiency of decoding/executing prefixed instructions slightly spoils the picture. But this fact is just of theoretical interest, as these instructions are not used in practice. Thus, this drawback will not manifest itself in reality, when executing real applications.



Dmitri Besedin (dmitri_b@ixbt.com)
March 22, 2006



Write a comment below. No registration needed!


Article navigation:



blog comments powered by Disqus

  Most Popular Reviews More    RSS  

AMD Phenom II X4 955, Phenom II X4 960T, Phenom II X6 1075T, and Intel Pentium G2120, Core i3-3220, Core i5-3330 Processors

Comparing old, cheap solutions from AMD with new, budget offerings from Intel.
February 1, 2013 · Processor Roundups

Inno3D GeForce GTX 670 iChill, Inno3D GeForce GTX 660 Ti Graphics Cards

A couple of mid-range adapters with original cooling systems.
January 30, 2013 · Video cards: NVIDIA GPUs

Creative Sound Blaster X-Fi Surround 5.1

An external X-Fi solution in tests.
September 9, 2008 · Sound Cards

AMD FX-8350 Processor

The first worthwhile Piledriver CPU.
September 11, 2012 · Processors: AMD

Consumed Power, Energy Consumption: Ivy Bridge vs. Sandy Bridge

Trying out the new method.
September 18, 2012 · Processors: Intel
  Latest Reviews More    RSS  

i3DSpeed, September 2013

Retested all graphics cards with the new drivers.
Oct 18, 2013 · 3Digests

i3DSpeed, August 2013

Added new benchmarks: BioShock Infinite and Metro: Last Light.
Sep 06, 2013 · 3Digests

i3DSpeed, July 2013

Added the test results of NVIDIA GeForce GTX 760 and AMD Radeon HD 7730.
Aug 05, 2013 · 3Digests

Gainward GeForce GTX 650 Ti BOOST 2GB Golden Sample Graphics Card

An excellent hybrid of GeForce GTX 650 Ti and GeForce GTX 660.
Jun 24, 2013 · Video cards: NVIDIA GPUs

i3DSpeed, May 2013

Added the test results of NVIDIA GeForce GTX 770/780.
Jun 03, 2013 · 3Digests
  Latest News More    RSS  

Platform  ·  Video  ·  Multimedia  ·  Mobile  ·  Other  ||  About us & Privacy policy  ·  Twitter  ·  Facebook


Copyright © Byrds Research & Publishing, Ltd., 1997–2011. All rights reserved.