1 / 8

Lab 4: MSP430 Microarchitecture

MSP430 Microarchitecture. Lab 4: MSP430 Microarchitecture. MSP430 Microarchitecture Simulator: Use the MSP430 Microarchitecture Simulator to create a Finite State Machine that implements the Texas Instruments MSP430 ISA.

jana-bryant
Download Presentation

Lab 4: MSP430 Microarchitecture

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. MSP430 Microarchitecture Lab 4: MSP430 Microarchitecture • MSP430 Microarchitecture Simulator: • Use the MSP430 Microarchitecture Simulator to create a Finite State Machine that implements the Texas Instruments MSP430 ISA. • Create states that fetch, decode, evaluate source, evaluate destination, execute, and store MSP430 instructions and operands. • Execute a program that displays an incrementing counter in the simulator LEDs. • Learning Objectives: After completing the Microarchitecture Lab, students will be able to: • Implement a MSP430 ISA microarchitecture that executes computer instructions. • Explain how a computer is a Finite State Machine. • List 7 ways operands are accessed by a computer instruction. • Use multiplexors, decoders, drivers, ALUs, and registers to move and store data within a computer. • Explain the functions of the program counter, stack pointer, and condition code registers. • Summarize the difference between clock cycles and instruction steps. Lab 4 - Microarchitecture Lab

  2. MSP430 Microarchitecture Microarchitecture Simulator • Simulator buttons: • Run: Generate continuous clocks • Step: Generate continuous clocks until next Fetch, Clock 1 state. • Clock: Generate one clock. • Back: Backup one clock state. • Current State: Current instruction execution state. • Next State: Next instruction state after a clock. • Reset: Reset FSM Control, registers, memory, clocks, and instructions. • Restart:Restarts current simulation. • Quit: Exit MicroArch Simulator. • Load Control: Read FSM control from a file. • Save Control: Save current control to a file. • Load Memory:Loads the currently selected program into memory. • Analyze FSM:Outputs and analysis of the FSM Control in the Notes window. • Please note: Save learned FSM Control after each instruction in a new file! Lab 4 - Microarchitecture Lab

  3. MSP430 Microarchitecture Lab 4 Machine Code ;************************************************************** ; MSP430 Micro-Architecture Simulator Code ; ; Description: Display an incrementing counter in LEDs. ;************************************************************** .cdeclsC,"msp430.h" .text 8000: 4031 0300 RESET: mov.w #0x0300,SP ; Initstack pointer 8004: 40b2 5a80 0120 mov.w #WDTPW+WDTHOLD,&WDTCTL ; Stop WDT 800a: d0f2 000f 001E bis.b #0x0f,&P4DIR ; Set P1.0-3 output 8010: 430e mov.w #0,r14 8012: 4ec2 001D loop: mov.b r14,&P4OUT ; output P1.0-3 8016: 531e add.w #1,r14 8018: f03e 000f and.w #0x000f,r14 ; mask counter 801c: 401f 0003 mov.w delay,r15 ; Delay to R15 8020: 120f push r15 8022: 8391 0000 wait: sub.w #1,0(sp) ; decrement delay count 8026: 23fd jne wait ; delay over? 8028: 41ef mov.w @sp+,r15 ; y 802a: 3ff3 jmp loop ; repeat 802c: 0002 delay: .word 2 .sect ".reset" ; MSP430 RESET Vector .word RESET ; NMI .end Lab 4 - Microarchitecture Lab

  4. MSP430 Microarchitecture MSP430 Microarchitecture Simulator Lab 4 - Microarchitecture Lab

  5. MSP430 Microarchitecture Pass-off • This lab is worth 10 points as follows: 1 point Your micro-architecture simulator executes the first instruction ("mov.w #0x0600,SP") correctly as outlined in the tutorial - a 2 word instruction with an immediate mode source operand and a register mode destination operand. 1 point Your micro-architecture simulator executes the second instruction ("mov.w#0x5a80,&WDTCTL") correctly - a three word instruction requiring three memory accesses with an absolute mode destination operand. 1 point Your micro-architecture simulator executes the third ("bis.b #0x000f,&P4DIR") and fourth ("mov.w #0,r14") instructions correctly - the fourth being an emulated instruction that uses the CG2 Constant Generator for the source operand and register mode for the destination operand. Lab 4 - Microarchitecture Lab

  6. MSP430 Microarchitecture Pass-off 1 point Your micro-architecture simulator executes the fifth instruction ("mov.br14,&P4OUT") correctly - a two word instruction writing a register to memory. 1 point Your micro-architecture simulator executes the sixth instruction ("add.w #1,r14") correctly - another double operand emulated instruction that uses the Constant Generator CG2 for the source operand. 1 point Your micro-architecture simulator executes the seventh ("and.w#0x000f,r14") and eighth ("mov.w Delay,r15") instructions correctly - the latter requiring a PC-Relative mode for the source operand. 1 point Your micro-architecture simulator executes the ninth ("push.wr15") instruction correctly - a single operand instruction that requires the EXECUTE phase. Lab 4 - Microarchitecture Lab

  7. MSP430 Microarchitecture Pass-off 1 point Your micro-architecture simulator executes the tenth ("sub.w #1,0x0000(SP)") instruction correctly - an emulated instruction that uses an indexed register mode for the destination operand. 1 point Your micro-architecture simulator executes the eleventh ("jne(L1)") instruction correctly - a PC-Relative jump format that does not require a source nor destination phase. 1 point Finally, your micro-architecture simulator executes the twelfth ("pop.wr15") and thirteenth ("jmp(Mainloop)") instructions correctly - the former instruction's source operand is obtained using the indexed auto-increment addressing mode "@Rs+". Lab 4 - Microarchitecture Lab

  8. MSP430 Microarchitecture Bonus • In addition to the above points, the following bonus / deductions apply: +1 point Passed off with a TA at least one day early. (Note: labs completed in a previous semester do NOT qualify for the early pass-off bonus.) +1 point Your MSP430 micro-architecture implementation is able to turn on all four LEDs at the same time (170 instructions) in less than 919 clocks. +2 points Your MSP430 microarchitecture implementation is able execute the Bonus program and turn on all four LEDs at the same time (97 instructions) in 544 or less clocks. -1 point For each school day late. (Timestamps may be used to verify completion time.) Lab 4 - Microarchitecture Lab

More Related