Chapter 10 Interrupts. Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2002 Chapter 10, Slide 2 Learning Objectives  Introduction to interrupts.

Slides:



Advertisements
Similar presentations
Chapter 7 Linear Assembly
Advertisements

Chapter 11 Interfacing C and Assembly Code
Chapter 9 Bootloader.
Details.L and.S units TMS320C6000 Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2004.
Dr. Rabie A. Ramadan Al-Azhar University Lecture 3
Exceptions. Exception Types Exception Handling Vectoring Interrupts Interrupt Handlers Interrupt Priorities Interrupt applications 6-2.
TMS320C6000 Architectural Overview.  Describe C6000 CPU architecture.  Introduce some basic instructions.  Describe the C6000 memory map.  Provide.
1/1/ / faculty of Electrical Engineering eindhoven university of technology Architectures of Digital Information Systems Part 1: Interrupts and DMA dr.ir.
Computer System Overview
ECE 447 Fall 2009 Lecture 9: TI MSP430 Interrupts & Low Power Modes.
CSCI 4717/5717 Computer Architecture
1/1/ / faculty of Electrical Engineering eindhoven university of technology Introduction Part 3: Input/output and co-processors dr.ir. A.C. Verschueren.
COMP3221: Microprocessors and Embedded Systems Lecture 15: Interrupts I Lecturer: Hui Wu Session 1, 2005.
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.
Chapter 9 Bootloader. Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2002 Chapter 9, Slide 2 Learning Objectives  Need for a bootloader.
Introduction An interrupt is an event which informs the CPU that its service (action) is needed. Sources of interrupts: internal fault (e.g.. divide by.
A look at interrupts What are interrupts and why are they needed.
Chapter 11 Interfacing C and Assembly Code. Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2002 Chapter 11, Slide 2 Learning Objectives 
INPUT/OUTPUT ORGANIZATION INTERRUPTS CS147 Summer 2001 Professor: Sin-Min Lee Presented by: Jing Chen.
Exception and Interrupt Handling
Introduction to Embedded Systems
Interrupts. What Are Interrupts? Interrupts alter a program’s flow of control  Behavior is similar to a procedure call »Some significant differences.
MICROPROCESSOR INPUT/OUTPUT
CoE3DJ4 Digital Systems Design Chapter 6: Interrupts.
CHAPTER 3 TOP LEVEL VIEW OF COMPUTER FUNCTION AND INTERCONNECTION
EE 445S Real-Time Digital Signal Processing Lab Fall 2013 Lab #2 Generating a Sine Wave Using the Hardware & Software Tools for the TI TMS320C6748 DSP.
Khaled A. Al-Utaibi  Interrupt-Driven I/O  Hardware Interrupts  Responding to Hardware Interrupts  INTR and NMI  Computing the.
PIC16F877 ISR Points to note Interrupt Triggers –Individual interrupt flag bits are set, regardless of the status of their corresponding mask bit, PEIE.
1 CS/COE0447 Computer Organization & Assembly Language Chapter 5 part 4 Exceptions.
Microprocessors 1 MCS-51 Interrupts.
Richard P. Paul, SPARC Architecture, Assembly Language Programming, and C Chapter 7 – Subroutines These are lecture notes to accompany the book SPARC Architecture,
13-Nov-15 (1) CSC Computer Organization Lecture 7: Input/Output Organization.
CSNB374: Microprocessor Systems Chapter 5: Procedures and Interrupts.
Hardware Interrupts (HWI) Chapter 5 C6000 Integration Workshop Copyright © 2005 Texas Instruments. All rights reserved. Technical Training Organization.
1 © Unitec New Zealand Interrupt Lecture 6 Date: - 20 Sept, 2011 Embedded Hardware ETEC 6416.
6-1 Infineon 167 Interrupts The C167CS provides 56 separate interrupt sources that may be assigned to 16 priority levels. The C167CS uses a vectored interrupt.
Dec Hex Bin 14 E ORG ; FOURTEEN Interrupts In x86 PC.
4 - 1 Texas Instruments Incorporated European Customer Training Center University of Applied Sciences Zwickau (FH) Module 4 : Interrupt System C28x 32-Bit-Digital.
Embedded Systems Design 1 Lecture Set 8 MCS-51 Interrupts.
DSP C5000 Chapter 10 Understanding and Programming the Host Port Interface (EHPI) Copyright © 2003 Texas Instruments. All rights reserved.
Lecture 3 CSE 341 – Microprocessors Lecture 3 Md. Omar Faruqe UB 1228
The 8051 Microcontroller Chapter 6 INTERRUPTS. 2/29 Interrupt is the occurrence of a condition an event that causes a temporary suspension of a program.
Introduction to Exceptions 1 Introduction to Exceptions ARM Advanced RISC Machines.
Chapter 10 Interrupts. Basic Concepts in Interrupts  An interrupt is a communication process set up in a microprocessor or microcontroller in which:
Interrupts. Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2002 Chapter 10, Slide 2 Learning Objectives  Introduction to interrupts.  Types.
Architectures of Digital Information Systems Part 1: Interrupts and DMA dr.ir. A.C. Verschueren Eindhoven University of Technology Section of Digital.
68HC11 Interrupts & Resets.
Microprocessor Systems Design I
Mon. Oct 2 Announcements Quiz Postponed to Wednesday – still only on 2.a + 2.b Video lecture for 2.a posted Lab 6 experiment extension You must come to.
Timer and Interrupts.
UNIT – Microcontroller.
Interrupts In 8085 and 8086.
Chapter 8 Input/Output I/O basics Keyboard input Monitor output
8259 Chip The Intel 8259 is a family of Programmable Interrupt Controllers (PIC) designed and developed for use with the Intel 8085 and Intel 8086 microprocessors.
The TMS320C6x Family of DSPs
Computer System Overview
Interrupts Interrupt is a process where an external device can get the attention of the microprocessor. The process starts from the I/O device The process.
Chapter 11 Interfacing C and Assembly Code
Chapter 10 Interrupts.
전자의료시스템 및 실습 System Configuration/Interrupt
Lecture 9: TI MSP430 Interrupts & Low Power Modes
Interrupts.
Interrupt handling Explain how interrupts are used to obtain processor time and how processing of interrupted jobs may later be resumed, (typical.
Computer System Overview
Chapter 9 Bootloader.
ME 4447/6405 Microprocessor Control of Manufacturing Systems and
COMP3221: Microprocessors and Embedded Systems
EE 345S Real-Time Digital Signal Processing Lab Fall 2007
Presentation transcript:

Chapter 10 Interrupts

Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2002 Chapter 10, Slide 2 Learning Objectives  Introduction to interrupts.  Types of interrupts and sources.  Interrupt timeline.  Handling and processing interrupts using C and assembly code.

Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2002 Chapter 10, Slide 3Introduction  Interrupts are used to interrupt normal program flow so that the CPU can respond to events.  The events can occur at anytime.

Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2002 Chapter 10, Slide 4 CPU Interrupts and Sources CPU Int RESET RESET NMI NMIreservedreserved INT4 INT4 INT5 INT5INT6INT7INT8INT9INT10INT11INT12INT13INT14INT15Sources (HPI) DSPINT TINT0TINT1SD_INTEXT_INT4EXT_INT5EXT_INT6EXT_INT7DMA_INT0DMA_INT1DMA_INT2DMA_INT3XINT0RINT0XINT1RINT1 Description HPI Interrupt Timer 0 Timer 1 SDRAM Refresh External Interrupt 4 External Interrupt 5 External Interrupt 6 External Interrupt 7 DMA Channel 0 DMA Channel 1 DMA Channel 2 DMA Channel 3 McBSP Channel 0 TX McBSP Channel 0 RX McBSP Channel 1 TX McBSP Channel 1 RX PriorityHighLow Note that there are more sources of interrupt than the CPU can handle.

Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2002 Chapter 10, Slide 5 CPU Interrupts and Sources  The IACK and INUM pins do not exist on the C621x, C671x and C64x devices. 'C6x RESET INT4 NMI IACK INUM3 INT5 INT6 INT7 INUM2 INUM1 INUM0

Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2002 Chapter 10, Slide 6 Interrupt Selection CPU Int RESET RESET NMI NMIreservedreserved INT4 INT4 INT5 INT5INT6INT7INT8INT9INT10INT11INT12INT13INT14INT15Sources (HPI) DSPINT TINT0TINT1SD_INTEXT_INT4EXT_INT5EXT_INT6EXT_INT7DMA_INT0DMA_INT1DMA_INT2DMA_INT3XINT0RINT0XINT1RINT1 Description HPI Interrupt Timer 0 Timer 1 SDRAM Refresh External Interrupt 4 External Interrupt 5 External Interrupt 6 External Interrupt 7 DMA Channel 0 DMA Channel 1 DMA Channel 2 DMA Channel 3 McBSP Channel 0 TX McBSP Channel 0 RX McBSP Channel 1 TX McBSP Channel 1 RX PriorityHighLow Each source interrupt can be made to trigger a specific CPU interrupt.

Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2002 Chapter 10, Slide 7 Interrupt Selection  The interrupt source mapping can be achieved by initialising the appropriate bit-fields of the interrupt multiplexer.  Each CPU interrupt has a selection number “INTSEL#” that specifies the source. Interrupt Multiplexer High Interrupt Multiplexer High ( INT10 - INT15 ) (address 0x19c0000) Interrupt Multiplexer Low Interrupt Multiplexer Low ( INT4 - INT9 ) (address 0x19c0004)2629INTSEL152124INTSEL141619INTSEL131013INTSEL1258INTSEL1103INTSEL INTSEL92124INTSEL81619INTSEL71013INTSEL658INTSEL503INTSEL4

Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2002 Chapter 10, Slide 8 Interrupt Selection  Example: Mapping EXT_INT5 to CPU INT12. Interrupt Multiplexer High Interrupt Multiplexer High ( INT10 - INT15 ) (address 0x19c0000) Interrupt Multiplexer Low Interrupt Multiplexer Low ( INT4 - INT9 ) (address 0x19c0004)2629INTSEL152124INTSEL141619INTSEL131013INTSEL1258INTSEL1103INTSEL INTSEL92124INTSEL81619INTSEL71013INTSEL658INTSEL503INTSEL x19c0000 0x19c0004 address Write 5 dec = 0101b to INTSEL12

Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2002 Chapter 10, Slide 9 Interrupt Selection  Writing code to initialise INT12 with 0101b, there are 3 methods: (1) Using assembly: (2) Using the Chip Support Library: MVKL0x19c0000, A1 MVKH0x19c0000, A1 LDW*A1, A0 CLRA0, 10, 13, A0 SETA0, 10, 10, A0 SETA0, 12, 12, A0 STWA0, *A1 #include #include IRQ_map (IRQ_EVT_EXTINT5, 12);

Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2002 Chapter 10, Slide 10 (3) Using the GUI interface:  Open the CDB file.  Select Hardware Interrupt Service Routine Manager.  Select the CPU interrupt 12 (HWI_INT12) and right click and select properties.  Select External_Pin_5 as the interrupt source. Interrupt Selection

Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2002 Chapter 10, Slide 11 Interrupt Timeline Configure 1. Select interrupt sources and map them. 2. Create interrupt vector table. Enable 3. Enable individual interrupts. 4. Enable global interrupt. 5. Check for valid signal. 6. Once a valid signal is detected set flag bit. 7. Check if interrupt is enabled, if yes branch to ISR. 8. Write context store routine. 9. Write the ISR. 10.Write context restore routine. 11.Return to main program. User Responsibility (Initialisation) Performed by the CPU User Responsibility (Algorithm)

Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2002 Chapter 10, Slide 12 (2) Creating an Interrupt Vector  When an interrupt occurs the CPU automatically recognises the source of the interrupt and jumps to the interrupt vector location.  In this location a program is found which instructs the processor on the action(s) to be taken.  Each vector location can accommodate eight instructions which correspond to a fetch packet.  Such a location is know as the Interrupt Service Fetch Packet (ISFP) address.

Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2002 Chapter 10, Slide 13 (2) Creating an Interrupt Vector  The following table shows the interrupt sources and associated ISFP addresses:

Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2002 Chapter 10, Slide 14 (2) Creating an Interrupt Vector  Example 1: ISR fits into a single Fetch Packet (FP).

Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2002 Chapter 10, Slide 15 (2) Creating an Interrupt Vector  Example 2: ISR fits into multiple successive FP’s (assuming the next interrupts are not used).

Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2002 Chapter 10, Slide 16 (2) Creating an Interrupt Vector  Example 3: ISR is situated outside the interrupt vector table. RESET NMI Res INT4 INT5 INT6 B IRP NOP 5 0x0000 0x0020 0x0080 MVK MVKH B ISR LDH MVC STR ZERO Branch to ISR after executing the FP ISR Return from interrupt after executing the ISR

Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2002 Chapter 10, Slide 17 (2) Relocating the Vector Table  In general the vector table or the section “vectors” is linked to address zero.  However in many applications there is a need to change the location of the vector table.

Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2002 Chapter 10, Slide 18 (2) Relocating the Vector Table  This is due to many factors such as:  Moving interrupt vectors to fast memory.  Having multiple vector tables for use by different tasks.  Boot ROM already contained in memory starting at address 0x0000.  Memory starting at location zero is external and hence there will be a need to move the vector table to internal memory to avoid bus conflict in shared memory system.  In order to relocate the vector table, the Interrupt Service Table Pointer (ISTP) register should be set up.

Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2002 Chapter 10, Slide 19 (2) Relocating the Vector Table reservedISTB ISTP

Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2002 Chapter 10, Slide 20 (2) Relocating the Vector Table  Example: Relocate the ISTP to address 0x800. (1) The interrupt vector code located between 0x000 and 0x200 must be copied to the location 0x800 and 0x x200 (0xA00). (2) Initialise the ISTP. MVKL0x800, A0 MVKH0x800, A0 MVCA0, ISTP

Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2002 Chapter 10, Slide 21 nmie1rsvrsvIE4IE5IE6IE7IE8IE9IE10IE11IE12IE13IE14IE Reserved R, W, +0 R,+1 (3) Enable Individual Interrupts  Example: Write some code to enable INT7.  To enable each int, write “ 1 ” to IE bit  IER bits are NOT affected by the value in global interrupt enable (GIE)

Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2002 Chapter 10, Slide 22 _asm_set_INT7 MVC.S2 IER, B0 SET.L2 B0,7, 7, B0 MVC.S2 B0, IER (3) Enable Individual Interrupts  Method 1: Using “C” code. #include #include void enable_INT7 (void) { IER = IER | 0x040; }  Method 2: Using assembly. #include #include IRQ_enable (IRQ_EVT_EXTINT7)  Method 3: Using the CSL.

Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2002 Chapter 10, Slide 23 (4) Enable Global Interrupt  IER allows the enabling or disabling of interrupts individually.  GIE bit allows the enabling or disabling of interrupts globally (all at once). Note: By disabling the GIE interrupts can be prevented from occurring during initialisation. NMI INT15 IER CSR GIE ‘C6000CPU RESET GIE

Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2002 Chapter 10, Slide 24 _asm_set_GIE MVC.S2 CSR, B0 SET.L2 B0,0, 0, B0 MVC.S2 B0, CSR (4) Enable Global Interrupt  Method 1: Using “C” code. #include #include void enable_GIE (void) { CSR = CSRIER | 0x1; }  Method 2: Using assembly. #include #include IRQ_globalEnable ()  Method 3: Using the CSL.

Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2002 Chapter 10, Slide 25 (4) Enable Global Interrupt RESET & NMI Reset: is not maskable. IER[0] = 1 NMI: once the NMI is enabled it will be non maskable.  NMIE bit enables the NMI. So why have a non maskable interrupt that can be masked?  Avoids unwanted NMI interrupts occurring between the time of a reset and the end of initialisation.

Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2002 Chapter 10, Slide 26 (4) Enable Global Interrupt RESET & NMI So how is the non maskable interrupt made maskable?  Once the NMI is enabled it cannot be disabled.  Also the NMI must be enabled before any other interrupt (except reset) can be activated.

Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2002 Chapter 10, Slide 27 (5) Check for a Valid Signal Conditions for recognition of an external interrupt:  The interrupt must be held low for at least 2 cycles then high for at least two cycles. Recognition of the interrupt:  The interrupts are latched on the rising edge of CLKOUT1.  The interrupt is finally recognised by the CPU one cycle after being latched. INTx CPU Clock (CLKOUT1) Interrupt latched Interrupt recognized by CPU Occurrence of Interrupt 2 cycles minimum

Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2002 Chapter 10, Slide 28 (6) Interrupt Flag Register (IFR)  When an interrupt is recognised the corresponding bit in the IFR is set:  e.g. if INT7 is recognised then IFR[7] bit is set. IER CSR GIE ‘C6000CPU RESET GIE IFR 0 0 INT7 0 INT15 INT7 1

Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2002 Chapter 10, Slide 29 (7) CPU Interrupt Hardware Sequence What does the CPU do when an interrupt is recognised? CPU Action Description 0  IFR (bit) Clears corresponding interrupt flag bit GIE  PGIE Save previous value of GIE 0  GIE Disables global interrupts Save next EP address Save return address in IRP/NRP Vector (ISTP)  PC Loads PC with interrupt vector addr 1  IACK pin IACK is asserted INUM(0-3) INUM pins display corresponding int IACK and INUM pins are only available on the C620x and C670x.

Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2002 Chapter 10, Slide 30 xxxx xxxx (7) CPU Interrupt Hardware Sequence e.g. if INT7 is recognised and IER[7] is set: IFR CSR 110 0x PC 0x INT7 -> 0x ADD A0, A1, A2 0x MPY A2, A6, A7 0x MPY A2, A6, A7 0x IRP 'C6x IACK INUM3 INUM2 INUM1 INUM IACK and INUM pins are only available on the C620x and C670x.

Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2002 Chapter 10, Slide 31 (8) Writing the ISR in C There are two methods of declaring an ISR: (1)Traditional method: interrupt void ISR_name (void); main (void) {...} interrupt void ISR_name (void) {...} Notes:  You need to use the interrupt keyword in order to inform the compiler that it is an ISR and therefore to handle the necessary register preservation and use the IRP for returning from the interrupt.  No arguments can be passed to the ISR.  No argument can be returned.

Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2002 Chapter 10, Slide 32 (8) Writing the ISR in C (2) Using the dispatcher in DSP/BIOS: Notes:  You do not need to use the interrupt keyword.  Interrupt nesting of interrupt functions written in “C” is allowed.  You can pass one argument.  You can specify which interrupts can be nested by specifying a mask. Insert figure

Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2002 Chapter 10, Slide 33 (8) Writing the ISR in Assembly  For maskable interrupts the return from interrupt address is always stored in the Interrupt Return Pointer (IRP).  For non-maskable interrupts the address is stored in the Non-maskable Return Pointer (NRP).

Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2002 Chapter 10, Slide 34 (8) Writing the ISR in Assembly _isr_functionstw...ldh...ldw... b irp nop 5 (1) Save any registers used by the ISR on the stack (2) Use the HWI macros, or (3) Use the hardware interrupt dispatcher Put you ISR code here (1) Restore the registers saved on the stack (2) Use the HWI macros, or (3) Use the HWI dispatcher Return (You can also use HWI macros) It is much simpler to use the HWI dispatcher rather than doing the save and restore of registers by yourself or the HWI_enter and HWI_exit macros.

Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2002 Chapter 10, Slide 35 Other Related Topics (1)Setting and clearing the Interrupt Flag Register (IFR):  Why do you need to read or write to the IFR?  By writing you can simulate an interrupt.  By reading you can check (poll) if an interrupt has occurred.  You cannot directly write to the IFR:  To set a bit you have to write to the Interrupt Set Register (ISR).  To clear a bit you have to write to Interrupt Clear Register (ICR).

Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2002 Chapter 10, Slide 36 Other Related Topics  Example: Set and clear bits 7 and A0 MVKL0x0180, A0 MVCA0, ISR ISR IFR 18 * One cycle later 17031A0 MVKL0x0180, A0 MVCA0, ICR ICR IFR 08 * One cycle later

Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2002 Chapter 10, Slide 37 Other Related Topics (2)Setting the polarity of the External Interrupts:  The External Interrupt Polarity (XIP) register allows the polarity of the external interrupt pins to be changed.  This prevents extra hardware (space and cost) being required if the source has a different polarity. 0x19c 0008 XIP XIP XIP6XIP5XIP = low to high (default) 1 = high to low (inverted)

Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2002 Chapter 10, Slide 38 Other Related Topics There are 3 ways of programming the XIP: MVKL2, A1 MVKL0x19c0008, A0 MVKH0x19c0008, A0 STWA1, *A0  Method 1: Using “C” code. * (unsigned volatile int*) _IRQ_EXTPOL_ADDR = 2;  Method 2: Using assembly.

Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2002 Chapter 10, Slide 39 Other Related Topics There are 3 ways of programming the XIP:  Method 3: Using the GUI configuration tool. Note: The XIP only affects interrupts to the CPU and has no effect on the EDMA events.

Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2002 Chapter 10, Slide 40 Programming Interrupt Examples  Interrupts are programmed in the code in the following chapters:  \Code\Chapter 14 - Finite Impulse Response Filters  \Code\Chapter 15 - Infinite Impulse Response Filters  \Code\Chapter 16 - Adaptive Filters  \Code\Chapter 17 - Goertzel Algorithm  \Code\Chapter 18 - Discrete Cosine Transform  \Code\Chapter 19 - Fast Fourier Transform

Chapter 10 Interrupts - End - Single and Multiple Assignment

Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2002 Chapter 10, Slide 42 Single and Multiple Assignment  Single assignment requires that no registers are read which have pending results.  Multiple assignment allows multiple values to re-use the same register in different time slots (sort of register based“TDM”) - thus reducing register pressure. Single Assignment: MVKH.S1 0x02,A1 SA: B.S1 SA LDW.D1 *A0,A1 LDW.D1 *A0,A1 NOP 4 NOP 4 MPY.M1 A1,A2,A3 MPY.M1 A1,A2,A3 NOP NOP SHR.S1 A3,15,A3 SHR.S1 A3,15,A3 ADD.L1 A3,A4,A4 ADD.L1 A3,A4,A4 Reads current value-- var(n) Uses current value -- var(n)

Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2002 Chapter 10, Slide 43 Single and Multiple Assignment  Single assignment requires that no registers are read which have pending results.  Multiple assignment allows multiple values to re-use the same register in different time slots (sort of register based“TDM”) - thus reducing register pressure. Multiple Assignment: MVKH.S1 0x02,A1 MA: B.S1 MA LDW.D1 *A0,A1 LDW.D1 *A0,A1 MPY.M1 A1,A2,A3 MPY.M1 A1,A2,A3 NOP NOP SHR.S1 A3,15,A3 SHR.S1 A3,15,A3 ADD.L1 A3,A4,A4 ADD.L1 A3,A4,A4

Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2002 Chapter 10, Slide 44 Single and Multiple Assignment  Single assignment requires that no registers are read which have pending results.  Multiple assignment allows multiple values to re-use the same register in different time slots (sort of register based“TDM”) - thus reducing register pressure. Single Assignment: MVKH.S1 0x02,A1 SA: B.S1 SA LDW.D1 *A0,A1 LDW.D1 *A0,A1 NOP 4 NOP 4 MPY.M1 A1,A2,A3 MPY.M1 A1,A2,A3 NOP NOP SHR.S1 A3,15,A3 SHR.S1 A3,15,A3 ADD.L1 A3,A4,A4 ADD.L1 A3,A4,A4 Multiple Assignment: MVKH.S1 0x02,A1 MA: B.S1 MA LDW.D1 *A0,A1 LDW.D1 *A0,A1 MPY.M1 A1,A2,A3 MPY.M1 A1,A2,A3 NOP NOP SHR.S1 A3,15,A3 SHR.S1 A3,15,A3 ADD.L1 A3,A4,A4 ADD.L1 A3,A4,A4

Dr. Naim Dahnoun, Bristol University, (c) Texas Instruments 2002 Chapter 10, Slide 45 Problem with Multiple Assignment Multiple Assignment: MVKH.S1 0x02,A1 MA: B.S1 MA LDW.D1 *A0,A1 LDW.D1 *A0,A1 MPY.M1 A1,A2,A3 MPY.M1 A1,A2,A3 NOP NOP SHR.S1 A3,15,A3 SHR.S1 A3,15,A3 ADD.L1 A3,A4,A4 ADD.L1 A3,A4,A4 Interrupt occurs here  If an interrupt occurs at the LDW, this instruction will be completed before the MPY is executed.  Therefore A1 will be loaded by the value pointed by A0 which will be used by the MPY instruction.  The result is that A1 will NOT be equal to 0x02 as intended.

Chapter 10 Interrupts - End -