Chapter 5 The LC-3 - PowerPoint PPT Presentation

1 / 23
About This Presentation
Title:

Chapter 5 The LC-3

Description:

... Set Architecture (ISA) Machine Instructions. Address Modes ... Example LC-3 Program. Write a program to add 12 integers and store the result in a Register. ... – PowerPoint PPT presentation

Number of Views:240
Avg rating:3.0/5.0
Slides: 24
Provided by: larry109
Category:
Tags: chapter | register

less

Transcript and Presenter's Notes

Title: Chapter 5 The LC-3


1
Chapter 5 The LC-3
  • LC-3 Computer
  • Architecture
  • Memory Map
  • Instruction Set Architecture (ISA)
  • Machine Instructions
  • Address Modes
  • Instructions
  • - Operate
  • - Data Move
  • - Control
  • Programming in Machine Code

2
The LC-3 Computera von Neumann machine
The Instruction Cycle
Fetch Next Instruction from Memory
(PC) ? (points to) next
instruction PC ?(PC) 1
Decode Fetched Instruction Evaluate Instr
Address (es) (find where
the data is) Load Operand (s)
(get data as specified) Execute
Operation Store Result
(if specified)
PSW
Memory
PSW (Program Status Word) Bits 15
10 9 8 2 1
0 S
Priority N Z P
3
Important Registers in the CPU
  • 8 General Purpose Registers (R0 R7) Holds
    Data or Addresses
  • Program Counter (PC) - Points to the next
    instruction
  • Instruction Register (IR) holds the instruction
    being executed
  • Memory Address Register (MAR) Holds the address
    of a memory location being accessed
  • Memory Data Register (MDR) Hold the data to be
    written into memory or the date read from memory
  • Program Status Word (PSW) holds the status of
    the program being executed, including N Z P
    Negative, Zero, Positive result of an operate
    instruction
  • Note These are all 16 bit registers

4
LC-3 Memory Map (64K of 16 bit words)
256 words (We will get to theses today) 256
words (We will get to these later) 23.5 K words
39.5 K words 512 words
5
LC-3 Instructions (Fig 5.3 Appendix a)
  • Addressing Modes
  • Register
  • (Operand is in one of the 8 registers)
  • PC-relative
  • (Operand is offset from where the PC points
  • - offsets are sign extended to 16 bits)
  • Base Offset (Base relative)
  • (Operand is offset from the contents of a
    register)
  • Immediate
  • (Operand is in the instruction)
  • Indirect
  • (The Operand points to the real address of
    Operand
  • rather than being the operand)
  • Note The LC-3 has No Direct Addressing Mode

6
Operate Instructions
  • There are only three operate Instructions
  • - ADD Register mode 0001 DR SR1 0 00
    SR2
  • Register/Immediate mode
    0001 DR SR1 1 imm5
  • - AND Register mode 0101 DR SR1 0 00
    SR2
  • Register/Immediate mode
    0101 DR SR1 1 imm5
  • - NOT Register mode 1001 DR SR 111111
  • The Source and Destination operands are
  • CPU Registers or Immediate Values

7
LC-3 Instructions (Fig 5.3 Appendix a)
  • Addressing Modes
  • Register
  • (Operand is in one of the 8 registers)
  • PC-relative
  • (Operand is offset from where the PC points
  • - offsets are sign extended to 16 bits)
  • Base Offset (Base relative)
  • (Operand is offset from the contents of a
    register)
  • Immediate
  • (Operand is in the instruction)
  • Indirect
  • (The Operand points to the real address of
    Operand
  • rather than being the operand)
  • Note The LC-3 has No Direct Addressing Mode

8
Data Movement Instructions
  • Load - read data from memory to a register
  • LD PC-relative mode 0010 DR PCoffset9
  • LDI Indirect mode 1010 DR PCoffset9
  • LDR Baseoffset mode 0110 DR BaseR offset6
  • Store - write data from a register to memory
  • ST PC-relative mode 0011 DR PCoffset9
  • STI Indirect mode 1011 DR PCoffset9
  • STR Baseoffset mode 0111 DR BaseR
    offset6
  • Load effective address address saved in
    register
  • LEA PC-relative mode 1110 DR PCoffset9

9
LC-3 Instructions (Fig 5.3 Appendix a)
  • Addressing Modes
  • Register
  • (Operand is in one of the 8 registers)
  • PC-relative
  • (Operand is offset from where the PC points
  • - offsets are sign extended to 16 bits)
  • Base Offset (Base relative)
  • (Operand is offset from the contents of a
    register)
  • Immediate
  • (Operand is in the instruction)
  • Indirect
  • (The Operand points to the real address of
    Operand
  • rather than being the operand)
  • Note The LC-3 has No Direct Addressing Mode

10
Control Instructions
  • Go to New Location in Program GO TO
  • BR PC-relative mode 0000 NZP PCoffset9
  • JMP Indirect mode 1100 000 BaseR 000000
  • Trap Service Routine Call
  • TRAP Indirect 1111 0000 TrapVec8
  • Jump to Subroutine (will be covered later)
  • JSR PC-relative mode 0100 1 PCoffset11
  • JSRR Indirect mode 0100 000 BaseR 000000
  • Return from Trap/Subroutine
  • RET No operand 1100 000 111 000000
  • Return from Interrupt (will be covered later)
  • RTI No operand 1000 000000000000

11
LC-3 Instructions (Fig 5.3 Appendix a)
  • Addressing Modes
  • Register
  • (Operand is in one of the 8 registers)
  • PC-relative
  • (Operand is offset from where the PC points
  • - offsets are sign extended to 16 bits)
  • Base Offset (Base relative)
  • (Operand is offset from the contents of a
    register)
  • Immediate
  • (Operand is in the instruction)
  • Indirect
  • (The Operand points to the real address of
    Operand
  • rather than being the operand)
  • Note The LC-3 has No Direct Addressing Mode

