

# MicroBlaze Debug Module (MDM) (v2.00.b)

DS641 March 1, 2011 Product Specification

#### Introduction

This document provides the design specification for the MicroBlaze™ Debug Module (MDM) which enables JTAG-based debugging of one or more MicroBlaze processors.

#### **Features**

- Support for JTAG-based software debug tools
- Support for debugging up to eight MicroBlaze processors (version 7 and higher)
- Support for synchronized control of multiple MicroBlaze processors
- Support for a JTAG-based UART with a configurable AXI4-Lite or PLBv46 interface
- Based on Boundary Scan (BSCAN) logic in Xilinx<sup>®</sup> FPGAs
- Supports connection to the ChipScope™ Pro ICON core through BSCAN signals

| LogiCORE™ IP Facts         |                                                                                                                                                                                        |          |     |     |
|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-----|-----|
|                            | Core Spe                                                                                                                                                                               | cifics   |     |     |
| Supported Device<br>Family | Spartan®-3, Spartan-3E, Spartan-3A/3A DSP, Automotive Spartan-3/-3A/3A DSP/3E, Spartan-6, Virtex®-4, Virtex-4Q, Virtex-4QV, Virtex-5, Virtex-5 FX, Virtex-6, Virtex-6CX <sup>(1)</sup> |          |     |     |
| Resources Used             | I/O LUTs FFs Block RAMs                                                                                                                                                                |          |     |     |
|                            | N/A                                                                                                                                                                                    | 4        | N/A | N/A |
| Pro                        | ovided w                                                                                                                                                                               | ith Core |     |     |
| Documentation              | Product Specification                                                                                                                                                                  |          |     |     |
| Design File Formats        | VHDL                                                                                                                                                                                   |          |     |     |
| Constraints File           | N/A                                                                                                                                                                                    |          |     |     |
| Verification               | N/A                                                                                                                                                                                    |          |     |     |
| Instantiation<br>Template  | N/A                                                                                                                                                                                    |          |     |     |
| Design Tool Requirements   |                                                                                                                                                                                        |          |     |     |
| Xilinx ISE® 13.1 ISE® 13.1 |                                                                                                                                                                                        |          |     |     |
| Verification               | N/A                                                                                                                                                                                    |          |     |     |
| Simulation                 | Mentor Graphics ModelSim 6.6d                                                                                                                                                          |          |     |     |
| Synthesis XST              |                                                                                                                                                                                        |          |     |     |
| Support                    |                                                                                                                                                                                        |          |     |     |
| Provided by Xilinx, Inc.   |                                                                                                                                                                                        |          |     |     |

#### Notes:

 S6 and V6 are the only device families that support the AXI4-Lite interface.



### **Overview**

The MicroBlaze Debug Module (MDM):

- Enables JTAG-based debugging of one or more MicroBlaze processors.
- Instantiates one BSCAN primitive. In devices that contain more than one BSCAN primitive, MDM uses the USER2 BSCAN by default.
- Includes a UART with a configurable slave bus interface which can be configured for either an AXI4-Lite interconnect or a PLBv46 bus.

The UART TX and RX signals are transmitted over the FPGA JTAG port to and from the Xilinx Microprocessor Debug (XMD) tool. The UART behaves in a manner similar to the LogiCORE IP AXI (UART) Lite core.

The block diagram of the module is shown in Figure 1:



Figure 1: Microblaze Debug Module (MDM) Block Diagram



# MDM I/O Signals

The I/O signals for the MicroBlaze Debug Module (MDM) are listed and described in Table 1.

Table 1: MDM I/O Signals

