Introduction
The Xilinx LogiCORE™ IP Distributed Memory Generator core uses Xilinx Synthesis Technology (XST) to create a variety of distributed memories.

Features
- Generates read-only memories (ROMs), single, simple dual, and dual-port random access memories (RAMs), and SRL16-based memories
- Supports data depths ranging from 16–65,536 words
- Supports data widths ranging from 1–1024 bits
- Optional registered inputs and outputs
- Optional pipelining when output is registered

<table>
<thead>
<tr>
<th>LogiCORE IP Facts</th>
</tr>
</thead>
<tbody>
<tr>
<td>Core Specifics</td>
</tr>
<tr>
<td>Supported Device Family</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Resources Used</th>
</tr>
</thead>
<tbody>
<tr>
<td>I/O LUTs FFs Block RAMs</td>
</tr>
<tr>
<td>Varies based on core configuration None</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>CLB/REG</th>
</tr>
</thead>
<tbody>
<tr>
<td>Varies based on core configuration</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Provided with Core</th>
</tr>
</thead>
<tbody>
<tr>
<td>Documentation</td>
</tr>
<tr>
<td>Design File Formats</td>
</tr>
<tr>
<td>Behavioral Models</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Design Tool Requirements</th>
</tr>
</thead>
<tbody>
<tr>
<td>Xilinx Implementation Tools</td>
</tr>
<tr>
<td>Verification</td>
</tr>
<tr>
<td>Simulation</td>
</tr>
<tr>
<td>Synthesis</td>
</tr>
</tbody>
</table>

Support
Provided by Xilinx, Inc.

---

1. For the complete list of supported devices, see Table 1, page 2 and the release notes for this core.
2. For the supported versions of the tools, see the ISE Design Suite 13: Release Notes Guide.

---

© 2009-2012 Xilinx, Inc. Xilinx, the Xilinx logo, Artix, ISE, Kintex, Spartan, Virtex, Zynq, and other designated brands included herein are trademarks of Xilinx in the United States and other countries. All other trademarks are the property of their respective owners.
Overview

The Distributed Memory Generator core is used to create memory structures using LUT distributed RAM resources. The core can create the following memory types:

- Distributed ROM, page 3
- Distributed Single-Port RAM, page 5
- Distributed Dual-Port RAM, page 6
- Distributed SRL16-Based RAM, page 8 (excluding Zynq™-7000, Artix™-7, Kintex™-7, Virtex-6, Virtex-5 and Spartan®-6 devices)
- Distributed Simple Dual-Port RAM, page 9

For detailed information about each memory type, see the respective memory type in the Functional Description, page 3.

Options are available for simple registering of inputs and outputs. Optional asynchronous and synchronous resets are available for the output registers. For timing information, see the Xilinx Product Specification for the specific target architecture.

Applications

Applications for Distributed Memory are diverse and numerous. Examples include

- Using the distributed ROM as a very large look-up table
- Using the single-port RAM as scratch pad memory for the embedded PowerPC™ microprocessors used within the Zynq-7000, 7 series, Virtex-6, Virtex-5, and Virtex-4 families, or for the MicroBlaze™ or PicoBlaze™ processors
- Using the simple dual and dual-port RAM within an asynchronous FIFO
- Using the SRL16-based RAM for pattern generation

A large number of Xilinx IP cores rely on the Distributed Memory Generator internally to implement memory structures.

Supported Devices

Table 1 shows the families and sub-families supported by the Distributed Memory Generator.

