# HB0940 Handbook CoreMRAM\_AHB v2.0





a MICROCHIP company

#### Microsemi Headquarters

One Enterprise, Aliso Viejo, CA 92656 USA Within the USA: +1 (800) 713-4113 Outside the USA: +1 (949) 380-6100 Sales: +1 (949) 380-6136 Fax: +1 (949) 215-4996

Email: sales.support@microsemi.com www.microsemi.com

©2020 Microsemi, a wholly owned subsidiary of Microchip Technology Inc. All rights reserved. Microsemi and the Microsemi logo are registered trademarks of Microsemi Corporation. All other trademarks and service marks are the property of their respective owners.

Microsemi makes no warranty, representation, or guarantee regarding the information contained herein or the suitability of its products and services for any particular purpose, nor does Microsemi assume any liability whatsoever arising out of the application or use of any product or circuit. The products sold hereunder and any other products sold by Microsemi have been subject to limited testing and should not be used in conjunction with mission-critical equipment or applications. Any performance specifications are believed to be reliable but are not verified, and Buyer must conduct and complete all performance and other testing of the products, alone and together with, or installed in, any end-products. Buyer shall not rely on any data and performance specifications or parameters provided by Microsemi. It is the Buyer's responsibility to independently determine suitability of any products and to test and verify the same. The information provided by Microsemi hereunder is provided "as is, where is" and with all faults, and the entire risk associated with such information is entirely with the Buyer. Microsemi does not grant, explicitly or implicitly, to any party any patent rights, licenses, or any other IP rights, whether with regard to such information itself or anything described by such information. Information provided in this document is proprietary to Microsemi, and Microsemi reserves the right to make any changes to the information in this document or to any products and services at any time without notice.

#### **About Microsemi**

Microsemi, a wholly owned subsidiary of Microchip Technology Inc. (Nasdaq: MCHP), offers a comprehensive portfolio of semiconductor and system solutions for aerospace & defense, communications, data center and industrial markets. Products include high-performance and radiation-hardened analog mixed-signal integrated circuits, FPGAs, SoCs and ASICs; power management products; timing and synchronization devices and precise time solutions, setting the world's standard for time; voice processing devices; RF solutions; discrete components; enterprise storage and communication solutions, security technologies and scalable anti-tamper products; Ethernet solutions; Power-over-Ethernet ICs and midspans; as well as custom design capabilities and services. Learn more at www.microsemi.com.



# **Contents**

| 1 | Revisi                | ion History                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |     |
|---|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
|   |                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |     |
| 2 | Introd<br>2.1         | uction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |
|   | 2.2<br>2.3            | Core Version                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |
|   | 2.4<br>2.5            | Key Features                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |
| 3 |                       | ional Block Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |
|   | 3.1<br>3.2            | Functional Overview                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | . 4 |
|   | 3.3                   | Timing Requirements of MRAM Device                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | . 5 |
| 4 | Tool F                | 3.3.2 Write Cycle                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |     |
| 4 | 4.1                   | Licenses                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | . 7 |
|   | 4.2                   | RTL SmartDesign Sm | . 7 |
|   | 4.4<br>4.5            | Simulation Flows Synthesis in Libero                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | . 7 |
| 5 | 4.6                   | Place-and-Route in Libero                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |     |
| 5 | 5.1                   | Parameters/Generics                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |     |
| 6 | Interfa<br>6.1<br>6.2 | ACE Descriptions  AHB Interface Signals  MRAM Interface Signals                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | . 9 |
| 7 |                       | ace Timings                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 11  |
| 8 |                       | n Constraints Timing Constraints                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 12  |
| 0 |                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |     |
| 9 | 9.1                   | ench Operation and Modifications Testbench Operation 9.1.1 VHDL User Testbench                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 16  |
|   | 9.2                   | Testbench Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 16  |



# **Figures**

