Independent timers build into the processor Basis for Lab. 2

Slides:



Advertisements
Similar presentations
A look at interrupts What are interrupts and why are they needed.
Advertisements

Microprocessor or Microcontroller Not just a case of “you say tomarto and I say tomayto” M. Smith, ECE University of Calgary, Canada.
Embedded System Timers Details of independent timers build into the Blackfin Assignment 2-- Watchdog Timer can be used to prevent the OS system from locking.
Daddy! -- Where do instructions come from? Program Sequencer controls program flow and provides the next instruction to be executed Straight line code,
6/2/2015 Labs in ENCM415. Laboratory 2 PF control, Copyright M. Smith, ECE, University of Calgary, Canada 1 Temperature Sensor Laboratory 2 Part 2 – Developing.
Thermal arm-wrestling Design of a video game using two programmable flags (PF) interrupts Tutorial on handling 2 Hardware interrupts from an external device.
Building a simple loop using Blackfin assembly code M. Smith, Electrical and Computer Engineering, University of Calgary, Canada.
Developing a bicycle speed-o-meter Part 2 A comparison between the Analog Devices ADSP-BF533 (Blackfin) and Motorola MC68332.
Lab. 2 – More details – Tasks 4 to 6 1. What concepts are you expected to understand after the Lab. 2 is finished? 2. How do you demonstrate that you have.
Microprocessor or Microcontroller Not just a case of “you say tomarto and I say tomayto” M. Smith, ECE University of Calgary, Canada.
A Play Core Timer Interrupts Acted by the Human Microcontroller Ensemble from ENCM415.
Core Timer Code Development How you could have done the Take- Home Quiz using a test driven development (TDD) approach.
A look at interrupts What are interrupts and why are they needed in an embedded system? Equally as important – how are these ideas handled on the Blackfin.
Developing a bicycle speed-o-meter A comparison between the Analog Devices ADSP-BF533 (Blackfin) and Motorola MC68332.
Timers and Timing Signals Tutorial. 6/18/2015 Timer Control Copyright M. Smith, ECE, University of Calgary, Canada 2 / 31 Temperature Sensor -- Lab 3.
Understanding the Blackfin ADSP-BF5XX Assembly Code Format
A look at interrupts What are interrupts and why are they needed.
Microprocessor or Microcontroller Not just a case of “you say tomarto and I say tomayto” M. Smith, ECE University of Calgary, Canada.
Laboratory 1 – ENCM415 Familiarization with the Analog Devices’ VisualDSP++ Integrated Development Environment.
Microprocessor or Microcontroller Not just a case of “you say tomarto and I say tomayto” M. Smith, ECE University of Calgary, Canada.
Tutorial Essentially all the Blackfin instruction you need for all of ENCM511. The instructions are easy. Its knowing when to use them that is the difficult.
Developing a bicycle speed-o-meter Midterm Review.
Blackfin Timers Independent timers build into the processor Watchdog Timer is a major part of Lab. 2 (Code provided to you to use)
M. Smith University of Calgary.  Many people like to sing in the shower.  However, its rather boring as there is no accompaniment.  The McVASH device.
A Play Core Timer Interrupts Acted by the Human Microcontroller Ensemble from ENCM511.
Lab. 2 Overview Move the tasks you developed in Lab. 1 into the more controllable TTCOS operating system Manual control of RC car.
Moving Arrays -- 1 Completion of ideas needed for a general and complete program Final concepts needed for Final Review for Final – Loop efficiency.
Handling multiple input signals Version #2 – co-operative scheduler Version #3 – pre-emptive scheduler.
Building a simple loop using Blackfin assembly code If you can handle the while-loop correctly in assembly code on any processor, then most of the other.
Lab. 1 – GPIO Pin control Using information ENEL353 and ENCM369 text books combined with Blackfin DATA manual.
A Play Core Timer Interrupts Acted by the Human Microcontroller Ensemble from ENCM415.
“Lab. 5” – Updating Lab. 3 to use DMA Test we understand DMA by using some simple memory to memory DMA Make life more interesting, since hardware is involved,
Developing a bicycle speed-o-meter
Moving Arrays -- 1 Completion of ideas needed for a general and complete program Final concepts needed for Final Review for Final – Loop efficiency.
Lab. 2 Overview – Earlier Tasks Prelaboratory T1, T3, T4 and T5
A Play Core Timer Interrupts
SPI Compatible Devices
Thermal arm-wrestling
DMA example Video image manipulation
The planned and expected
Handling Arrays Completion of ideas needed for a general and complete program Final concepts needed for Final.
Lab. 2 – More details – Later tasks
Moving Arrays -- 1 Completion of ideas needed for a general and complete program Final concepts needed for Final Review for Final – Loop efficiency.
Moving Arrays -- 2 Completion of ideas needed for a general and complete program Final concepts needed for Final DMA.
Thermal arm-wrestling
Using Arrays Completion of ideas needed for a general and complete program Final concepts needed for Final.
A Play Lab. 2 Task 8 Core Timer Interrupts
General purpose timers
Moving Arrays -- 2 Completion of ideas needed for a general and complete program Final concepts needed for Final DMA.
Handling Arrays Completion of ideas needed for a general and complete program Final concepts needed for Final.
Tutorial Essentially all the Blackfin instruction you need for all of ENCM511. The instructions are easy. Its knowing when to use them that is the difficult.
General purpose timers
Thermal arm-wrestling
Concept of TDD Test Driven Development
Blackfin Timers Independent timers build into the Blackfin
Lab. 1 – GPIO Pin control Using information ENEL353 and ENCM369 text books combined with Blackfin DATA manual.
Handling Arrays Completion of ideas needed for a general and complete program Final concepts needed for Final.
DMA example Video image manipulation
Developing a bicycle speed-o-meter
Blackfin Timers Independent timers build into the processor
Independent timers build into the processor
Developing a bicycle speed-o-meter
Lab. 2 Overview Move the tasks you developed in Lab. 1 into the more controllable TTCOS operating system.
Developing a bicycle speed-o-meter
Thermal arm-wrestling
Building a simple loop using Blackfin assembly code
Developing a bicycle speed-o-meter Part 2
Post Lab Quiz 3 Review Assignment 2 Help
Blackfin Syntax Stores, Jumps, Calls and Conditional Jumps
Presentation transcript:

Independent timers build into the processor Basis for Lab. 2 Blackfin Timers Independent timers build into the processor Basis for Lab. 2

Timers available on Blackfin Watchdog timer – Hardware Reference 15-49 Core timer – Hardware Reference 15-45 General purpose timers 15-1 Pulse Width Modulation Pulse Width Count and Capture External Event Application of timers to provide code safety and improved version of UseFixedTimeASM( ) Introduction to timer interrupts 2/24/2019 Timer Control Copyright M. Smith, ECE, University of Calgary, Canada

Basic concept – watchdog timer Your code on an embedded system that is running in the field Something goes unexpectedly wrong with your program, and one piece of code (a subroutine) keeps running, and running and running Other parts of the system self-destruct as there are no control signals send to them Fix this issue with “WatchDog Timer” 2/24/2019 Timer Control Copyright M. Smith, ECE, University of Calgary, Canada

WatchDogTimer Demonstrate (code provided) Lab 2 Task 1 int main( ) { SetUpWatchDogTimerASM( ); StartWatchDogTimerASM( ); ResetWatchDogTimerASM( ); for ( ; ; ) { // For-ever loop CriticalTask1( ); CriticalTask2( ); CriticalTask3( ); ResetWatchDogTimerASM( ); } } If any task hangs up (does NOT return in time to Reset the WatchDog Timer) then the system can be made to reboot, or send error message etc. HANGS UP – because an expected external signal does not arrive because of equipment failure (SW5 connection “broken” in Lab. 2 Task 1) 2/24/2019 Timer Control Copyright M. Smith, ECE, University of Calgary, Canada

Watchdog Timer Operation 2/24/2019 Timer Control Copyright M. Smith, ECE, University of Calgary, Canada

Timer Control Copyright M. Smith, ECE, University of Calgary, Canada Lab. 2 Tasks 1 and 2 details WHAT I WANTED TO DO WHAT I DID WHAT YOU WILL DO IN ASSEMBLY CODE (Task 2 is for Midterm Exam practice) 2/24/2019 Timer Control Copyright M. Smith, ECE, University of Calgary, Canada

Example code -- use same idea in Lab.2 Tasks for CORETIMER registers _SetUpWatchDogTimerASM__Fv: P0.H = hi(WDOG_CNT) P0.L = lo(WDOG_CNT) // Get the address into P0 // Put 0x08000000 into R1; R1.L = 0x0000; How long is 0x0800 0000 ticks? R1.H = 0x0800; [P0] = R1; // Watchdog Count Register and Watchdog Register 2/24/2019 Timer Control Copyright M. Smith, ECE, University of Calgary, Canada

Better Code (other code did not work as we had not read the manual) _SetUpWatchDogTimerASM__Fv: P0.H = hi(WDOG_CTL) P0.L = lo(WDOG_CTL) // Get the address into P0 // Put 0x0AD0 into R1.L; R1.L = 0x0AD0; W[P0] = R1; // Watchdog control register – disable SSYNC; // System synchronize – Count read/write ops. P0.H = hi(WDOG_CNT) P0.L = lo(WDOG_CNT) // Get the address into P0 // Put 0x08000000 into R1; R1.L = 0x0000; R1.H = 0x0800; [P0] = R1; // Watchdog Count Register and Watchdog Register 2/24/2019 Timer Control Copyright M. Smith, ECE, University of Calgary, Canada

Watchdog Status Register WDOG_STAT 2/24/2019 Timer Control Copyright M. Smith, ECE, University of Calgary, Canada

My actual working code for L2 Task 1 NOT 0x0AD6 but 0x8AD6 to clear bit 15 (W1C) NOTE: WDOG_CTL bit 15 is a W1C bit Write one to clear means Write one to make 0 2/24/2019 Timer Control Copyright M. Smith, ECE, University of Calgary, Canada

Starting the watchdog timer _StartWatchDogTimerASM__Fv: P0.H = hi(WDOG_CTL) P0.L = lo(WDOG_CTL) // Get the address into P0 // Put 0x0000 into R1.L; Will force a “RESET EVENT” R1.L = 0x0000; W[P0] = R1; // Watchdog control register – counter enabled ssync; 2/24/2019 Timer Control Copyright M. Smith, ECE, University of Calgary, Canada

My actual code with hints for Lab. 2 Task 2 Look in the Blackfin Hardware manual for correct settings For you to complete L2 T2 as practice for Midterm 2/24/2019 Timer Control Copyright M. Smith, ECE, University of Calgary, Canada

Lab 2 – Watchdog video game 2/24/2019 Timer Control Copyright M. Smith, ECE, University of Calgary, Canada

ResetWatchDogTimerASM( ); -- Needed for Lab. 2 Task 2 TAKE-HOME EXERCISE You write the required code – base on standard Blackfin Assembly language Stub _ResetWatchDogTimerASM: My version – 24 lines of assembly code. However, I re-read the manual – resetting the timer can be done in 4 lines of code excluding LINK / UNLINK code 2/24/2019 Timer Control Copyright M. Smith, ECE, University of Calgary, Canada

Temperature Sensor -- Lab 3 Q – how can you time “High” time? +5V GROUND SIGNAL TO BLACKFIN -- hook into PF8. Check using the same “when switch SW1 pressed, when released” code as in Lab. 1 ANALOG DEVICES TMP03 Temperature Sensor HIGH LOW 2/24/2019 Timer Control Copyright M. Smith, ECE, University of Calgary, Canada

C++ version of code Lab. 2 Task 3 (interval counter) Develop a routine UseUpFixedAmountTimeCPP( ) that uses up a fixed amount of time Count how many times this routine must be called from main( ) while the temperature signal is HIGH Could be constructed using “for-loop” construct void UseUpFixedAmoutTimeCPP(unsigned long int timeToUse) { unsigned short int counter = 0; for (int num = 0; num <= timeToUse; num ++) { counter = counter; // Waste time } // Spin the wheels on the processor QUESTIONS FOR POST LAB 1 QUIZ – This code may not work in VDSP RELEASE mode – why not, and how would you check if it is a problem (meaning what would you look for in the assembly code produced by C++ compiler), and how would you fix if it was a problem 2/24/2019 Timer Control Copyright M. Smith, ECE, University of Calgary, Canada

Counting amount of time thermal sensor signal is high while (1) { int countHigh = 0; // Why must this be inside and not outside the loop int countLo = 0; while (SW1 is high) /* do nothing */; while (SW1 is low) / * do nothing */; // Get to the START of the low-to-high transition while (SW1 is high) { // Relative time high UseUpTime( ); countHigh++; } while (SW1 is low) {// Relative time high countLo++; int temperature = CalculateTemperature(countHigh, countLow); DisplayTemperatureOnLEDs(temperature); 4 while loops needed – NOT 2 (key lab / exam concept) Uses same ASM files For reading PF flags as in Lab. 1 Uses WriteLEDASM( ) 2/24/2019 Timer Control Copyright M. Smith, ECE, University of Calgary, Canada

Improved “more accurate” Timer to provide “more accurate” Temperatures void UseUpFixedAmountTime(unsigned long int timeToUse) { Load the core timer counter register with parameter “time_to_use” Start the core timer – which causes the core-timer register to count down to zero While the core timer counter register ! = 0 continue counter When the core timer count register equals 0 -- Return } Core timer changes at 500 MHz – so can get very accurate timing values 2/24/2019 Timer Control Copyright M. Smith, ECE, University of Calgary, Canada

Timer Control Copyright M. Smith, ECE, University of Calgary, Canada Core Timer You set Core timer register TSCALE to 0 (decrement by 0 + 1) You set register TPERIOD to 0x2000 You set register TCOUNT to 0x4000 You enable timer using control register TCNTL TCOUNT is decreased by 1 until it reaches 0 (0x4000 system clock ticks) When TCOUNT reaches 1, interrupt is caused and TCOUNT is reloaded with TPERIOD (0x2000) – counts down again 2/24/2019 Timer Control Copyright M. Smith, ECE, University of Calgary, Canada

TCOUNT and TPERIOD registers 2/24/2019 Timer Control Copyright M. Smith, ECE, University of Calgary, Canada

TSCALE and TCNTL registers 2/24/2019 Timer Control Copyright M. Smith, ECE, University of Calgary, Canada

Timer Control Copyright M. Smith, ECE, University of Calgary, Canada Two new instructions The INTERRUPT mask contains information (bits set or clear) about which devices are allowed to interrupt the processor CLI Rx Save a copy of the “INTERRUPT” mask into data register Rx and then clear the mask (block all interrupts) STI Rx Copy the bit pattern from data register Rx into the “INTERRUPT” mask, effectively reactivating all the devices that were allowed to interrupt the processor 2/24/2019 Timer Control Copyright M. Smith, ECE, University of Calgary, Canada

Timer Control Copyright M. Smith, ECE, University of Calgary, Canada Lab. 2 Task 7 and 8 Place a bookmark on these slides Need to build code to initialize CORE TIMER, and then activate an interrupt Code needed is very similar to parts of the code for the non-interrupt driven function void UseUpFixedAmoutTimeASM (unsigned long int timeToUse) 2/24/2019 Timer Control Copyright M. Smith, ECE, University of Calgary, Canada

void UseUpFixedAmoutTimeASM (unsigned long int timeToUse) - 1 Stop interrupts -- Why is this needed CLI R2; // Clear interrupts -- re-enable interrupts STI R2; Stop the timer by changing the bits in the timer control register P0.H = hi(TCNTL) P0.L = lo(TCNTL) // Get the address into P0 R1 = 0; [P0] = R1; SSYNC; Load the core timer counter register with parameter “time_to_use (R0)” P0.H = hi(TCOUNT) P0.L = lo(TCOUNT) // Get the address into P0 [P0] = R0; SSYNC; Start the core timer by changing the bits in the timer control register R1 = 3; 2/24/2019 Timer Control Copyright M. Smith, ECE, University of Calgary, Canada

void UseUpFixedAmoutTime (unsigned long int timeToUse) - 2 Stop interrupts Stop the timer Load the core timer counter register with parameter “time_to_use” Start the core timer P0.H = hi(TCNTL) P0.L = lo(TCNTL) // Get the address into P0 R1 = 3; // Bit pattern %0000 0000 0000 0011 [P0] = R1; SSYNC; While the core timer counter register ! = 0 continue P0.H = hi(TCOUNT) P0.L = lo(TCOUNT) // Get the address into P0 SSYNC // Necessary or not? TIMER_LOOP: R0 = [P0]; // Keep reading the timer counter CC = R0 == 0; // TIMER COUNTER IS VOLATILE IF !CC JUMP TIMER_LOOP DE-ACTIVATE TIMER REACTIVATE INTERRUPTS – Old values stored in R2 RETURN 2/24/2019 Timer Control Copyright M. Smith, ECE, University of Calgary, Canada

void UseUpFixedAmoutTime (unsigned long int timeToUse) - 3 While the core timer counter register ! = 0 continue P0.H = hi(TCOUNT) P0.L = lo(TCOUNT) // Get the address into P0 SSYNC // Necessary or not? TIMER_LOOP: R0 = [P0]; // Read the timer counter CC = R0 == 0; IF !CC JUMP TIMER_LOOP DE-ACTIVATE TIMER // You provide the required code REACTIVATE INTERRUPTS – Old values stored in R2 RETURN 2/24/2019 Timer Control Copyright M. Smith, ECE, University of Calgary, Canada

Problem -- CODE IS “WAITING” and uses up processor power uselessly While the core timer counter register ! = 0 continue P0.H = hi(TCOUNT) P0.L = lo(TCOUNT) // Get the address into P0 SSYNC // Necessary or not? TIMER_LOOP: R0 = [P0]; // Read the timer counter CC = R0 == 0; IF !CC JUMP TIMER_LOOP Here the processor is waiting, which means that the processor can’t be calculating other values (computer graphics) or servicing other requests Fixed by using interrupts to do the counting in the background Perhaps there are no other values to calculate. In that case we need to put the processor in a low power mode, and then wake it up Fixed with IDLE instruction and then wake-up enable register 2/24/2019 Timer Control Copyright M. Smith, ECE, University of Calgary, Canada

Concepts of interrupt code Task 1 – file 1 volatile int foo_flag = 8; int main( ) { SetUpTimerInterrupts(ISR_count); StartTimerInterrupts( ); while (foo_flag != 0) { WriteLEDASM(foo_flag); DoSomething Complicated( ); } StopTimerInterrupts(); Task 2 – file 2 (C++ or ASM) extern volatile int foo_flag; SPECIAL C++ CODE NEEDED TO Tell “C++” that I am not a function or subroutine that is called within the program. I am an ISR – interrupt service routine and proud of it. I can happen at any time because of an outside external signal ????declare??? ISR_count( ) { foo_flag--; Tell the timer that the interrupt has been serviced } 2/24/2019 Timer Control Copyright M. Smith, ECE, University of Calgary, Canada

How it is supposed to work First task 1 (main( ) ) – starts Sets up the timer so that it will cause an interrupt When this interrupt starts – task 1 will stop, task 2 will start start doing some processing – spend NO time looking at the timer NOTE – if the ISR – interrupt service routine – does not happen (because external hardware not working) then task 1 will never stop When Task 1 stops – turn off the interrupts 2/24/2019 Timer Control Copyright M. Smith, ECE, University of Calgary, Canada

Task 2 and Task 1 in this code (Not Lab. 2 Tasks 1 and 2) Task 1 and Task 2 communicate via the “volatile foo_flag” variable – “message” Every time the timer counts down to zero The TCOUNTER register is reloaded with TPERIOD register value The timer counts down again An interrupt is issued and latched 2/24/2019 Timer Control Copyright M. Smith, ECE, University of Calgary, Canada

Timer Control Copyright M. Smith, ECE, University of Calgary, Canada Unanswered questions What does “volatile” mean? Why will “optimized code” probably not work if volatile is not used? How do you tell C++ that this function is an ISR and not a standard function? Why do you need to tell C++ that this function is an ISR and not a standard function? What is the difference (in coding) between an ISR and a standard function? How does an interupt get latched, why and where? Why do I have to tell the timer that the interrupt has been serviced, and how do I do it? Task 2 – file 2 (C++ or ASM) extern volatile int foo_flag; Tell “C++” that I am not a function but I am an ISR – interrupt service routine ????declare as ISR??? ISR_count( ) { foo_flag--; Tell the timer that the interrupt has been serviced } 2/24/2019 Timer Control Copyright M. Smith, ECE, University of Calgary, Canada

Timer Control Copyright M. Smith, ECE, University of Calgary, Canada Tackled today Watchdog timer – Hardware Reference 15-49 Core timer – Hardware Reference 15-45 General purpose timers 15-1 Pulse Width Modulation Pulse Width Count and Capture External Event Application of timers to provide code safety and improved version of UseFixedAmountTimeASM( ) Introduction to timer interrupts 2/24/2019 Timer Control Copyright M. Smith, ECE, University of Calgary, Canada

Timer Control Copyright M. Smith, ECE, University of Calgary, Canada Information taken from Analog Devices On-line Manuals with permission http://www.analog.com/processors/resources/technicalLibrary/manuals/ Information furnished by Analog Devices is believed to be accurate and reliable. However, Analog Devices assumes no responsibility for its use or for any infringement of any patent other rights of any third party which may result from its use. No license is granted by implication or otherwise under any patent or patent right of Analog Devices. Copyright  Analog Devices, Inc. All rights reserved. 2/24/2019 Timer Control Copyright M. Smith, ECE, University of Calgary, Canada