<table>
<thead>
<tr>
<th>FPGA Family</th>
<th>Sub-Family</th>
</tr>
</thead>
<tbody>
<tr>
<td>Spartan-3</td>
<td></td>
</tr>
<tr>
<td>Spartan-3E</td>
<td></td>
</tr>
<tr>
<td>Spartan-3A</td>
<td></td>
</tr>
<tr>
<td>Spartan-3AN</td>
<td></td>
</tr>
<tr>
<td>Spartan-3A DSP</td>
<td></td>
</tr>
<tr>
<td>Spartan-6</td>
<td>LX/LXT</td>
</tr>
<tr>
<td>Virtex-4</td>
<td>LX/FX/SX</td>
</tr>
<tr>
<td>Virtex-5</td>
<td>LXT/FXT/SXT/TXT</td>
</tr>
<tr>
<td>Virtex-6</td>
<td>CXT/HXT/LXT/SXT</td>
</tr>
<tr>
<td>Virtex-7</td>
<td></td>
</tr>
<tr>
<td>Kintex-7</td>
<td></td>
</tr>
</tbody>
</table>
**Feature Summary**

**Depth.** In all supported FPGA families, the depth can range from 16–65536 words in multiples of 16.

**Width.** The width of each word can be anywhere in the range of 1–1024 bits.

**Optional Input Registering.** The following inputs to the memory can be registered or non-registered. When input registering is used, these inputs can be clock-enabled.

- Write Address
- Data
- Write Enable
- Output Register Clock Enable
- Dual-port RAM Read Address
- Simple Dual-port RAM Read Address

**Optional Output Registering and Pipelining.** The memory can be non-registered, registered, or both. The output registers can have a variety of controls, including

- Asynchronous Reset
- Synchronous Reset
- Clock Enable

In addition, the Clock Enable and Synchronous Reset can be configured so the Synchronous Reset overrides the Clock Enable, and vice versa. In single-port, simple dual-port and dual-port distributed RAM cores with registered outputs, an additional pipeline register may be added to the output path to improve the operating speed at the expense of an additional cycle of latency.

**Functional Description**

The following sections provide a functional description and illustration of each of the four memory types.

**Distributed ROM**

The Distributed Memory Generator uses LUT-based distributed ROM resources to create 16-bit deep, 1-bit wide ROMs, and generates a fabric-based bus multiplexer to create a deeper and wider ROM. The content of this memory is defined by supplying an input coefficient (COE) file to the CORE Generator™ software when the memory is generated, after which the content is fixed.

To create the distributed ROM, the core parses the initialization data provided by the user-supplied COE file. From that data, any necessary logic or optional registering is inferred and created. Figure 1 shows the distributed ROM schematic symbol, and Figure 2 illustrates one of the possible
implementations of a distributed ROM core. For distributed ROM timing information, see the user guide for the specific FPGA family-related architecture.
Distributed Single-Port RAM

The distributed single-port RAM uses the single-port distributed RAM resource of the LUT. Writes to the Single-Port RAM are synchronous to the clock (CLK). However, read operations can be asynchronous (SPO) or synchronous to the clock (QSPO). Figure 3 illustrates the distributed single-port RAM schematic symbol, and Figure 4 illustrates its internal implementation. If a pipeline register is added to a registered core (not illustrated), the additional register is re-timed into the SPO MUX array. For timing information about the distributed single-port RAM, see the appropriate user guide for the target FPGA architecture.

![Distributed Single-Port RAM Schematic Symbol](image)

Figure 3: Distributed Single-Port RAM Schematic Symbol

![Distributed Single-Port RAM Module Schematic](image)

Figure 4: Distributed Single-Port RAM Module Schematic

*3 for LUT4 architecture

**Qualification of WE with I_CE optional
Distributed Dual-Port RAM

Writes to the distributed dual-port RAM are synchronous to the clock (CLK). However, read operations from the distributed dual-port RAM can be asynchronous or synchronous with respect to either of the two clocks (CLK or QDPO_CLK). Figure 5 illustrates the dual-port RAM schematic symbol, showing the relevant ports. Figure 6 shows the internal implementation of the distributed dual-port RAM. If a pipeline register is added to a registered core (not illustrated), the additional register is re-timed into the SPO MUX array and DPO MUX array.

In implementing the most simple dual-port RAM, two LUTs sharing a common write logic are used. When RAM is written to, both LUTs continue to share common content but have different address buses for reading. In this way, contents from two different memory locations can be addressed and read from the SPO and DPO outputs. Different clock domains can also be used to clock the data read out of the SPO and DPO pins if the outputs are also registered.