| Figure 1 | CoreMRAM_AHB Application                                            | 2 |
|----------|---------------------------------------------------------------------|---|
|          | CoreMRAM_AHB Block Diagram                                          |   |
|          | Read Cycle AC Timing                                                |   |
|          | Write Cycle AC Timing                                               |   |
|          | CoreMRAM_AHB Configuration Within SmartDesign                       |   |
| Figure 6 | CoreMRAM_AHB write transaction of HSIZE = 2 and 1, BYTE_MODE_EN = 0 | 1 |
| Figure 7 | CoreMRAM_AHB Read transaction of HSIZE = 2 and 1, BYTE_MODE_EN = 0  | 1 |
| Figure 8 | CoreMRAM_AHB Testbench                                              | ( |



# **Tables**

| Table 1 | CoreMRAM AHB Device Utilization and Performance |
|---------|-------------------------------------------------|
| Table 2 | Read Cycle AC Timing Requirements               |
| Table 3 | Read Cycle AC Timing Requirements               |
| Table 4 | CoreMRAM Write Cycle AC Timing Requirements     |
| Table 5 | CoreMRAM_AHB Generics                           |
| Table 6 | Local Bus Signals                               |
| Table 7 | MRAM Interface Signals                          |



# 1 Revision History

The revision history describes the changes that were implemented in the document. The changes are listed by revision, starting with the most current publication.

## **1.1** Revision **1.0**

The first publication of this document.



## 2 Introduction

#### 2.1 Core Overview

CoreMRAM\_AHB provides a high-performance interface to single-data-rate (SDR) synchronous Non-Volatile Magneto-Resistive RAM (MRAM) Honeywell HXNV01600 device. CoreMRAM\_AHB accepts read and write commands using the advanced high-performance bus (AHBL) slave interface and translates these requests to the command sequences required by the MRAM device.

A typical application using CoreMRAM AHB is shown in Figure 1.

Figure 1 • CoreMRAM\_AHB Application



#### 2.2 Core Version

This handbook applies to CoreMRAM\_AHB v2.0. The release notes provided with the core, list the known discrepancies between this handbook and the core release associated with the release notes.

## 2.3 Supported Device Families

- PolarFire<sup>®</sup> SoC
- PolarFire<sup>®</sup>
- RTG4<sup>TM</sup>
- IGLOO®2
- SmartFusion<sup>®</sup>2

## 2.4 Key Features

The following key features are supported in the CoreMRAM\_AHB module:

- Provides high performance, Non-Volatile Magneto-Resistive RAM (MRAM) controller for standard Honeywell HXNV01600 Device.
- · Provides synchronous interface, fully pipelined internal architecture
- · Supports up to 16 Megabit of memory
- Configuration supports 16Mb (x8 or x16)
- Supports Core Clock frequencies 12, 24, and 48 MHz
- Supports the ECC feature on internal RAM
- Supports for Advanced High-performance Lite Bus (AHBL) slave interface



### 2.5 Device Utilization and Performance

 $\label{eq:coreMRAM} \textbf{CoreMRAM\_AHB has been implemented in several Microsemi} \begin{tabular}{l} \textbf{@ device families. A summary of the implementation data is listed in Table 1.} \end{tabular}$ 

Table 1 • CoreMRAM\_AHB Device Utilization and Performance

| FPGA Family                          | Parameter Name | Utilization |      |       |       | Frequency (MHz) |          |
|--------------------------------------|----------------|-------------|------|-------|-------|-----------------|----------|
| and Device                           | BYTE_MODE_EN   | Sequential  | Comb | Total | %     | HCLK            | CORE_CLK |
| PolarFire SoC<br>MPFS250T ES-FCG1152 | 0              | 495         | 738  | 1230  | 0.24  | 200             | 175      |
| WII 1 32301_L3-1 C31132              | 1              | 503         | 731  | 1234  | 0.24  | 199             | 175      |
| PolarFire<br>MPF500T-1FCG1152E       | 0              | 495         | 714  | 1209  | 0.125 | 219             | 194      |
| WII 1 0001-11 OG1102E                | 1              | 503         | 724  | 1227  | 0.125 | 233             | 205      |
| RTG4<br>RT4G150-1FCG1657M            | 0              | 567         | 828  | 1395  | 0.46  | 157             | 150      |
| 1014G130-11 GG1007W                  | 1              | 575         | 845  | 1420  | 0.47  | 145             | 142      |
| IGLOO2<br>M2GL050T-FG484             | 0              | 567         | 839  | 1406  | 1.25  | 161             | 137      |
| WIZGE0301-1 0-10-1                   | 1              | 575         | 795  | 1370  | 1.21  | 156             | 132      |
| SmartFusion2<br>M2S050T- FG484       | 0              | 567         | 839  | 1406  | 1.25  | 161             | 137      |
| WZ-00501-1 0404                      | 1              | 575         | 795  | 1370  | 1.21  | 156             | 132      |

**Note:** All data was obtained using a default system configuration. All performance data was obtained under commercial (COM) conditions.



## 3 Functional Block Description

#### 3.1 Functional Overview

CoreMRAM AHB consists of the following primary blocks, as shown in Figure 2:

- AHBL Slave Interface Perform Read and write transactions on the AHBL.
- Synchronization Module Consist of write data buffer, read data buffer, and control signal synchronization module, which handles asynchronous data transfer between AHB HCLK and CORE CLK clock domain and vice versa to support AHB Burst transactions.
- MRAM Controller: This block generates the required MRAM interface data, control, and clock signal.
- This core has three clock domains. That is AHB Clock, Core clock, and MRAM clock domain.

Figure 2 • CoreMRAM\_AHB Block Diagram



## 3.2 Clocking and Reset

The Memory interface clock (MRAMCLK\_OUT) is derived from CORE\_CLK inside the IP. The MRAMCLK\_OUT minimum required time-period for read and write transactions are 120ns and 140ns respectively. Table 2 shows the Read Cycle Time and Write Cycle Time corresponding to CORE\_CLK frequency.

The CORE\_CLK can be asynchronous to HCLK. The read/write buffers in the IP core handles the clock domain crossing of signals between HCLK to CORE\_CLK and vice-versa.

Table 2 • Read Cycle AC Timing Requirements

| CORE_CLK (MHz) | Read Cycle Time (ns) | Write Cycle Time (ns) |
|----------------|----------------------|-----------------------|
| 12             | 251                  | 166                   |
| 24             | 166                  | 166                   |
| 48             | 125                  | 145                   |



## 3.3 Timing Requirements of MRAM Device

### 3.3.1 Read Cycle

The non-volatile MRAM is synchronous in operation relative to the rising edge of the CLK signal. With the initiation of a rising CLK signal, the Address and the Write Enable (WE) signals are captured, and the read operation begins from the desired memory location. The addressed memory locations are read and compared with the ECC values. Any single bit errors are detected and corrected. If WE is low when captured, the data word is sent to the output drivers. In addition to WE low being captured, Output Enable (OE) must be set to high to enable the DQ output buffers. OE is not captured and may be set high before or after the rising edge of CLK. Figure 3 and Table 3 show the timing requirement for control and address signals.

Figure 3 • Read Cycle AC Timing



Table 3 • Read Cycle AC Timing Requirements

| Name   | Description                                 | Min | Max | Units |
|--------|---------------------------------------------|-----|-----|-------|
| Tads   | Address Setup Time                          | 5   | -   | ns    |
| Tadh   | Address Hold Time                           | 15  | -   | ns    |
| Twes   | WE Setup Time                               | 5   | -   | ns    |
| Tweh   | WE Hold Time                                | 15  | -   | ns    |
| Tcebs  | CE B Setup Time                             | 5   | -   | ns    |
| Tcebh  | CE B Hold Time                              | 15  | -   | ns    |
| Tclkdv | DQ valid with respect to rising edge of CLK | 50  | 95  | ns    |
| Tclkhz | Clock Low to DQ Hi-z                        | 1   | 15  | ns    |
| Toedv  | OE access time                              | -   | 15  | ns    |
| Toehz  | OE de-asserted to DQ Hi-z                   | 1   | 15  | ns    |
| Tminr  | Read Cycle Time                             | 120 | -   | ns    |
| Tlo    | Clock Low Time                              | 15  | -   | ns    |
|        |                                             |     |     |       |



#### 3.3.2 Write Cycle

The MRAM is synchronous in operation relative to the rising edge of the CLK signal. With the initiation of a rising edge CLK signal, the Address, and WE signals are captured into the device. The WRITE CYCLE begins by reading the currently addressed value in memory. The current memory data are compared to the data to be written. If the location needs to change the value, the data are then written. The bit cell construction of this device does not provide a method of simply writing a "1" or a "0" to match the data. The "write" to a bit can only change its state, thus the need to read the bit location first. Only the bits which need to "change state" are written. Figure 4 and Table 4 show the timing requirement for control and address signals with respect to CLK.

Figure 4 • Write Cycle AC Timing



Table 4 • CoreMRAM Write Cycle AC Timing Requirements

| Name  | Description        | Min | Max | Units |
|-------|--------------------|-----|-----|-------|
| Tads  | Address Setup Time | 5   | -   | ns    |
| Tadh  | Address Hold Time  | 15  | -   | ns    |
| Twes  | WE Setup Time      | 5   | -   | ns    |
| Tweh  | WE Hold Time       | 15  | -   | ns    |
| Tcebs | CE B Setup Time    | 5   | -   | ns    |
| Tcebh | CE B Hold Time     | 15  | -   | ns    |
| Tdqs  | Data Setup Time    | 5   | -   | ns    |
| Tdqh  | Data Hold Time     | 15  | -   | ns    |
| Tminw | Write Cycle Time   | 140 | -   | ns    |
| Thi   | Clock High Time    | 15  | -   | ns    |
| Tlo   | Clock Low Time     | 15  | -   | ns    |



## 4 Tool Flows

#### 4.1 Licenses

No license is required for this core.

#### 4.2 RTL

Complete RTL source code is provided for the core and testbenches.

## 4.3 SmartDesign

CoreMRAM\_AHB is available for download in the Libero<sup>®</sup> SoC IP catalog through the web repository. Once it is listed in the catalog, the core can be instantiated using the SmartDesign flow. For information on using SmartDesign to configure, connect, and generate cores, refer to the *Using DirectCore in Libero User Guide* or consult the Libero SoC online help. The core can be configured using the configuration GUI within SmartDesign, as shown in Figure 5.

Figure 5 • CoreMRAM\_AHB Configuration Within SmartDesign



### 4.4 Simulation Flows

To run simulations, select the user testbench within the SmartDesign CoreMRAM\_AHB configuration GUI, right-click, and select **Generate Design** (Figure 5).

When SmartDesign generates the design files, it will install the appropriate testbench files. To run the simulation, set the design root to the CoreMRAM\_AHB instantiation in the Libero design hierarchy pane, and click **Simulation** in the Libero **Design Flow** window. This invokes ModelSim<sup>®</sup> and automatically runs the simulation.

## 4.5 Synthesis in Libero

Set the design root appropriately and click the Synthesis icon in the Libero. The synthesis window appears, displaying the Synplicity<sup>®</sup> project. To perform synthesis, click **Run**.

### 4.6 Place-and-Route in Libero

After the design has been synthesized, click **Layout** in Libero to invoke the designer. CoreMRAM\_AHB requires no special place-and-route settings.



# **5** Core Parameters

## 5.1 Parameters/Generics

The generics are listed in Table 5 as required in the source code.

Table 5 • CoreMRAM\_AHB Generics

|                     | Default |                    |                                                                                                                          |
|---------------------|---------|--------------------|--------------------------------------------------------------------------------------------------------------------------|
| Generic             | Setting | Valid Values       | Description                                                                                                              |
| FAMILY              | 25      | 19, 24, 25, 26, 27 | 19 - SmartFusion2<br>24 - IGLOO2<br>25 - RTG4<br>26 - PolarFire<br>27 - PolarFire SoC                                    |
| BYTE_MODE_EN        | 0       | 0-1                | Select 16 bits / 8bits Memory interface 0 - enable x16 memory interface 1 - enable x8 memory interface                   |
| CORE_CLK_ FREQUENCY | 12      | 12,24,48           | CORE_CLK frequency in MHz                                                                                                |
| ECC                 | 0       | 0-1                | 0 - ECC Disabled 1 - ECC Enabled Note: ECC is only available for the RTG4, PolarFire, and PolarFire SoC device families. |
| BUFFER_DEPTH        | 16      | 16-1024            | Configurable FIFO depth, can be configure power of 2 values within 16 to 1024 range.                                     |



# 6 Interface Descriptions

The port signals for CoreMRAM\_AHB are defined in Table 6 and Table 7. The port signals are also shown in Figure 6, page 11 and Figure 7, page 11. All signals are designated either input (input-only) or output (output-only), except DQ, which is bidirectional.

## 6.1 AHB Interface Signals

The user interface to CoreMRAM\_AHB is referred to as the local bus interface. The local bus signals are listed in Table 6.

Table 6 • Local Bus Signals

| Signal         | I/O    | Description                                                                                                                                                                                     |
|----------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CORE_CLK       | Input  | MRAM Controller Clock                                                                                                                                                                           |
| CORECLK_RESETN | Input  | Asynchronous reset (Active low and asynchronous)                                                                                                                                                |
| HCLK           | Input  | AHB clock                                                                                                                                                                                       |
| HRESETN        | Input  | AHB reset (Active low and asynchronous)                                                                                                                                                         |
| HADDR[31:0]    | Input  | AHB address                                                                                                                                                                                     |
| HREADYIN       | Input  | AHB ready in                                                                                                                                                                                    |
| HTRANS[1:0]    | Input  | AHB transfer type                                                                                                                                                                               |
| HWRITE         | Input  | AHB write/read                                                                                                                                                                                  |
| HSIZE[2:0]     | Input  | AHB transfer size                                                                                                                                                                               |
| HBURST[2:0]    | Input  | AHB burst type                                                                                                                                                                                  |
| HSEL           | Input  | AHB slave select                                                                                                                                                                                |
| HREADY         | Output | AHB ready out                                                                                                                                                                                   |
| HRESP[1:0]     | Output | AHB response                                                                                                                                                                                    |
| HWDATA[31:0]   | Input  | AHB data in                                                                                                                                                                                     |
| HRDATA[31:0]   | Output | AHB data out                                                                                                                                                                                    |
| ECC_ERROR_SB   | Output | Single bit error correct ECC status signal, when set to logic 1, indicates that the data buffer/FIFO has a single bit error corrected by ECC logic. Visible at the port when parameter ECC = 1. |
| ECC_ERROR_DB   | Output | Double bit error detects ECC status signal, when set to logic 1, indicates that the data buffer/FIFO has double bit error detected by ECC logic. Visible at the port when parameter ECC = 1.    |



## 6.2 MRAM Interface Signals

The external interface to the Non-Volatile Magneto-Resistive RAM device is referred to as the MRAM interface. The MRAM interface signals are listed in Table 7.

Table 7 • MRAM Interface Signals

| Signal      | I/O          | Description                                                                                                                      |
|-------------|--------------|----------------------------------------------------------------------------------------------------------------------------------|
| MRAMCLK_OUT | Output       | MRAM interface clock                                                                                                             |
| A[20:0]     | Output       | Address Bus                                                                                                                      |
| WE          | Output       | Write Enable                                                                                                                     |
| X8          | Output       | Byte Mode configuration                                                                                                          |
| OE          | Output       | Output Enable, tristate control for DQ data                                                                                      |
| DQ [15:0]   | Input/Output | MRAM in/out data When OE=1, it drives read data, otherwise it drives write data.                                                 |
| AUTO_INCR   | Output       | AUTO_INCR pin drive logic 0, as Auto Increment Feature is not supported.                                                         |
| OVERFLOW_I  | Output       | OVERFLOW_I pin drive logic 0, as Auto Increment Feature is not supported.                                                        |
| INIT        | Output       | INIT pin drive logic 0, as Auto Increment Feature is not supported.                                                              |
| DONE        | Output       | DONE pin drive logic 0, as Auto Increment Feature is not supported.                                                              |
| OVERFLOW_O  | Input        | Internal Overflow Counter Indicator, as Auto Increment Feature is not supported this signal does not drive logic inside IP core. |



# 7 Interface Timings

#### 7.1 MRAM Writes and Reads

Figure 6 shows an example CoreMRAM\_AHB write transaction of HSIZE = 2 and 1, BYTE\_MODE\_EN = 0.

Figure 6 • CoreMRAM\_AHB write transaction of HSIZE = 2 and 1, BYTE\_MODE\_EN = 0



Figure 7 shows an example CoreMRAM\_AHB Read transaction of HSIZE = 2 and 1, BYTE\_MODE\_EN = 0.

Figure 7 • CoreMRAM\_AHB Read transaction of HSIZE = 2 and 1, BYTE\_MODE\_EN = 0





## 8 Design Constraints

This section describes the timing constraints of the CoreMRAM AHB IP core.

### 8.1 Timing Constraints

Asynchronous FIFO and Pulse Synchronizer used in the core to transfer data between asynchronous clock domains and to synchronize control signal in all the clock domains respectively, requires timing constraint for synthesis, place and route, and timing verification. Add the constraints for the path from HCLK clock domain to CORE\_CLK clock domain and from CORE\_CLK clock domain to HCLK domain is as follows:

CoreMRAM\_AHB\_0--- Instance name of CoreMRAM\_AHB module.

When the parameter BYTE\_MODE\_EN is set to 0

```
set false path -from [get cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/command burst*} ] -to [qet cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/rx fifo rd cnt*} ]
set false path -from [get cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/command burst*} ] -to [get cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/rx fifo rd done*} ]
set false path -from [get cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/number of mram trans*} ] -to [get cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/number of mram trans ahb s*} ]
set false path -from [get cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/trans type ahb*} ] -to [get cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/trans type core s*} ]
set false path -from [get cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/wr follow rd*} ] -to [get cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/wr follow rd core s*}]
set false path -from [get cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/command*} ] -to [get cells
{CoreMRAM_AHB_0/U_COREMRAM_AHBLIF/command_addr*} ]
set false path -from [get cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/command*} ] -to [get cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/command size*}]
set false path -from [get cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/command*} ] -to [get cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/command burst*}]
set false path -from [get cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/number of mram trans cnt*} ] -to
[get_cells {CoreMRAM_AHB_0/U_COREMRAM MRAMIF/DQ out*}]
set false path -from [get cells
{CoreMRAM_AHB_0/U_COREMRAM_AHBLIF/number_of mram trans cnt*} ] -to
[get cells {CoreMRAM AHB 0/U COREMRAM MRAMIF/A int*}]
set false path -from [get cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/CORESYNC TERMINATE/pulse gen i/toggle o
ut*} ] -to [get cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/CORESYNC TERMINATE/pulse cdc sync i/syn
c ff*}]
```



```
set false path -from [get cells
{CoreMRAM_AHB_0/U_COREMRAM_AHBLIF/CORESYNC_NEW_TRANS_MRAM/pulse gen i/tog
gle out*} ] -to [get cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/CORESYNC NEW TRANS MRAM/pulse cdc sync
i/sync_ff*}]
set false path -from [get cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/CORESYNC TX FIFO RD EN/pulse gen i/togg
le out*} ] -to [get cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/CORESYNC TX FIFO RD EN/pulse cdc sync i
/sync ff*}]
set false path -from [get cells
{CoreMRAM_AHB_0/U_COREMRAM_AHBLIF/CORESYNC_RX_ADDR_LOAD_EN/pulse_gen_i/to
ggle out*} ] -to [get cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/CORESYNC RX ADDR LOAD EN/pulse cdc sync
_i/sync_ff*}]
set false path -from [get cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/CORESYNC SHIFT MRAM ADDR EN/pulse gen i
/toggle out*} ] -to [get cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/CORESYNC SHIFT MRAM ADDR EN/pulse cdc s
ync i/sync ff*}]
set false path -from [get cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/CORESYNC TRANSACTION DONE/pulse gen i/t
oggle out*} ] -to [get cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/CORESYNC TRANSACTION DONE/pulse cdc syn
c i/sync ff*}]
set false path -from [get cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/coresync load address/pulse gen i/toggl
e out*} ] -to [get cells
{CoreMRAM_AHB_0/U_COREMRAM_AHBLIF/coresync_load_address/pulse cdc sync i/
sync ff*}]
set false path -from [get cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/TX DATA FIFO/wrGrayCounter/cntGray*} ]
-to [get_cells {CoreMRAM_AHB_0/U_COREMRAM_AHBLIF/TX_DATA_FIFO/wrPtr_s1*}]
set false path -from [get cells
{CoreMRAM_AHB_0/U_COREMRAM_AHBLIF/RX_DATA_FIFO/wrGrayCounter/cntGray*} ]
-to [get cells {CoreMRAM AHB 0/U COREMRAM AHBLIF/RX DATA FIFO/wrPtr s1*}]
When the parameter BYTE_MODE_EN is set to 1:
set false path -from [get cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/command burst*} ] -to [get cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/rx fifo rd cnt*} ]
set false path -from [get cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/command burst*} ] -to [get cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/rx fifo rd done*} ]
set false path -from [get cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/number of mram trans*} ] -to [get cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/number of mram trans ahb s*} ]
set_false_path -from [get_cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/trans type ahb*} ] -to [get cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/trans type core s*} ]
```



```
set false path -from [get cells
{CoreMRAM AHB 0/U_COREMRAM_AHBLIF/command*} ] -to [get_cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/command addr*} ]
set false path -from [get cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/command*} ] -to [get cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/command size*}]
set_false_path -from [get_cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/command*} ] -to [get cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/command burst*}]
set false path -from [get cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/number of mram trans cnt*} ] -to
[get cells {CoreMRAM AHB 0/U COREMRAM MRAMIF/DQ out*}]
set false path -from [get cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/number of mram trans cnt*} ] -to
[get cells {CoreMRAM AHB 0/U COREMRAM MRAMIF/A int*}]
set_false_path -from [get_cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/CORESYNC TERMINATE/pulse gen i/toggle o
ut*} ] -to [get cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/CORESYNC TERMINATE/pulse cdc sync i/syn
c ff*}]
set false path -from [get cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/CORESYNC NEW TRANS MRAM/pulse gen i/tog
gle out*} ] -to [get cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/CORESYNC NEW TRANS MRAM/pulse cdc sync
i/sync ff*}]
set false path -from [get cells
{CoreMRAM_AHB_0/U_COREMRAM_AHBLIF/CORESYNC_TX_FIFO_RD_EN/pulse_gen_i/togg
le out*} ] -to [get cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/CORESYNC TX FIFO RD EN/pulse cdc sync i
/sync_ff*}]
set false path -from [get cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/CORESYNC RX ADDR LOAD EN/pulse gen i/to
ggle out*} ] -to [get cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/CORESYNC RX ADDR LOAD EN/pulse cdc sync
i/sync ff*}]
set false path -from [get cells
{CoreMRAM_AHB_0/U_COREMRAM_AHBLIF/CORESYNC_SHIFT_MRAM_ADDR_EN/pulse_gen_i
/toggle out*} ] -to [get cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/CORESYNC SHIFT MRAM ADDR EN/pulse cdc s
ync i/sync ff*}]
set false path -from [get cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/CORESYNC TRANSACTION DONE/pulse gen i/t
oggle out*} ] -to [get cells
{CoreMRAM_AHB_0/U_COREMRAM_AHBLIF/CORESYNC_TRANSACTION_DONE/pulse_cdc_syn
c i/sync ff*}]
set false path -from [get cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/coresync load address/pulse gen i/toggl
e_out*} ] -to [get_cells
{CoreMRAM AHB 0/U COREMRAM AHBLIF/coresync load address/pulse cdc sync i/
sync ff*}]
```



```
set_false_path -from [get_cells
{CoreMRAM_AHB_0/U_COREMRAM_AHBLIF/TX_DATA_FIFO/wrGrayCounter/cntGray*} ]
-to [get_cells {CoreMRAM_AHB_0/U_COREMRAM_AHBLIF/TX_DATA_FIFO/wrPtr_s1*}]
set_false_path -from [get_cells
{CoreMRAM_AHB_0/U_COREMRAM_AHBLIF/RX_DATA_FIFO/wrGrayCounter/cntGray*} ]
-to [get_cells {CoreMRAM_AHB_0/U_COREMRAM_AHBLIF/RX_DATA_FIFO/wrPtr_s1*}]
```



## 9 Testbench Operation and Modifications

### 9.1 Testbench Operation

The following testbench is provided with CoreMRAM AHB:

VHDL testbench with Verilog Memory Model.

#### 9.1.1 VHDL User Testbench

The VHDL user testbench is provided as a reference and can be modified to suit the requirements. The source code for the VHDL testbench is provided to ease the process of integrating the CoreMRAM\_AHB macro into the design and verifying its functionality.

## 9.2 Testbench Description

A user testbench is included with the RTL release of CoreMRAM\_AHB. A simplified block diagram of the testbench is shown in Figure 8. By default, the VHDL version, tb\_user.vhd instantiates a Honeywell HXNV01600 16 Mbits Model (Honeywell\_HXNV01600\_0190423.v). The testbench instantiates the design under test (DUT), which is the CoreMRAM\_AHB, the MRAM model, as well as the test vector modules that provide stimuli sources for the DUT. A procedural testbench controls each module and applies the sequential stimuli to the DUT.

Figure 8 • CoreMRAM\_AHB Testbench



A commented bus functional model (BFM) ASCII script source file (.bfm) is included in the following directory: YourLiberoProjectDirectory/ simulation, where the Libero Project Dir represents the path to the Libero SoC project where CoreMRAM\_AHB is used. The BFM source file is for controlling the AHB-Lite master and is named master.bfm. The BFM source file is automatically recompiled each time the simulation is invoked from Libero SoC by bfmtovec.exe, if running on a Windows® platform, or by bfmtovec.lin, if running on a Linux platform. The output .vec file created by the bfmtovec executable is read in by the BFM modules for simulation in ModelSim.

The BFM scripts can be altered if desired. For more information, refer to the *DirectCore AMBA BFM User Guide*. The source code for the user testbench, BFM scripts, and compiled ModelSim simulation library containing the BFM modules are available with the CoreMRAM\_AHB RTL release.