Please be aware that an important notice concerning availability, standard warranty, and use in critical applications of
Texas Instruments semiconductor products and disclaimers thereto appears at the end of this data sheet.
PRODUCTION DATA information is current as of publication date.
Products conform to specifications per the terms of Texas Instruments
standard warranty. Production processing does not necessarily include
testing of all parameters.
The TMS320VC5420 fixed-point digital signal processor (DSP) is a dual CPU device capable of up to 200-MIPS
performance. The ’5420 consists of two independent ’54x subsystems capable of core-to-core
communications.
Each subsystem CPU is based on an advanced, modified Harvard architecture that has one program memory
bus and three data memory buses. The processor also provides an arithmetic logic unit (ALU) that has a high
degree of parallelism, application-specific hardware logic, on-chip memory , and additional on-chip peripherals.
Each subsystem has separate program and data spaces, allowing simultaneous accesses to program
instructions and data. Two read operations and one write operation can be performed in one cycle. Instructions
with parallel store and application-specific instructions can fully utilize this architecture. Furthermore, data can
be transferred between program and data spaces. Such parallelism supports a powerful set of arithmetic, logic,
and bit manipulation operations that can be performed in a single machine cycle. In addition, the ’5420 includes
the control mechanisms to manage interrupts, repeated operations, and function calls.
The ’5420 is offered in two temperature ranges and individual part numbers as shown below . (Please note that
the industrial temperature device part numbers do not follow the typical numbering tradition.)
DVDD is the power supply for the I/O pins while CVDD is the power supply for the core CPU. VSS is the ground for both the I/O
pins and the core CPU.
§
Pin configuration shown for nonmultiplexed mode only. See the Pin Assignments for the TMS320VC5420PGE table for multiplexed
A_BDR0
A_BFSX0
A_BCLKR0
SS
DD
V
CV
DD
V
DV
B_BDX0
SS
B_BFSX0
SS
DD
V
CV
B_BDR0
B_BCLKR0
R/W
PPA2
B_BFSR0
PPA3
PPD8
SELA/B
PPD9
PPD10
SS
V
PPD11
functions of specific pins.
POST OFFICE BOX 1443 • HOUSTON, TEXAS 77251–1443
3
TMS320VC5420
FIXED-POINT DIGITAL SIGNAL PROCESSOR
SPRS080C – MARCH 1999 – REVISED APRIL 2000
TMS320VC5420 GGU PACKAGE
(BOTTOM VIEW)
12
3456781012 11139
A
B
C
D
E
F
G
H
J
K
L
M
N
The pin assignments table for the TMS320VC5420GGU lists each pin name and its associated pin number for
this 144-pin ball grid array (BGA) package.
4
POST OFFICE BOX 1443 • HOUSTON, TEXAS 77251–1443
TMS320VC5420
FIXED-POINT DIGITAL SIGNAL PROCESSOR
SPRS080C – MARCH 1999 – REVISED APRIL 2000
pin assignments
The ’5420 pin assignments tables list each pin name and corresponding pin number for the two package types.
Some of the ’5420 pins can be configured for one of two functions. For these pins, the primary pin name is listed
in the primary column. The secondary pin name is listed in the secondary column and is shaded grey.
PPA13K11PPD10HD10L11
PPD9HD9M11PPD8HD8N11
PPA6A12PPA14B12
PPA16C12B_INT1D12
B_GPIO1E12CV
B_BDX1G12CV
B_RSJ12HPIRSK12
DV
DD
PPD11HD11N12PPA7A13
PPA15B13PPA17C13
B_NMID13B_GPIO0E13
V
SS
B_BCLKX1H13XIOJ13
HMODEK13V
PPA11M13PPA10N13
SECONDARY
SECONDARY
SIGNAL NAME
SIGNAL NAME
B_GPIO3
B_TOUT
BALL
BALL
NO.
NO.
A9V
M9CV
E10B_BFSR1F10
H11B_XFJ11
L12V
F13V
PRIMARY
PRIMARY
SIGNAL NAME
SIGNAL NAME
SS
SS
DD
DD
SS
DD
DD
SS
SS
SS
SECONDARY
SECONDARY
SIGNAL NAME
SIGNAL NAME
BALL
BALL
NO.
NO.
N8
B9
N9
A11
C11
F12
H12
M12
G13
L13
8
POST OFFICE BOX 1443 • HOUSTON, TEXAS 77251–1443
TMS320VC5420
5
PPA15
y
PPA12
Parallel ort address bus. The DSP can access the external memory locations by way of the external memory
(
PPA9
The PPA[17:0] ins are also multi lexed with the HPI interface. In HPI mode (XIO in is low), the external address
PPA6
PPA3
FIXED-POINT DIGITAL SIGNAL PROCESSOR
SPRS080C – MARCH 1999 – REVISED APRIL 2000
signal descriptions
The ’5420 signal descriptions table lists each pin name, function, and operating mode(s) for the ’5420 device.
Some of the ’5420 pins can be configured for one of two functions; a primary function and a secondary function.
The names of these pins in secondary mode are shaded in grey in the following table.
Signal Descriptions
I/O/Z
I/O/Z
†
DATA SIGNALS
Parallel port address bus. The DSP can access the external memory locations by way of the external memor
interface using PPA[17:0] in external memory interface (EMIF) mode when the XIO pin is logic high.
The PPA[17:0] pins are also multiplexed with the HPI interface. In HPI mode
pins PPA[17:0] are used by a host processor for access to the memory map by way of the on-chip HPI. Refer
to the HPI section of this table for details on the secondary functions of these pins.
These pins are placed into the high-impedance state when OFF is low.
Parallel port data bus. The DSP uses this bidirectional data bus to access external memory when the device is
in external memory interface (EMIF) mode (the XIO pin is logic high).
This data bus is also multiplexed with the 16-bit HPI data bus. When in HPI mode, the bus is used to transfer data
between the host processor and internal DSP memory via the HPI. Refer to the HPI section of this table for details
on the secondary functions of these pins.
¶
The data bus includes bus holders to reduce power dissipation caused by floating, unused pins. The bus holders
also eliminate the need for external pullup resistors on unused pins. When the data bus is not being driven by
the ’5420, the bus holders keep data pins at the last driven logic level. The data bus keepers are disabled at reset
and can be enabled/disabled via the BH bit of the BSCR register.
These pins are placed into high-impedance state when OFF
INITIALIZATION, INTERRUPT, AND RESET OPERATIONS
External user interrupts. INT0–INT3 are prioritized and are maskable by the interrupt mask register (IMR) and
I
the interrupt mode bit. INT0
Nonmaskable interrupt. NMI is an external interrupt that cannot be masked by way of the INTM or the IMR. When
I
NMI
is activated, the processor traps to the appropriate vector location.
–INT3 can be polled and reset by way of the interrupt flag register (IFR).
I = Input, O = Output, S = Supply, Z = High Impedance
‡
This pin has an internal pullup resistor.
§
These pins have Schmitt trigger inputs.
¶
This pin has an internal bus holder controlled by way of the BSCR register in subchip A.
#
This pin is used by Texas Instruments for device testing and should be left unconnected.
||
This pin has an internal pulldown resistor.
†
INITIALIZATION, INTERRUPT, AND RESET OPERATIONS (CONTINUED)
Reset. RS causes the digital signal processor (DSP) to terminate execution and causes a reinitialization of the
CPU and peripherals. When RS
I
memory. RS
The XIO pin is used to configure the parallel port as a host-port interface (HPI mode when XIO pin is low), or as
an asynchronous memory interface (EMIF mode when XIO pin is high).
At device reset, the logic combination of the XIO, HMODE, and SELA/B pin levels determines the initialization
value of the MP/MC bit (a bit in the processor mode status (PMST) register ) Refer to the memory section for
details.
External flag output (latched software-programmable output-only signal). Bit addressable. A_XF and B_XF are
O
placed into the high-impedance state when OFF
General-purpose I/O pins (software-programmable I/O signal). V alues can be latched (output) by writing into the
GPIO register. The states of GPIO pins (inputs) can be read by reading the GPIO register. The GPIO direction
is also programmable by way of the DIRn field in the GPIO register.
I/O
General-purpose I/O. These pins can be configured in the same manner as GPIO0–1; however in input mode,
the pins also operate as the traditional branch control bit (BIO
-conditional instructions, these pins operate as general inputs.
BIO
IOSTRB
I/O
IS
Program space select signal. The PS signal is asserted during external program space accesses. This pin is
placed into the high-impedance state when OFF
O
This pin is also multiplexed with the HPI, and functions as the HDS1
to the HPI section of this table for details on the secondary function of this pin.
Data space select signal. The DS signal is asserted during external data space accesses. This pin is placed into
the high-impedance state when OFF
O
This pin is also multiplexed with the HPI, and functions as the HDS2
to the HPI section of this table for details on the secondary function of this pin.
I/O space select signal. The IS signal is asserted during external I/O space accesses. This pin is placed into the
high-impedance state when OFF
This pin is also multiplexed with the general purpose I/O feature, and functions as the B_GPIO3 (B_TOUT)
input/output signal in HPI mode. Refer to the General Purpose I/O section of this table for details on the secondary
function of this pin.
Program and data memory strobe (active in EMIF mode). This pin is placed into the high-impedance state when
O
OFF
affects various registers and status bits.
GENERAL-PURPOSE I/O SIGNALS
PRIMARY
by the general-purpose I/O control register. TOUT bit must be set to “1” to drive the timer
output on the pin. IF TOUT = 0, then these pins are general-purpose I/Os. In EMIF mode
O
(XIO pin high), these signals serve their primary functions and are active during external
I/O space accesses.
MEMORY CONTROL SIGNALS
is low.
is brought to a high level, execution begins at location 0FF80h of program
is low.
en the device is in
is low.
is low.
mode and
is low.
). If application code does not perform
= 0 (mu
data strobe input signal in HPI mode. Refer
data strobe input signal in HPI mode. Refer
p
exed), these pins are controlle
p
10
POST OFFICE BOX 1443 • HOUSTON, TEXAS 77251–1443
FIXED-POINT DIGITAL SIGNAL PROCESSOR
Signal Descriptions (Continued)
TMS320VC5420
SPRS080C – MARCH 1999 – REVISED APRIL 2000
NAMEDESCRIPTIONTYPE
READYI
R/WO
IOSTRBO
SELA/BI
†
MEMORY CONTROL SIGNALS (CONTINUED)
Data-ready input signal. READY indicates that the external device is prepared for a bus transaction to be
completed. If the device is not ready (READY = 0), the processor waits one cycle and checks READY again. The
processor performs the READY detection if at least two software wait states are programmed.
This pin is also multiplexed with the HPI, and functions as the Host-port data ready (output) in HPI mode. Refer
to the HPI section of this table for details on the secondary function of this pin.
Read/write output signal. R/W indicates transfer direction during communication to an external device. R/W is
normally in the read mode (high), unless it is asserted low when the DSP performs a write operation.
This pin is also multiplexed with the HPI, and functions as the Host-port Read/write input in HPI mode. Refer to
the HPI section of this table for details on the secondary function of this pin.
This pin is placed into the high-impedance state when OFF
I/O space memory strobe. External I/O space is accessible by the CPU and not the direct memory access (DMA)
controller. The DMA has its own dedicated I/O space that is not accessible by the CPU.
This pin is also multiplexed with the general pupose I/O feature, and functions as the A_GPIO3(A_TOUT) signal
in HPI mode. Refer to the general purpose I/O section of this table for details on the secondary function of this
pin.
This pin is placed into the high-impedance state when OFF
The SELA/B pin designates which DSP subsystem has access to the parallel-port interface. Furthermore, this
pin determines which subsystem is accessible by the host via the HPI.
For external memory accesses (XIO pin high), when SELA/B is low subsystem A has control of the external
memory interface. Similarly, when SELA/B is high subsystem B has control.
See Table 7 for a truth table of SELA/B, HMODE and XIO pins and functionality.
is low.
is low.
At device reset, the logic combination of the XIO, HMODE, and SELA/B pin levels determines the initialization
value of the MP/MC bit (a bit in the processor mode status (PMST) register ) Refer to the memory section for
details.
I = Input, O = Output, S = Supply, Z = High Impedance
‡
This pin has an internal pullup resistor.
§
These pins have Schmitt trigger inputs.
¶
This pin has an internal bus holder controlled by way of the BSCR register in subchip A.
#
This pin is used by Texas Instruments for device testing and should be left unconnected.
||
This pin has an internal pulldown resistor.
‡§
‡§
‡§
‡§
‡§
‡§
I/O/Z
Master clock output signal. CLKOUT cycles at the machine-cycle rate of the CPU. The internal machine cycle
is bounded by the falling edges of this signal. The CLKOUT pin can be turned off by writing a “1” to the CLKOFF
O
bit of the PMST register. CLKOUT goes into the high-impedance state when EMU1/OFF
IInput clock to the device. CLKIN connects to an oscillator circuit/device.
VCO is the output of the voltage-controlled oscillator stage of the PLL. This is a 3-state output during normal
operation. Active in silicon test/debug mode.
MULTICHANNEL BUFFERED SERIAL PORT 0, 1, AND 2 SIGNALS
Receive clocks. BCLKR serves as the serial shift clock for the buffered serial-port receiver . Input from an external
clock source for clocking data into the McBSP. When not being used as a clock, these pins can be used as
general-purpose I/O by setting RIOEN = 1.
BCLKR can be configured as an output by the way of the CLKRM bit in the PCR register.
is low.
POST OFFICE BOX 1443 • HOUSTON, TEXAS 77251–1443
11
TMS320VC5420
(
mode (HMODE in is high), to address the on-chi RAM of the 5420. These ins are
I = Input, O = Output, S = Supply, Z = High Impedance
‡
This pin has an internal pullup resistor.
§
These pins have Schmitt trigger inputs.
¶
This pin has an internal bus holder controlled by way of the BSCR register in subchip A.
#
This pin is used by Texas Instruments for device testing and should be left unconnected.
||
This pin has an internal pulldown resistor.
‡§
‡§
‡§
‡§
‡§
‡§
†
MULTICHANNEL BUFFERED SERIAL PORT 0, 1, AND 2 SIGNALS (CONTINUED)
Transmit clocks. Clock signal used to clock data from the transmit register. This pin can also be configured as
an input by setting the CLKXM = 0 in the PCR register. BCLKX can be sampled as an input by way of the IN1
I/O/Z
I/O/Z
I/O/Z
bit in the SPC register. When not being used as a clock, these pins can be used as general-purpose I/O by setting
XIOEN = 1.
These pins are placed into the high-impedance state when OFF
Buffered serial data receive (input) pin. When not being used as data-receive pins, these pins can be used as
I
general-purpose I/O by setting RIOEN = 1.
Buffered serial-port transmit (output) pin. When not being used as data-transmit pins, these pins can be used as
general-purpose I/O by setting XIOEN = 1. These pins are placed into the high-impedance state when OFF
O/Z
low.
Frame synchronization pin for buffered serial-port input data. The BFSR pulse initiates the receive-data process
over BDR pin.
general-purpose I/O by setting RIOEN = 1.
Buffered serial-port frame synchronization pin for transmitting data. The BFSX pulse initiates the transmit-data
process over BDX pin. If RS
by the reset operation.
general-purpose I/O by setting XIOEN = 1. These pins are placed into the high-impedance state when OFF
low.
PRIMARY
When not being used as data-receive synchronization pins, these pins can be used as
is asserted when BFSX is configured as output, then BFSX is turned into input mode
When not being used as data-transmit synchronization pins, these pins can be used as
HOST-PORT INTERFACE SIGNALS
HPI address inputs. HA[0:17] are used by the host device, in the HPI non-multiplexed
HMODE pin is high), to address the on-chip RAM of the ’5420. These pins are
mode
shared with the external memory interface and are only used by the HPI when the interface
is in HPI mode (XIO pin is low).
Parallel bidirectional data bus. HD[0:15] are used by the host device to transfer data to
and from the on-chip RAM of the ’5420. These pins are shared with the external memory
interface and are only used by the HPI when the interface is in HPI mode (XIO pin is low).
The data bus includes bus holders to reduce power dissipation caused by floating, unused
I/O/Z
pins. The bus holders also eliminate the need for external pullup resistors on unused pins.
When the data bus is not being driven by the ’5420, the bus holders keep data pins at the
last driven logic level. The data bus keepers are disabled at reset and can be
enabled/disabled via the BH bit of the BSCR register. These pins are placed into the
high-impedance state when OFF
is low.
is
is
is low.
12
POST OFFICE BOX 1443 • HOUSTON, TEXAS 77251–1443
FIXED-POINT DIGITAL SIGNAL PROCESSOR
Signal Descriptions (Continued)
TMS320VC5420
SPRS080C – MARCH 1999 – REVISED APRIL 2000
NAMEDESCRIPTIONTYPE
HCNTL0
HCNTL1
‡§
HAS
‡§
HCS
‡§
HDS1
‡§
HDS2
HR/WIR/WO
HRDYOREADYI
A_HINT
B_HINT
§
HPIRS
HMODEI
AV
DD
CV
DD
DV
DD
V
SS
†
I = Input, O = Output, S = Supply, Z = High Impedance
‡
This pin has an internal pullup resistor.
§
These pins have Schmitt trigger inputs.
¶
This pin has an internal bus holder controlled by way of the BSCR register in subchip A.
#
This pin is used by Texas Instruments for device testing and should be left unconnected.
||
This pin has an internal pulldown resistor.
†
HOST-PORT INTERFACE SIGNALS (CONTINUED)
PRIMARY
HPI control inputs. The HCNTL0 and HCNTL1 values between HPIA, and HPID registers
PPA3
I
PPA2
IPPA4
IMSTRB
I
O
IHost-port interface (HPI) reset pin. This signal resets the host port interface and both subsystems.
SDedicated power supply that powers the PLL. AVDD = 1.8 V. AVDD can be connected to CVDD.
SDedicated power supply that powers the core CPUs. CVDD = 1.8 V
SDedicated power supply that powers the I/O pins. DVDD = 3.3 V
SDigital ground. Dedicated ground plane for the device.
‡§
‡§
‡§
PS
‡§
DS
PPA0
PPA1
Host mode select. When this pin is low it selects the HPI multiplexed address/data mode. The multiplexed
address/data mode allows hosts with multiplexed address/data lines access to the HPI registers HPIC, HPIA,
and HPID. Host-to-DSP and DSP-to-host interrupts are supported in this mode.
When HMODE is high, it selects the HPI nonmultiplexed mode. HPI nonmultiplexed mode allows hosts with
separate address/data buses to access the HPI address range by way of the 18-bit address bus and the HPI data
(HPID) register via the 16-bit data bus. Host-to-DSP and DSP-to-host interrupts are not supported in this mode.
during HPI reads and writes. These signals are only used in HPI multiplexed address/data
mode (HMODE pin is low).
O
These pins are shared with the external memory interface and are only used by the HPI
when the interface is in HPI mode (XIO pin is low).
Address strobe input. Hosts with multiplexed address and data pins require HAS to latch
the address in the HPIA register. This signal is only used in HPI multiplexed address/data
mode (HMODE pin is low).
O
This pin is shared with the external memory interface and is only used by the HPI when
the interface is in HPI mode (XIO pin is low).
HPI chip-select signal. Thissignal must be active during HPI transfers, and can remain
active between concurrent transfers.
O
This pin is shared with the external memory interface and is only used by the HPI when
the interface is in HPI mode (XIO pin is low).
HPI data strobes. HDS1 and HDS2 are driven by the host read and write strobes to control
transfer HPI transfers.
O
These pins are shared with the external memory interface and are only used by the HPI
when the interface is in HPI mode (XIO pin is low).
HPI read/write signal. This signal is used by the host to control the direction of an HPI
transfer.
This pin is shared with the external memory interface and is only used by the HPI when
the interface is in HPI mode (XIO pin is low).
HPI data-ready output. The ready output informs the host when the HPI is ready for the
next transfer.
This pin is shared with the external memory interface and is only used by the HPI when
the interface is in HPI mode (XIO pin is low). HRDY is placed into the high-impedance state
when OFF
Host interrupt pin. HPI can interrupt the host by asserting this low. The host can clear this
interrupt by writing a “1” to the HINT
O
multiplexed address/data mode (HMODE pin is low). These pins are placed into the
high-impedance state when OFF
is low.
SUPPLY PINS
bit of the HPIC register. Only supported in HPI
is low.
POST OFFICE BOX 1443 • HOUSTON, TEXAS 77251–1443
13
TMS320VC5420
FIXED-POINT DIGITAL SIGNAL PROCESSOR
SPRS080C – MARCH 1999 – REVISED APRIL 2000
Signal Descriptions (Continued)
NAMEDESCRIPTIONTYPE
V
SSA
#
TEST
‡§
TCK
‡
TDI
TDOO
‡
TMS
||
TRST
EMU0I/O/Z
EMU1/OFFI/O/Z
†
SUPPLY PINS (CONTINUED)
Analog ground. Dedicated ground for the PLL. V
S
not separated.
TEST PIN
No connection
EMULATION/TEST PINS
Standard test clock. This is normally a free-running clock signal with a 50% duty cycle. Changes on the test
access port (TAP) of input signals TMS and TDI are clocked into the TAP controller, instruction register, or
I
selected test-data register on the rising edge of TCK. Changes at the TAP output signal (TDO) occur on the falling
edge of TCK.
Test data input. Pin with an internal pullup device. TDI is clocked into the selected register (instruction or data)
I
on a rising edge of TCK.
Test data pin. The contents of the selected register is shifted out of TDO on the falling edge of TCK. TDO is in
high-impedance state except when the scanning of data is in progress. These pins are placed into high-impedance state when OFF
Test mode select. Pin with internal pullup device. This serial control input is clocked into the TAP controller on
I
the rising edge of TCK.
T est reset. When high, TRST gives the scan system control of the operations of the device. If TRST is driven low,
the device operates in its functional mode and the emulation signals are ignored. Pin with internal pulldown
I
device.
Emulator interrupt 0 pin. When TRST is driven low, EMU0 must be high for the activation of the EMU1/OFF
condition. When TRST is driven high, EMU0 is used as an interrupt to or from the emulator system and is defined
as I/O.
Emulator interrupt 1 pin. When TRST is driven high, EMU1/OFF is used as an interrupt to or from the emulator
system and is defined as I/O. When TRST
= 0 puts all output drivers into the high-impedance state.
Note that OFF is used exclusively for testing and emulation purposes (and not for multiprocessing applications).
Therefore, for the OFF
is low.
transitions from high to low, then EMU1 operates as OFF. EMU/OFF
condition, the following conditions apply:
can be connected to VSS if digital and analog grounds are
SSA
TRST = 0, EMU0 = 1, EMU1 = 0
†
I = Input, O = Output, S = Supply, Z = High Impedance
‡
This pin has an internal pullup resistor.
§
These pins have Schmitt trigger inputs.
¶
This pin has an internal bus holder controlled by way of the BSCR register in subchip A.
#
This pin is used by Texas Instruments for device testing and should be left unconnected.
||
This pin has an internal pulldown resistor.
14
POST OFFICE BOX 1443 • HOUSTON, TEXAS 77251–1443
functional overview
TMS320VC5420
FIXED-POINT DIGITAL SIGNAL PROCESSOR
SPRS080C – MARCH 1999 – REVISED APRIL 2000
P, C, D, E Buses and Control Signals
Pbus
’C54x Core A
Modified HPI16
DSP Subsystem A
Interprocessor IRQ’s
Cbus
Dbus
CPU BUS
Host Access Bus
Ebus
Cbus
Pbus
Ebus
36K
Program
SARAM
Peripheral
Bus
Bridge
(6 channels)
P, C, D, E Buses and Control Signals
Dbus
Pbus
48K Prog/Data
SARAM
Peripheral Bus
DMA
Ebus
DMA Bus
Pheripheral Bus
DMA BusDMA Bus
Clocks
Core-to-Core
FIFO Interface
Cbus
Dbus
Pbus
16K Prog/Data
DARAM
GPIO[3:0]
McBSP0
McBSP1
McBSP2
TIMER
APLL
JTAG
Ebus
Pbus
’C54x Core B
Modified HPI16
DSP Subsystem B
Ebus
Cbus
Dbus
Host Access Bus
CPU Bus
Pbus
36K
Program
SARAM
Ebus
Peripheral
Bridge
Pbus
Cbus
48K Prog/Data
SARAM
Bus
Peripheral Bus
DMA
(6 channels)
Dbus
Ebus
DMA Bus
Figure 1. Functional Block Diagram
DMA Bus
Peripheral Bus
Pbus
Cbus
Dbus
16K Prog/Data
DARAM
GPIO[3:0]
McBSP0
McBSP1
McBSP2
TIMER
JTAG
Ebus
POST OFFICE BOX 1443 • HOUSTON, TEXAS 77251–1443
15
TMS320VC5420
FIXED-POINT DIGITAL SIGNAL PROCESSOR
SPRS080C – MARCH 1999 – REVISED APRIL 2000
memory
The total memory address range for each ’5420 subsystem is 384K 16-bit words. The memory space is divided
into three specific memory segments: 256K-word program, 64K-word data, and 64K-word I/O. The program
memory space contains the instructions to be executed as well as tables used in execution. The data memory
space stores data used by the instructions. The I/O memory space is used to interface to external
memory-mapped peripherals and can also serve as extra data storage space. The CPU I/O space should not
be confused with the DMA I/O space, which is completely independent and not accessible by the CPU.
on-chip dual-access RAM (DARAM)
The ’5420 subsystems A and B each have 16K
Each of these RAM blocks can be accessed twice per machine cycle. This memory is intended primarily to store
data values; however, it can be used to store program as well. At reset, the DARAM is mapped into data memory
space. DARAM can be mapped into program/data memory space by setting the OVL Y bit in the PMST register.
on-chip single-access RAM (SARAM)
The ’5420 subsystems A and B each have 84K-word × 16-bit on-chip SARAM (ten blocks of 8K words each and
one block of 4K words).
Each of these SARAM blocks is a single-access memory . This memory is intended primarily to store data values;
however, it can be used to store program as well. At reset, the SARAM (4000h–7FFFh) is mapped into data
memory space. This memory range can be mapped into program/data memory space by setting the OVL Y bit
in the PMST register. The SARAM at 8000h–FFFFh is program memory at reset and can be configured as
program/data memory by setting the DROM bit. SARAM spaces18000h–1FFFFh and 2F000h–2FFFFh are
mapped as program memory only.
program memory
The ’5420 device features a paged extended memory scheme in program space to allow access of up to 256K
of program memory relative to each subsystem. This extended program memory (each subsystem) is organized
into four pages (0–3), each 64K in length. A hardware pin is used to select which DSP subsystem (A or B) has
control of the external memory interface. To implement the extended program memory scheme, the ’5420
device includes the following features:
× 16-bit on-chip DARAM (2 blocks of 8K words).
Two additional address lines (for a total of 18)
A pin (SELA/B) for external memory interface arbitration between subsystem A and B
data memory
The data memory space on each ’5420 subsystem contains up to 64K 16-bit word addresses. The device
automatically accesses the on-chip RAM when addressing within its bounds. When an address is generated
outside the RAM bounds, the device automatically generates an external access.
parallel I/O ports
Each subsystem of the ’5420 has a total of 64K I/O ports. These ports can be addressed by PORTR and
PORTW . The IS
external devices through the I/O ports while requiring minimal off-chip address-decoding logic. The SELA/B pin
selects which subsystem has access to the external I/O space.
external memory interface
The ’5420 has a single external memory interface shared between both subsystems. The external memory
interface enables the ’5420 subsystems to connect to external memory devices or other parallel interfaces. The
SELA/B pin is used to determine which subsystem has access to the external memory interface. When the
SELA/B pin is low , subsystem A has access to the external memory interface, and when it is high, subsystem
16
signal indicates the read/write access through an I/O port. The devices can interface easily with
POST OFFICE BOX 1443 • HOUSTON, TEXAS 77251–1443
TMS320VC5420
FIXED-POINT DIGITAL SIGNAL PROCESSOR
SPRS080C – MARCH 1999 – REVISED APRIL 2000
external memory interface (continued)
B has access to the interface. The external memory interface is also shared with the host port interface (HPI).
The XIO pin is used to select between the external memory interface and the hostport interface. When the XIO
pin is high, the external memory interface is active, and when it is low, the host port interface is active.
processor mode status register (PMST)
Each subsystem has a processor-mode status register (PMST) that controls memory configuration. The bit
layout of the PMST register is shown in Figure 1
1576543210
IPTR
R/WR/WR/WR/WR/WR/WR/WR/W
LEGEND: R = Read, W = Write
Figure 1. Processor Mode Status Register (PMST) Bit Layout
The functions of the PMST register bits are illustrated in the memory map. The MP/MC bit is used to map the
upper address range of all program space pages (x8000–xFFFF) as either external or internal memory. The
OVL Y bit is used to overlay the on-chip DARAM0 and SARAM1 blocks from dataspace onto to program space.
Similarly, the DROM bit is used to overlay the SARAM2 block from program space onto data space. See the
TMS320C54x DSP CPU and Peripherals Reference Set, Volume 1
description of the other bits of the PMST register.
MP/MCOVLYAVISDROMCLKOFFSMULSST
(literature number SPRU131) for a
Due to the dual-processor configuration and the several EMIF/HPI options available, the MP/MC bit is initialized
at the time of device reset to a logic level that is dependent on the XIO, HMODE, and SELA/B pins. Table 1
shows the initialized logic level of the MP/MC bit and how it depends on these pins.
Table 1. MP/MC Bit Logic Levels at Reset
’5420 PINSMP/MC BIT
XIOHMODESELA/BSUBSYSTEM ASUBSYSTEM B
0XX00
10X11
11010
11101
POST OFFICE BOX 1443 • HOUSTON, TEXAS 77251–1443
17
TMS320VC5420
FIXED-POINT DIGITAL SIGNAL PROCESSOR
SPRS080C – MARCH 1999 – REVISED APRIL 2000
memory map
DataHexProgram Page 0Hex
0000
005F
0060
007F
0080
3FFF
4000
7FFF
8000
FFFF
†
The external memory interface must be enabled by driving the XIO pin high, in order for external memory accesses to occur.
Memory-
Mapped
Registers
Scratch-Pad
DARAM
On-Chip
DARAM 0
(16K Words)
On-Chip
SARAM 1
(16K Words)
On-Chip
SARAM 2
(32K Words)
Prog/Data
(DROM=1)
External
(DROM=0)
0000
On-Chip
DARAM 0
(16K Words)
Prog/Data
(OVLY=1)
External
†
(OVLY=0)
3FFF
4000
On-Chip
SARAM 1
(16K Words)
Prog/Data
(OVLY=1)
External
†
(OVLY=0)
7FFF
8000
On-Chip
SARAM 2
(32K Words)
Prog/Data
(MP/MC=0)
External
†
(MP/MC=1)
FFFF
†
(extended)
10000
13FFF
14000
17FFF
18000
1FFFF
Program Page 1Hex
On-Chip
DARAM 0
(16K Words)
Prog/Data
(OVLY=1)
External
†
(OVLY=0)
On-Chip
SARAM 1
(16K Words)
Prog/Data
(OVLY=1)
External
†
(OVLY=0)
On-Chip
SARAM 3
(32KWords)
(MP/MC=0)
External
(MP/MC=1)
†
(extended)(extended)
20000
23FFF
24000
27FFF
28000
2EFFF
2F000
2FFFF
Program Page 2Hex
On-Chip
DARAM 0
(16K Words)
Prog/Data
(OVLY=1)
External
(OVLY=0)
On-Chip
SARAM 1
(16K Words)
Prog/Data
(OVLY=1)
External
(OVLY=0)
Reserved
(MP/MC=0)
External
(MP/MC=1)
On-Chip
SARAM 4
(4K Words)
(MP/MC=0)
External
(MP/MC=1)
Program Page 3Hex
30000
On-Chip
DARAM 0
(16K Words)
Prog/Data
(OVLY=1)
†
33FFF
34000
†
37FFF
38000
†
†
3FFFF
External
(OVLY=0)
On-Chip
SARAM 1
(16K Words)
Prog/Data
(OVLY=1)
External
(OVLY=0)
Reserved
(MP/MC=0)
External
(MP/MC=1)
(extended)
†
†
†
0000
FFFF
I/OHex
64K
External
I/O Ports
†
Figure 2. Memory Map for Each CPU Subsystem
multicore reset signals
The ’5420 device includes three reset signals: A_RS, B_RS, and HPIRS. The A_RS and B_RS pins function
as the CPU reset signal for subsystem A and subsystem B, respectively. These signals reset the state of the
CPU registers and upon release, initiates the reset function. Additionally, the A_RS signal resets the on-chip
PLL and initializes the CLKMD register to bypass mode.
The HPI reset signal (HPIRS) places the HPI peripheral into a reset state. It is necessary to wait three clock
cycles after the rising edge of HPIRS
reset vector initialization
The ’5420 device does not have on-chip ROM and therefore does not contain bootloader routines/software.
Consequently , the user must have a valid reset vector in place before releasing the reset signal. This is referred
reset vector initialization
to as
program memory and begins to execute the instructions found in memory . The application code is raw program
and data words and does not require the traditional
before performing an HPI access.
. After reset, the ’5420 device fetches the reset vector at address 0xFF80 in
boot-table
or
boot-packet
format.
18
POST OFFICE BOX 1443 • HOUSTON, TEXAS 77251–1443
TMS320VC5420
FIXED-POINT DIGITAL SIGNAL PROCESSOR
SPRS080C – MARCH 1999 – REVISED APRIL 2000
reset vectorinitialization (continued)
The selection of the reset initialization option is determined by the state of three pins; XIO, XMODE, and SELA/B.
The options include:
The HPI method is only valid when the level of the XIO pin is low. The ’5420 acts as a slave to an external master
host. The host device must keep the ’5420 device in reset as it downloads code to the subsystem that is
determined by the logic level of the SELA/B pin. When SELA/B is low, the master downloads code to
subsystem A. By driving SELA/B high, the master host can subsequently download code to subsystem B. The
HMODE pin determines the configuration of the HPI (multiplexed or nonmultiplexed) and is an asynchronous
input. Therefore, HMODE can be changed to the desired configuration while A_RS
the transfer. Once the subsystem(s) have been loaded and are ready to execute, the master host can release
the reset pin(s).
There are two valid options for controlling the reset function of the subsystems. The first option is to hold the
A_RS and B_RS pins low while the HPIRS pin transitions from low to high. This keeps the cores in reset while
allowing the HPI full access to download the application code. The host can now drive the A_RS
signals high simultaneously or separately to release the respective subsystem from reset. The subsystems then
fetch their respective reset vector. If the subsystems are released from reset seperately, subsystem A should
be released from reset first, since the A_RS pin resets the on-chip PLL that is common to both subsystems.
and B_RS are low prior to
and B_RS
Another valid option is to keep the A_RS and B_RS pins high while the host transitions the HPIRS pin from low
to high. Special internal logic causes the HPI to be fully operable and the cores remain in reset. As a result, after
the host processor has downloaded the application code via the HPI, it must perform an additional HPI write
(any value) to address 0x2F. This releases the respective subsystem from reset. By changing the value of
SELA/B, the host can write to 0x2F via the HPI to release the other subsystem from reset.
EMIF-to-HPI
In this particular vector initialization method, the host processor controlling the HPI is one of the subsystems.
The master host is subsystem A if SELA/B is low and subsystem B when SELA/B is high. As described in the
signal descriptions table, the address, data, and control signals of the program space are multiplexed with the
HPI signals. In a special mode when XIO is high (EMIF mode) and HMODE is high (HPI nonmultiplexed mode),
these multiplexed signals are connected, making it possible for the master subsystem’s EMIF to initialize the
slave subsystem via the slave’s HPI. The master subsystem then releases the slave from reset either by
transitioning the hardware reset signal (x_RS
HPI. As a result, the slave core fetches the reset vector.
) high, or in software, by writing to memory location 0x2F via the
simultaneous EMIF
The simultaneous EMIF vector initialization option allows both subsystems to access external memory
simultaneously . The subsystems are designed to operate synchronized with one another while accessing the
same locations simultaneously . In this mode, when XIO is high and HMODE is low , one subsystem is given full
control of the EMIF while the other subsystem relies on the synchronization of the two subsystems. Instructions
fetched by one subsystem are ready for both subsystems to execute. After the application code is executed or
transferred to internal memory, write accesses to external memory are prohibited.
This method requires the A_RS and B_RS pins to be tied high while HPIRS transitions from low to high. When
HPIRS transitions high, both subsystems fetches the same reset vector .
POST OFFICE BOX 1443 • HOUSTON, TEXAS 77251–1443
19
TMS320VC5420
FIXED-POINT DIGITAL SIGNAL PROCESSOR
SPRS080C – MARCH 1999 – REVISED APRIL 2000
sequential EMIF
The sequential EMIF option allows one master subsystem to run from external memory while controlling the
slave subsystem’s RS signal and the SELA/B pin. At system reset, only the master subsystem is actually reset.
Upon a low-to-high transition of the master’s RS signal, the master subsystem fetches the reset vector and
proceeds to copy external application code to internal memory space. The master subsystem begins executing
the application code, then changes the state of SELA/B, relinquishing the external EMIF to the slave subsystem.
The master then releases the slave RS
the external application code to internal memory space. Note, GPIO pins on the master subsystem can be used
to control the SELA/B and slave reset (x_RS) pins externally.
on-chip peripherals
All the ’54x devices have the same CPU structure; however, they have dif ferent on-chip peripherals connected
to their CPUs. The on-chip peripheral options provided on each subsystem of the ’5420 are:
Software-programmable wait-state generator
Programmable bank-switching
16-bit host-port interface (HPI16)
Multichannel buffered serial ports (McBSPs)
A hardware timer
A software-programmable clock generator with a phase-locked loop (PLL)
signal. As a result, the slave fetches the reset vector and begins to copy
software-programmable wait-state generators
The Software-programmable wait-state generator can be used to extend external bus cycles up to fourteen
machine cycles to interface with slower off-chip memory and I/O devices. Note that all external memory
accesses on the ’5420 require at least one wait state. The software wait-state register (SWWSR) controls the
operation of the wait-state generator. The SWWSR of a particular DSP subsystem (A or B) is used for the
external memory interface, depending on the logic level of the SELA/B pin.The 14 LSBs of the SWWSR specify
the number of wait states (0 to 7) to be inserted for external memory accesses to five separate address ranges.
This allows a different number of wait states for each of the five address ranges.
Additionally, the software wait-state multiplier (SWSM) bit of the software wait-state control register (SWCR)
defines a multiplication factor of 1 or 2 for the number of wait states. At reset, the wait-state generator is initialized
to provide seven wait states on all external memory accesses. The SWWSR bit fields are shown in Figure 3
and described in Table 2.
Table 2. Software Wait-State Register (SWWSR) Bit Fields
TMS320VC5420
SPRS080C – MARCH 1999 – REVISED APRIL 2000
BIT
NO.NAME
15XPA0
14–12I/O1
11–9Data1
8–6Data1
5–3Program1
2–0Program1
RESET
VALUE
FUNCTION
Extended program address control bit. XP A is used in conjunction with the program space fields
(bits 0 through 5) to select the address range for program space wait states.
I/O space. The field value (0–7) corresponds to the base number of wait states for I/O space accesses
within addresses 0000–FFFFh. The SWSM bit of the SWCR defines a multiplication factor of 1 or 2 for
the base number of wait states.
Upper data space. The field value (0–7) corresponds to the base number of wait states for external
data space accesses within addresses 8000–FFFFh. The SWSM bit of the SWCR defines a
multiplication factor of 1 or 2 for the base number of wait states.
Lower data space. The field value (0–7) corresponds to the base number of wait states for external
data space accesses within addresses 0000–7FFFh. The SWSM bit of the SWCR defines a
multiplication factor of 1 or 2 for the base number of wait states.
Upper program space. The field value (0–7) corresponds to the base number of wait states for external
program space accesses within the following addresses:
XPA = 0: x8000 – xFFFFh
XPA = 1: The upper program space bit field has no effect on wait states.
The SWSM bit of the SWCR defines a multiplication factor of 1 or 2 for the base number of wait
states.
Program space. The field value (0–7) corresponds to the base number of wait states for external
program space accesses within the following addresses:
XPA = 0: x0000–x7FFFh
XPA = 1: 00000–3FFFFh
The SWSM bit of the SWCR defines a multiplication factor of 1 or 2 for the base number of wait
states.
The software wait-state multiplier bit of the software wait-state control register (SWCR) is used to extend the
base number of wait states selected by the SWWSR. The SWCR bit fields are shown in Figure 4 and described
in Table 3.
115
Reserved
R/W-0
LEGEND: R = Read, W = Write
0
SWSM
R/W-0
Figure 4. Software Wait-State Control Register (SWCR) [MMR Address 002Bh]
Table 3. Software Wait-State Control Register (SWCR) Bit Fields
PIN
NO.NAME
15–1Reserved0
0SWSM0
RESET
VALUE
FUNCTION
These bits are reserved and are unaffected by writes.
Software wait-state multiplier . Used to multiply the number of wait states defined in the SWWSR by a factor
of 1 or 2.
SWSM = 0: wait-state base values are unchanged (multiplied by 1).
SWSM = 1: wait-state base values are mulitplied by 2 for a maximum of 14 wait states.
POST OFFICE BOX 1443 • HOUSTON, TEXAS 77251–1443
21
TMS320VC5420
FIXED-POINT DIGITAL SIGNAL PROCESSOR
SPRS080C – MARCH 1999 – REVISED APRIL 2000
programmable bank-switching
Programmable bank-switching can be used to insert one cycle automatically when crossing memory-bank
boundaries inside program memory or data memory space. One cycle can also be inserted when crossing from
program-memory space to data-memory space (’54x) or one program memory page to another program
memory page. This extra cycle allows memory devices to release the bus before other devices start driving the
bus; thereby avoiding bus contention. The size of the memory bank for the bank-switching is defined by the
bank-switching control register (BSCR). The BSCR of a particular DSP subsystem (A or B) is used for the
external memory interface depending on the logic level of the SELA/B pin.
151211109873210
BNKCMP
R/WR/WR/WR/WR/WR/W
LEGEND: R = Read, W = Write
PS-DSReservedIPIRQReservedBHReservedEXIO
Figure 5. BSCR Register Bit Layout for Each DSP Subsystem
Table 4. BSCR Register Bit Functions for Each DSP Subsystem
BIT
NO.
15–12BNKCMP1111
11PS-DS1
10–9Reserved0These bits are reserved and are unaffected by writes.
8IPIRQ0
7–3Reserved0These bits are reserved and are unaffected by writes.
2BH0
1Reserved0These bits are reserved and are unaffected by writes.
0EXIO0
BIT
NAME
RESET
VALUE
FUNCTION
Bank compare. BNKCMP determines the external memory-bank size. BNKCMP is used to mask the four
MSBs of an address. For example, if BNKCMP = 1111b, the four MSBs (bits 12–15) are compared,
resulting in a bank size of 4K words. Bank sizes of 4K words to 64K words are allowed.
Program read – data read access. PS-DS inserts an extra cycle between consecutive accesses of
program read and data read or data read and program read.
PS-DS = 0 No extra cycles are inserted by this feature.
PS-DS = 1One extra cycle is inserted between consecutive data and program reads.
The IPIRQ bit is used to send an interprocessor interrupt to the other subsystem. IPIRQ=1 sends the
interrupt. IPIRQ must be cleared before subsequent interrupts can be made. Refer to the interrupts section
for more details
Bus holder. BH controls the data bus holder feature: BH is cleared to 0 at reset.
BH = 0The bus holder is disabled.
BH = 1The bus holder is enabled. When not driven, the data bus (PPD[15:0]) is held in the
previous logic level.
External bus interface off. The EXIO bit controls the external bus-off function.
EXIO = 0 The external bus interface functions as usual.
EXIO = 1 The address bus, data bus, and control signals become inactive after completing the
current bus cycle. Note that the DROM, MP/MC
HM bit of ST1 cannot be modified when the interface is disabled.
, and OVLY bits in the PMST and the
22
POST OFFICE BOX 1443 • HOUSTON, TEXAS 77251–1443
TMS320VC5420
FIXED-POINT DIGITAL SIGNAL PROCESSOR
SPRS080C – MARCH 1999 – REVISED APRIL 2000
16-bit host-port interface (HPI16)
The HPI16 is an enhanced 16-bit version of the ’C54x 8-bit host-port interface (HPI). The HPI16 is designed
to allow a 16-bit host to access the DSP on-chip memory, with the host acting as the master of the interface.
Figure 6 illustrates the available memory accessible by the HPI. It should be noted that neither the CPU nor DMA
I/O spaces can be accessed using the host-port interface.
16-bit bidirectional host-port interface (HPI16)
Hex
0000
001F
0020
005F
0060
3FFF
4000
7FFF
8000
Program Page 0
Reserved
McBSP
DXR/DRR
MMRegs Only
On-Chip
DARAM 0
(Overlayed)
Prog/Data
On-Chip
SARAM 1
(Overlayed)
Prog/Data
On-Chip
SARAM 2
(32K Words)
Prog/Data
Hex
10000
1005F
10060
13FFF
14000
17FFF
18000
Program Page 1
Reserved
On-Chip
DARAM 0
(Overlayed)
Prog/Data
On-Chip
SARAM 1
(Overlayed)
Prog/Data
On-Chip
SARAM 3
(32K Words)
Program
Hex
20000
2005F
20060
23FFF
24000
27FFF
28000
2EFFF
2F000
Program Page 2
Reserved
On-Chip
DARAM 0
(Overlayed)
Prog/Data
On-Chip
SARAM 1
(Overlayed)
Prog/Data
Reserved
On-Chip
SARAM 4
(4K Words)
Program
Hex
30000
3005F
30060
33FFF
34000
37FFF
38000
Program Page 3
Reserved
On-Chip
DARAM 0
(Overlayed)
Prog/Data
On-Chip
SARAM 1
(Overlayed)
Prog/Data
Reserved
FFFF
1FFFF
2FFFF
Figure 6. Memory Map Relative to Host-Port interface
16-bit bidirectional data bus
Multiple data strobes and control signals to allow glueless interfacing to a variety of hosts
Multiplexed
18-bit address bus used in nonmultiplexed mode to allow access to all internal memory (including internal
extended address pages)
18-bit address register used in multiplexed mode. Includes address autoincrement feature for faster
accesses to sequential addresses
Interface to on-chip DMA module to allow access to entire internal memory space
HRDY signal to hold off host accesses due to DMA latency
Control register available in
interrupts, extended addressing, and data prefetch capability
The HPI16 acts as a slave to a 16-bit host processor and allows access to the on-chip memory of the DSP . There
are two modes of operation as determined by the HMODE signal:
HPI multiplexed mode
and
nonmultiplexed address/data modes
multiplexed
mode only . Accessible by either host or DSP to provide host/DSP
multiplexed
mode and
nonmultiplexed
mode.
In
multiplexed
products. A host with a multiplexed address/data bus can access the HPI16 data register (HPID), address
register (HPIA), or control register (HPIC) via the HD bidirectional data bus. The host initiates the access with
the strobe signals (HDS1
signals. The DSP can interrupt the host via the HINT signal, and can stall host accesses via the HRDY signal.
host/DSP interrupts
multiplexed
In
HPIC register.
For host-to-DSP interrupts, the host must write a “1” to the DSPINT bit of the HPIC register. This generates an
interrupt to the DSP . This interrupt can also be used to wake the DSP from any of the IDLE 1,2, or 3 states. Note
that the DSPINT bit is always read as “0” by both the host and DSP.
For DSP-to-host interrupts, the DSP must write a “1” to the HINT bit of the HPIC register to interrupt the host
via the HINT
register. Note that writing a “0” to the HINT bit by either host or DSP has no effect.
mode, HPI16 operation is very similar to the standard 8-bit HPI, which is available with other ’C54x
, HDS2, HCS) and controls the type of access with the HCNTL, HR/W, and HAS
mode, the HPI16 offers the capability for the host and DSP to interrupt each other through the
pin. The host acknowledges and clear this interrupt by also writing a “1” to the HINT bit of the HPIC
HPI nonmultiplexed mode
In
nonmultiplexed
via the HD 16-bit bidirectional data bus, and the address register (HPIA) via the 18-bit HA address bus. The host
initiates the access with the strobe signals (HDS1, HDS2, HCS) and controls the direction of the access with
the HR/W signal. The HPI16 can stall host accesses via the HRDY signal. Note that the HPIC register is not
available in
read or write access.
mode, a host with separate address/data buses can access the HPI16 data register (HPID)
nonmultiplexed
mode since there are no HCNTL signals available. All host accesses initiate a DMA
other HPI16 system considerations
operation during IDLE2
The HPI16 can continue to operate during IDLE1 or IDLE2 by using special clock management logic that turns
on relevant clocks to perform a synchronous memory access, and then turns the clocks back off to save power .
The DSP CPU does not wake up from the IDLE mode during this process.
24
POST OFFICE BOX 1443 • HOUSTON, TEXAS 77251–1443
Loading...
+ 53 hidden pages
You need points to download manuals.
1 point = 1 manual.
You can buy points or you can get point for every manual you upload.