The QDPO_CE port controls DPRA only when Dual Port Output CE is selected under output options.

The width of the data buses must be identical on input and output. If width conversion is required from a memory instance, consider using the Block Memory Generator core.
Figure 5: Dual-Port RAM Schematic Symbol

Figure 6: Dual-Port RAM Module Schematic

* 3 for LUT4 architecture
** Qualification of WE with I_CE optional
Distributed SRL16-Based RAM

*Note:* The Virtex-5 and above architectures do not support SRL16-based memories.

Figure 7 shows the schematic symbol of the distributed SRL16-based RAM. Note that Address Bus A, used to write data to a specific address in the SRL16 array, does not contain the full range of bits normally required for a memory of a given depth. Address Bus A is missing the four least significant bits because the four address bits on each SRL16 are driven by the four least significant bits from the read address bus SPRA. (The address pins on the SRL16 determine where in the SRL16 the data is read from, not where data is written to.)

Where written data is placed in the address space is determined by the specific SRL16 written to, and where previous data has gone, because data is sequentially written into the SRL16. This means that the four least-significant bits in address bus A are not required.

Because 16-bit deep shift registers are being used in place of the LUT4 primitives, the SRL16-based RAM is not a genuine RAM. Specifically, random access is given to addresses the client of the memory wants to read from to access the SRL16 holding the data of interest. To write data to a specific location in memory, the application using the memory has to enable a specific SRL16 or set of SRL16s (when the width of the RAM is greater than 1 bit), and then assert the Write Enable for the RAM. The Write Enable actually drives the Clock Enable on the SRL16, allowing data to be shifted into the SRL16s.

![SRL16-Based RAM Schematic Symbol](image-url)
Distributed Simple Dual-Port RAM

**Note:** Simple Dual-Port RAM is supported only for Zynq-7000, 7 series, Virtex-6, Virtex-5, and Spartan-6 device families.

Writes to the distributed simple dual-port RAM are synchronous to the clock (CLK). However, read operations from the distributed simple dual-port RAM can be asynchronous or synchronous with respect to either of the two clocks (CLK or QDPO_CLK). Figure 9 illustrates the simple dual-port RAM schematic symbol, showing the relevant ports. Figure 10 shows the internal implementation of the distributed simple dual-port RAM. If a pipeline register is added to a registered core (not illustrated), the additional register is re-timed into the DPO MUX array.

The QDPO_CE port controls DPRA only when Simple Dual Port Output CE is selected under output options.

The width of the data buses must be identical on input and output. If width conversion is required from a memory instance, consider using the Block Memory Generator core.

**Figure 8: SRL16-Based RAM Module Schematic**
Figure 9: Simple Dual-Port RAM Schematic Symbol

Figure 10: Simple Dual-Port RAM Module Schematic

* 3 for LUT4 architecture
** Qualification of WE with I_CE optional
Waveforms

Detailed timing diagrams for Distributed Memory cores vary depending on the target architecture. Examples can be found in the user guide for the target architecture. See the Xilinx Support Library for available user guides.

Signal List

Table 2 defines the Distributed Memory core signals.

**Table 2: Core Signal Pinout**

