George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 ME 4447/6405 Microprocessor Control of Manufacturing Systems and Introduction.

Slides:



Advertisements
Similar presentations
More fun with Timer/Counters
Advertisements

4-1 Timers Timers can be used for  timing  event counting  pulse width measurement  pulse generation  frequency multiplication There are 8 Timers.
Programmable Interval Timer
Programmable Keyboard/ Display Interface: 8279
8051 Core Specification.
10-1 EE 319K Introduction to Microcontrollers Lecture 10: Interrupts, Output Compare Periodic Interrupts Read Book Sections 9.1, 9.2, 9.4, 9.6.1, 9.6.2,
EET 2261 Unit 10 Enhanced Capture Timer  Read Almy, Chapter 20.  Homework #10 and Lab #10 due next week.  Quiz next week.
68HC11 Polling and Interrupts
Timers Chapter 10 9S12DP256. Timers The 9S12DP256 Programmable Timer Output Compares Pulse Train Using Interrupts Input Capture Measuring the Period of.
Timers and Interrupts Shivendu Bhushan Summer Camp ‘13.
Timers ME4447 INTRODUCTION TO MECHATRONICS Anthony Wingo Carlos Alzate Jim Kitchen.
Lecture 9 Timer Operations and Programming. 2  Introduction  Summary of timers  Timer programming sequence  Summary of timer SFRs  Timer 0: 8-bit.
Range Measurement Unit Messenger Mercury Laser Altimeter Basic Familiarization.
1 Timing System Timing System Applications. 2 Timing System components Counting mechanisms Input capture mechanisms Output capture mechanisms.
ENG3640 Microcomputer Interfacing Week #6 Timing Generation and Measurement.
ECE 371- Unit 11 Timers and Counters (“Stop Watches and Alarm Clocks”)
7/23 Timers in Coldfire Processor Computer Science & Engineering Department Arizona State University Tempe, AZ Dr. Yann-Hang Lee (480)
8253 TIMER. Engr 4862 Microprocessors 8253 / 8254 Timer A.k.a. PIT (programmable Interval Timer), used to bring down the frequency to the desired level.
HCS12 Technical Training Module 8 –Enhanced Timer, Slide 1 MOTOROLA and the Stylized M Logo are registered in the US Patent & Trademark Office. All other.
ARM Timers.
System Clocks.
Timers ELEC 330 Digital Systems Engineering Dr. Ron Hayne
Chapter 4 TIMER OPERATION
Unit 10.2 Timer Examples. Example – Music Generation Channel 6 – Set up as a timer Output to Generate Square Waves Channel 4 – Set up as a timer Output.
Revised: Aug 1, ECE 263 Embedded System Design Lessons 23, 24 - Exceptions - Resets and Interrupts.
ECE 447: Lecture 8 Timer System (1). ECE 447: 68HC11 Timer System 1.Generating delays - imposing a specific delay between two points in the program by.
Microprocessors 1 MCS-51 Interrupts.
Chapter 11: Timer Subsystem Esteban Rodriguez-Marek Eastern Washington University Department of Engineering & Design.
ELE22MIC Lecture 15 Applications of Parallel Input Output (I/O)
George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 ME 4447/6405 Microprocessor Control of Manufacturing Systems and Introduction.
George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 ME 4447/6405 Microprocessor Control of Manufacturing Systems and Introduction.
1 68HC11 Timer Chapter HC11 Timer Subsystem Several timing functions: Basic timing Basic timing Real time interrupts Real time interrupts Output.
Lecture 12 Multi-Function Timer Pulse Unit 2 (MTU2a)
George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 ME 4447/6405 Microprocessor Control of Manufacturing Systems and Introduction.
George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 ME 4447/6405 Microprocessor Control of Manufacturing Systems and Introduction.
1 68HC11 Timer HC11 or HC12: Chapter HC11 Timer Subsystem  Several timing functions: Basic timing Basic timing Real time interrupts Real time.
Interrupts  An interrupt is any service request that causes the CPU to stop its current execution stream and to execute an instruction stream that services.
Embedded Systems Design 1 Lecture Set 8 MCS-51 Interrupts.
Lecture 4 General-Purpose Input/Output NCHUEE 720A Lab Prof. Jichiang Tsai.
#1 of 10 Tutorial Introduction PURPOSE -To explain how to configure and use the Timer Interface Module in common applications OBJECTIVES: -Identify the.
George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 ME 4447/6405 Microprocessor Control of Manufacturing Systems and Introduction.
1 68HC11 Timer. 2 68HC11 Timer Subsystem Several timing functions: Basic timing Basic timing Real time interrupts Real time interrupts Output compare.
Timers Presented by: Griffin Reid Rohit Vardhan Freddie Wilson Date: October 25, 2005.
George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 ME 4447/6405 Microprocessor Control of Manufacturing Systems and Introduction.
George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 ME 4447/6405 Microprocessor Control of Manufacturing Systems and Introduction.
ELE22MIC Lecture 17 Writing 68HC11 software 68HC11 Main Timer System –Output Compare –What is different about TOC1?
George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 ME 4447/6405 Microprocessor Control of Manufacturing Systems and Introduction.
EET 2261 Unit 13 Enhanced Capture Timer
Why are Timer Functions Important?
ELE22MIC Lecture 18 Writing 68HC11 software 68HC11 Main Timer System
ECE 3430 – Intro to Microcomputer Systems
Timer and Interrupts.
ELE22MIC Lecture 18 Writing 68HC11 software 68HC11 Main Timer System
Programmable Interval Timer
Programmable Interval Timer
AVR Addressing Modes Subject: Microcontoller & Interfacing
BVM Engineering College Electrical Engineering Department : Microprocessor and Microcontroller Interfacing Interrupts of 8051 Prepared by:
RX 8-Bit Timer (TMR) 4/20/2011 Rev. 1.00
An Introduction to Microprocessor Architecture using intel 8085 as a classic processor
Programmable Interval timer 8253 / 8254
Programmable Interval timer 8253 / 8254
Lecture 12 Multi-Function Timer Pulse Unit 2 (MTU2a)
ME 4447/6405 Microprocessor Control of Manufacturing Systems and
8253 – PROGRAMMABLE INTERVAL TIMER (PIT). What is a Timer? Timer is a specialized type of device that is used to measure timing intervals. Timers can.
ME 4447/6405 Microprocessor Control of Manufacturing Systems and
MCO556 Timer System Exercise.
ME 4447/6405 Microprocessor Control of Manufacturing Systems and
ME 4447/6405 Microprocessor Control of Manufacturing Systems and
Presentation transcript:

