Intel ARCHITECTURE IA-32 User Manual Page 254

  • Download
  • Add to my manuals
  • Print
  • Page
    / 568
  • Table of contents
  • BOOKMARKS
  • Rated. / 5. Based on customer reviews
Page view 253
IA-32 Intel® Architecture Optimization
4-34
Memory Optimizations
You can improve memory accesses using the following techniques:
Avoiding partial memory accesses
Increasing the bandwidth of memory fills and video fills
Prefetching data with Streaming SIMD Extensions (see Chapter 6,
“Optimizing Cache Usage”).
The MMX registers and XMM registers allow you to move large
quantities of data without stalling the processor. Instead of loading
single array values that are 8, 16, or 32 bits long, consider loading the
values in a single quadword or double quadword, then incrementing the
structure or array pointer accordingly.
Any data that will be manipulated by SIMD integer instructions should
be loaded using either:
the SIMD integer instruction that loads a 64-bit or 128-bit operand
(for example,
movq MM0, m64)
the register-memory form of any SIMD integer instruction that
operates on a quadword or double quadword memory operand (for
example,
pmaddw MM0, m64).
All SIMD data should be stored using the SIMD integer instruction that
stores a 64-bit or 128-bit operand (for example,
movq m64, MM0)
The goal of these recommendations is twofold. First, the loading and
storing of SIMD data is more efficient using the larger block sizes.
Second, this helps to avoid the mixing of 8-, 16-, or 32-bit load and store
operations with SIMD integer technology load and store operations to
the same SIMD data. This, in turn, prevents situations in which small
loads follow large stores to the same area of memory, or large loads
follow small stores to the same area of memory. The Pentium II,
Pentium III, and Pentium 4 processors stall in these situations; see
Chapter 2, “General Optimization Guidelines” for more details.
Page view 253
1 2 ... 249 250 251 252 253 254 255 256 257 258 259 ... 567 568

Comments to this Manuals

No comments