<table>
<thead>
<tr>
<th>Name</th>
<th>Direction</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>D[P:0]</td>
<td>Input</td>
<td>Data input to be written into the memory for single-port, simple dual-port, dual-port and SRL16-based RAMs.</td>
</tr>
<tr>
<td>A[N:0]</td>
<td>Input</td>
<td>Address inputs. Only address input for ROMs and single-port RAMs. On SRL16-based RAMs, it defines the most significant bits (4 and up) of the memory locations written to. On dual-port memories, it defines memory location written to and memory location read out on the SPO[P:0] outputs. On simple dual-port memories, it defines memory location written to.</td>
</tr>
<tr>
<td>SPRA[N:0]</td>
<td>Input</td>
<td>Single-Port Read Address. Present only on SRL16-based RAMs and defines memory location read out on the SPO[P:0] outputs.</td>
</tr>
<tr>
<td>DPRA[N:0]</td>
<td>Input</td>
<td>Dual/Simple Dual-Port Read Address. Present only on dual-port and simple dual-port RAMs and defines memory location read out on the DPO[P:0] outputs.</td>
</tr>
<tr>
<td>SPO[P:0]</td>
<td>Output</td>
<td>Non-registered single-port output bus. Non-registered data output bus for ROMs, single-port, and SRL16-based RAMs. One of two non-registered output buses on dual-port RAMs.</td>
</tr>
<tr>
<td>QSPO[P:0]</td>
<td>Output</td>
<td>Registered single-port output bus. Registered data output bus for ROMs, single-port, and SRL16-based RAMs. One of two registered output buses on dual-port RAMs.</td>
</tr>
<tr>
<td>DPO[P:0]</td>
<td>Output</td>
<td>Non-registered dual/simple dual-port output bus. One of the non-registered data output buses for dual-port and simple dual-port RAMs. Data stored at the address location specified by DPRA[N:0] appears at this port.</td>
</tr>
<tr>
<td>QDPO[P:0]</td>
<td>Output</td>
<td>Registered dual/simple dual-port output bus. One of two registered output buses on dual-port and simple dual-port RAMs.</td>
</tr>
<tr>
<td>CLK</td>
<td>Input</td>
<td>Write clock and register clock for ROMs, single-port, and SRL16-based RAMs. On dual-port RAMs signal is the write clock and register clock for single-port input and output registers.</td>
</tr>
<tr>
<td>QDPO_CLK</td>
<td>Input</td>
<td>On dual-port and simple dual-port RAMs, signal is the write clock and register clock for dual-port input and output registers.</td>
</tr>
<tr>
<td>WE</td>
<td>Input</td>
<td>Write Enable.</td>
</tr>
<tr>
<td>I_CE</td>
<td>Input</td>
<td>Input Clock Enable. Signal is present for RAMs which have registered inputs. The clock enable controls input data register, address register and WE register.</td>
</tr>
<tr>
<td>QSPO_CE</td>
<td>Input</td>
<td>On ROMs, clock enable controls all input and output registers. On dual-port memories, controls output registers in QSPO path.</td>
</tr>
<tr>
<td>QDPO_CE</td>
<td>Input</td>
<td>Present only on dual-port and simple dual-port RAMs. Controls output registers in QDPO path.</td>
</tr>
</tbody>
</table>
Generating the Core

The Distributed Memory Generator can be found in two places in the CORE Generator graphical user interface (GUI) View by Function pane.

To access the Distributed Memory Generator, do one of the following:

- Choose Basic Elements > Memory Elements.
- Choose Memories & Storage Elements > RAMs & ROMs.

CORE Generator Parameter Screens

The Distributed Memory Generator GUI uses three screens.

- Main Screen (Figure 11)
- Input, Dual-Port, and Output Options Screen (Figure 12)
- Initial Content and Reset Options Screen (Figure 13)

All the screens share common tabs and buttons to provide information about the core and perform specific actions, such as generating the core and navigating among screens.

### Table 2: Core Signal Pinout (Cont’d)

<table>
<thead>
<tr>
<th>Name</th>
<th>Direction</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>QSPO_RST</td>
<td>Input</td>
<td>Single-port registered output asynchronous reset.</td>
</tr>
<tr>
<td>QDPO_RST</td>
<td>Input</td>
<td>Available only on dual-port and simple dual-port RAMs. Dual/Simple Dual-port registered output asynchronous reset.</td>
</tr>
<tr>
<td>QSPO_SRST</td>
<td>Input</td>
<td>Single-port registered output synchronous reset</td>
</tr>
<tr>
<td>QDPO_SRST</td>
<td>Input</td>
<td>Available only on dual-port and simple dual-port RAMs. Dual-port registered output synchronous reset</td>
</tr>
</tbody>
</table>

