w10 SAP-2
w10 SAP-2
w10 SAP-2
cmpt-150-arc Sections 8-8, 8-9, 9-4, 9-5, 9.6, 9.8 1. Well do this in bits and pieces, doing the beginning of each section rst.
I.
Intro
1. The SAP-2 adds a lot of functionality to the SAP-1 hardware, and well present this to see what the hardware does, but the important additions are to the instruction set. 2. The hardware diagram and instruction set are on the web. A. Whats new 1. Well, before you get worked up, nothing is really that new. Datapath is bigger, but operation remains the same. 2. Datapath size is still 8 bits (i.e. accumulator is still 8 bits, for eg) 3. the RAM is 64k now, so we need 16 bits to address it, so the bus is now 16 bits. 4. Control sequencer is much bigger as a result of all the extra registers we added, but we wont worry about whats inside. New Registers 1. MEMORY DATA REGISTER: This register holds the result of a memory access, so we can do other things with the bus while the memory access happens. 2. B IS NOW CALLED TMP: this makes more sense because it really is an implementation register. 3. B AND C REGISTERS: these can hold operands and can be used for other instructions. These are archetectural registers, because they show up in the instructions (as well see) C. Other new things (will become clear as we do examples) 1. Adder/Subtractor is now called the ARITHMETIC/LOGIC UNIT, because it will be doing other things besides adding and subtraction, specically logic operations like complement etc. 2. ags(0:1) will tell us useful information about the ALU operations we perform 3. Addresses are now 16 bits, and opcodes are now 8 bits (because we will have more instructions than we had room for in 4 bits of opcode) so instructions take 3 memory locations each (at least) 4. Instructions can now be variable length: the rst byte we fetch (the opcode) tells us how many more bytes of the instruction to fetch.
B.
Page 1 of 8
the SAP-2
II.
B.
III.
Instructions
A. Load/Store instructions 1. The SAP-2 can now store data into the RAM as well as load data. 2. Recall: instructions that need a memory memory 7 0 address are 3 bytes long: one for the k opcode bytes opcode, and the remaining 2 for the high k+1 address(low byte) and low halves (bytes) of the address. k+2 address(high byte) 3. This is direct addressing: specifying the operand by including the memory address. 4. Example: Store whats in the A register in memory 3c55h a) SAP-2: sta 3c55 is translated to 32h / 55h / 3ch b) HC11: staa 3c55 is translated to b7h / 3ch / 55 c) Note that HC11 and SAP-2 use different order for the halves (bytes) of
Page 2 of 8
the SAP-2
the address. (1) in HC11, the most signicant byte comes rst (smaller address) (2) in SAP-2, the least signicant byte comes rst. d) Note also that the instructions have different opcodes - This is not surprising, as the different instruction sets have different instructions etc. e) We nd the opcode for the HC11 instruction by looking in appendix A f) it tells us that if we want to store whats in A to a two-byte memory address, we use opcode 67. g) If you look, it also tells us that this is called extended addressing. For the HC11, Direct addressing just like we use it, except with the most signicant byte =00h. h) Extended addressing in the HC11 is direct addressing using the full 16 bit address. 5. Note that while the HC11 has staa and stab, the SAP-2 doesnt have stb or stc a) This kind of asymmetry is common in assembly language design - some other function was deemed more important in the SAP-2. B. Immediate Operands 1. An immediate operand is specied in the instruction itself instead of memory. 2. Instead of going to memory to nd the value, the value is in the instruction after the opcode, where the address was in direct addressing. 3. This is called immediate addressing. 4. It is used frequently for small integers (i.e. 1,2,3, ascii characters etc) 5. It is more efcient than direct addressing because it needs only one memory fetch after the opcode (to fetch the next chunk of the instruction) a) Direct addressing needs two memory fetches: Get the next chunk of the instruction, which is the address, then use that address to get the data. 6. Example: to load ascii Z into register B. (SAP-2) a) Instruction code is MVI (Move Immediate) memory 7 0 b) The hex code for ascii Z is 5ah k 06h c) The full instruction is MVI B, 5ah k+1 5ah d) and the machine language for the full instruction is 06h rst byte, 5ah second byte. (as shown) 7. And in HC11: a) instruction code is LDA (load accumulator) b) The version we want is LDAB (machine code c6h)
Page 3 of 8
the SAP-2
c) The full instruciton is LDAB #5ah. The # indicates an immediate operand (see chap 6). The machine code looks like: C.
7 k
memory c6h
k+1 5ah Some notes on opcodes 1. Were looking at two assembly languages at the same time, and they do things a bit differently. 2. The OPCODE is what tells the computer what to do, i.e. how many more bytes to fetch and what to do with them. 3. Different assembly languages use opcodes in different ways. 4. For example, take these two operations: Load register A with the immediate value 2ah (A <- 2ah), and Load register A with the value in memory location 2ah (A <- M[2ah]). a) in SAP-2, (1) we use MVI A, 2ah for the immediate (3eh / 2ah) (2) and LDA 002ah for the direct. (3ah / 2ah / 00h) b) in HC11, (1) we use LDAA #2ah for immediate (86h / 2ah) (2) and LDAA 002ah for the direct (b6h / 00h / 2ah) 5. SAP-2 uses different mnemonics for the different addressing modes, but HC11 uses the same mnemonic and the addressing mode is distinguished by the prex to the operand. 6. Note that in both cases, the operand is different for different addressing modes.
D.
Inherent or implied Operands 1. If there is an instruction that always uses the same operand, we dont need to explicitly state it. the operand is INHERENT in the instruction. 2. The opcode is all we need in this case. 3. This is called INHERENT or IMPLIED addressing mode. 4. All of the SAP-1 instructions used inherent addressing - the A register was always implied (except in HLT). 5. The register - register transfer instructions in SAP-2 are inherent. 6. EXAMPLE: if we want to move whats in A into B (B<-A) we use the instruction MOV A,B. The opcode is 78h, and the operands (A and B) are implied in the opcode. 7. The comprable HC11 instruction is TAB (transfer A to B). In this case, even the assembly language has no operands. The opcode is 16h and thats all there is.
Page 4 of 8
the SAP-2
8. Another example: in SAP-2, the ADD instruction implies ADD to A. a) ADD B executes A <- A+B, and the opcode is 80h, no operands. b) in HC11, the instruction is ABA (Add B to A), and the machine language is simply the opcode 1bh 9. Note that unlike direct and immediate oparands, inherent addressing doesnt tell you anything about where the operand is. It could be a register, or it could be a constant (increment a register) or other things (as well see) 10. And be aware that it is possible for each operand of an instruction to be specied with a different addressing mode. E. Register Operands 1. Registers are very common inherent operands. In fact, all of the examples we have seen so far of inherent operands have been registers. 2. There is a special name for inherent operands that are registers - Register addressing. Its a little more useful, though the HC11 doesnt use it explicityl. Logical instructions 1. Weve looked briey at arithmetic instructions (add etc) but one of the improvements in the SAP-2 is this Arithmetic Logic unit. Well, as the name implies it can do logic as well. 2. SAP-2 can do NOT, AND, OR, XOR, and the opcodes are CMA (complement), ANA, ORA, and XRA respectively. 3. Each of these use register A as an inherent operand, and the other operand is specied immediately as register B or C. 4. The result is a bitwise logical operation. eg if A=00001111 and B=10101010 then ANA B would result in A=00001010. 5. There are immediate versions of these as well: ANI, ORI, XRI 6. the corresponding HC11 instructions are COM, AND, ORA, EOR Shifts and Rotates 1. SAP-2 has two instructions that do register rotate. 2. Rotate is like a shift except that the MSB is transferred to the LSB for a left rotate, and 7 for a right rotate, the LSB is fed into the MSB. 3. SAP-2 instructions are RAL and RAR (for 7 rotate A left and rotate A right 4. HC11 has ROR and ROL (usage, eg: RORA), but theyre slightly different, as well see.
F.
G.
left rotate
right rotate
Page 5 of 8
the SAP-2
H.
Flow of Control Instructions 1. Weve got a lot of functionality so far, but its not very useful if we have to go from top to bottom 2. We want to be able to change what we do depending on what we have just done (if-then constructions and loops!) 3. Before we see how we do this, we need to talk about condition codes a) CONDITION CODES are single-bit values that record useful info about the result of an ALU operation. b) In the SAP-2, these are the ags(1:0) that we saw. c) One ag is set if the result of the ALU operation is zero (the Z ag) d) The other is set if the result of the operation is negative (the S ag, for sign) e) Only operations that use the ALU will affect the condition codes. These are in table 11-3 as well. (1) Usually, Arith or Logic operations affect the control codes, while data movement instructions do not. f) HC11 has 8 condition code bits (see section 6.1.5 on page 6-4 of the manual) and the analgous condition code bits are Z for zero and N for negative. g) the HC11 has a C condition code for carry-out, and V condition code for overow. These are affected by arithmetic operations but not by logic operations. Condition codes are used in ow-of-control operations. a) in SAP-2, these are called jumps, and there are two types: Conditional and unconditional. b) The operand of the jump is the location in memory to jump to. Recall that for normal operation, an instruction fetch looks like this: a) The value in PC is used as the address of the instruction to fetch b) PC is incremented during the fetch, so it is ready to get the next instruction c) The instruction fetched from PC is stored in ir. The important thing to notice is that the PC is already pointing at the next instruction when the current instruction begins to execute. If we want to fetch a different instruction, we need to change the value in the pc. An unconditional jump loads a new value into the pc. A Conditional jump loads a new value into the pc only if the condition is met.
4.
5.
6. 7. 8. 9.
Page 6 of 8
the SAP-2
10. The condition that may or may not be met depends on the result of the last instruction executed. a) For example, in the SAP-1, the jz instruction consults the zero ag (from the ALU) and will jump if the zero ag is 1. If not, the next instruction in sequence is fetched I. Example Assembly Code 1. Lets discover what assembly language would be generated from this Highlevel language segment (in pseudo-C) [overhead] if(widget_cnt > 0) { got_widgets = 1;} else {got_widgets = 0; } 2. How would this look in SAP-2? a) We need memory storage locations for widget_cnt and got_widgets, so lets assume weve allocated a couple of bytes, say 2ah and 2bh. b) We need to gure out what needs to be done. (1) Load widget_cnt into a register (2) test if its greater than zero (3) use jump commands to go to teh appropriate chunk of code (4) place a 1 or a 0 in got_widgets, whichever is appropriate. 3. we can use lda to load the value into the A register. 4. We need an instruction that will give A at the ALU without changing A. 5. Lots of instructions affect the condition codes (see overhead) but we want to use one that has the correct result with the least side-effects. a) add, sub, anda, ora, xra all require something to be in B or C b) ani, ori, xri will work well because they use immediate addressing. c) lets use ori 00h. 6. Heres the assembly language fragment (overhead) a) org is a pseudo-op to tell the assembler to start putting instructions or data in a specic place in memory. b) With this command, we neednt write our assembly language program in order, as long as we keep our orgs straight. c) but the assembler will overwrite previous orgs if we tell it to, so we gotta be careful. 7. the lda and ora instructions get the value of widget_cnt as we have already seen.
Page 7 of 8
the SAP-2
8. Then we want to do one of two things depending on the value of the z and s ags. 9. First, if z is true, we jump to no widgets. 10. Then, if s is true, we also jump to no widgets (jm=jump if minus) 11. These two together skip to the else clause if widget_cnt 0. 12. If neither s nor z are true, the next instructions (widgets) are executed. a) but then we need to skip over the else clause, so we jmp to set_value, which is where execution continues after both the if clause and the else clause: we store the A value back into memory. 13. Note that we could do this the other way: have the else clause rst, and jump over it if widget_cnt > 0. J. Example listing le 1. If we were to assemble that code, wed get this listing le (overhead) 2. Leftmost column shows memory address in hex 3. next column shows memory contents, in hex. 4. During assembly, the assembler resolves labels to memory addresses, and uses them in other instructions as necessary. a) eg, for jz no_widgets b) This instruction is in memory 0005h to 0007h. c) The opcode is cah, stored in memory 0005h. d) the target of the jump (the operand) is the mvi instruction, located in memory location 0010h, so that address is placed in memory 0006h and 0007h, LSbyte rst as is the convention for SAP-2. 5. Another example: mvi is an immediate instruction, which moves the value in A to the indicated memory. The assembly language said put it in got_widgets, but the assembler knew that this corresponds to memory location 2bh.
Page 8 of 8