IBM 750GL Computer Accessories User Manual


 
User’s Manual
IBM PowerPC 750GX and 750GL RISC Microprocessor
gx_08.fm.(1.2)
March 27, 2006
Bus Interface Operation
Page 297 of 377
The 750GX supports misaligned memory operations, although their use can substantially degrade perfor-
mance. Misaligned memory transfers address memory that is not aligned to the size of the data being trans-
ferred (such as, a word read of an odd byte address). Although most of these operations hit in the primary
cache (or generate burst memory operations if they miss), the 750GX interface supports misaligned transfers
within a word (32-bit aligned) boundary, as shown in Table 8-5 on page 298.
Note: The 4-byte transfer in Table 8-5 is only one example of misalignment. As long as the attempted trans-
fer does not cross a word boundary, the 750GX can transfer the data on the misaligned address (for example,
a half-word read from an odd byte-aligned address). An attempt to address data that crosses a word bound-
ary requires two bus transfers to access the data.
Due to the performance degradations associated with misaligned memory operations, they are best avoided.
In addition to the double-word straddle boundary condition, the address-translation logic can generate
substantial exception overhead when the load/store multiple and load/store string instructions access
misaligned data. It is strongly recommended that software attempt to align data where possible.
Word
1 0 0 000 xxxx————
1 0 0 100 ———— xxxx
Double word 0 0 0 000 xxxxxxxx
Table 8-4. Aligned Data Transfers (Page 2 of 2)
Transfer Size TSIZ0 TSIZ1 TSIZ2 A[29–31]
Data-Bus Byte Lane(s)
01234567
Note: The entries with an “x” indicate the byte portions of the requested operand that are read or written during a bus transaction.
The entries with a “–” are not required and are ignored during read transactions, and they are driven with undefined data during all write
transactions.