**Note:** All control inputs are Active High. If an Active Low input is required for a specific control pin, an inverter must be placed in the path to the pin; the inverter is absorbed appropriately during mapping.
Main Screen

Figure 11: Main Screen

Component Name. The base name of the output files generated for the core. Names must begin with a letter and be composed of any of the following characters: a to z, 0 to 9 and “_.”

Depth. Enter a value in the valid range from 16–65536, in steps of 16. Default value is 64.

Data Width: Enter the width of the memory in the valid range from 1–1024. The default value is 16.

Memory Type: Select one of five options. The default setting is single-port RAM.

- **ROM.** Figure 2 is a schematic of the structure of the ROM modules. The address register is optional (controlled by the setting of the Input Options parameter). Output registering is also optional (controlled by the setting of the Output Options parameter). Note that the clock is not required when these registers are not present. The resets and clock enables are optional.

- **Single-Port RAM.** Figure 4 is a schematic of the structure of the single-port RAM modules. The address and data registers are optional (controlled by the setting of the Input Options parameter). Output registering is also optional (controlled by the setting of the Output Options parameter). The resets and clock enables are optional. The clock CLK is always required because writes to the single-port RAM are synchronous to that clock.

- **Dual-Port RAM.** Figure 6 is a schematic of the structure of the dual-port RAM modules. The address and data registers are optional (controlled by the setting of the Input Options parameter). The dual-port read address register is optional (controlled by the setting of the Dual-Port Address parameter). Output registers for both output ports are also optional (controlled by the setting of the Output Options parameter). When registered outputs are selected, the two output ports can be
clocked by the same or different clock signals and can have the same or different clock enables (based on the settings selected for the Common Output Clock and Common Output CE parameters). All resets and clock enables are optional. Note that the clock CLK is always required, because writes to the RAM are synchronous to that clock.

- **SRL16-Based RAM.** Figure 8 is a schematic of the structure of the SRL16-based RAM module. The address and data registers are optional (controlled by the setting of the Input Options parameter). Output registers are also optional (controlled by the setting of the Output Options parameter). The resets and clock enables are optional. When the project family is set to Virtex-5 and above architectures, this option will be greyed-out.

- **Simple Dual-Port RAM.** Figure 10 is a schematic of the structure of the simple dual-port RAM modules. The address and data registers are optional (controlled by the setting of the Input Options parameter). The simple dual-port read address register is optional (controlled by the setting of the Simple Dual-Port Address parameter). Output registers for both output ports are also optional (controlled by the setting of the Output Options parameter).

When registered outputs are selected, the output port can be clocked by the same or different clock signals and can have the same or different clock enables (based on the settings selected for the Common Output Clock and Common Output CE parameters). All resets and clock enables are optional. Note that the clock CLK is always required because writes to the RAM are synchronous to that clock. When the project family is not set to the Zynq-7000, 7 series, Virtex-6, Virtex-5, or Spartan-6 family, this option will be greyed-out.

**Input, Dual-Port, and Output Options Screen**

![Distributed Memory Options Screen](image)

**Figure 12: Distributed Memory Options Screen**

**Input Options.** Select an option for the required input types. Non-registered is the default setting. Selecting Registered produces different effects depending on the selected memory type. For ROM, an
address register is generated; for single-port RAM, simple dual-port, dual-port, and SRL16-based RAM, a register on the A[N:0] address input, a data input register, and a WE register are generated.

- **Input Clock Enable.** An optional input available when Input Options are set to Registered and Memory Type is *not* a ROM.

- **Qualify WE with I_CE.** Valid only for single-port RAM, simple dual-port RAM, dual-port RAM, and SRL16-based RAM with Input Options set to Registered and Input Clock Enable selected. When deselected, the WE register has no clock-enable control. When selected, the WE register has a clock enable driven by the I_CE input.

**Dual/Simple Dual-Port Address.** Valid only for simple dual-port RAM and dual-port RAMs, and controls the presence or absence of a register on the DPRA[N:0] inputs. Non-registered is the default setting.