| Signal Name                        | Interface        | I/O   | Initial<br>State | Description                                      |  |  |
|------------------------------------|------------------|-------|------------------|--------------------------------------------------|--|--|
| System Signals                     |                  |       |                  |                                                  |  |  |
| Interrupt                          |                  | 0     | 0                | Interrupt from UART                              |  |  |
| Debug_SYS_Rst                      |                  | 0     | 0                | Debug system reset                               |  |  |
| Ext_BRK                            |                  | 0     | 0                | External break                                   |  |  |
| Ext_NM_BRK                         |                  | 0     | 0                | External non-maskable break                      |  |  |
|                                    | PLB Interface Si | gnals |                  |                                                  |  |  |
| SPLB_Clk                           | SPLB             | I     | -                | PLB clock                                        |  |  |
| SPLB_Rst                           | SPLB             | ı     | -                | PLB reset                                        |  |  |
| PLB_ABus[0:31]                     | SPLB             | ı     | -                | PLB address bus                                  |  |  |
| PLB_UABus[0:31]                    | SPLB             | ı     | -                | PLB upper address bus                            |  |  |
| PLB_PAValid                        | SPLB             | ı     | -                | PLB primary address valid                        |  |  |
| PLB_SAValid                        | SPLB             | ı     | -                | PLB secondary address valid                      |  |  |
| PLB_rdPrim                         | SPLB             | ı     | -                | PLB secondary to primary read request indicator  |  |  |
| PLB_wrPrim                         | SPLB             | ı     | -                | PLB secondary to primary write request indicator |  |  |
| PLB_MasterID[0:C_SPLB_MID_WIDTH-1] | SPLB             | I     | -                | PLB current master identifier                    |  |  |
| PLB_busLock                        | SPLB             | ı     | -                | PLB bus lock                                     |  |  |
| PLB_abort                          | SPLB             | ı     | -                | PLB abort                                        |  |  |
| PLB_RNW                            | SPLB             | ı     | -                | PLB read not write                               |  |  |
| PLB_BE[0:C_SPLB_DWIDTH/8 - 1]      | SPLB             | ı     | -                | PLB byte enables                                 |  |  |
| PLB_MSize[0:1]                     | SPLB             | ı     | -                | PLB data bus width indicator                     |  |  |
| PLB_size[0:3]                      | SPLB             | ı     | -                | PLB size of requested transfer                   |  |  |
| PLB_type[0"2]                      | SPLB             | ı     | -                | PLB transfer type                                |  |  |
| PLB_lockErr                        | SPLB             | ı     | -                | PLB lock error                                   |  |  |
| PLB_wrDBus[0:C_SPLB_DWIDTH-1]      | SPLB             | ı     | -                | PLB write data bus                               |  |  |
| PLB_wrBurst                        | SPLB             | ı     | -                | PLB burst write transfer                         |  |  |
| PLB_rdBurst                        | SPLB             | I     | -                | PLB burst read transfer                          |  |  |
| PLB_wrPendReq                      | SPLB             | ı     | -                | PLB pending bus write request                    |  |  |
| PLB_rdPendReq                      | SPLB             | ı     | -                | PLB pending bus read request                     |  |  |
| PLB_wrPendPri[0:1]                 | SPLB             | ı     | -                | PLB pending write request priority               |  |  |
| PLB_rdPendPri[0:1]                 | SPLB             | ı     | -                | PLB pending read request priority                |  |  |
| PLB_reqPri[0:1]                    | SPLB             | ı     | -                | PLB current request priority                     |  |  |
| PLB_TAttribute[0:15]               | SPLB             | ı     | -                | PLB transfer attribute                           |  |  |
| SI_addrAck                         | SPLB             | 0     | -                | Slave address acknowledge                        |  |  |
| SI_SSize[0:1]                      | SPLB             | 0     | -                | Slave data bus size                              |  |  |



Table 1: MDM I/O Signals (Cont'd)

| Signal Name                           | Interface        | 1/0    | Initial<br>State | Description                          |
|---------------------------------------|------------------|--------|------------------|--------------------------------------|
| SI_wait                               | SPLB             | 0      | -                | Slave wait                           |
| SI_rearbitrate                        | SPLB             | 0      | -                | Slave bus re-arbitrate               |
| SI_wrDAck                             | SPLB             | 0      | -                | Slave write data acknowledge         |
| SI_wrComp                             | SPLB             | 0      | -                | Slave write transfer complete        |
| SI_wrBTerm                            | SPLB             | 0      | -                | Slave terminate write burst transfer |
| SI_rdDBus[0:C_SPLB_DWIDTH -1]         | SPLB             | 0      | -                | Slave read data bus                  |
| SI_rdWdAddr[0:3]                      | SPLB             | 0      | -                | Slave read word address              |
| SI_rdAck                              | SPLB             | 0      | -                | Slave read data acknowledge          |
| SI_rdComp                             | SPLB             | 0      | -                | Slave read transfer complete         |
| SI_rdBTerm                            | SPLB             | 0      | -                | Slave terminate read burst transfer  |
| SI_MBusy<br>[0:C_SPLB_NUM_MASTERS-1]  | SPLB             | 0      | -                | Slave busy                           |
| SI_MWrErr<br>[0:C_SPLB_NUM_MASTERS-1] | SPLB             | 0      | -                | Slave write error                    |
| SI_MrdErr<br>[0:C_SPLB_NUM_MASTERS-1] | SPLB             | 0      | -                | Slave read error                     |
| SI_MIRQ<br>[0:C_SPLB_NUM_MASTERS-1]   | SPLB             | 0      | -                | Master interrupt request             |
| AX                                    | 4-Lite Interface | Signa  | ls               |                                      |
| S_AXI_ACLK                            | S_AXI            | I      | -                | AXI Clock                            |
| S_AXI_ARESETN                         | S_AXI            | I      | -                | AXI Reset, active low                |
| S_AXI_AWADDR[C_S_AXI_ADDR_WIDTH-1:0]  | S_AXI            | ı      | -                | Write Address                        |
| S_AXI_AWVALID                         | S_AXI            | ı      | -                | Write Address Valid                  |
| S_AXI_AWREADY                         | S_AXI            | 0      | 0                | Write Address Ready                  |
| S_AXI_AWDATA[C_S_AXI_DATA_WIDTH-1:0]  | S_AXI            | ı      | -                | Write Data                           |
| S_AXI_AWSTB[C_S_AXI_DATA_WIDTH/8-1:0] | S_AXI            | ı      | -                | Write Strobes                        |
| S_AXI_WVALID                          | S_AXI            | I      | -                | Write Valid                          |
| S_AXI_WREADY                          | S_AXI            | 0      | 0                | Write Ready                          |
| S_AXI_BRESP[1:0]                      | S_AXI            | 0      | 0                | Write Response                       |
| S_AXI_BVALID                          | S_AXI            | 0      | 0                | Write Response Valid                 |
| S_AXI_BREADY                          | S_AXI            | I      | -                | Write Response Ready                 |
| S_AXI_ARADDR[C_S_AXI_ADDR_WIDTH-1:0]  | S_AXI            | ı      | -                | Read Address                         |
| S_AXI_ARVALID                         | S_AXI            | ı      | -                | Read Address Valid                   |
| S_AXI_ARREADY                         | S_AXI            | 0      | 0                | Read Address Ready                   |
| S_AXI_RRESP[1:0]                      | S_AXI            | 0      | 0                | Read Response                        |
| S_AXI_RVALID                          | S_AXI            | 0      | 0                | Read Valid                           |
| S_AXI_RREADY                          | S_AXI            | ı      | -                | Read Ready                           |
| MicroBI                               | aze Debug Inter  | face S | ignals           | 1                                    |
| Dbg_Clk_n                             | MBDEBUG_n        | 0      | 0                | MicroBlaze Debug Clock               |



Table 1: MDM I/O Signals (Cont'd)

| Signal Name      | Interface         | I/O    | Initial<br>State | Description                         |
|------------------|-------------------|--------|------------------|-------------------------------------|
| Dbg_TDI_n        | MBDEBUG_n         | 0      | 0                | MicroBlaze Debug TDI                |
| Dbg_TDO_n        | MBDEBUG_n         | ı      | -                | MicroBlaze Debug TDO                |
| Dbg_Reg_En_n     | MBDEBUG_n         | 0      | 0                | MicroBlaze Debug Register Enable    |
| Dbg_Capture_n    | MBDEBUG_n         | 0      | 0                | MicroBlaze Debug Capture            |
| Dbg_Shift_n      | MBDEBUG_n         | 0      | 0                | MicroBlaze Debug Shift              |
| Dbg_Update_n     | MBDEBUG_n         | 0      | 0                | MicroBlaze Debug Update             |
| Dbg_Rst_n        | MBDEBUG_n         | 0      | 0                | MicroBlaze Debug Reset              |
| MicroBlaze       | e Trace Core Into | erface | Signals          |                                     |
| Ext_JTAG_DRCK    | XMTC              | 0      | 0                | Connection to MicroBlaze Trace Core |
| Ext_JTAG_RESET   | XMTC              | 0      | 0                | Connection to MicroBlaze Trace Core |
| Ext_JTAG_SEL     | XMTC              | 0      | 0                | Connection to MicroBlaze Trace Core |
| Ext_JTAG_CAPTURE | XMTC              | 0      | 0                | Connection to MicroBlaze Trace Core |
| Ext_JTAG_SHIFT   | XMTC              | 0      | 0                | Connection to MicroBlaze Trace Core |
| Ext_JTAG_UPDATE  | XMTC              | 0      | 0                | Connection to MicroBlaze Trace Core |
| Ext_JTAG_TDI     | XMTC              | 0      | 0                | Connection to MicroBlaze Trace Core |
| Ext_JTAG_TDO     | XMTC              | I      | -                | Connection to MicroBlaze Trace Core |
| Chipso           | ope ICON Interfa  | ice Si | gnals            |                                     |
| bscan_tdi        | ICON              | 0      | 0                | Connection to Chipscope ICON core   |
| bscan_reset      | ICON              | 0      | 0                | Connection to Chipscope ICON core   |
| bscan_shift      | ICON              | 0      | 0                | Connection to Chipscope ICON core   |
| bscan_update     | ICON              | 0      | 0                | Connection to Chipscope ICON core   |
| bscan_capture    | ICON              | 0      | 0                | Connection to Chipscope ICON core   |
| bscan_sel1       | ICON              | 0      | 0                | Connection to Chipscope ICON core   |
| bscan_drck1      | ICON              | 0      | 0                | Connection to Chipscope ICON core   |
| bscan_tdo1       | ICON              | I      | -                | Connection to Chipscope ICON core   |



## **MDM Design Parameters**

Table 2 lists and describes the features that can be parameterized in MDM.

Table 2: MDM Design Parameters

| Feature / Description                                  | Feature / Description Parameter Name Allowab |                                                                                                                                                                                                     | Default<br>Value | VHDL Type        |
|--------------------------------------------------------|----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|------------------|
|                                                        | System Para                                  | ameters                                                                                                                                                                                             |                  |                  |
| Target FPGA family                                     | C_FAMILY                                     | spartan3, aspartan3,<br>spartan3e, aspartan3e,<br>spartan3a, aspartan3a,<br>spartan3adsp,<br>aspartan3adsp, spartan6,<br>virtex4, qrvirtex4, qvirtex4,<br>virtex5, virtex5fx, virtex6,<br>virtex6cx | virtex5          | string           |
|                                                        | Debug Para                                   | meters                                                                                                                                                                                              |                  |                  |
| Number of MicroBlaze debug ports                       | C_MB_DBG_PORTS                               | 0-8                                                                                                                                                                                                 | 1                | integer          |
| Position in the FPGA JTAG chain                        | 1 = USER1<br>2 = USER2                       |                                                                                                                                                                                                     | 2                | integer          |
|                                                        | UART Para                                    | meters                                                                                                                                                                                              |                  |                  |
| Enables the UART interface                             | es the UART interface C_USE_UART 0,1         |                                                                                                                                                                                                     | 1                | integer          |
| Selects the bus interface for the UART                 | C_INTERCONNECT                               | 1 = PLBv46,<br>2 = AXI                                                                                                                                                                              | 1                | integer          |
| UART Base Address                                      | C_BASEADDR                                   | Valid Address <sup>(1)</sup>                                                                                                                                                                        | None (1)         | std_logic_vector |
| UART High Address                                      | ph Address C_HIGHADDR Valid Address (1)      |                                                                                                                                                                                                     | None (1)         | std_logic_vector |
|                                                        | PLB Parar                                    | neters                                                                                                                                                                                              |                  |                  |
| PLB address width                                      | C_SPLB_AWIDTH                                | 32                                                                                                                                                                                                  | 32               | integer          |
| PLB data width                                         | C_SPLB_DWIDTH                                | 32                                                                                                                                                                                                  | 32               | integer          |
| Selects point-to-point or shared PLB topology          | C_SPLB_P2P                                   | 0 = Shared Bus Topology 1 = Point-to- Point Bus Topology                                                                                                                                            | 0                | integer          |
| PLB MAster ID Bus Width                                | C_SPLB_MID_WIDTH                             | log <sub>2</sub> (C_SPLB<br>_NUM_MASTERS) with a<br>minimum value of 1                                                                                                                              | 1                | integer          |
| Number of PLB Masters                                  | C_SPLB_NUM_<br>MASTERS                       | 1-16                                                                                                                                                                                                | 1                | integer          |
| Width of the Slave Data Bus                            | C_SPLB_NATIVE_WIDTH                          | 32                                                                                                                                                                                                  | 32               | integer          |
| Selects the transactions as being single beat or burst | C_SPLB_SUPPORT_<br>BURSTS                    | 0 = Supports only single beat transactions                                                                                                                                                          | 0                | integer          |
|                                                        | AXI4-Lite Par                                | rameters                                                                                                                                                                                            |                  |                  |
| AXI Address Bus Width                                  | C_S_AXI_ADDR_WIDTH                           | 32                                                                                                                                                                                                  | 32               | integer          |
| AXI Data Bus Width                                     | C_S_AXI_DATA_WIDTH                           | 32                                                                                                                                                                                                  | 32               | integer          |
|                                                        |                                              |                                                                                                                                                                                                     |                  |                  |

<sup>1.</sup> The range specified by C\_BASESADDR and C\_HIGHADDR must be sized and aligned to some power of 2, 2n. Then, the least n significant bits of C\_BASEADDR are zero. This range needs to encompass the addresses needed by the MDM UART registers.



In addition to the parameters listed in this table, there are also parameters that are inferred for each AXI interface in the EDK tools. Through the design, these EDK-inferred parameters control the behavior of the AXI Interconnect. For a complete list of the interconnect settings related to the AXI interface, see DS768, AXI Interconnect IP Data Sheet.

#### **Allowable Parameter Combinations**

There are no restrictions on parameter combinations for this core.

## **Parameter-Port Dependencies**

The core has no parameter-port dependencies.

## **MDM Registers**

The MDM registers are listed and described in Table 3.

Table 3: MDM Registers

| Register<br>Name | Size (bits)  | Address<br>Offset | Initial<br>State | Description                                                                                                             |
|------------------|--------------|-------------------|------------------|-------------------------------------------------------------------------------------------------------------------------|
| Rx_FIFO          | C_UART_WIDTH | 0                 | 0                | JTAG UART receive data                                                                                                  |
| Tx_FIFO          | C_UART_WIDTH | 4                 | 0                | JTAG UART transmit data                                                                                                 |
| Status_reg       | 8            | 8                 | 0x04             | Read only bit 7 rx_Data_Present bit 6 rx_Buffer_Full bit 5 tx_Buffer_Empty bit 4 tx_Buffer_Full bit 3 enable_interrupts |
| Ctrl_reg         | 8            | С                 | 0x03             | Write only bit 3 enable_interrupts bit 5 Clear Ext BRK signal bit 6 Reset_RX_FIFO bit 7 Reset_TX_FIFO                   |

# **MDM Interrupts**

If the interrupt enable register bit in the control register is set, the UART raises the interrupt signal in the cycle when the TX FIFO goes empty, or in every cycle where the RX FIFO has data available.

# **Design Implementation**

## **Target Technology**

The target technology is an FPGA listed in the Supported Device Family field of the LogiCORE IP Facts Table.

#### **Device Utilization and Performance Benchmarks**

Not available.



## **Specification Exceptions**

When programming a System Ace device, the MDM clock must be at least twice as fast as the System Ace<sup>TM</sup> tool controller clock for the ELF file to load correctly.

#### **Reference Documents**

The MDM core is intended to be used with the EDK XMD tool. For more information on how to debug using MDM and XMD, see the *Embedded System Tools Reference Manual*.

## **Revision History**

The following table shows the revision history for this document:

| Date       | Version | Revision                                                         |  |  |
|------------|---------|------------------------------------------------------------------|--|--|
| 09/21/2010 | 2.0     | Initial Xilinx release for MDM v2.00.a with AXI4-Lite interface. |  |  |
| 03/01/2010 | 2.1     | Xilinx release for MDM v2.00.b with AXI4-Lite interface.         |  |  |

## **Notice of Disclaimer**

Xilinx is providing this product documentation, hereinafter "Information," to you "AS IS" with no warranty of any kind, express or implied. Xilinx makes no representation that the Information, or any particular implementation thereof, is free from any claims of infringement. You are responsible for obtaining any rights you may require for any implementation based on the Information. All specifications are subject to change without notice. XILINX EXPRESSLY DISCLAIMS ANY WARRANTY WHATSOEVER WITH RESPECT TO THE ADEQUACY OF THE INFORMATION OR ANY IMPLEMENTATION BASED THEREON, INCLUDING BUT NOT LIMITED TO ANY WARRANTIES OR REPRESENTATIONS THAT THIS IMPLEMENTATION IS FREE FROM CLAIMS OF INFRINGEMENT AND ANY IMPLIED WARRANTIES OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Except as stated herein, none of the Information may be copied, reproduced, distributed, republished, downloaded, displayed, posted, or transmitted in any form or by any means including, but not limited to, electronic, mechanical, photocopying, recording, or otherwise, without the prior written consent of Xilinx.