

# **SMT410**

**User Manual V1.0** 



# **Revision History**

| Date     | Comments             | Engineer | Version |
|----------|----------------------|----------|---------|
| 11/04/00 | Initial SMT410 Draft | SP       | 1.0     |
|          |                      |          |         |
|          |                      |          |         |

# **Table of Contents**

| 1  |     | Intro         | ductio | n                                                                                        | . 8 |  |  |  |  |
|----|-----|---------------|--------|------------------------------------------------------------------------------------------|-----|--|--|--|--|
| 2  |     | Fund          | tional | Description                                                                              | . 9 |  |  |  |  |
| 3  |     | Setti         | ng Up  | the SMT410                                                                               | 10  |  |  |  |  |
| 4  |     | Mem           | ory N  | lap                                                                                      | 11  |  |  |  |  |
|    | 4.1 |               | PCI I  | Bridge Chip Internal Register (BAR0)                                                     | 11  |  |  |  |  |
|    | 4.2 | 2             | I/O S  | Space Register Assignments (BAR1)                                                        | 11  |  |  |  |  |
|    | 4.3 | 3             | Mem    | ory Space Assignments(BAR2)                                                              | 12  |  |  |  |  |
| 5  |     | DSP           | Resc   | esource Memory Map13                                                                     |     |  |  |  |  |
| 6  |     | Shar          | ed Me  | emory Resource                                                                           | 14  |  |  |  |  |
| 7  |     | Com           | Ports  |                                                                                          | 15  |  |  |  |  |
|    | 7.1 |               | Buffe  | ered ComPort                                                                             | 16  |  |  |  |  |
| 8  |     | Com           | Port t | o PCI Interface                                                                          | 18  |  |  |  |  |
|    | 8.1 |               | Com    | Port Registers (Offset 0x10, BAR1)                                                       | 18  |  |  |  |  |
|    | 8.2 | 2             | Cont   | rol Register (Offset 0x14, BAR1)                                                         | 18  |  |  |  |  |
|    | 8.3 | 3             | Statu  | us Register (Offset 0x14, BAR1 , Read-Only)                                              | 19  |  |  |  |  |
|    | 8.4 | ŀ             | Inter  | rupt Control Register (Offset 0x18, BAR1)                                                | 20  |  |  |  |  |
| 9  | ,   | JTAC          | G Con  | stroller                                                                                 | 22  |  |  |  |  |
| 10 | )   | Usin          | g the  | SMT410 External/Internal JTAG with TI Tools                                              | 24  |  |  |  |  |
| 11 | l   | Firm          | ware   | Upgrades                                                                                 | 25  |  |  |  |  |
| 12 | 2   | Glob          | al/Loc | cal Bus Transfers, DSP <-> PCI                                                           | 27  |  |  |  |  |
|    | 12. | .1            | Mailb  | pox Accesses                                                                             | 27  |  |  |  |  |
|    |     | 12.1.         | 1      | Doorbell Interrupts                                                                      | 28  |  |  |  |  |
|    | 12. | .2            | DSP    | Interrupt Control                                                                        | 28  |  |  |  |  |
|    | 12. | .3            | DSP    | To Local Aperture 0 control and Accessing                                                | 29  |  |  |  |  |
|    |     | 12.3.         | 1      | Global bus access protocol                                                               | 31  |  |  |  |  |
| 13 | 3   | Inter         | rupts. |                                                                                          | 34  |  |  |  |  |
|    | 13. | .1            | SMT    | 410-To-PCI Interrupts                                                                    | 34  |  |  |  |  |
|    | 13. | .2            |        | To-SMT410 Interrupts                                                                     |     |  |  |  |  |
|    | 13. | .3            | Inter  | rupt Registers                                                                           | 35  |  |  |  |  |
|    |     | 13.3.         | 1      | PCI Interrupt Configuration Register(Offset 0x4C, BAR0)                                  |     |  |  |  |  |
|    |     | 13.3.         | 2      | PCI Interrupt Status Register(Offset 0x48, BAR0)                                         | 37  |  |  |  |  |
|    |     | 13.3.         | 3      | Local Bus Interrupt Mask Register(Offset 0x77, BAR0)                                     | 38  |  |  |  |  |
|    |     | 13.3.         | 4      | Local Bus Interrupt Status Register(Offset 0x76, BAR0)                                   | 39  |  |  |  |  |
|    |     | 13.3.<br>0xD2 |        | PCI Mailbox WRITE/READ Interrupt Control Register(Offset: Write 0xD0, BAR0 Re            |     |  |  |  |  |
|    |     | 13.3.<br>Read |        | Local Bus Mailbox WRITE/READ Interrupt Control Register(Offset: Write 0xD4, BAI 6, BAR0) |     |  |  |  |  |

|    | 13.3<br>BAF | 8.7<br>RO) | Mailbox Write/Read Interrupt Status Register(Offset: Write 0xD8, BAR0 Read 0xD 41 | ıΑ, |
|----|-------------|------------|-----------------------------------------------------------------------------------|-----|
|    | 13.3        | 8.8        | INTREG Register(Offset 0x40, BAR1)                                                | 41  |
| 1  | 3.4         | Exar       | mple                                                                              | 42  |
| 14 | Perf        | ormar      | nce Figures                                                                       | 44  |
| 15 | Med         | hanica     | al Dimensions                                                                     | 45  |
| 16 | Pow         | er cor     | nsumption                                                                         | 45  |
| 17 | Cab         | les an     | d Connectors                                                                      | 46  |
| 1  | 7.1         | Com        | Ports                                                                             | 46  |
| 1  | 7.2         | Buffe      | ered ComPort Cabling                                                              | 46  |
| 1  | 7.3         | JTA        | G cabling                                                                         | 47  |
| 18 | Whe         | ere's th   | nat Jumper?                                                                       | 49  |

# **Table of Tables**

| Table 1 : Table of Abbreviations                                   | 7  |
|--------------------------------------------------------------------|----|
| Table 2 : I/O address space map                                    | 11 |
| Table 3 : Memory space map                                         | 12 |
| Table 4 : Memory space map                                         | 13 |
| Table 5 : ComPort configuration register                           | 16 |
| Table 6 : Comport selection                                        | 16 |
| Table 7 : Control Register                                         | 18 |
| Table 8 : Status Register                                          | 20 |
| Table 9 : Interrupt Control Register                               | 21 |
| Table 10 : JTAG Header pin function                                | 26 |
| Table 11 : PCI Interrupt Configuration Register                    | 37 |
| Table 12 : PCI Interrupt Status Register                           | 38 |
| Table 13: Local Bus Interrupt Mask Register                        |    |
| Table 14 : Local Bus Interrupt Status Register                     | 39 |
| Table 15 : PCI Mailbox WRITE/READ Interrupt Control Register       | 40 |
| Table 16 : Local Bus Mailbox WRITE/READ Interrupt Control Register | 40 |
| Table 17 : Mailbox Write/Read Interrupt Status Register            | 41 |
| Table 18 : INTREG Register                                         | 42 |
| Table 19 : Buffered ComPort connector pin out                      | 47 |
| Table 20 : Internal JTAG out (XDS-510) pin descriptions            | 48 |
| Table 21: Internal JTAG in (XDS-510) pin descriptions              | 48 |

# **Table of Figures**

| Figure 1: ComPort connection diagram               | 15 |
|----------------------------------------------------|----|
| Figure 2 : TBC Data Routing                        | 22 |
| Figure 3 : JTAG header pin numbers                 | 26 |
| Figure 4 : Local Bus to DSP Connectivity           | 27 |
| Figure 5 : DSP Transfer via the Local Aperture 0   | 30 |
| Figure 6 : Timing diagram for DSP local bus access | 32 |
| Figure 7 : SMT410 to PCI Interrupts                | 34 |
| Figure 8 : PCI to SMT410 Interrupts                | 35 |
| Figure 9 : Jumper Finder Diagram                   | 49 |

# **Table Of Abbreviations**

| BAR  | Base Address Region                    |  |
|------|----------------------------------------|--|
| DMA  | Direct Memory Access                   |  |
| EPLD | Electrically Programmable Logic Device |  |
| PCI  | Peripheral Component Interconnect      |  |
| SDB  | Sundance Digital Bus                   |  |
| SRAM | Static Random Access Memory            |  |
| TBC  | Test Bus Controller                    |  |
| TIM  | Texas Instruments Module               |  |

**Table 1: Table of Abbreviations** 



#### 1 Introduction

The SMT410 is a single site module carrier board that provides access to a TIM module over the PCI Mezzanine Card bus.

An on-board JTAG controller allows systems to be debugged using Code Composer Studio. This JTAG controller also has buffered outputs that can be accessed using connectors on the carrier's back panel. This allows off-board devices to be connected into the JTAG chain.

A single buffered ComPort with conflict protection is also available on the chassis back panel. This will have the versatility to access all six ComPorts on the TIM.

The main connection to the PCI bus is via the module Global Bus. A single ComPort is also be mapped to the PCI bus providing support for application boot and data transfer.

A 1 MB of SRAM is mapped on to the Global Bus and can be accessed by the TIM as a global resource or by the PCI Bridge.

The board requires a 3.3 volt supply, which is generated from the 5 volt supply that is taken from the PMC connector, and is made available at the fixing pillars for the module.





## 2 Functional Description

The PCI interface connects to a Quick Logic EPC363 Bridge device. It has a 32-bit 33MHz PCI interface that supports I<sup>2</sup>C control, mailbox register access, and direct memory reads and writes. The PCI bus is translated to a Local PCI bus, which is connected to the following devices:

- Shared SRAM 1MB
- Control EPLD that manages ComPort access and the SDB interface
- JTAG controller
- Module Global Bus
- PCI Bridge device

An on-board arbitration unit controls which device, Master Module or PCI Bridge, has access to this local PCI bus resource.

The local PCI bus has a 33MHz clock to control transfers between the various resources. This is available on the CLKIN pin on the Master site and should be selected in preference to the on-board oscillator to allow the DSP to synchronise its accesses to and from the PCI Bridge registers. The PCI Bridge has an input and output FIFO capable of transferring 256 32-bit words of data to and from the DSP at 33MHz, thus bursting a maximum local bus transfer rate of 132MB/s.

The Master Module can access the SRAM over the PCI local bus at transfer rates up to 100MB/s. The number of wait states required by the Master Module will vary depending on the speed of the module. Maximum access rates use a 20ns strobe cycle.

The JTAG controller is based on the TI 8990 device, and drivers can be supplied for Code Composer Studio (Part Number <u>SMT6012</u>).





# 3 Setting Up the SMT410

The SMT410 should be set up in the following way.

- Turn the PC off and insert the Card into a spare PMC PCI slot.
- Switch on PC and wait for the OS to boot up.
- Windows 95/98/NT/2000 will detect a new hardware.
- Windows should automatically find the drivers from the CD, if not browse to the CD or if you downloaded from the ftp site to the folder where you unzipped the SMT6300 software.
- 3L application software will detect the SMT410 if the SET TISLINK variable is set to SMT320.
- You can run the SMTBoardInfo application to detect the number of SMT410s in your system and report their slot positions and I/O addresses. This information is required when setting up code composer for the board. SMTBoardInfo is part of the SMT6300 package.





## 4 Memory Map

All address information is given in bytes:

#### 4.1 PCI Bridge Chip Internal Register (BAR0)

Please see V363EPC Local Bus PCI Bridge User Manual V1.04 (<a href="http://www.quicklogic.com/home.asp?PageID=223&sMenuID=114#Docs">http://www.quicklogic.com/home.asp?PageID=223&sMenuID=114#Docs</a>) for details of internal registers.

Note: Where required, registers from the V<sup>3</sup> datasheet have been included.

#### 4.2 I/O Space Register Assignments (BAR1)

In target mode, the SMT410 is accessed by a host device across the PCI bus. This allows access to the target mode registers. The operating system or BIOS will normally allocate a base address for the target mode registers of each SMT410. Access to each register within the SMT410 is then specified by this base address and the offset shown in the table below.

The I/O address space is decoded as shown in the table below.

| Offset       | Register(Write)       | Register(Read)        | Width |
|--------------|-----------------------|-----------------------|-------|
| 0x0          | -                     | -                     |       |
| 0x4          | -                     | -                     |       |
| 0x8          | -                     | -                     |       |
| 0x0C         | -                     | -                     |       |
| 0x10         | COMPORT_OUT           | COMPORT_IN            | 32    |
| 0x14         | CONTROL               | STATUS                | 32    |
| 0x18         | INT_CONTROL           |                       | 32    |
| 0x1C         | -                     | -                     |       |
| 0x20 to 0x3F | COMPORT Configuration | COMPORT Configuration |       |
| 0x24         | -                     | -                     |       |
| 0x40         | INTREG                | INTREG                | 16    |
| 0x80 to 0xAF | TBC Write             | TBC Read              | 16    |

Table 2: I/O address space map





## 4.3 Memory Space Assignments(BAR2)

| Address                   | Description                | Notes                                                                       |
|---------------------------|----------------------------|-----------------------------------------------------------------------------|
| 0x0000 0000 – 0x000F FFFF | Shared Memory Bank         | 1MB SRAM                                                                    |
| 0x00200090                | ComPort Data<br>Mirror     | Mirror of COMPORT_OUT / COMPORT_IN in I/O Space Register Assignments (BAR1) |
|                           |                            | See Note 2                                                                  |
| 0x00200094                | ComPort Status<br>Mirror   | Mirror of Control / Status in I/O<br>Space Register<br>Assignments (BAR1)   |
|                           |                            | See Note 2                                                                  |
| 0x00200098                | ComPort Int_Control Mirror | Mirror of Int_Control in I/O<br>Space Register<br>Assignments (BAR1)        |
|                           |                            | See Note 2                                                                  |
| 0x0020 0000-0x0020 007F   | Global Bus                 | See Note 1                                                                  |
| 0x0020 0240 – 0x0020 025F | SDB Data Register          | Input/Output 16 bit SDB Interface                                           |
| 0x0020 0260 – 0x0020 027F | SDB Control Register       | SDB Control/Status                                                          |

Table 3: Memory space map

Note 1: In order for the TIM to respond to accesses for this area address line GADD30 and GADD19 of the TIM site connector must be decoded as high and GADD7 and GADD5 must be decoded as low.

Note 2: These mirrors of Addresses in the I/O Space (BAR1) allow increased transfer speeds across the host ComPort link (in excess of 10X increase).





# 5 DSP Resource Memory Map

The Master module on the SMT410 can access the various resources available, including the Shared SRAM and the PCI Bridge. Access to the PCI Bridge allows the DMA engine in the PCI Bridge to be initiated by the DSP, mailbox registers can also be manipulated. The table below illustrates the resources and their corresponding address region when accessed by the Master module.

| C60 Address Access        | Description             | Notes                         |
|---------------------------|-------------------------|-------------------------------|
| 0xD000 0000 – 0xD00F FFFF | Shared Memory Bank      | 1Mbyte SRAM                   |
| 0x1C00 0000 - 0x1C00 00FF | PCI Bridge Registers    | PCI Bridge Internal resisters |
| 0x1800 0000 – 0x183F FFFF | Local-to-PCI Aperture 0 | PCI Bridge Aperture 0 Space   |

Table 4: Memory space map





## **6 Shared Memory Resource**

The shared memory on the SMT410 is 1 MB of SRAM, which can be accessed by the PCI host and the TIM module. This allows applications to transfer data between the host PC and the DSP at data rates approaching 100MB/s. The address of the shared memory is shown in the memory map.

The PCI Bridge DMA processor sees the shared memory at a different address from that used for normal accesses. For normal memory access the memory base address register offset is 0x0000 0000. For DMA access address line A28 (On hardware interface) must be high, therefore DMA memory access starts at 0x4000 0000 (Not 0x1000 0000 as addressing is in bytes).





#### 7 ComPorts

The SMT410 gives access to all six TIM site ComPorts. One of four ComPorts can be connected through a high drive buffer to a connector on the rear panel of the card. This connection and switching is achieved using *Quick switches* alleviating the need for patch cables.

Two of the TIM site ComPorts are connected straight to 14-way surface-mount FMS connectors for connection to other ComPort compatible devices within the same chassis.

There is a connection from the PCI interface to ComPort 3 for booting the TIM. This connection can be severed with a quick switch (clear CENc) allowing ComPort 3 to be used for other purposes. This also allows the PCI interface ComPort to be used independently of the TIM as it is also wired to a 14-way surface-mount FMS connector.



Figure 1: ComPort connection diagram

The configuration of the ComPorts on the SMT410 can be set using the ComPort configuration register (I/O Offset 0x20).

Default = 0x2C (Assuming no FMS cables connected)



| D7 | D6 | D5   | D4   | D3   | D2   | D1   | D0   |
|----|----|------|------|------|------|------|------|
| Х  | Х  | CENc | CENb | SELC | SELB | SEL1 | SEL0 |

Table 5 : ComPort configuration register

The table below illustrates the different setting of the register.

| CENc | CENb | SEL1 | SEL0 | Function                                               |
|------|------|------|------|--------------------------------------------------------|
| 1    | Х    | Х    | Х    | Connects DSP ComPort 3 to PCI Host <sup>1</sup>        |
| 0    | Х    | Х    | X    | Disconnects DSP ComPort 3 to PCI Host                  |
| Х    | 0    | Х    | X    | Disables all DSP connections to Buffered ComPort       |
| Х    | 1    | 0    | 0    | Connect DSP ComPort 0 to Buffered ComPort <sup>2</sup> |
| Х    | 1    | 0    | 1    | Connect DSP ComPort 2 to Buffered ComPort <sup>2</sup> |
| Х    | 1    | 1    | 0    | Connect DSP ComPort 3 to Buffered ComPort <sup>2</sup> |
| Х    | 1    | 1    | 1    | Connect DSP ComPort 5 to Buffered ComPort <sup>2</sup> |

**Table 6: Comport selection** 

BUF COM DIR: Selects the direction of the buffered ComPort = SEL1

#### 7.1 Buffered ComPort

From the TIM site, 4 ComPorts are taken to a back panel mounted connector via quick switches. All signals are pulled up to +3.3 volts with 330 ohm resistors. The active devices are mounted as close as possible to the connector they serve.

The back panel mounted connector is a 26 pin 3M type, (3M part number 10226-5212JL). The connector pin-out is given in the following table, with pair numbers for 13 off twisted pair cable (3M part number KUCKMPVVSB28-13PAIR).

The buffer circuit for the connector is designed such that the reset direction is defined by the TIM ComPort number to which it is connected. The quick switch arrangement allows cable less connection between the TIM site and the buffer. There is also a 14-way surface-mount FMS connector allowing the buffer to be connected to some external source of data. When this connector is used, all other quick switch TIM site connections are removed.

<sup>&</sup>lt;sup>1</sup> If SELC is read as 0 then CENc is overridden as DSP ComPort 3 is now being driven by the external FMS connector J2.

<sup>&</sup>lt;sup>2</sup>If SELB is read as 0 then CENb is overridden as buffered ComPort is now connected to external FMS connector J1.

As well as the 12 C4x ComPort signals and signal grounds, there are 6 additional signals. Note that these signals are NOT essential for communications:

| Name     | Description                                                                              |
|----------|------------------------------------------------------------------------------------------|
| I/O_OUT  | Output high when port is outputting data, output low when port is receiving data.        |
| I/O_IN   | Input which prevents bus contention if connected to I/O_OUT                              |
| /RST_OUT | Active low open collector copy of the board reset drive.                                 |
| /RST_IN  | Active low board reset input, pulled up to 3.3V by 100 ohms.                             |
| VCC      | 1 AMP +5 Volt supply, with resettable 1 Amp fuse, to power a remote buffer, if required. |
| SHIELD   | Overall cable shield, connected to plug shells and chassis.                              |

The /RST\_OUT is intended to allow synchronised reset of a number of boards by driving the /RST\_IN input.

The ComPort configuration register controls the way in which the quick switches route the TIM site ComPorts to the buffer (see table 4). There is also an overall enable bit *CENb* that must be set to enable the quick switches.



#### 8 ComPort to PCI Interface

The ComPort interface is memory mapped to the PCI Bridge as illustrated in table 1: I/O address space map. The ComPort uses the Control and Data registers to detect the state of the input and output FIFO. The following section describes the bit definitions for these registers.

#### 8.1 ComPort Registers (Offset 0x10, BAR1)

The host is connected to the first TIM site using ComPort 3. This port is bi-directional and will automatically switch direction to meet a request from either the host or the DSP. Both input and output registers are 32 bits wide. Data can only be written to COMPORT\_OUT when STATUS[OBF] is 0. Data received from the DSP is stored in COMPORT\_IN and STATUS[IBF] is set to 1. Reading COMPORT\_IN will clear STATUS[IBF] and allow another word to be received from the DSP.

## 8.2 Control Register (Offset 0x14, BAR1)

The CONTROL register can only be written. It contains flags, which control the boot modes of the first TIM site.

| 7-5 | 4      | 3     | 2     | 1     | 0     |
|-----|--------|-------|-------|-------|-------|
|     | notNMI | IIOF2 | IIOF1 | IIOF0 | RESET |

| RESET                   | Write a 1 to this bit to assert the reset signal to the TIM module on the SMT410.                                       |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------|
| IIOF0<br>IIOF1<br>IIOF2 | These bits connect to the corresponding pins on the TIM site 1. Writing 0 causes the corresponding IIOF line to go low. |
| NotNMI                  | A 0 written to this bit will assert the active low NMI to the TIM.                                                      |

**Table 7: Control Register** 

Note. On PCI system reset, RESET is asserted to the TIM site.





# 8.3 Status Register (Offset 0x14, BAR1, Read-Only)

| 31:22 | 21       | 20         | 19 | 18     | 17  | 16  | 15:12 | 11  | 10  | 9   | 8    |
|-------|----------|------------|----|--------|-----|-----|-------|-----|-----|-----|------|
|       | CONFIG_L | TBC<br>RDY | 0  | MASTER | IBF | OBF |       | IM2 | IM1 | IM0 | INTD |

| 7       | 6       | 5       | 4       | 3      | 2      | 1      | 0      |
|---------|---------|---------|---------|--------|--------|--------|--------|
| C40 INT | TBC INT | IBF INT | OBE INT | C40 IE | TBC IE | IBF IE | OBE IE |

| OBE IE  | Set if ComPort output buffer empty interrupts enabled.                                                                               |
|---------|--------------------------------------------------------------------------------------------------------------------------------------|
| IBF IE  | Set if ComPort input buffer full interrupts enabled                                                                                  |
| TBC IE  | Set if JTAG interrupts enabled                                                                                                       |
| C40 IE  | Set if interrupt from TIM DSP enabled                                                                                                |
| OBE INT | Set if the ComPort output buffer becomes empty. Cleared by writing a 1 to the corresponding bit in the interrupt control register.   |
| IBF INT | Set if the ComPort input buffer receives a word. Cleared by writing a 1to the corresponding bit in the interrupt control register    |
| TBC INT | Set when the TBC asserts its interrupt. Cleared by removing the source of the interrupt in the TBC.                                  |
| C40 INT | Set when the TIM DSP sets its host interrupt bit. Cleared by writing a 1 to the corresponding bit in the interrupt control register. |
| INTD    | The logical OR of bits 7—4 in this register gated with each one's enable bit.                                                        |
| OBF     | Set when a word is written to the ComPort output register. Cleared when the word has been transmitted to the DSP.                    |
| IM0     | Interrupt mask 0. Returns Interrupt Control Register Bit 8.                                                                          |
| IM1     | Interrupt mask 1. Returns Interrupt Control Register Bit 9.                                                                          |
| IM2     | Interrupt mask 2. Returns Interrupt Control Register Bit 10.                                                                         |
| IBF     | Set when a word is in the ComPort input register.                                                                                    |
| MASTER  | Set when the SMT410 Bridge owns the ComPort interface token.                                                                         |
| TBC RDY | Reflects the current state of the TBC RDY pin. This bit is active high and therefore and inversion of the TBC pin.                   |



| CONFIG_L | Reflects the state of the TIMs' CONFIG signal. Active low. |
|----------|------------------------------------------------------------|
|----------|------------------------------------------------------------|

Table 8 : Status Register

INTD is the input interrupt into the PCI Bridge from the SMT410, this can be routed to either INTA, INTB, or INTC using the PCI Interrupt Configuration Register (offset 0x4C, BAR0)

#### 8.4 Interrupt Control Register (Offset 0x18, BAR1)

This write-only register controls the generation of interrupts on the PCI bus. Each interrupt source has an associated enable and clear flag. This register can be written with the contents of bits 7:0 of the Status Register.

| 10              | 9               |
|-----------------|-----------------|
| DSP-PC IIOF2 En | DSP-PC IIOF1 En |

| 8                  | 7                | 6 | 5                | 4                | 3      | 2      | 1      | 0      |
|--------------------|------------------|---|------------------|------------------|--------|--------|--------|--------|
| DSP-PC<br>IIOF0 En | CLEAR<br>C40 INT | 0 | CLEAR<br>IBF INT | CLEAR OBE<br>INT | C40 IE | TBC IE | IBF IE | OBE IE |

| DSP-PC IIOF2 En | Enables DSP-PC interrupts on IIOF2                                                                                                                     |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| DSP-PC IIOF1 En | Enables DSP-PC interrupts on IIOF1                                                                                                                     |
| DSP-PC IIOF0 En | Enables DSP-PC interrupts on IIOF0                                                                                                                     |
| IBF IE          | ComPort Input Buffer Full Interrupt Enable. Allows an interrupt to be generated when the host ComPort input register is loaded with data from the C40. |
| OBE IE          | ComPort Output Buffer Empty Interrupt. Allows an interrupt to be generated when the host ComPort register has transmitted its contents.                |
| TBC IE          | Test Bus Controller Interrupt Enable. Interrupts from the Texas JTAG controller are enabled when set.                                                  |
| C40 IE          | C40 Interrupt Enable. Allows a programmed interrupt to be generated by the C40 when set.                                                               |

| CLEAR OBE INT | Write a one to this bit to clear the interrupt resulting from a ComPort output event. |
|---------------|---------------------------------------------------------------------------------------|
| CLEAR IBF INT | Write a one to this bit to clear the interrupt event resulting from ComPort input.    |
| CLEAR C40 INT | Write a one to this bit to clear down the C40 INT event.                              |

# **Table 9 : Interrupt Control Register**

The JTAG controller which generates TBC INT must be cleared of all interrupt sources in order to clear the interrupt.



#### 9 JTAG Controller

The SMT410 has an on board Test Bus Controller (TBC). The TBC is controlled from the PCI bus giving access to the on site TIM and/or any number of external TIMs. The TBC is a SN74ACT8990 from Texas Instruments. Please refer to the Texas Instruments data sheet for details of this controller. The TBC is accessed in I/O space at the Base address + 0x80.



Figure 2: TBC Data Routing

The SMT410 can operate in two TBC modes; Master mode and Slave mode. In Master mode, the Test Bus Controller on the SMT410 drives the JTAG scan chain through the TIM site on the SMT410. If the site is not populated with a TIM then the module SENSE signal is used to enable a tri-state buffer connecting the TDI and TDO (JTAG Data In and Data Out) on the site, maintaining the integrity of the JTAG data path. This switching is automatic. The SMT410 auto detects JTAG connections and switches the JTAG circuitry accordingly.

When the SMT410 is configured in Slave mode, the TBC on the SMT410 is disabled, as the TBC is assumed to be on another device connected to the SMT410.

There are two JTAG connectors (J5, J31). J31 is used when in master mode to connect to slave devices and J5 is used in slave mode to connect master devices to



the SMT410. Both connectors can be used at the same time to produce a chain of boards.



# 10 Using the SMT410 External/Internal JTAG with TI Tools.

For details on using the SMT410 with T.I. Code Composer range, see the <u>SMT6012</u> documentation.

The SMT6012 is Sundance's driver for the T.I. Code Composer range of products and can be purchased separately. The SMT6012 is free of charge when the SMT410 is bought with the Code Composer software from Sundance.

The Texas Instruments Evaluation Module (EVM) kits can be used as stand-alone devices with a SMT410 as the JTAG master. When running with the EVM kits ensure that the EVM jumper has been set up correctly. i.e. External JTAG has been selected and the DSP boot location is valid (set for internal memory space).





## 11 Firmware Upgrades

Much of the SMT410's control interface is achieved using CPLD's. Sometime customers require slightly different interface protocols, which can be catered for by a firmware upgrade. To upgrade firmware Xilinx JTAG programming software is required together with a lead to connect to the SMT410's header. The image below shows the location of pin 1 of the JTAG connector J21. This connector is a 2x3 2mm pin header.







Figure 3 : JTAG header pin numbers

| Pin Number | Function |
|------------|----------|
| 1          | Vcc (5v) |
| 2          | Gnd      |
| 3          | TCK      |
| 4          | TDO      |
| 5          | TDI      |
| 6          | TMS      |

Table 10 : JTAG Header pin function



#### 12 Global/Local Bus Transfers, DSP <-> PCI.

The traditional global bus interface on C6x DSP modules interfaces to the SMT410 via a local bus. This allows Global bus transfers on the DSP to be converted into local bus accesses. This allows direct DSP accesses to the PCI Bridge chip.

The resources in the PCI Bridge chip are illustrated in the figure below.



Figure 4 : Local Bus to DSP Connectivity

#### 12.1 Mailbox Accesses

The mailbox registers can be used if small amounts of data or commands between the PCI bus and the DSP, via the local bus, need to be transferred. Rather than sending ComPort data, and therefore require the DSP to be checking its ComPort for commands, a mailbox write by the PCI bus can be initialized to generate an interrupt on an DSP IIOF line indicating, to the DSP, that data is available. The PCI Bridge device provides 16 8-bit mailbox registers, which may be used to transmit and receive data between the DSP and Host.



The mailbox registers are accessed from the DSP through the Local-to-Internal Register (LB\_IO\_BASE) aperture. As illustrated in section 5, table 4 of this document this region is accessed by the DSP via a global bus access to the PCI Bridge Registers (Address: 0x1C00 0000).

The mailbox registers themselves are on byte boundaries with offsets 0xC0 -> 0xCF, from the LB\_IO\_BASE. As DSP global bus accesses are carried out on WORD (32-bit) boundaries a write access over the global bus to 0x1C00 0000 + 0xC0 will write to the first 4 mailbox registers in the PCI Bridge device.

The mailbox registers are accessed from the PCI bus through the PCI-to-Internal Register (PCI\_IO\_BASE) aperture. This is accessed via the PCI Bridge Chip Internal Register (BAR0), byte offset 0xC0 -> 0xCF.

#### **12.1.1 Doorbell Interrupts**

Each of the 16 mailbox registers can generate four different interrupt requests called doorbell interrupts. Each of these requests can be independently masked for each mailbox register. The four doorbell interrupt types are:

- DSP interrupt request on read from PCI side
- DSP interrupt request on write from PCI side
- PCI interrupt request on read from DSP side
- PCI interrupt request on write from DSP side

The PCI read and DSP read interrupts are OR'd together and latched in the mailbox read interrupt status register (MAIL\_RD\_STAT). Similarly, the PCI write and DSP write interrupts are OR'd together and latched in the mailbox write interrupt status register (MAIL\_WR\_STAT). All of the interrupt request outputs from the status registers are OR'd together to form a single mailbox unit interrupt request and routed to both the Local and PCI Interrupt Control Units.

When a block of mailbox registers are accessed simultaneously, for example when 4 mailbox registers are read as a word quantity, then each register affected will request a separate interrupt if programmed to do so.

See section 14 for further information on Interrupts.

#### 12.2 DSP Interrupt Control

Interrupts can be enabled from a number of different sources i.e. DSP-> Host and Host -> DSP. See section 14 for a description of these functions.



#### 12.3 DSP To Local Aperture 0 control and Accessing

The quickest way to transfer information from the DSP to PCI Bus or vice versa is to use the Local-to-PCI Aperture 0 in the PCI Bridge device. A DSP unit may be required to transfer large amounts of acquired data to the PC host for data storage or post-processing etc. Allowing the DSP to take control of the PCI bus means that the HOST only requires to transfer data, from an internal allocated region of memory, after the transfer has been completed by the DSP. Alerting the Host that data has been transferred can be accomplished in a number of ways i.e. writing to the mailbox register, which can then generate an interrupt.

As shown in Table 4, section 5. The Local-to-PCI Aperture 0 is mapped as a region of addressable space from 0x1800 0000 – 0x183F FFFF (words).

There are a number of registers in initialise before data can be read or written via this address space.

- Unlock the PCI Bridge System register. This requires a write to
- Write the upper 8 bits of your destination address (in bytes) to the upper 8 bits of the 32-bit Local Bus to PCI Map 0 register (LB\_MAP0\_RES, offset in bytes 0x5c).
- Convert you lower 24-bit address to a word aligned value.
- Write/Read data from Local-to-PCI Aperture 0.

The diagram below illustrates this procedure.

In the example below the *WritetoPCIregisters*(offset,data) function writes data over the DSP's Global bus, at a base address of 0x1800 0000 (words), the first parameter passed to this function in the offset address in words, and the second is the data to be written.



# Receive Target address via Com-Port Link i.e. 0xFE12 3000

#### Unlock the system register in PCI Bridge

#define LB\_CFG\_SYSTEM (0x78>>2) (divide by 4 to word align offset address of PCI bridge register)

WritePCIRegisters((unsigned int)LB\_CFG\_SYSTEM,0xA05F); // Unlock Code
WritePCIRegisters((unsigned int)LB\_CFG\_SYSTEM,0x22008800); // Restore Value

## Write Lower 24 bits of byte TargetAddress to the LB\_MAP0\_RES register

#define LB\_MAP0\_RES (0x5C>>2)
#define LB\_MAP0\_MEMORY\_RW 0x00060000
#define LB\_MAP0\_ADDRESS\_MASK 0xFF000000

WritePCIRegisters((unsigned int)LB\_MAP0\_RES,(unsigned int)(TargetAddress & LB\_MAP0\_ADDRESS\_MASK) | LB\_MAP0\_MEMORY\_RW);

// The LB\_MAPO\_MEMORY\_RW must be Or'ed with the data to ensure the other register in // the 32-bit word has its correct value.

## Write WORD Aligned data to Local Aperture space 0.

```
WritePCIApperture0((ByteToWord32(((TargetAddress) & ~LB_MAP0_ADDRESS_MASK))),Length,buffer);
Where
void WritePCIApperture0(unsigned int address,unsigned long Length,unsigned int *buffer)
{
unsigned int Index;
    globalbuswriteClockMB(0x18000000 + address , Length , buffer);
}
```

Figure 5 : DSP Transfer via the Local Aperture 0

#### 12.3.1 Global bus access protocol

In Figure 6, the WritePCIApperture function calls a function C6xGlobalWriteClockMB().

This function enables the DSP's global bus to transfer *Length* words from the DSP's internal memory map pointed to by *buffer*. The function puts the Global bust into burst mode. This interface allows a synchronous stream of data to be written to the 256 WORD input FIFO of the Local To PCI aperture 0. For more information on setting this mode from the DSP can be found in the *SMT335 Users Guide*. This section concentrates on the burst mode interface and arbitration mechanism for the DSP to PCI Bridge aperture access.

The Global bus interface of the DSP uses the following signals to interface to the local bus of the SMT410.

#### **DSP Signals.**

#### AE\*, DE\*, CE0\*

AE\*/DE\* are active low address/Data enable signal driven by the SMT410, when the DSP has ownership of the Bus this signal is driven low by the SMT410 allowing the DSP to drive the Address pins and Data pins.

CE0\* is the Tri-state control for the DSP's global bus control pins. This is permanently tied low by the SMT410 as the control signal is always enable.

#### STRB1\*

Data strobe signal from the DSP's global bus. This is driven low when the DSP is carrying out an access cycle. The DSP waits for the RDY1\* to be driven low by the SMT410 to indicate transfer has been completed. This interface is carried out in synchronous burst mode. This requires the DSP to indicate when the burst transfer is completed. This is accomplished by the DSP by pulling STAT0 low.

#### RDY1\*

Active low transfer acknowledgement. This is driven by the SMT410 to indicate that the current transfer has been completed.

#### STATO..3

DSP Status line. When all of the signals are logic '1' then the DSP Global bus interface is in an idle state. When any of these signals is driven low the DSP requesting ownership of the SMT410's local bus. STAT0 has a special status and indicates the last data packet transfer when driven low by the DSP.



A0..A30

DSP's global Bus address lines

D0..D31

DSP's global Bus data lines

IIOF0, IIOF1 & IIOF2

DSP's Interrupt signals. These are open collector signals on the SMT410. They can be driven by the DSP to generate an interrupt to the host, or they can be driven by the host to interrupt the DSP.

In the timing diagram below all signals change relative to the rising LCLK signal. This signal is the H1 clock signal of the DSP when using the DSP global bus in synchronous mode (see SMT335 User Guide).



Figure 6: Timing diagram for DSP local bus access

The DSP initiates a global bus R/W by asserting the STRB1 low and STAT[1:3} change (see TIM Spec for details of STAT[1..3] details). Once the arbitration unit detects this, it waits for the last cycle of the Local bus to be completed by the PCI Bridge, before allowing the DSP to become Bus Master. Once the DSP is Master the arbitration unit drives AE and DE low to enable the DSP's address and data lines. RDY1 is driven low by the arbitor to indicate to the DSP, on the next rising LCLK, that the data packet has been transferred. If the input FIFO (256 Words Deep) becomes



<sup>\*</sup> LCLK Period =30nS, frequency is 33MHz.

full, the arbitration logic de-asserts the RDY1 signal to indicate a hold-off state. Once the data has been transferred from the FIFO to the PCI bus RDY1 is re-asserted to continue the transfer. The end of the burst access is indicated by asserting STAT0 low. If RDY1 is not active then STAT0 should remain asserted until ready is asserted and the final data transaction has been completed.

Situations can arise where a deadlock condition car arrive, i.e. the PCI bus is trying to read from the SMT410 resources while the DSP is reading from the PCI Bus. If this situation arises the arbitration unit gives the PCI Bridge device priority and services the HOST PCI access before giving bus ownership back to the DSP.

When running code composer applications to debug the DSP a reduction in the speed of the debugger will be noticed. The DSP has priority when accessing the local bus and any other accesses will only occur under the following conditions.

- · Burst access is finished
- Deadlock condition occurs which releases DSP ownership of the Bus.

For multi-threaded applications the length of the DSP burst can be lowered to allow PCI bus R/W cycles to snatch cycles from the DSP.



# 13 Interrupts

#### 13.1 SMT410-To-PCI Interrupts



Figure 7: SMT410 to PCI Interrupts

Interrupts can also be caused by the SMT410 by writing or reading the mailbox registers in the PCI Bridge.





#### 13.2 PCI-To-SMT410 Interrupts



Figure 8 : PCI to SMT410 Interrupts

#### 13.3 Interrupt Registers

The following register are used to control PCI-To-DSP and DSP-To-PCI interrupts: Note that Control Register (Offset 0x14, BAR1) and Interrupt Control Register (Offset 0x18, BAR1) are also used to control interrupts.

#### 13.3.1 PCI Interrupt Configuration Register(Offset 0x4C, BAR0)

| Bits | Name      | Description                                                                   |
|------|-----------|-------------------------------------------------------------------------------|
| 31   | MAILBOX   | Mailbox Interrupt Enable: Enables a PCI interrupt from the mailbox unit       |
| 30   | LOCAL     | Local Bus Direct Interrupt Enable: Enables direct local bus to PCI interrupts |
| 29   | MASTER_PI | PCI Master Local Interrupt Enable: (see V3 datasheet)                         |
| 28   | SLAVE_PI  | PCI Slave Local Interrupt Enable: (see V3 datasheet)                          |
| 27   | OUT-POST  | I2O Outbound Post List Not Empty: (see V3 datasheet)                          |



| 26    | -          | Reserved                                                                                                          |
|-------|------------|-------------------------------------------------------------------------------------------------------------------|
| 25    | DMA1       | DMA Channel 1 interrupt enable                                                                                    |
| 24    | DMA0       | DMA Channel 0 interrupt enable                                                                                    |
| 23-22 | MODE_D     | INTD interrupt mode: Determines use of corresponding interrupt pin                                                |
|       |            | 00 Active low level triggered input                                                                               |
|       |            | 01 High-to-low edge triggered input                                                                               |
|       |            | 10 Software cleared output. INTD pin is asserted via an interrupt event and cleared through PCI_INT_STAT register |
|       |            | 11 Reserved                                                                                                       |
| 21-20 | MODE_C     | INTC interrupt mode (as MODE_D)                                                                                   |
| 19-18 | MODE_B     | INTB interrupt mode (as MODE_D)                                                                                   |
| 17-16 | MODE_A     | INTA interrupt mode (as MODE_D)                                                                                   |
| 15    | INTD_TO_LB | 1=INTD will request LICU interrupts when the input is active                                                      |
|       |            | 0=INTD will never request LICU interrupts                                                                         |
| 14    | INTC_TO_D  | When set INTC will act as interrupt request for INTD output                                                       |
| 13    | INTB_TO_D  | When set INTB will act as interrupt request for INTD output                                                       |
| 12    | INTA_TO_D  | When set INTA will act as interrupt request for INTD output                                                       |
| 11    | INTD_TO_C  | When set INTD will act as interrupt request for INTC output                                                       |
| 10    | INTC_TO_LB | 1=INTC will request LICU interrupts when the input is active                                                      |
|       |            | 0=INTC will never request LICU interrupts                                                                         |
| 9     | INTB_TO_C  | When set INTB will act as interrupt request for INTC output                                                       |
| 8     | INTA_TO_C  | When set INTA will act as interrupt request for INTC output                                                       |
| 7     | INTD_TO_B  | When set INTD will act as interrupt request for INTB output                                                       |
| 6     | INTC_TO_B  | When set INTC will act as interrupt request for INTB output                                                       |

| 5 | INTB_TO_LB | 1=INTB will request LICU interrupts when the input is active |
|---|------------|--------------------------------------------------------------|
|   |            | 0=INTB will never request LICU interrupts                    |
| 4 | INTA_TO_B  | When set INTA will act as interrupt request for INTB output  |
| 3 | INTD_TO_A  | When set INTD will act as interrupt request for INTA output  |
| 2 | INTC_TO_A  | When set INTC will act as interrupt request for INTA output  |
| 1 | INTB_TO_A  | When set INTB will act as interrupt request for INTA output  |
| 0 | INTA_TO_LB | 1=INTA will request LICU interrupts when the input is active |
|   |            | 0=INTA will never request LICU interrupts                    |

**Table 11 : PCI Interrupt Configuration Register** 

## 13.3.2 PCI Interrupt Status Register(Offset 0x48, BAR0)

| Bits  | Name      | Description                                                |
|-------|-----------|------------------------------------------------------------|
| 31    | MAILBOX   | Mailbox Interrupt:                                         |
|       |           | 1=Mailbox interrupt request active                         |
|       |           | 0=No mailbox interrupts pending                            |
|       |           | Cleared by clearing MAIL_RD_STAT and MAIL_WR_STAT          |
| 30    | LOCAL     | Local bus direct interrupt:                                |
|       |           | 1=Local bus master requests a PCI interrupt                |
|       |           | 0=No operation                                             |
|       |           | This bit is set by writing 1 and cleared by writing 0      |
| 29-28 | -         | Reserved                                                   |
| 27    | OUT_POST  | I2O outbound post list not empty: (see V3 datasheet)       |
| 26    | -         | Reserved                                                   |
| 25    | DMA1      | DMA channel 1 interrupt                                    |
| 24    | DMA0      | DMA channel 0 interrupt                                    |
| 23-15 | -         | Reserved                                                   |
| 14    | INTC_TO_D | INTD output from INTC input: when set (1) an interrupt has |

|    |           | occurred on INTC                                                            |
|----|-----------|-----------------------------------------------------------------------------|
| 13 | INTB_TO_D | INTD output from INTB input: when set (1) an interrupt has occurred on INTB |
| 12 | INTA_TO_D | INTD output from INTA input: when set (1) an interrupt has occurred on INTA |
| 11 | INTD_TO_C | INTC output from INTD input: when set (1) an interrupt has occurred on INTD |
| 10 | -         | Reserved                                                                    |
| 9  | INTB_TO_C | INTC output from INTB input: when set (1) an interrupt has occurred on INTB |
| 8  | INTA_TO_C | INTC output from INTA input: when set (1) an interrupt has occurred on INTA |
| 7  | INTD_TO_B | INTB output from INTD input: when set (1) an interrupt has occurred on INTD |
| 6  | INTC_TO_B | INTB output from INTC input: when set (1) an interrupt has occurred on INTC |
| 5  | -         | Reserved                                                                    |
| 4  | INTA_TO_B | INTB output from INTA input: when set (1) an interrupt has occurred on INTA |
| 3  | INTD_TO_A | INTA output from INTD input: when set (1) an interrupt has occurred on INTD |
| 2  | INTC_TO_A | INTA output from INTC input: when set (1) an interrupt has occurred on INTC |
| 1  | INTB_TO_A | INTA output from INTB input: when set (1) an interrupt has occurred on INTB |
| 0  | -         | Reserved                                                                    |

Table 12 : PCI Interrupt Status Register

## 13.3.3 Local Bus Interrupt Mask Register(Offset 0x77, BAR0)

| Bits | Name     | Description                                    |
|------|----------|------------------------------------------------|
| 7    | MAILBOX  | Global mailbox interrupt enable                |
| 6    | PCI_RD   | PCI read error interrupt enable                |
| 5    | PCI_WR   | PCI write error interrupt enable               |
| 4    | PCI_INT  | Global PCI interrupt to local interrupt enable |
| 3    | PCI_PERR | PCI parity error interrupt enable              |
| 2    | I2O_QWR  | I2O inbound post queue write interrupt enable  |

| 1 | DMA1 | DMA channel 1 interrupt enable |
|---|------|--------------------------------|
| 0 | DMA0 | DMA channel 0 interrupt enable |

Table 13: Local Bus Interrupt Mask Register

## 13.3.4 Local Bus Interrupt Status Register(Offset 0x76, BAR0)

| Bits | Name     | Description                                                            |
|------|----------|------------------------------------------------------------------------|
| 7    | MAILBOX  | 1=interrupt has been requested by one or more of the mailbox registers |
|      |          | 0=no mailbox interrupts pending                                        |
| 6    | PCI_RD   | See V3 datasheet                                                       |
| 5    | PCI_WR   | See V3 datasheet                                                       |
| 4    | PCI_INT  | See V3 datasheet                                                       |
| 3    | PCI_PERR | See V3 datasheet                                                       |
| 2    | I2O_QWR  | See V3 datasheet                                                       |
| 1    | DMA1     | See V3 datasheet                                                       |
| 0    | DMA0     | See V3 datasheet                                                       |

Table 14 : Local Bus Interrupt Status Register

# 13.3.5 PCI Mailbox WRITE/READ Interrupt Control Register(Offset: Write 0xD0, BAR0 Read 0xD2, BAR0)

| Bits | Name | Description                                                  |
|------|------|--------------------------------------------------------------|
| 15   | EN15 | Local interrupts on PCI bus writes/reads to mailbox15 enable |
| 14   | EN14 | Same as above for mailbox 14                                 |
| 13   | EN13 | Same as above for mailbox 13                                 |
| 12   | EN12 | Same as above for mailbox 12                                 |
| 11   | EN11 | Same as above for mailbox 11                                 |
| 10   | EN10 | Same as above for mailbox 10                                 |
| 9    | EN9  | Same as above for mailbox 9                                  |
| 8    | EN8  | Same as above for mailbox 8                                  |
| 7    | EN7  | Same as above for mailbox 7                                  |
| 6    | EN6  | Same as above for mailbox 6                                  |
| 5    | EN5  | Same as above for mailbox 5                                  |
| 4    | EN4  | Same as above for mailbox 4                                  |

| 3 | EN3 | Same as above for mailbox 3 |
|---|-----|-----------------------------|
| 2 | EN2 | Same as above for mailbox 2 |
| 1 | EN1 | Same as above for mailbox 1 |
| 0 | EN0 | Same as above for mailbox 0 |

Table 15 : PCI Mailbox WRITE/READ Interrupt Control Register

# 13.3.6 Local Bus Mailbox WRITE/READ Interrupt Control Register(Offset: Write 0xD4, BAR0 Read 0xD6, BAR0)

| Bits | Name | Description                                                  |
|------|------|--------------------------------------------------------------|
| 15   | EN15 | PCI interrupts on Local bus writes/reads to mailbox15 enable |
| 14   | EN14 | Same as above for mailbox 14                                 |
| 13   | EN13 | Same as above for mailbox 13                                 |
| 12   | EN12 | Same as above for mailbox 12                                 |
| 11   | EN11 | Same as above for mailbox 11                                 |
| 10   | EN10 | Same as above for mailbox 10                                 |
| 9    | EN9  | Same as above for mailbox 9                                  |
| 8    | EN8  | Same as above for mailbox 8                                  |
| 7    | EN7  | Same as above for mailbox 7                                  |
| 6    | EN6  | Same as above for mailbox 6                                  |
| 5    | EN5  | Same as above for mailbox 5                                  |
| 4    | EN4  | Same as above for mailbox 4                                  |
| 3    | EN3  | Same as above for mailbox 3                                  |
| 2    | EN2  | Same as above for mailbox 2                                  |
| 1    | EN1  | Same as above for mailbox 1                                  |
| 0    | EN0  | Same as above for mailbox 0                                  |

Table 16 : Local Bus Mailbox WRITE/READ Interrupt Control Register



# 13.3.7 Mailbox Write/Read Interrupt Status Register(Offset: Write 0xD8, BAR0 Read 0xDA, BAR0)

| Bits | Name | Description                                                        |
|------|------|--------------------------------------------------------------------|
| 15   | EN15 | 1=Mailbox 15 has requested a PCI or Local write/read interrupt     |
|      |      | 0=Mailbox 15 has not requested a PCI or Local write/read interrupt |
| 14   | EN14 | Same as above for mailbox 14                                       |
| 13   | EN13 | Same as above for mailbox 13                                       |
| 12   | EN12 | Same as above for mailbox 12                                       |
| 11   | EN11 | Same as above for mailbox 11                                       |
| 10   | EN10 | Same as above for mailbox 10                                       |
| 9    | EN9  | Same as above for mailbox 9                                        |
| 8    | EN8  | Same as above for mailbox 8                                        |
| 7    | EN7  | Same as above for mailbox 7                                        |
| 6    | EN6  | Same as above for mailbox 6                                        |
| 5    | EN5  | Same as above for mailbox 5                                        |
| 4    | EN4  | Same as above for mailbox 4                                        |
| 3    | EN3  | Same as above for mailbox 3                                        |
| 2    | EN2  | Same as above for mailbox 2                                        |
| 1    | EN1  | Same as above for mailbox 1                                        |
| 0    | EN0  | Same as above for mailbox 0                                        |

Register cleared by writing 1, writing 0 has no effect

Table 17: Mailbox Write/Read Interrupt Status Register

### 13.3.8 INTREG Register(Offset 0x40, BAR1)

| Bits | Name | Description |
|------|------|-------------|
| 15   | -    | Reserved    |
| 14   | -    | Reserved    |
| 13   | -    | Reserved    |
| 12   | -    | Reserved    |
| 11   | -    | Reserved    |



| 10 | -       | Reserved                            |
|----|---------|-------------------------------------|
| 9  | -       | Reserved                            |
| 8  | -       | Reserved                            |
| 7  | -       | Reserved                            |
| 6  | -       | Reserved                            |
| 5  | -       | Reserved                            |
| 4  | -       | Reserved                            |
| 3  | -       | Reserved                            |
| 2  | IIOF2EN | PC to DSP TIMIIOF2 interrupt enable |
| 1  | IIOF1EN | PC to DSP TIMIIOF1 interrupt enable |
| 0  | IIOF0EN | PC to DSP TIMIIOF0 interrupt enable |

**Table 18: INTREG Register** 

#### 13.4 Example

The example below shows how the DSP can cause an interrupt on the PC by writing to mailbox register 0.

The PC must first enable the interrupts, to do this the following register bits must be altered, and an interrupt thread handler needs to be created.

PCI Interrupt Configuration Register(Offset 0x4C, BAR0) – bit 31 must be set.

Local Bus Interrupt Mask Register(Offset 0x77, BAR0) – bit 7 must be set.

PCI Mailbox WRITE/READ Interrupt Control Register(Offset: Write 0xD0, BAR0 Read 0xD2, BAR0) – bit 0 of the write register (0xD4) must be set.\*

An Interrupt service routine must be set up, in this the following register will need to be cleared.



Mailbox Write/Read Interrupt Status Register(Offset: Write 0xD8, BAR0 Read 0xDA, BAR0) – bit 0 of the write register (0xD8) must be cleared.\*\*

Local Bus Interrupt Status Register(Offset 0x76, BAR0) – bit 7 must be cleared.

To cause the interrupt the DSP needs to write to the mailbox register in the  $V^3$  chip, this is done by writing to address 0x1C0000C0 (this will write to the first four mailboxes).

\*These are two separate registers, one to enable interrupts on reads from the mailbox registers the other to enable interrupts on writes to the mailbox registers.

\*\*These are two separate registers, one shows interrupt status for reads from the mailbox register the other to show interrupt status on writes to the mailbox registers.





## 14 Performance Figures

Following are the performance figures for the SMT410. Performance figures are stated for the SMT410 with the Rev. A1  $V^3$  PCI bridging device fitted. Further performance figures will be issued as faster  $V^3$  PCI bridging devices become available and are fitted to the SMT410.

| Transfer type                 | Speed in Mbytes/second | Comments                           |
|-------------------------------|------------------------|------------------------------------|
| Standard read from Global bus | TBA                    |                                    |
| Standard write to Global bus  | ТВА                    |                                    |
| DMA read from Global bus      | ТВА                    |                                    |
| DMA write to Global bus       | ТВА                    |                                    |
| DMA read from shared memory   | 75-100                 | Will Vary depending on PCI traffic |
| DMA write to shared memory    | 75-100                 | Will Vary depending on PCI traffic |
| DMA read from SDB             | 75-100                 | Will Vary depending on PCI traffic |
| DMA write to SDB              | 75-100                 | Will Vary depending on PCI traffic |
| DMA read from ComPort         | ТВА                    |                                    |
| DMA write to ComPort          | ТВА                    |                                    |





#### 15 Mechanical Dimensions

The board size is 149 mm by 74 mm

### 16 Power consumption

The SMT410 is powered from the PC's internal power supply. The card uses the 3.3v and 5v supplies. The following current consumption figures were measured using a LEM current clamp during a quiescent period.

Current drawn from 3.3v supply : TBC mA

Current drawn from 5v supply : TBC mA





#### 17 Cables and Connectors

#### 17.1 ComPorts

The cables used with FMS connectors are not supplied with the SMT410. You can order them separately from Sundance with part number SMT500-FMSxx, where xx is the cable length in centimetres.

#### 17.2 Buffered ComPort Cabling

Connecting between buffered ComPorts requires a 1 to 1 cable; the SMT502-Buffer is the recommended cable assembly and can be purchased separately.

Cable plugs 3M Scotchflex 10126-6000EL FES part 038740A
Plug shells 3M Scotchflex 10326-A200-00 FES part 038760D

Cable type 3M Scotchflex KUCKMPVVSB28-13PAIR FES part 038781E

This cable has 13 individual pairs, with an overall shield, and an outer diameter of 7mm. Cable length should be as short as possible. The maximum tested cable length is 1 meter.

On reset, each ComPort initialises to being either an input or an output.

**Do not** connect 'Reset to Input' ComPorts together.

**Do not** connect 'Reset to Output' ComPorts together.

However if this should occur, no damage will result, because ComPort direction signals disable relevant ComPorts.

The following table shows connector pin-out and cable pair connections. This is important, as the critical signals must be paired with a ground as shown. The allocation to twisted pairs is based on grouping the data signals because they change at the same time, so that crosstalk is not an issue. Each control signal has its own ground:

| Pin | Twisted<br>Pair | RTI<br>Signal | RTO<br>Signal | Pin | Twisted<br>Pair | RTI Signal | RTO Signal |
|-----|-----------------|---------------|---------------|-----|-----------------|------------|------------|
| 1   | 1               | I/O_OUT       | I/O_IN        | 15  | 8               | D2         | D2         |
| 2   | 1               | GND           | GND           | 16  | 8               | D3         | D3         |
| 3   | 2               | I/O_IN        | I/O_OUT       | 17  | 9               | D4         | D4         |
| 4   | 2               | GND           | GND           | 18  | 9               | D5         | D5         |
| 5   | 3               | /CSTRB        | /CSTRB        | 19  | 10              | D6         | D6         |



| 6  | 3 | GND   | GND   | 20    | 10 | D7       | D7       |
|----|---|-------|-------|-------|----|----------|----------|
| 7  | 4 | /CRDY | /CRDY | 21    | 11 | VCC      | VCC      |
| 8  | 4 | GND   | GND   | 22    | 11 | GND      | GND      |
| 9  | 5 | /CREQ | /CREQ | 23    | 12 | /RST_OUT | /RST_IN  |
| 10 | 5 | GND   | GND   | 24    | 12 | GND      | GND      |
| 11 | 6 | /CACK | /CACK | 25    | 13 | /RST_IN  | /RST_OUT |
| 12 | 6 | GND   | GND   | 26    | 13 | GND      | GND      |
| 13 | 7 | D0    | D0    | SHELL | -  | SHIELD   | SHIELD   |
| 14 | 7 | D1    | D1    |       |    |          |          |

Table 19: Buffered ComPort connector pin out

The overall shield is attached to the body of the metal plug shell.

The signal VCC is fused on the board at 1 amp; it automatically resets when the load is removed.

When the buffered ComPort is reset to input, pins 1 and 23 are always driven and pins 3 and 25 are always receivers. When the buffered ComPort is reset to output, pins 3 and 25 are always driven and pins 1 and 23 are always receivers.

### 17.3 JTAG cabling

Internal JTAG (XDS-510 compatible) pin header pin information: J31

| Pin | Signal  | Direction | Description           |
|-----|---------|-----------|-----------------------|
| 1   | TMS     | Out       | JTAG Test mode select |
| 2   | /TRST   | Out       | JTAG Reset            |
| 3   | TDI     | Out       | JTAG data out         |
| 4   | GND     |           |                       |
| 5   | PD (+5) |           | XDS_OUT detect        |
| 6   | Key     |           | 5v Power              |
| 7   | TDO     | In        | JTAG data in          |
| 8   | GND     |           |                       |
| 9   | TCK_RET | In        | JTAG clock return     |
| 10  | GND     |           |                       |

| 11 | TCK  | Out | JTAG clock 10MHz |
|----|------|-----|------------------|
| 12 | GND  |     |                  |
| 13 | EMU0 | In  | Buffered EMU0 In |
| 14 | EMU1 | In  | Buffered EMU1In  |

Table 20 : Internal JTAG out (XDS-510) pin descriptions

J5

| Pin | Signal  | Direction | Description           |
|-----|---------|-----------|-----------------------|
| 1   | TMS     | In        | JTAG Test mode select |
| 2   | /TRST   | In        | JTAG Reset            |
| 3   | TDI     | In        | JTAG data in          |
| 4   | GND     |           |                       |
| 5   | PD (+5) |           | 5v Power              |
| 6   | Key     |           | XDS_IN detect         |
| 7   | TDO     | Out       | JTAG data out         |
| 8   | GND     |           |                       |
| 9   | TCK_RET | Out       | JTAG clock return     |
| 10  | GND     |           |                       |
| 11  | TCK     | In        | JTAG clock 10MHz      |
| 12  | GND     |           |                       |
| 13  | EMU0    | Out       | Buffered EMU0 Out     |
| 14  | EMU1    | Out       | Buffered EMU1 Out     |

Table 21 : Internal JTAG in (XDS-510) pin descriptions



## 18 Where's that Jumper?

Below is a diagram to help locate the jumpers:



Figure 9 : Jumper Finder Diagram

J7, J8, J9 and J10 are test points and should not be connected.

