EECE.3170 Microprocessor Systems Design I

Slides:



Advertisements
Similar presentations
Instruction formats for the PIC series. ROM encoding Instructions are encoded in binary in ROM. The instructions are fixed format, each occupying 14 bits.
Advertisements

Control structures Hot to translate high level control structures to assembler.
Prof. Jorge A. Ramón Introducción a Microcontroladores.
Flow Control Instructions
Microprocessor Systems Design I Instructor: Dr. Michael Geiger Fall 2013 Lecture 26: PIC microcontroller intro.
16.317: Microprocessor System Design I Instructor: Dr. Michael Geiger Spring 2012 Lecture 30: PIC data memory.
Microprocessor Systems Design I Instructor: Dr. Michael Geiger Fall 2013 Lecture 27: PIC instruction set.
Lecture – 5 Assembly Language Programming
9/20/6Lecture 21 -PIC Architecture1 PIC Architecture Instruction Set.
Microcontroller Programming How to make something almost do something else Raffi Krikorian MAS November 2003.
Two’s Complement Number wheel for 4 bit numbers
Building Assembler Programs Chapter Five Dr. Gheith Abandah1.
Microprocessor and Interfacing PIC Code Execution
PIC18F Programming Model and Instruction Set
Lecture – 4 PIC18 Family Instruction Set 1. Outline Literal instructions. Bit-oriented instructions. Byte-oriented instructions. Program control instructions.
Microprocessors Monday, Apr. 13 Dr. Asmaa Farouk Faculty of Engineering, Electrical Department, Assiut University.
EEE237 Introduction to Microprocessors Week x. SFRs.
Department of Electronic & Electrical Engineering Lecture 2 ● Introduction to IO ● Using a subroutine ● Driving a 7seg display.
PIC12F629/675. “Wide variety” 8-84 pin RISC core, 12/14/16bit program word USART/AUSART, I 2 C, ADC, ICSP, ICD OTP/UV EPROM/FLASH/ROM Families: PIC12,
Department of Electronic & Electrical Engineering Lecture 4. ➢ Loops ➢ Delays ➢ Conditional instructions ➢ Simple clock example.
Applications examples. A binary count : stepped manually and reset with push buttons. Define ports Reset portd Reset =0? INCF portd no Step =0? yes.
Microprocessor Systems Design I
Microprocessor Systems Design I
Unit 1 Instruction set M.Brindha AP/EIE
Lecture – 5 Assembly Language Programming
Microprocessor Systems Design I
Microprocessor Systems Design I
Microprocessor Systems Design I
Microprocessor Systems Design I
Microprocessor T. Y. B. Sc..
Microprocessor Systems Design I
Micro-processor vs. Micro-controller
3.Instruction Set of 8085 Consists of 74 operation codes, e.g. MOV
Microprocessor Systems Design I
Microprocessor Systems Design I
Microprocessor Systems Design I
Microprocessor Systems Design I
Microprocessor Systems Design I
Microprocessor Systems Design I
PIC – ch. 2b Md. Atiqur Rahman Ahad.
PIC 16F877.
16.317: Microprocessor System Design I
Microprocessor Systems Design I
EECE.3170 Microprocessor Systems Design I
EECE.3170 Microprocessor Systems Design I
EECE.3170 Microprocessor Systems Design I
Morgan Kaufmann Publishers Computer Organization and Assembly Language
Symbolic Instruction and Addressing
EECE.3170 Microprocessor Systems Design I
EECE.3170 Microprocessor Systems Design I
Shift & Rotate Instructions)
EECE.3170 Microprocessor Systems Design I
EECE.3170 Microprocessor Systems Design I
EECE.3170 Microprocessor Systems Design I
EECE.3170 Microprocessor Systems Design I
INSTRUCTION SET.
EECE.3170 Microprocessor Systems Design I
EECE.3170 Microprocessor Systems Design I
EECE.3170 Microprocessor Systems Design I
EECE.3170 Microprocessor Systems Design I
EECE.3170 Microprocessor Systems Design I
EECE.3170 Microprocessor Systems Design I
EECE.3170 Microprocessor Systems Design I
EECE.3170 Microprocessor Systems Design I
EECE.3170 Microprocessor Systems Design I
EECE.3170 Microprocessor Systems Design I
EECE.3170 Microprocessor Systems Design I
EECE.3170 Microprocessor Systems Design I
Chapter 6 –Symbolic Instruction and Addressing
EECE.3170 Microprocessor Systems Design I
Presentation transcript:

EECE.3170 Microprocessor Systems Design I Instructor: Dr. Michael Geiger Fall 2016 Lecture 25: PIC assembly programming (continued)

Microprocessors I: Lecture 25 Lecture outline Announcements/reminders HW 7 to be posted; due date TBD No lecture Friday (Veterans Day) Review Common simple operations Today’s lecture Multi-byte data Sample programming sequences 4/16/2019 Microprocessors I: Lecture 25

Review: complex operations Multiple registers Data must be transferred through working register Conditional jumps Usually btfsc/btfss instruction + goto Equality/inequality—use subtract in place of CMP If you subtract X – Y: X > Y  Z = 0, C = 1 X == Y  Z = 1, C = 1 X < Y  Z = 0, C = 0 X <= Y  Z == C X != Y  Z = 0 X >= Y  C = 1 Shift/rotate Manipulate carry before operation (or appropriate bit after) Use loop for multi-bit shift/rotate 4/16/2019 Microprocessors I: Lecture 25

Microprocessors I: Lecture 25 Multi-byte data Logical operations can be done byte-by-byte Arithmetic and shift/rotate operations require you to account for data flow between bytes Carry/borrow in arithmetic Bit shifted between bytes in shift/rotate Order of these operations is important Arithmetic: must do least significant bytes first Shift/rotate: move through bytes in same order as shift  bits being shifted will move through carry Initial instruction should be appropriate operation (shift or rotate) All other instructions must be rotate operations 4/16/2019 Microprocessors I: Lecture 25

Microprocessors I: Lecture 25 4/16/2019 Working with 16-bit data Assume a 16-bit counter, the upper byte of the counter is called COUNTH and the lower byte is called COUNTL. Decrement a 16-bit counter movf COUNTL, F ; Set Z if lower byte == 0 btfsc STATUS, Z decf COUNTH, F ; if so, decrement COUNTH decf COUNTL, F ; in either case decrement COUNTL Test a 16-bit variable for zero btfsc STATUS, Z ; If not, then done testing movf COUNTH, F ; Set Z if upper byte == 0 btfsc STATUS, Z ; if not, then done goto BothZero ; branch if 16-bit variable == 0 CarryOn 4/16/2019 Microprocessors I: Lecture 25 Chapter 9

Microprocessors I: Lecture 25 Examples Translate these x86 operations to PIC code Assume that there are registers defined for each x86 register (e.g. AL, AH, BL, BH, etc.) 16-bit values (e.g., AX) must be dealt with as individual bytes MOVZX AX, BL MOVSX AX, BL INC AX SUB BX, AX RCL AX, 5 4/16/2019 Microprocessors I: Lecture 25

Microprocessors I: Lecture 25 Example solutions MOVZX AX, BL movf BL, W ; Copy BL to W movwf AL ; Copy W to AL clrf AH ; Clear upper byte MOVSX AX, BL btfsc AL, 7 ; Test sign bit decf AH, F ; If sign bit = 1, set ; AH = 00 - 1 = 0xFF 4/16/2019 Microprocessors I: Lecture 25

Microprocessors I: Lecture 25 Example solutions INC AX incf AL, F ; Increment low byte btfsc STATUS, Z ; Check zero bit incf AH, F ; If Z == 1, increment ; high byte SUB BX, AX movf AL, W ; Copy AL to W subwf BL, F ; BL = BL – AL movf AH, W ; Copy AH to W subwfb BH, F ; BH = BH - AH 4/16/2019 Microprocessors I: Lecture 25

