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.