George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 ME 4447/6405 Microprocessor Control of Manufacturing Systems and Introduction to Mechatronics Instructor: Professor Charles Ume Timers

George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 Lecture Outline The Timer Sub-system Includes these Distinct Features: 16-bit Counter Seven-Stage Programmable Prescaling Eight Input Capture Channels Eight Output Compare Channels 16-bit Pulse Accumulator

George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405

ME4447/6405 Look at Page 31 in Reference Manual for Actual Register Addresses Central element of timer:16-bit free running counter –At reset counter is disabled –Once enabled, counter starts from $0000 and counts up continuously –When $FFFF is reached, counter rolls over to $0000 –Cannot be written to during operation (only writable in test mode) –May be reset upon successful Output Compare 7 General Description of Main Timer Bit 15 - Bit 8 Bit 7Bit 0 TCNT $0045 $

George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 Enabling the Free-Running Counter Timer Enable (TEN) bit determines operation of the timer and counter Writing a 1 to TEN turns on the counter, writing a 0 disables the system, reducing power consumption TEN TSWAI0 TSCR1$0046 TSFRZ TFFCA

George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 Counter Prescaler Allows 8 clocking rates of the timer counter –E-Clock rate divided by: 1, 2, 4, 8, 16, 32, 64, 128 At reset the default prescale factor is 1 Prescale may be changed at any time –Will take effect after some number of clock cycles where all prescale counter stages equal zero. (see p. 450 of Family Reference Manual for details)