12
Branch Instruction
  • BR 0000 nzp PCoffset9
  • Branch specifies one or more condition codes
  • Program Status Word (PSW)
  • Bits 15 10 9 8
    2 1 0
  • S Priority
    NZP
  • If the specified bit(s) is (are) set, the branch
    is taken
  • PC is set to the address specified in the
    instruction
  • Target (new PC) address is computed by
  • adding SEXT(IR80) to the PC contents
  • If the branch is not taken - the next
    sequential instruction is executed (presently
    pointed to by the PC).

13
BR


SEXT
14
Jump Instruction
  • JMP BaseR 1100 000 BaseR 000000
  • Jump is an unconditional branch -- always taken.
  • BaseR
  • New PC contents (an Address) is the contents of
    the Base register
  • Allows any target address !

15
Example LC-3 Program
  • Write a program to add 12 integers and store the
    result in a Register.

16
Compute the Sum of 12 Integers Program
  • Program begins at location x3000.
  • Integers begin at location x3100.

R1 ? x3100R3 ? 0 (Sum)R2 ? 12(count)
R20?
R4 ? MR1 R3 ? R3R4R1 ? R11 R2 ? R2-1
NO
YES
R1 Array index pointer (Begin with location
3100) R3 Accumulator for the sum of
integers R2 Loop counter (Count down from
12) R4 Temporary register to store next integer
17
Sum integers from x3100 x310B
Address Instruction Comments
x3000 1 1 1 0 0 0 1 0 1 1 1 1 1 1 1 1 R1 ? x3100
x3001 0 1 0 1 0 1 1 0 1 1 1 0 0 0 0 0 R3 ? 0
x3002 0 1 0 1 0 1 0 0 1 0 1 0 0 0 0 0 R2 ? 0
x3003 0 0 0 1 0 1 0 0 1 0 1 0 1 1 0 0 R2 ? 12
x3004 0 0 0 0 0 1 0 0 0 0 0 0 0 1 0 1 If Z, goto x300A
x3005 0 1 1 0 1 0 0 0 0 1 0 0 0 0 0 0 Load next value to R4
x3006 0 0 0 1 0 1 1 0 1 1 0 0 0 1 0 0 Add to R3
x3007 0 0 0 1 0 0 1 0 0 1 1 0 0 0 0 1 Increment R1 (pointer)
X3008 0 0 0 1 0 1 0 0 1 0 1 1 1 1 1 1 Decrement R2 (counter)
x3009 0 0 0 0 1 1 1 1 1 1 1 1 1 0 1 0 Goto x3004
R1 Array index pointer (Begin with location
3100) R3 Accumulator for the sum of
integers R2 Loop counter (Count down from 12)
R4 Temporary register to
store next integer What happens at location 300A
?
18
LC-3 Instructions (Fig 5.3 Appendix a)
  • Addressing Modes
  • Register
  • (Operand is in one of the 8 registers)
  • PC-relative
  • (Operand is offset from where the PC points
  • - offsets are sign extended to 16 bits)
  • Base Offset (Base relative)
  • (Operand is offset from the contents of a
    register)
  • Immediate
  • (Operand is in the instruction)
  • Indirect
  • (The Operand points to the real address of
    Operand
  • rather than being the operand)
  • Note The LC-3 has No Direct Addressing Mode

19
The Sum program in binary
  • x3000 1110001011111111 R1x3100
  • x3001 0101011011100000 R30
  • x3002 0101010010100000 R20
  • x3003 0001010010101100 R2R212
  • x3004 0000010000000101 If z goto x300A
  • x3005 0110100001000000 Load next value into
    R4
  • x3006 0001011011000100 R3R3R4
  • x3007 0001001001100001 R1R11
  • x3008 0001010010111111 R2R2-1
  • x3009 0000111111111010 goto x3004
  • x300A 1111000000100101 halt

20
The Sum program in hex
  • x3000 E2FF R1x3100
  • x3001 56E0 R30
  • x3002 54A0 R20
  • x3003 14AC R2R212
  • x3004 0405 If z goto x300A
  • x3005 6840 Load next value into R4
  • x3006 16C4 R3R3R4
  • x3007 1261 R1R11
  • x3008 14BF R2R2-1
  • x3009 0FFA goto x3004
  • x300A F025 halt

21
The Sum program Data in hex
  • x3100 0001 Loc x3100
  • x3101 0002
  • x3102 0004
  • x3103 0008
  • x3104 FFFF
  • x3105 1C10
  • x3106 11B1
  • x3107 0019
  • x3108 0F07
  • x3109 0004
  • x310A 0A00
  • x310B 400F Loc x310B

22
TRAP Instruction
  • Calls a service routine, identified by 8-bit
    trap vector.
  • Register R7 is loaded with the incremented
    contents of the PC.
  • The PC is loaded with the address in the
    Trapvector Table at position trapvector8
  • R0 is typically used for passing values between
    the Program and the Trap Routine
  • RET 1100 000 111 000000
  • When service routine is done, an RET will load R7
    (the incremented value of the PC before jumping
    to the TRAP routine) into the PC, and the
    program will continue with the next instruction
    after the TRAP, i.e. the program will return
    from the TRAP Routine.
  • Note an RET is a JMP Base-relative with Base
    R7

vector Service routine (Partial List)
x23 input a character from the keyboard
x21 output a character to the monitor
x25 halt the program
23
TRAPS
See page 543.
Write a Comment
User Comments (0)
About PowerShow.com