Pipelining Options: When registered single-port RAMs, simple dual-port RAMs and dual-port RAMs are selected, an optional pipeline register can be placed into the output path.

- **Pipeline Stages.** Select ‘0’ for no pipeline registers and ‘1’ for a single pipeline stage in the output multiplexer.

**Output Options**: Select an option for the required output types. Non-registered is the default setting.

- **Single-Port Output Clock Enable.** Enabled for registered output memory or for input registered ROM to provide this optional pin.

- **Dual/Simple Dual-Port Output Clock Enable.** Enabled only for output registered simple dual-port RAM and dual-port RAMs to provide this optional pin.

- **Common Output CLK.** Enabled only for registered simple dual-port RAMs and dual-port RAMs. If not selected, the SPO registers are clocked by the CLK input and the DPO registers are clocked from the QDPO_CLK input. Default setting is selected, where all output registers are clocked from the CLK input.

- **Common Output CE.** Enabled only for non-registered simple dual-port RAMs and dual-port RAMs and only if Common Output Clock is also selected. If Common Output CE is deselected, the SPO register clocks are enabled by the QSPO_CE input and the DPO register clocks are enabled from the QDPO_CE input. Default setting is selected, where all output register clocks are enabled by the QSPO_CE input.
Initial Content and Reset Options

Load COE File
The initial values of the memory elements can be set using a COE file.
- To load the COE file, click Browse.
- To view the initial contents, click Show.

For a description of the COE file, see Specifying Memory Contents Using a COE File.

COE Options
Enter the initial value to be stored in memory locations not otherwise initialized in the COE file.
- Default Data: When no value is entered, the field defaults to 0. Values can be entered in binary, decimal, or hexadecimal formats, as defined by the Default Data Radix entry.
- Radix: Choose the radix of the Default Data value. Valid entries are 2, 10, and 16.

Reset Options
- Reset QSPO: Enabled only when the core has a registered single-port output. If selected, an asynchronous single-port output reset pin is available.
- Reset QDPO: Enabled only when the core has a registered simple dual-port and dual-port output. If selected, an asynchronous simple dual-port and dual-port output reset pin is available.
- Synchronous Reset QSPO: Enabled only when the core has a registered single-port output. If selected, a synchronous single-port output reset pin is available.
• **Synchronous Reset QDPO**: Enabled only when the core has a registered simple dual-port and dual-port output. If selected, a synchronous simple dual-port and dual-port output reset pin is available.

• **CE Overrides Sync Controls**: Enabled only when one of the synchronous reset options has been selected and an output clock enable has been selected. When selected, the synchronous control signals are qualified by the clock enable pin.

• **Sync Controls Overrides CE**: Enabled only when one of the synchronous reset options has been selected and an output clock enable has been selected. When selected, the synchronous control signals operate regardless of the state of the output clock enable signals.

### Specifying Memory Contents Using a COE File

The initial contents of the memory can be defined using the COE file, which consists of two parameters: `memory_initialization_radix` and `memory_initialization_vector`. Each line is terminated by a semicolon.

- **memory_initialization_radix**: The radix of the initialization value is specified here, with the choices being 2, 10, or 16.

- **memory_initialization_vector**: Each row of memory elements are defined with a binary, decimal, or hexadecimal number having an equivalent binary value that represents whether an individual memory element along the width of the row is set to ‘1’ or ‘0.’ Each row of memory initialization is separated by a comma or white space, up to the depth of the memory. Negative values are not allowed.

An example COE file:

```
; Sample Initialization file for a 16x32 distributed ROM
memory_initialization_radix = 16;
memory_initialization_vector =
  23f4 0721 11ff ABel 0001 1 0A 0
  23f4 0721 11ff ABel 0001 1 0A 0
  23f4 721 11ff ABel 0001 1 A 0
  23f4 721 11ff ABel 0001 1 A 0;
```

### MIF File Description