George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 Changing the Counter Prescaler Note: Clock frequency is 8 MHz Trade-off between timer resolution and timer range TOI0 PR0 TSCR2 $004D 0 0TCRE PR2PR Prescale Factor Resolution (one count) Range (Overflow) PR2PR1PR ns 250 ns 500 ns 1  s 2  s 4  s 8  s 16  s ms ms ms ms ms ms ms s

George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 Counter Overflows Timer overflow flag (TOF) status bit set each time the counter rolls over from $FFFF to $0000 TOF status bit can generate an automatic interrupt request by setting the timer overflow interrupt (TOI) enable bit TOF 00 TFLG2$004F TOI 0PR0 TSCR2$004D 0 0TCREPR2PR

George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 Interrupt Vector Table MON12 in use Standard S12C32 Interrupt Vector Jump Table is not available with MON12 MON12 supplies alternate Interrupt Jump Table User’s interrupt service routine must be stored in $4000-$7FFF (External RAM) if Autostart is to be used Monitor Interrupt Vector Table (CML- C32 User’s Guide)

George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 Measuring Long Periods Using Counter Overflow Extending the range of the 16-bit counter with an 8-bit software counter –Software keeps track of counter overflows –Creates a 24-bit counter (16-bit + 8-bit) –Time values are stored as 3-byte numbers

George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 Input Capture Vs. Output Compare Each of the eight I/O pins of Port T may be used as either an input capture or an output compare If IOSX is 0, the corresponding channel acts as an input capture If IOSX is 1, the corresponding channel acts as an output compare

George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 Input Capture Concept Used to record time event occurs When input signal is received by input capture channel –Contents of free-running counter is transferred to 16-bit register corresponding to that input capture channel

George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 Features of Input Capture Function 16-bit registers Input edge-detection logic Interrupt generation logic

George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 Input Capture Registers Eight 16-bit input capture registers are available –Each register has a corresponding timer input pin (TC0- TC7) located on Port T pins PT0-PT7 When edge is detected at timer input pin, current value of free-running counter is stored in corresponding input capture register

George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 Input Capture Registers (cont’d) Can be read at any time as a pair of 8-bit registers using instructions like LDD or LDX Writing to register when used as Input Capture has no meaning Bit 15 - Bit 8 Bit 7Bit 0 TC0 $0051 $0050 Bit 15Bit 8 Bit 7Bit 0 TC7 $005F $005E …

George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 Input Edge-Detection Logic Used to select which edge of input signal is detected Configuration EDGxBEDGxA Capture Disabled00 Capture on Rising Edge Only01 Capture on Falling Edge Only10 Capture on Any Edge11 EDG0A TCTL4$004B EDG0BEDG1AEDG1BEDG2AEDG2BEDG3AEDG3BEDG4A TCTL3$004A EDG4BEDG5AEDG5BEDG6AEDG6BEDG7AEDG7B

George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 Interrupt Generation Logic Input capture status flags are automatically set to one each time a selected edge is detected Input capture interrupt enable bits If CXI is 1when CXF is set, interrupt condition is met C7FC6F C0F TFLG1$004E C5FC4FC3F C2FC1F C7IC6I C0I TIE$004C C5IC4IC3I C2IC1I

George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 Application of Input Captures Period or frequency measurement – Capture the time of two successive rising or falling edges Pulse width measurement –Capture the time between two adjacent edges

