Summary: Large amounts of data can be stored in external memory. The READPROG and WRITPROG macros copy data between internal memory and external memory.
firs
instruction requires filter coefficients in the Program
address space.) The Data space is 64K long and is accessed
using the 16-bit auxiliary registers
(ARx). Although the Program space is normally
accessed using 16-bit literals stored in your program code,
the Program space is, in fact, significantly larger than 64K.
Using special "extended addressing" instructions, the TI DSP
can access up to 8192K-words of memory in the Program space.
The extended addressing instructions include far calls and
jumps that reset the full 23-bit program counter, as well as
accumulator-addressed data-transfer instructions.
![]() Figure 1: DSP EVM memory maps |
ARx) and address-extension words and the
mapping of Data memory is not affected by the
OVLY bit. However, because the Program memory
space is much larger than can be addressed by the 16-bit
addressing register or the 16-bit literals stored in the
program, it is split up into 64K (16-bit) pages by the
hardware. Normal instructions, such as call,
firs, and mvpd accept only 16-bit
addresses, and can therefore only address the current "page"
(usually address in the form 00xxxxh, which
corresponds to the addresses the linker uses for your
program's code). To access the full 23-bit address space,
the DSP offers special accumulator-addressed load, store,
and jump instructions.
OVLY bit affects the mapping of the Program
memory space. If you remember, before we load our DSP
program, we have to change the PMST to
FFE0h. We do this to set the OVLY
bit in the PMST, which maps the internal memory
into both the Program and Data spaces of the DSP. If
OVLY is 1, the internal memory appears in both
the Data and Program memory address space at locations
0080h to 07FFFh. Therefore, with
OVLY set, anything written into Data memory
below 07FFFh will overwrite a program stored in
the same location. 1 In addition, copies of the internal memory
also appear in the extended Program address space, occupying
locations 0080h-7FFFh of each
page. Therefore, with OVLY set, any addresses
to Program memory locations in the form of
xx0000h-xx7FFFh reference internal
memory.
OVLY is zero, internal memory is not
mapped into the Program space at all; in this case, the
Program space includes only external memory. In this mode,
all 192K words of external Program RAM are accessible,
although several wait states will be required for accessing
each item of memory. In the overlay mode, only addresses in
the ranges of 08000h-0FF00h,
1800h-1FFFFh, and
28000h-2FFFFh are available to
store your data buffers; the remaining addresses are
unmapped or map to the on-chip RAM.
PMST indirectly. Instead of accessing the
external Program RAM directly, we can use the special macros
to access the RAM that is normally "hidden" by the internal
memory. This allows us to use the full range of external
memory available: addresses
000000h-00FF00h and
010000h-02FFFF. However, since
addresses 00FF00h-00FFFFh are
reserved by the core file, you must be careful not to write
to addresses in this range. READPROG and
WRITPROG. These macros allow the processor to
copy data between data memory and external Program
memory. Both macros address external Program memory using the
value in accumulator A. READPROG
reads data from the external Program memory location pointed
to by A and writes it to the data memory location pointed to
by AR1. WRITPROG reads data from the
memory location pointed to by AR1 and writes it
to the location in external Program RAM specified by
accumulator A. Both macros take one parameter, a
count; specifying 1 reads or writes one word from external
memory, and specifying some other number
A and AR1. AR1 is left
pointing at the word after the last word read or written; no
other registers are modified.
023456h into the
location 0064h in data memory using the
READPROG macro:
1 stm #64h,AR1 ; load 64h into AR1
2 ld #02h,16,A ; load 02h in high part of A
3 adds #3456h,A ; fill in low part of A
4 ; A contains 023456h
5 READPROG 1 ; read from 023456h in external Program RAM
6 ; into *AR1 in Data RAM
WRITPROG macro can be used similarly to write
into extended Program RAM:
1 stm #64h,AR1 ; load 64h into AR1
2 ld #02h,16,A ; load 02h in high part of A
3 adds #3456h,A ; fill in low part of A
4 ; A contains 023456h
5 WRITPROG 1 ; write from *AR1 in Data RAM to
6 ; 023456h in external Program RAM
READPROG and WRITPROG macros on data
memory.
6000h-7FFFh - does not overlap
with any of the space allocated for the data
segments.