# Memory CS 447, Spring 2016 ## **Memory transfer instructions** - How to get values to/from memory? - · Also called memory access instructions - Only two types of instructions - · Load: move data from memory to register ("load the register") - e.g., lw \$s5, 4(\$t6) # \$s5 ← memory[\$t6 + 4] - · Store: move data from register to memory ("save the register") - e.g., sw \$s7, 16(\$t3) # memory[\$t3+16] ← \$s7 - In MIPS (32-bit architecture) there are memory transfer instructions for - 32-bit word: "int" type in C (lw, sw) - 16-bit half-word: "short" type in C (lh, sh; also unsigned lhu) - 8-bit byte: "char" type in C (lb, sb; also unsigned lbu) CS/CoE0447: Computer Organization and Assembly Language University of Pittsburgh 2 ## **Memory view** - Memory is a large, single-dimension 8-bit (byte) array with an address to each 8-bit item ("byte address") - A memory address is just an index into the array loads and stores give the index (address) to access CS/CoE0447: Computer Organization and Assembly Language University of Pittsburgh - Memory is a large, single-dimension 8-bit (byte) array with an address to each 8-bit item ("byte address") - A memory address is just an index into the array loads and stores give the index (address) to access CS/CoE0447: Computer Organization and Assembly Language University of Pittsburgh 20 ## **Memory view** - Memory is a large, single-dimension 8-bit (byte) array with an address to each 8-bit item ("byte address") - A memory address is just an index into the array loads and stores give the index (address) to access CS/CoE0447: Computer Organization and Assembly Language University of Pittsburgh - Memory is a large, single-dimension 8-bit (byte) array with an address to each 8-bit item ("byte address") - A memory address is just an index into the array loads and stores give the index (address) to access CS/CoE0447: Computer Organization and Assembly Language University of Pittsburgh 2 ## **Memory view** - Memory is a large, single-dimension 8-bit (byte) array with an address to each 8-bit item ("byte address") - A memory address is just an index into the array loads and stores give the index (address) to access CS/CoE0447: Computer Organization and Assembly Language University of Pittsburgh - Memory is a large, single-dimension 8-bit (byte) array with an address to each 8-bit item ("byte address") - A memory address is just an index into the array loads and stores give the index (address) to access CS/CoE0447: Computer Organization and Assembly Language University of Pittsburgh ## **Memory view** - Memory is a large, single-dimension 8-bit (byte) array with an address to each 8-bit item ("byte address") - A memory address is just an index into the array loads and stores give the index (address) to access University of Pittsburgh - Memory is a large, single-dimension 8-bit (byte) array with an address to each 8-bit item ("byte address") - A memory address is just an index into the array loads and stores give the index (address) to access CS/CoE0447: Computer Organization and Assembly Language University of Pittsburgh 35 ### **Effective Address calculation** - Effective memory address specified as immediate(\$register) - · Register to keep the base address - Immediate to determine an offset from the base address - · Thus, address is contents of register + immediate - The offset can be positive or negative, 16-bit value (uses I-format) - Suppose base register \$t1=64, then: ``` lw $t0, 12($t1) address = 64 + 12 = 76 lw $t0, -12($t1) address = 64 - 12 = 52 ``` MIPS uses this simple address calculation; other architectures such as PowerPC and x86 support different methods CS/CoE0447: Computer Organization and Assembly Language University of Pittsburgh ## Hint on addresses (la - load address) Often, you need to reference a particular variable. Puts the address of variable "var" into \$t0 la \$t0, var lw \$t1,0(\$t0) lw \$t2,4(\$t0) value at the address in \$t0 is loaded ino \$t1 la is a "pseudo-instruction". It is turned into a sequence to put a large address constant into \$t0. lui \$at,upperbitsofaddres ori \$t0,\$1,lowerbitsofaddress CS/CoE0447: Computer Organization and Assembly Language University of Pittsburgh 3 ### Let's try an in-class exercise together! - Create a word (integer) variable "myVar" - Give the variable the value 20 - Print the value to the console (Run I/O window) - Terminate the program - Extension: Add 10 to the value, store it to myVar, print it - To do this, we'll need to use: - · Data segment declaration with a word variable type - · Instruction segment declaration - Load word instruction - · Syscall instruction - · Assorted la and li instructions CS/CoE0447: Computer Organization and Assembly Language University of Pittsburgh ## **In-class Example** set myVar=20, print myVar, terminate ``` .data .word 20 myVar: .text $t0,myVar # address of "myVar" la $a0,0($t0) # load value into $a0 lw li $v0,1 # print integer service # call operating system syscall $v0,10 # terminate service syscall # call operating system ``` CS/CoE0447: Computer Organization and Assembly Language University of Pittsburgh 39 ## **Another example** - What about an array? - · A sequence of data elements - Each element can be accessed ("references") by an index - 10 elements: Index 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 - E.g., declare a C array of integers with 5 numbers - int A[5]; - 5elements: A[0], A[1], A[2], A[3], A[4] - This is data. How is it represented? - 5 integers in memory; an integer is a word in MIPS (4 bytes) - · Element 0: at lowest address - · Element 4: at highest address CS/CoE0447: Computer Organization and Assembly Language University of Pittsburgh # **Memory Organization** ### 32-bit byte address: - 2<sup>32</sup> bytes with byte addresses from 0 to 2<sup>32</sup>-1 - 230 words with byte addresses 0, 4, 8, ..., 232-4 ### Words are aligned • 2 least significant bits (LSBs) of an address are 0s #### Half words are aligned · LSB of an address is 0 ### Addressing within a word: - · Which byte appears first and which byte last? - · Big-endian vs. little-endian - · Little end (LSB) comes first (at low address) - Big end (MSB) comes first (at low address) | 0 | WORD #0 | |----|---------| | 4 | WORD #1 | | 8 | WORD #2 | | 12 | WORD #3 | | 16 | WORD #4 | | 20 | WORD #5 | | Low<br>Address | | | High<br>Address | | | | | |----------------|---|---|-----------------|---|--|--|--| | 0 | 0 | 1 | 2 | 3 | | | | | Little Endian | | | | | | | | # Alignment ### A misaligned access • Assume \$t0=0, then 1w \$s4, 3(\$t0) How do we define a word at an address? - Data in byte 0, 1, 2, 3 - If you meant this, use the address 0, not 3. - Data in byte 3, 4, 5, 6 - If you meant this, it is indeed misaligned! - · Certain hardware implementation may support this; usually not. - If you still want to obtain a word starting from the address 3 get a byte from address 3, a word from address 4 and manipulate the two data to get what you want Alignment issue does not exist for byte access. ### Easy rule: Aligned if: ADDRESS mod TYPESIZE == 0 E.g., Is 13 aligned for a word? 13 mod $4 \stackrel{!}{=} 0 \Rightarrow$ not aligned Is 14 aligned for a halfword? 14 mod $2 == 0 \Rightarrow$ aligned