George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 Period Measurement Example Code FIRSTEQU $2000DEFINE A 2-BYTE LOCATION TO STORE FIRST EDGE PERIODEQU $2002 DEFINE A 2-BYTE LOCATION TO STORE PERIOD ORG $1000 LDAA#$80 STAA$0046ENABLES FREE RUNNING COUNTER LDAA#$00ENSURES PT1 IS USED AS AN INPUT CAPTURE STAA$0040NOTE: THIS IS THE CASE BY DEFAULT LDAA #$04ie Input Capture 1 is being used STAA $004BEDGE DETECTION FOR IC1 SET TO RISING EDGES LDAA #$02 STAA $004ECLEARS ANY OLD FLAGS FROM IC1F LOOP1BRCLR$4E #$02LOOP1LOOP HERE UNTIL FIRST RISING EDGE IS DETECTED LDD $0052READ TIME OF FIRST CAPTURE STD FIRSTSTORE FIRST CAPTURE VALUE LDAA #$02 STAA $004ECLEAR THE IC1F FLAG BEFORE NEXT EDGE LOOP2BRCLR $4E #$02LOOP2LOOP HERE UNTIL NEXT RISING EDGE IS DETECTED LDD $0052READ TIME OF SECOND CAPTURE SUBD FIRSTFIND THE TIME DIFFERENCE BEWTEEN EDGES STD PERIODSTORE THE RESULT AS THE PERIOD (cycles) :

George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 Application of Input Captures (cont’) Can be used as time reference for output function. –Input capture records event time –Offset representing time delay is added to input capture and stored to output compare. Both input captures and output compares are referenced from same counter, so software latencies do not affect accuracy to time delay

George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 Other Uses of Input Capture Pins Can be used as general purpose I/O pins when the timer functions are not needed Logic levels can be read even if input-capture function is enabled Can serve as flexible interrupt input pins –Have some advantages over IRQ pin

George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 Output Compare: Basic Concept 8 Output Compare Registers to store numbers:  Each is 16-Bit Register 8 comparators-one for each channel Comparator checks Number against Free Running Counter (TCNT Register) This is done in hardware, no processor time used When Counter matches TCx Register, it triggers an event

George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 What “Event” is triggered? Three Non-Exclusive Possibilities: Changes output of:  One of port T pins if either of registers corresponding to Output Compare 0 to 6 successfully compares to TCNT register  One/several of Port T pins if Output Compare 7 register successfully compares to TCNT register Set a Flag in TFLG Register Cause an Interrupt

George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 Output Compare causes Port T Pins to change state (Part I) Output Compares 0 to 6: Each Output compare controls a SINGLE PIN: Output Compare 0PT0 Output Compare 1PT1 Output Compare 2PT2 Output Compare 3PT3 Output Compare 4PT4 Output Compare 5PT5 Output Compare 6PT6

George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 Output Compare causes Port T Pins to change state (Part II) Output Compares 0 to 6: TCTL1 ($0048) and TCTL2 ($0049) Registers Control How Each Pin Changes TCTL1 $1020

George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 Output Compare causes Port T Pins to change state (Part II)

George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 Output Compare causes Port T Pins to change state (Part III) Output Compare 7: Causes 8 Port T pins to change simultaneously Notice PT0-PT6 are also used by Output Compares 0-6 Successful channel 7 compare overrides any channel 0:6 compares OC7M7OC7M6OC7M5OC7M4OC7M3OC7M2OC7M1OC7M0 Output Compare 7 Mask Register (OC7M) determines which Port T Pins will be Controlled by Successful Output Compare 7 PA7PA6PA5PA4PA3 OC7M $0042 OC7D $0043 OC7D7OC7D6OC7D5OC7D4OC7D3OC7D2OC7D1OC7D0 PA2PA1 PA0 OC7D Register sets value to be written to Port T pins selected in OC7M Rgister

George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 Output Compare Causes Flag to Be Set (Part I) When Output Compare is successful it sets corresponding Flag in TFLG1 Control Register: Software must constantly poll TFG1 register to check for flags C7FC6F C0F TFLG1$004E C5FC4FC3F C2FC1F

George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 Output Compare Causes Flag to be Set part (II) Use LDAA, STAA commands to write 1 to Flag But DON’T USE BSET!!!! You Must clear the Flag after it is set You clear the Flag by writing a 1 to the corresponding Bit in TFLG !

George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 Output Compare Causes a Interrupt Successful Output compare will cause an interrupt when corresponding bit in TIE is set: C7IC6I C0I TIE$004C C5IC4IC3I C2IC1I