The COE file provides a high-level method for specifying initial memory contents. During core generation, the COE file is converted into a MIF file, which holds the actual binary data used to initialize the memory in the core and simulation models. The MIF file consists of one line of text per memory location. The first line in the file corresponds to address 0, and the second line corresponds to address 1, and so forth. The text on each line must be the initialization value (MSB first) for the corresponding memory address in binary format, with exactly one binary digit per bit of memory width.

**Note**: For HDL simulations, the MIF file must reside in the simulation directory.
Core Implementation

Functional Simulation
VHDL and Verilog behavioral models of the Distributed Memory Generator core are provided with the XilinxCoreLib library for use within a simulation environment. Note that neither a test bench nor test fixture is provided with the Distributed Memory Generator.

The functional simulation model for this core is behavioral. Certain conditions such as out-of-range writes are not modelled in a cycle-accurate manner. Run timing simulation to more closely simulate cycle-based behavior.

Synthesis
Synthesis of the memory produced by the Distributed Memory Generator is performed with XST by the CORE Generator software.

Xilinx Tools
See the LogiCORE IP Facts table on page 1.

Static Timing Analysis
Static timing analysis can be performed using trce, following ngdbuild, map, and par.

Gate-level Simulation
If desired, the CORE Generator software can create a UniSim-based VHDL or Verilog model for gate level simulation, which is delivered with the NGC netlist. Alternatively, the netlist produced by the CORE Generator for the desired memory can be processed using ngdbuild and netgen to produce a SimPrim-based model for simulation.

Verification
Verification of the netlist produced by the CORE Generator is completed by a cycle-by-cycle comparison against the VHDL and Verilog behavioral models of the core contained within the XilinxCoreLib behavioral model library.

Core Resource Utilization
When designing distributed memories, the LUTs in the slices are used to implement memory primitives or to construct multiplexers. The registers available in these slices are used for input and output registering.

When input registering is requested, extra registers are used. One per control bit (WE, QSPO_CE, and QDPO_CE) and one per bit of data and address (D[P:0], A[N:0], and SPRA[N:0]/DPRA[N:0]).

Support
Xilinx provides technical support at www.xilinx.com/support for this LogiCORE™ IP product when used as described in the product documentation. Xilinx cannot guarantee timing, functionality, or
support of product if implemented in devices that are not defined in the documentation, if customized beyond that allowed in the product documentation, or if changes are made to any section of the design labeled DO NOT MODIFY.

See the IP Release Notes Guide (XTP025) for more information on this core. For each core, there is a master Answer Record that contains the Release Notes and Known Issues list for the core being used. The following information is listed for each version of the core:

- New Features
- Resolved Issues
- Known Issues

Ordering Information

The Distributed Memory Generator LogiCORE IP core is included at no additional charge with the Xilinx ISE Design Suite software and is provided under the terms of the Xilinx End User License Agreement. The version of the core documented in this data sheet can be generated using the ISE CORE Generator system. For more information, please visit the Distributed Memory Generator core page.

Information about additional Xilinx LogiCORE modules is available at the Xilinx IP Center. For information on pricing and availability of other Xilinx LogiCORE modules and software, please contact your local Xilinx sales representative.

Revision History

The following table shows the revision history for this document:

