Specialized Video (8-bit) and Vector (16-bit) Instructions on the Blackfin Expand on these ideas for Q9 question and answer on the final.

Slides:



Advertisements
Similar presentations
Microprocessors.
Advertisements

Processor Architecture Needed to handle FFT algoarithm M. Smith.
Jan 28, 2004Blackfin Compute Unit REV B A comparison of DSP Architectures BlackFin ADSP-BFXXX Compute Unit Based on a ENEL white paper prepared by.
Microprocessor or Microcontroller Not just a case of “you say tomarto and I say tomayto” M. Smith, ECE University of Calgary, Canada.
Blackfin BF533 EZ-KIT Control The O in I/O Activating a FLASH memory “output line” Part 2.
Boot Issues Processor comparison TigerSHARC multi-processor system Blackfin single-core.
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.
Specialized Video (8-bit) and Vector (16-bit) Instructions on the Blackfin There is always a “MAKE-UP-YOUR-QUESTION-AND-ANSWER-IT” Question on a Dr. Smith.
Developing a bicycle speed-o-meter Part 2 A comparison between the Analog Devices ADSP-BF533 (Blackfin) and Motorola MC68332.
Review of Blackfin Syntax Moves and Adds 1) What we already know and have to remember to apply 2) What we need to learn.
Software and Hardware Circular Buffer Operations First presented in ENCM There are 3 earlier lectures that are useful for midterm review. M. R.
Microprocessor or Microcontroller Not just a case of “you say tomarto and I say tomayto” M. Smith, ECE University of Calgary, Canada.
Core Timer Code Development How you could have done the Take- Home Quiz using a test driven development (TDD) approach.
LCD programming Design and implementation details on the way to a valid SPI-LCD interface driver.
1 Foundations of Software Design Lecture 3: How Computers Work Marti Hearst Fall 2002.
Developing a bicycle speed-o-meter A comparison between the Analog Devices ADSP-BF533 (Blackfin) and Motorola MC68332.
Understanding the Blackfin ADSP-BF5XX Assembly Code Format
Microprocessor or Microcontroller Not just a case of “you say tomarto and I say tomayto” M. Smith, ECE University of Calgary, Canada.
Getting the O in I/O to work on a typical microcontroller Ideas of how to send output signals to the radio controlled car. The theory behind the LED controller.
Laboratory 1 – ENCM415 Familiarization with the Analog Devices’ VisualDSP++ Integrated Development Environment.
Blackfin BF533 EZ-KIT Control The O in I/O Activating a FLASH memory “output line” Part 2.
Getting the O in I/O to work on a typical microcontroller Activating a FLASH memory “output line” Part 1 Main part of Laboratory 1 Also needed for “voice.
Jan 28, 2004Blackfin Compute Unit REV B ENEL DSP Architectures BlackFin Compute Unit.
Blackfin BF533 EZ-KIT Control The O in I/O
Microprocessor or Microcontroller Not just a case of “you say tomarto and I say tomayto” M. Smith, ECE University of Calgary, Canada.
Developing a bicycle speed-o-meter Midterm Review.
The 8051 Microcontroller and Embedded Systems
Processor Architecture Needed to handle FFT algoarithm M. Smith.
Introduction to Chapter 6  Digital circuits are frequently used for arithmetic operations  Fundamental arithmetic operations on binary numbers and digital.
Binary Arithmetic In today’s lesson we will look at: a reminder of how binary works adding binary numbers overflow complements negative numbers and subtraction.
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.
Chapter 10 Instruction Sets: Characteristics and Functions Felipe Navarro Luis Gomez Collin Brown.
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. 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,
♣Multiplying Decimals♣
CHAPTER 18 Circuits for Arithmetic Operations
Microcomputer Programming
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.
Software and Hardware Circular Buffer Operations
SPI Compatible Devices
Thermal arm-wrestling
DMA example Video image manipulation
The planned and expected
Trying to avoid pipeline delays
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.
ECEG-3202 Computer Architecture and Organization
Thermal arm-wrestling
Using Arrays Completion of ideas needed for a general and complete program Final concepts needed for Final.
Moving Arrays -- 2 Completion of ideas needed for a general and complete program Final concepts needed for Final DMA.
Expand on these ideas for Q9 question and answer on the final
ECEG-3202 Computer Architecture and Organization
Thermal arm-wrestling
Concept of TDD Test Driven Development
Multiplying and Dividing in Scientific Notation
DMA example Video image manipulation
Developing a bicycle speed-o-meter
Independent timers build into the processor
Developing a bicycle speed-o-meter
Developing a bicycle speed-o-meter
CHAPTER 18 Circuits for Arithmetic Operations
Thermal arm-wrestling
Building a simple loop using Blackfin assembly code
Developing a bicycle speed-o-meter Part 2
Presentation transcript:

Specialized Video (8-bit) and Vector (16-bit) Instructions on the Blackfin Expand on these ideas for Q9 question and answer on the final

6/3/2015Video, Copyright M. Smith, ECE, University of Calgary, Canada 2 / 30 Problem to solve Using the video capability on Blackfin Specialized instruction Examine and explain examples in detail (working program) for Q9 format for final. Take something we have done in a laboratory and vectorize it for example

6/3/2015Video, Copyright M. Smith, ECE, University of Calgary, Canada 3 / 30 Blackfin Evaluation Board 8-bit values

6/3/2015Video, Copyright M. Smith, ECE, University of Calgary, Canada 4 / 30 Getting video information in DMA activity Values coming in using PPI (Parallel Port Interface) which shares many of its pins with PF Stored in SDRAM BF561 – 2 core Blackfin, handles both video in and out at the same time Possible Q9 question – one whole chapter in Hardware book on this area Web pages to go up on ECE-ADI-Project pages soon

6/3/2015Video, Copyright M. Smith, ECE, University of Calgary, Canada 5 / 30 Special 8 bit ALUS

6/3/2015Video, Copyright M. Smith, ECE, University of Calgary, Canada 6 / 30 Video image Blanking information Frame 1 - luminance + colour information Blanking information Frame 2 - luminance + colour information Blanking information Have ability to manipulate frame information with touching blanking information

6/3/2015Video, Copyright M. Smith, ECE, University of Calgary, Canada 7 / 30 Frame information Pixel 1 uses G1 + CB1 + CR1 Pixel 2 uses G2 + CB1 + CR1 Pixel 3 uses G3 + CB3 + CR3 Pixel 4 uses G4 + CB3 + CR3 CB1G1CR1G2CB3G3CR3G4CB5G5CR5G6 Image brightness decreasing

6/3/2015Video, Copyright M. Smith, ECE, University of Calgary, Canada 8 / 30 Frame information R0 = [P0] brings in information on pixel 1 and 2 intensity and colour One memory access, 2 pixel info One memory access, 4 pixel intensity information CB1G1CR1G2CB3G3CR3G4CB5G5CR5G6 G1G2G3G4G5G6G7G8

6/3/2015Video, Copyright M. Smith, ECE, University of Calgary, Canada 9 / 30 BYTEOP16P (Quad 8-bit ADD) 8 pixel values stored in R1 and R0 I0 register used to select which 4 pixel values used in operations – called “byte alignment” I0 = 0; use all bytes in R0 I0 = 1; Lowest byte in R1, top 3 in R0 8 pixel value stored in R3 and R2 I1 used to select the 4 pixels used If I0=1, I1 = 1; and (R4, R6) = byteop16p(R3:2, R1:0) ; // sum then we got 4 16-bit answers -- “my byte notation” R4.H = R3.B0 + R1.B0; // Bottom byte R4.L = R2.B3 + R0.B3; // Highest byte R6.H = R2.B2 + R0.B2; // Next highest byte R6.L = R2.B1 + R0.B1; // Next highest byte

6/3/2015Video, Copyright M. Smith, ECE, University of Calgary, Canada 10 / 30 BYTEOP1P (Quad 8-bit Average) 8 pixel values stored in R1 and R0 I0 register used to select which 4 pixel values used in operations – called “byte alignment” I0 = 0; use all bytes in R0 I0 = 1; Lowest byte in R1, top 3 in R0 8 pixel value stored in R3 and R2 I1 used to select the 4 pixels used If I0=1, I1 = 1; and R4 = byteop1p(R3:2, R1:0) ; // sum and average then we got 4 16-bit answers R4.B3 = (R3.B0 + R1.B0) / 2; // Bottom byte R4.B2 = (R2.B3 + R0.B3) / 2; // Highest byte R4.B1 = (R2.B2 + R0.B2) / 2; // Next highest byte R4.B0 = (R2.B1 + R0.B1) / 2; // Next highest byte

6/3/2015Video, Copyright M. Smith, ECE, University of Calgary, Canada 11 / 30 BYTEOP2P (Quad 8-bit Average Half word) 8 pixel values stored in R1 and R0 I0 register used to select which 4 pixel values used in operations – called “byte alignment” I0 = 0; use all bytes in R0 I0 = 1; Lowest byte in R1, top 3 in R0 8 pixel value stored in R3 and R2 I1 used to select the 4 pixels used If I0=1, I1 = 1; and R4 = byteop2p(R3:2, R1:0) ; // sum and average then we got 4 16-bit answers R4.B2 = (R3.B0 + R1.B0 + R2.B3 + R0.B3) / 4; // Highest 4 bytes R4.B0 = (R2.B2 + R0.B2 + R2.B1 + R0.B1) / 4;

