AN 307: Intel® FPGA Design Flow for Xilinx* Users

ID 683562
Date 3/20/2018
Public

A newer version of this document is available. Customers should click here to go to the newest version.

Document Table of Contents

4.2.1.2.6. Byte Enable

To ensure that the operation writes only specific bytes of data, embedded memory blocks support the byte enable property, that masks the input data. The unwritten bytes or bits retain the previous value.
Note: Xilinx* RAMs support byte enable in Virtex* -4 and newer devices.

The following table compares byte enable implementation in Xilinx* and Intel® FPGA RAMs

Table 44.  Byte Enables Differences in Xilinx* RAM and Intel® FPGA RAM
Differences Xilinx* RAM Intel® FPGA RAM
Controlling signals

The WEA[n:0] signal controls the byte enable.

Each bit in WEA[n:0] acts as a write enable for the corresponding input data byte.

Uses two signals, write_enable and byte_enable.

To control which byte to write, assert the write_enable signal and the specific bit of the byte_enable signal. For example, in a RAM block in x16 mode:
byte_enable Writing on data[7..0] Writing on data[15..8]
01 Enabled Disabled
11 Enabled Enabled
To create a byte_enable port, the width of the input data port must be a multiple of the byte's size for the port.
Input data width support Support multiples of 8 or 9 bits. Support multiples of 5, 8, 9, 10 bits. For configurations smaller than two bytes wide, the write_enable or clock_enable signals control the write operation.25
Output value of masked byte when performing read-during-write to the same location. Output depends on read-during-write configuration:
  • WRITE_FIRST
  • READ_FIRST
  • NO_CHANGE
Output depends on the type of memory block:
Memory Block Output of Masked Bytes
SDP DONT_CARE or OLD_DATA
True dual Port DONT_CARE
Simple Quad port DONT_CARE
25 Only MLAB memory blocks support byte_enable for input data width that is multiple of 5.