<< Chapter < Page Chapter >> Page >
Large amounts of data can be stored in external memory. The READPROG and WRITPROG macros copy data between internal memory and external memory.

Introduction

The TI DSP evaluation boards you use have a large amount of memory; in addition to the 32K words internal to the DSP,there are another 256K words of memory installed on the EVM board. For many exercises, the data sets are small, and youworked with only the on-chip memory of the DSP and were not expected to consider how the use of memory impactedperformance. However, the large delays often required in audio processing, for example, require that many thousands ofsamples be stored in memory. There is not enough memory on the DSP microprocessor itself to store a second or more of samplesat a 44.1 kHz sample rate, so the off-chip memory must be used.

Evm memory maps

As you have seen, the TI TMS320C54x DSP has two separate memory spaces, called Program and Data. Usually, Programcontains your assembled program, and Data contains data, but sometimes it may be convenient or more efficient to violatethis convention. (For instance, the firs instruction requires filter coefficients in the Program address space.) The Data space is 64K long and is accessedusing 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 DSPcan access up to 8192K-words of memory in the Program space. The extended addressing instructions include far calls andjumps that reset the full 23-bit program counter, as well as accumulator-addressed data-transfer instructions.

Internal and external memory

In many exercises, it is possible to store program instructions and data entirely in the DSP's on-chip("internal") memory. This internal memory has several advantages over off-chip ("external") memory: it is muchfaster (data stored can be accessed without delay), and multiple reads and writes can access the DSP's on-chipmemory simultaneously. However, many applications (including the audio delay effect of Using External Memory ) require a data buffer too large to fit into the on-chip memory. For these large buffers, wemust use the larger but slower external memory.

When writing programs that require large amounts of memory, use the internal memory to hold your code, filtercoefficients, and any small buffers you need. External memory should be used for large buffers that you only accessa few times per sample, like the delay buffer described in Audio Effects: Using External Memory .

Tms320c549x dsp evm memory maps

DSP EVM memory maps

As these memory maps show, the EVM's Data address space is addressed fully by the 16-bit auxiliary registers( 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-bitaddressing register or the 16-bit literals stored in the program, it is split up into 64K (16-bit) pages by thehardware. 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 yourprogram's code). To access the full 23-bit address space, the DSP offers special accumulator-addressed load, store,and jump instructions.

Further complicating matters is the fact that the OVLY bit affects the mapping of the Program memory space. If you remember, before we load our DSPprogram, 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.

This is why the memory allocated for your program - 6000h - 7FFFh - does not overlap with any of the space allocated for the datasegments.
In addition, copies of the internal memory also appear in the extended Program address space, occupyinglocations 0080h - 7FFFh of each page. Therefore, with OVLY set, any addresses to Program memory locations in the form of xx0000h - xx7FFFh reference internal memory.

When OVLY is zero, internal memory is not mapped into the Program space at all; in this case, theProgram 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 inthe ranges of 08000h - 0FF00h , 1800h - 1FFFFh , and 28000h - 2FFFFh are available to store your data buffers; the remaining addresses areunmapped or map to the on-chip RAM.

To escape this confusion and allow the full 192K-words of external Program RAM to be used for your data buffers, thecore file provides mechanisms for manipulating the PMST indirectly. Instead of accessing the external Program RAM directly, we can use the special macrosto access the RAM that is normally "hidden" by the internal memory. This allows us to use the full range of externalmemory available: addresses 000000h - 00FF00h and 010000h - 02FFFF . However, since addresses 00FF00h - 00FFFFh are reserved by the core file, you must be careful not to writeto addresses in this range.

Accessing extended program ram

The core file provides two macros for accessing data stored in the external Program RAM: READPROG and WRITPROG . These macros allow the processor to copy data between data memory and external Programmemory. 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 toby AR1 . WRITPROG reads data from the memory location pointed to by AR1 and writes it to the location in external Program RAM specified byaccumulator A . Both macros take one parameter, a count; specifying 1 reads or writes one word from externalmemory, and specifying some other number n transfers n words starting at the locations pointed to by A and AR1 . AR1 is left pointing at the word after the last word read or written; noother registers are modified.