Microprocessors I: Lecture 25 Example solutions RCL AX, 5 movlw 5 ; W = 5 movwf COUNT ; COUNT = W = 5 ; Assumes register ; COUNT is defined L: rlf AL, F ; Rotate low byte ; Bit transferred from ; low to high byte is ; now in carry rlf AH, F ; Rotate high byte decfsz COUNT, F ; Decrement & test COUNT goto L ; Return to start of loop if ; COUNT != 0 4/16/2019 Microprocessors I: Lecture 25

Microprocessors I: Lecture 25 4/16/2019 A Delay Subroutine ; *********************************************************************************** ; TenMs subroutine and its call inserts a delay of exactly ten milliseconds ; into the execution of code. ; It assumes a 4 MHz crystal clock. One instruction cycle = 4 * Tosc. ; TenMsH equ 13 ; Initial value of TenMs Subroutine's counter ; TenMsL equ 250 ; COUNTH and COUNTL are two variables TenMs nop ; one cycle movlw TenMsH ; Initialize COUNT movwf COUNTH movlw TenMsL movwf COUNTL Ten_1 decfsz COUNTL,F ; Inner loop goto Ten_1 decfsz COUNTH,F ; Outer loop goto Ten_1 return 4/16/2019 Microprocessors I: Lecture 25 Chapter 9

Microprocessors I: Lecture 25 Blinking LED example Assume three LEDs (Green, Yellow, Red) are attached to Port D bit 0, 1 and 2. Write a program for the PIC16F874 that toggles the three LEDs every half second in sequence: green, yellow, red, green, …. For this example, assume that the system clock is 4MHz. 4/16/2019 Microprocessors I: Lecture 25

Microprocessors I: Lecture 25 Top Level Flowchart Initialize: Initialize port D, initialize the counter for 500ms. Blink: Toggle the LED in sequence, green, yellow, red, green, …. Which LED to be toggled is determined by the previous state. Wait for 500ms: Keep the LED on for 500ms and then toggle the next one. 4/16/2019 Microprocessors I: Lecture 25

Microprocessors I: Lecture 25 Strategy to “Blink” The LEDs are toggled in sequence - green, yellow, red, green, yellow, red… Let’s look at the lower three bits of PORTD 001=green, 010=yellow, 100=red The next LED to be toggled is determined by the current LED. 001->010->100->001->… 4/16/2019 Microprocessors I: Lecture 25

Microprocessors I: Lecture 25 “Blink” Subroutine Blink btfsc PORTD, 0 ; is it Green? goto toggle1 ; yes, goto toggle1 btfsc PORTD, 1 ; else is it Yellow? goto toggle2 ; yes, goto toggle2 ;toggle0 bcf PORTD, 2 ; otherwise, must be red, change to green bsf PORTD, 0 ; 100->001 return toggle1 bcf PORTD, 0 ; change from green to yellow bsf PORTD, 1 ; 001->010 toggle2 bcf PORTD, 1 ; change from yellow to red bsf PORTD, 2 ; 010->100 4/16/2019 Microprocessors I: Lecture 25

Another way to code “Blink” ---- Table Use movf PORTD, W ; Copy present state of LEDs into W andlw B'00000111' ; and keep only LED bits addwf PCL,F ; Change PC with PCLATH and offset in W retlw B'00000001' ; (000 -> 001) reinitialize to green retlw B'00000011' ; (001 -> 010) green to yellow retlw B'00000110' ; (010 -> 100) yellow to red retlw B'00000010' ; (011 -> 001) reinitialize to green retlw B'00000101' ; (100 -> 001) red to green retlw B'00000100' ; (101 -> 001) reinitialize to green retlw B'00000111' ; (110 -> 001) reinitialize to green retlw B'00000110' ; (111 -> 001) reinitialize to green In calling program call BlinkTable ; get bits to change into W xorwf PORTD, F ; toggle them into PORTD 4/16/2019 Microprocessors I: Lecture 25

Microprocessors I: Lecture 25 Final notes Next time: More on PIC assembly programming Reminders HW 7 to be posted; due date TBD No lecture Friday (Veterans Day) 4/16/2019 Microprocessors I: Lecture 25