<table>
<thead>
<tr>
<th>Date</th>
<th>Version</th>
<th>Description of Revisions</th>
</tr>
</thead>
<tbody>
<tr>
<td>10/20/04</td>
<td>1.0</td>
<td>Initial draft.</td>
</tr>
<tr>
<td>4/28/05</td>
<td>1.1</td>
<td>Initial Xilinx release.</td>
</tr>
<tr>
<td>1/11/06</td>
<td>2.0</td>
<td>Updated version, ISE to 8.1i, fixed licensing section.</td>
</tr>
<tr>
<td>7/13/06</td>
<td>3.0</td>
<td>Updated for IP1i minor release. Added Virtex-5 support.</td>
</tr>
<tr>
<td>9/21/06</td>
<td>4.0</td>
<td>Updated core version to 3.2; added support for Spartan-3A.</td>
</tr>
<tr>
<td>2/15/07</td>
<td>5.0</td>
<td>Updated core version to 3.3; Xilinx tools 9.1i; added support for Spartan-3AN.</td>
</tr>
<tr>
<td>4/02/07</td>
<td>5.5</td>
<td>Added support for Spartan-3A DSP devices.</td>
</tr>
<tr>
<td>10/15/07</td>
<td>6.0</td>
<td>Updated core version to 3.4; Corrected Figure 6.</td>
</tr>
<tr>
<td>3/24/08</td>
<td>7.0</td>
<td>Updated core to version 3.4; ISE tools to 10.1.</td>
</tr>
<tr>
<td>12/17/08</td>
<td>7.0.1</td>
<td>Early access document.</td>
</tr>
<tr>
<td>4/24/09</td>
<td>8.0</td>
<td>Updated core to version 4.1 and ISE tools to version 11.1.</td>
</tr>
<tr>
<td>6/24/09</td>
<td>9.0</td>
<td>Updated ISE tools to version 11.2.</td>
</tr>
<tr>
<td>9/16/09</td>
<td>10.0</td>
<td>Updated core to version 4.2 and ISE tools to version 11.3.</td>
</tr>
<tr>
<td>12/02/09</td>
<td>11.0</td>
<td>Updated core to version 4.3 and ISE tools to version 11.4.</td>
</tr>
<tr>
<td>4/19/10</td>
<td>12.0</td>
<td>Updated core to version 5.1 and ISE tools to version 12.1</td>
</tr>
<tr>
<td>3/1/11</td>
<td>13.0</td>
<td>Updated core to version 6.1 and ISE tools to version 13.1. Added support for Virtex-7 and Kintex-7 FPGAs.</td>
</tr>
<tr>
<td>Date</td>
<td>Version</td>
<td>Description of Revisions</td>
</tr>
<tr>
<td>--------</td>
<td>---------</td>
<td>---------------------------------------------------</td>
</tr>
<tr>
<td>6/22/11</td>
<td>14.0</td>
<td>Updated core to version 6.2 and ISE tools to version 13.2.</td>
</tr>
<tr>
<td>1/18/12</td>
<td>15.0</td>
<td>Updated core to version 6.3 and ISE tools to version 13.4.</td>
</tr>
</tbody>
</table>
Notice of Disclaimer

The information disclosed to you hereunder (the “Materials”) is provided solely for the selection and use of Xilinx products. To the maximum extent permitted by applicable law: (1) Materials are made available “AS IS” and with all faults, Xilinx hereby DISCLAIMS ALL WARRANTIES AND CONDITIONS, EXPRESS, IMPLIED, OR STATUTORY, INCLUDING BUT NOT LIMITED TO WARRANTIES OF MERCHANTABILITY, NON-INFRINGEMENT, OR FITNESS FOR ANY PARTICULAR PURPOSE; and (2) Xilinx shall not be liable (whether in contract or tort, including negligence, or under any other theory of liability) for any loss or damage of any kind or nature related to, arising under, or in connection with, the Materials (including your use of the Materials), including for any direct, indirect, special, incidental, or consequential loss or damage (including loss of data, profits, goodwill, or any type of loss or damage suffered as a result of any action brought by a third party) even if such damage or loss was reasonably foreseeable or Xilinx had been advised of the possibility of the same. Xilinx assumes no obligation to correct any errors contained in the Materials or to notify you of updates to the Materials or to product specifications. You may not reproduce, modify, distribute, or publicly display the Materials without prior written consent. Certain products are subject to the terms and conditions of the Limited Warranties which can be viewed at http://www.xilinx.com/warranty.htm; IP cores may be subject to warranty and support terms contained in a license issued to you by Xilinx. Xilinx products are not designed or intended to be fail-safe or for use in any application requiring fail-safe performance; you assume sole risk and liability for use of Xilinx products in Critical Applications: http://www.xilinx.com/warranty.htm#critapps.