George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 Measuring Long Intervals: Problems with Overflow Bit You must measure this length of time t time This is where timer rolls over (overflow) t Record Start Time Record End Time t = [T END -T START ]+(# of overflows)*(T overflow ) But I only have this much time to record last overflow …then I need to record the end time!

George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 Forced Output If you need to change state of Port T Pin BEFORE output compare occurs Use Forced Output  Software triggers compare to occur  Pin T will change state accordingly. For Forced Compare, Flag is not set. Forced Compare takes precedence over regular compare if both occur at same time in same channel  No Flag will be set. FOC7FOC6FOC5FOC4FOC3 FOC2 FOC1FOC0 CFORC $0041

George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 Pulse Accumulator Overview Features: 16-bit Counter Incremented by:  Edge on pin  Logic level of pin Used to measure:  Duration of pulse  Number of events

George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 Key Things to Know Can be read or written to at any time 2 Modes –Event Counter –Gated Time Accumulation Pulse Accumulator Input Pin: Port T Pin 7 Registers

George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 Pulse Accumulator Registers PACNT $0062 & $0063 –16 Bit PA Count PACTL $0060 PAFLG $0061 B15 B8 B7 B0

George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405

ME4447/6405 Register Settings PAEN: 0 = Disabled, 1 = Enabled PAMOD: 0 = Event Counter, 1 = Gated Time PEDGE:  Event Counter:  0 : Falling Edges,  1 : Rising Edges  Gated Time:  0 : IOC7 input pin high enables bus clock divided by 64 clock to pulse Accumulator, and trailing falling edge on IOC7 sets PAIF flag  1: IOC7 input pin low enables bus clock divided by 64 clock to pulse Accumulator, and trailing rising edge on IOC7 sets PAIF flag

George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 Register Settings CLK[0:1]: Timer Clock Selection (See page 454 Reference Manual) PAOVF: 0 = No Overflow, 1 = Overflow PAOVI: 0 = Polling, 1 = Interrupt-Driven PAIF: 0 = No Trailing Falling Edge Detected, 1 = Trailing Rising Edge Detected PAIF: 0 = No Trailing Rising Edge Detected, 1 = Trailing Falling Edge Detected PAI: 0 = Polling, 1 = Interrupt-Driven

George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405

ME4447/6405

ME4447/6405 Event Counting Mode PAMOD = 0 Counts Active Edge of PAI pin Example: (PACNT = 0; PAEN = 1; PEDGE = 1) PT7/ IOC7 16-BIT COUNTER PACNT PAI 1234 PACNT Value

George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 Event Counting Example A light emitter/detector pair can be used in an assembly line to count the number of parts going by.

George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 Gated Time Accumulation Mode PAMOD = 1 Free-running bus clock divided by 64 Subject to PT7/IOC7 pin being active PT7/ IOC7 Clock 16-BIT COUNTER PACNT bus/64 CLOCK (from Main Timer) AND

George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 Gated Time Example PACNT = 0; PAEN = 1; PEDGE = 1 (inhibit counting when PT7/IOC7 is 1) PT7 is set to PACNT Value bus/64 65

George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 Pulse Width Measurement  Common use of Gated mode Measure duration of single pulses  Easier than with Input Capture  Counter is zero before pulse starts  After pulse, pulse time directly read (need starting and ending count for input capture)

George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 Example: Interrupt at Specified Time  Gated Time Accumulation (PAMOD = 1) –Set Pulse Accumulator to cause interrupt to occur after 5ms Steps:  Calculate time for one bus/64 cycle  Divide delay by time for one bus/64 cycle  Take 2’s complement and store in PACNT  When input goes to active level, counter will increment until overflow

George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 Assembly Code: Initialization to Count Negative (falling) Edges LDAA#$01 STAAPAFLG ; Clear PAIF by writing 1 to it LDAA#$41 ; PAEN = 1, PAMOD = 0, PEDGE = 0, PAI = 1 STAAPACTL

George W. Woodruff School of Mechanical Engineering, Georgia Tech ME4447/6405 Questions???