Analog Devices ee-11 Application Notes

aEngineer To Engineer Note EE-11
Notes on using Analog Devices’ DSP, audio, & video components from the Computer Products Division
Phone: (800) ANALOG-D or (781) 461-3881, FAX: (781) 461-3010, EMAIL: dsp.support@analog.com
Here is a quick summary of DMA holdoffs:
ADSP-2181 Priority Chain & IDMA Holdoffs
QUESTION:
What is the prioritization of a core write, BDMA write, SPORT write and IDMA write? Does the worst case of 3.5 cycles on an IDMA Long Read Cycle account for concurrent BDMA and SPORT write requests to the same internal memory location? If so, is this a case where /IACK is a must use signal?
ANSWER:
The ADSP-2181 Priority Chain for concurrent requests occurring at instruction cycle boundaries is as follows:
ADSP-2181 PRIORITY CHAIN
1. COMPLETION OF AN EXTERNAL MEMORY ACCESS
2. IDMA INTERNAL MEMORY TRANSFERS
3. BDMA INTERNAL MEMORY TRANSFERS
4. SPORT AUTOBUFFER OPERATIONS
5. EMULATOR INTERRUPT
6. EMULATOR INSTRUCTION
7. POWERDOWN INTERRUPT
8. UNMASKED INTERRUPT
9. NORMAL INSTRUCTION EXECUTION
1) Bus Request
2) External Accesses with waitstates
3) Multiple External Accesses
4) IDLE n Instruction
5) SPORT Autobuffering to external memory with waitstated access
6) EZ-ICE Emulation
The 3.5 cycles assumes no external memory operations (multiple external accesses when executing multifunction instructions or an external access with waits states) or Bus Request activity. So in the case of trying to write to the same
memory region (internal) the IDMA port will always execute in 3.5 cycles. Therefore, in this case using /IACK is unnecessary. If your code does contain DMA holdoffs as described in
Chapter 11 of the ADSP-2100 Family user’s manual, then you must use /IACK in your design to guarantee that IDMA transfers will always operate properly.
Loading...