For instance, the following code fragment loads the value contained in memory location 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

The 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

Note that Code Composer will not display or allow you to change the contents of the external Program RAM on thememory-dump or disassembly screen, though you can view or change it indirectly by watching the effects of the READPROG and WRITPROG macros on data memory.

Questions & Answers

how does Neisseria cause meningitis
Nyibol Reply
what is microbiologist
Muhammad Reply
what is errata
Muhammad
is the branch of biology that deals with the study of microorganisms.
Ntefuni Reply
What is microbiology
Mercy Reply
studies of microbes
Louisiaste
when we takee the specimen which lumbar,spin,
Ziyad Reply
How bacteria create energy to survive?
Muhamad Reply
Bacteria doesn't produce energy they are dependent upon their substrate in case of lack of nutrients they are able to make spores which helps them to sustain in harsh environments
_Adnan
But not all bacteria make spores, l mean Eukaryotic cells have Mitochondria which acts as powerhouse for them, since bacteria don't have it, what is the substitution for it?
Muhamad
they make spores
Louisiaste
what is sporadic nd endemic, epidemic
Aminu Reply
the significance of food webs for disease transmission
Abreham
food webs brings about an infection as an individual depends on number of diseased foods or carriers dully.
Mark
explain assimilatory nitrate reduction
Esinniobiwa Reply
Assimilatory nitrate reduction is a process that occurs in some microorganisms, such as bacteria and archaea, in which nitrate (NO3-) is reduced to nitrite (NO2-), and then further reduced to ammonia (NH3).
Elkana
This process is called assimilatory nitrate reduction because the nitrogen that is produced is incorporated in the cells of microorganisms where it can be used in the synthesis of amino acids and other nitrogen products
Elkana
Examples of thermophilic organisms
Shu Reply
Give Examples of thermophilic organisms
Shu
advantages of normal Flora to the host
Micheal Reply
Prevent foreign microbes to the host
Abubakar
they provide healthier benefits to their hosts
ayesha
They are friends to host only when Host immune system is strong and become enemies when the host immune system is weakened . very bad relationship!
Mark
what is cell
faisal Reply
cell is the smallest unit of life
Fauziya
cell is the smallest unit of life
Akanni
ok
Innocent
cell is the structural and functional unit of life
Hasan
is the fundamental units of Life
Musa
what are emergency diseases
Micheal Reply
There are nothing like emergency disease but there are some common medical emergency which can occur simultaneously like Bleeding,heart attack,Breathing difficulties,severe pain heart stock.Hope you will get my point .Have a nice day ❣️
_Adnan
define infection ,prevention and control
Innocent
I think infection prevention and control is the avoidance of all things we do that gives out break of infections and promotion of health practices that promote life
Lubega
Heyy Lubega hussein where are u from?
_Adnan
en français
Adama
which site have a normal flora
ESTHER Reply
Many sites of the body have it Skin Nasal cavity Oral cavity Gastro intestinal tract
Safaa
skin
Asiina
skin,Oral,Nasal,GIt
Sadik
How can Commensal can Bacteria change into pathogen?
Sadik
How can Commensal Bacteria change into pathogen?
Sadik
all
Tesfaye
by fussion
Asiina
what are the advantages of normal Flora to the host
Micheal
what are the ways of control and prevention of nosocomial infection in the hospital
Micheal
what is inflammation
Shelly Reply
part of a tissue or an organ being wounded or bruised.
Wilfred
what term is used to name and classify microorganisms?
Micheal Reply
Binomial nomenclature
adeolu
Got questions? Join the online conversation and get instant answers!
Jobilize.com Reply

Get Jobilize Job Search Mobile App in your pocket Now!

Get it on Google Play Download on the App Store Now




Source:  OpenStax, Digital signal processing laboratory (ece 420). OpenStax CNX. Sep 27, 2006 Download for free at http://cnx.org/content/col10236/1.14
Google Play and the Google Play logo are trademarks of Google Inc.

Notification Switch

Would you like to follow the 'Digital signal processing laboratory (ece 420)' conversation and receive update notifications?

Ask