6/3/2015Video, Copyright M. Smith, ECE, University of Calgary, Canada 12 / 30 BYTEOP16M (Quad 8-bit SUBTRACT) 8 pixel values stored in R1 and R0 I0 register used to select which 4 pixel values used in operations – called “byte alignment” I0 = 0; use all bytes in R0 I0 = 1; Lowest byte in R1, top 3 in R0 8 pixel value stored in R3 and R2 I1 used to select the 4 pixels used If I0=1, I1 = 1; and (R4, R6) = byteop16M(R3:2, R1:0) ; // sum then we got 4 16-bit answers -- “my byte notation” R4.H = R3.B0 - R1.B0; // Bottom byte R4.L = R2.B3 - R0.B3; // Highest byte R6.H = R2.B2 - R0.B2; // Next highest byte R6.L = R2.B1 - R0.B1; // Next highest byte

6/3/2015Video, Copyright M. Smith, ECE, University of Calgary, Canada 13 / 30 SAA -- Quad 4-bit Subtract, Absolute and Accumulate Take the differences between 2 images R0 = [P0++]; -- 4 pixels – image 1 R1 = [I1++]; -- 4 pixels -- image 2 R2 = 0; sum of differences Loop N - 1 times R2 = SAA(R1, R0) || R0 = [P0++] || R1 = [I1++]; R2 = SAA(R1, R0); Now add the 4 bytes together from R2 How to do efficiently – sounds like Q9 question to me

6/3/2015Video, Copyright M. Smith, ECE, University of Calgary, Canada 14 / 30 Worked Examples

6/3/2015Video, Copyright M. Smith, ECE, University of Calgary, Canada 15 / 30 Vector operations Many of the operations give 16 bit results Example Quad 8-bit Add (R4, R6) = byteop16P(R3:2, R1:0) Now you want to add the results together R5 = R4 +|- R6; R4.H + R6.H with R4.L + R6.L R5.L = R5.H + R5.L (NS);

6/3/2015Video, Copyright M. Smith, ECE, University of Calgary, Canada 16 / 30 Vector operations R0 = R1 +|+ R0; R1.H + R0.H, R1.L + R0.L R0 = R1 +|+ R0 (co); R1.H + R0.L, R1.L + R0.H co – word order “cross over” Can be +|+, +|-, -|+ or -|-; R3 = R1 + R0, R4 = R1 – R0; 32 bit add and subtract at same time Must use same source registers R3 = R1 +|+ R0, R1 -|- R0; 2 16-bit adds and 2 16-bit subtracts at same time R3 = R1 +|+ R0, R1 -|- R0 (asr); 2 16-bit adds and 2 16-bit subtracts at same time – and then afterwards do an arithmetic shift right (add and average, subtract and average)

6/3/2015Video, Copyright M. Smith, ECE, University of Calgary, Canada 17 / 30 Vector operations Normal max instruction (32-bit) R0 = MAX(R1, R2); R0 is largest of R1 and R2 Ditto MIN(R1, R2); Vector max R0 = MAX(R1, R2) (V) R0.H is largest of R1.H and R2.H R0.L is largest of R0.L and R2.L

6/3/2015Video, Copyright M. Smith, ECE, University of Calgary, Canada 18 / 30 VIT_MAX – Compare and Select R0 = VIT_MAX(R1, R2); R1 = 0x R2 = 0x R2.H and R1.L are largest R0 = 0x A0.W = binary 10 indicating R2.H and R1.L was largest

6/3/2015Video, Copyright M. Smith, ECE, University of Calgary, Canada 19 / 30 Other neat vector operations Vector ABS R2 = ABS R1 (V); absolute values of R1.H and R1.L stored in R2 Vector arithmetic shift R2 = R1 >>> 3 (V) – 2 16-bit shifts Vector multiply and accumulate Vector Negate -- etc

6/3/2015Video, Copyright M. Smith, ECE, University of Calgary, Canada 20 / 30 Worked examples

6/3/2015Video, Copyright M. Smith, ECE, University of Calgary, Canada 21 / 30 Problem to solve Using the video capability on Blackfin Specialized instruction Examine and explain examples in detail (working program) for Q9 format for final. Take something we have done in a laboratory and vectorize it for example

6/3/2015Video, Copyright M. Smith, ECE, University of Calgary, Canada 22 / 30 Information taken from Analog Devices On-line Manuals with permission 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.