

# ProNoC

### RAM

#### Copyright ©2014–2018 Alireza Monemi

This file is part of ProNoC

ProNoC (stands for Prototype Network-on-Chip) is free software: you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation, either version 2 of the License, or (at your option) any later version.

ProNoC is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details. You should have received a copy of the GNU Lesser General Public License along with ProNoC. If not, see <a href="http://www.gnu.org/licenses/">http://www.gnu.org/licenses/</a>.



WB Single Port Figure 1 depicts the functional block diagram of single port RAM module. RAM block diagram:





(b) WB Single port RAM with JTAG\_CONNECT configured as "JTAG\_WB".

Figure 1: WB Single port RAM

Parameters Description

| Name         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Permitted values                                                                 | Default   |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|-----------|
| Dw           | RAM Data width in bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | $\begin{array}{c} n \in \mathbb{N}, \\ 8 \leqslant n \leqslant 1024 \end{array}$ | 32        |
| Aw           | RAM Address width in bits. Total memory size is $2^{Aw} \times Dw$ in bits.                                                                                                                                                                                                                                                                                                                                                                                                                            | $n \in \mathbb{N}, \\ 4 \leqslant n \leqslant 31$                                | 12        |
| BYTE_WR_EN   | Byte enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | "YES" , "NO"                                                                     | "YES"     |
| FPGA_VENDOR  | The target FPGA vendor. If it is defined as AL-<br>TERA, then the altera memory instance (altsyn-<br>cram) is used in generated Verilog code. Oth-<br>erwise, the memory RTL code is written com-<br>pletely in Verilog. Note that for some FPGA de-<br>vices (e.g Cyclone V families) if the byte enable<br>is activated while burst mode is not, the Quar-<br>tus compiler fail to map the memory into any<br>available FPGA BRMA module.                                                            | "ALTERA",<br>"GENERIC"                                                           | "ALTERA"  |
| JTAG_CONNECT | <ul> <li>Define how the memory is programed at run time using JTAG port:</li> <li>"DISABLED": The memory cannot be accessed at run time.</li> <li>"JTAG_WB": The actual memory implements as a dual port BRAM (using altsyncram RAM instance) with the second port is connected to "JTAG_WB" module inside altsyncram.</li> <li>"ALTERA_IMCE": The actual memory implements as a dual port BRAM with the second port is connected to Altera In-System Memory Content Editor control module.</li> </ul> | "DISABLED",<br>"JTAG_WB",<br>"ALTERA_<br>IMCE"                                   | "JTAG₋WB" |
| JTAG_INDEX   | A unique index number which will be used for<br>accessing the memory content using JTAG ca-<br>ble. The default value is the processing tile id<br>(CORE_ID). You can also inter a unique num-<br>ber for each individual memory or any equa-<br>tion with CORE_ID variable. This parameter<br>is valid if the JTAG_CONNECT is not config-<br>ured as "DISABLED".                                                                                                                                      | $n \in \mathbb{N},$<br>or<br>$n = f(CORE\_ID)$<br>$0 \leqslant n \leqslant 127$  | CORE_ID   |
| BURST_MODE   | Enable the Wishbone bus Incrementing burst<br>mode data transfer. Support Linear burst and<br>4,8,16-beat wrap burst types.                                                                                                                                                                                                                                                                                                                                                                            | "DISABLED",<br>"ENABLED"                                                         | "ENABLED" |

#### Table 1: WB single port RAM GUI Parameters.

ProNoC homepage

| Name                      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Permitted values         | Default |
|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|---------|
| MEM_CONTENT_<br>FILE_NAME | <ul> <li>The memory file name (without file type extension ) that is used for writing the memory content either at run time or at initialization time.</li> <li>File Path: <ul> <li>For bus-based SoC the file path is [ProNoC_work]/SOC/[soc_name]/sw/RAM/[file_type]/MEM_FILE_NAME.</li> <li>For NoC-based MPSoC the file path is [ProNoC_work]/MPSOC/[mpsoc_name]/sw/tile[tile_num]/RAM/ [file_type]/MEM_FILE_NAME</li> </ul> </li> <li>File_type: <ul> <li>bin: raw binary format . It will be used by JTAG_WB to change the memory content at runtime.</li> <li>memh: hexadecimal-string format . It will be used for initialing the Generic RAM using \$readmemh command.</li> <li>mif: memory initialization file format. This file can be used to initialize Altera FPGA memory. Also if the JTAG_CONECT is selected as ALTERA_IEMC it can be used for changing the memory content at run time.</li> </ul> </li> </ul> | Any<br>arbitrary<br>name | "ram0"  |
| INITIAL_EN                | It selected as "YES", the memory content<br>will be initialized at compilation time using<br>MEM_CONTENT_FILE_NAME.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | "YES", "NO"              | "NO"    |

## WB Dual Port A Wishbone bus-based dual port Random Access Memory (RAM). RAM

WB Dual Port RAM block diagram:

t Figure2 depicts the functional block diagram of dual port RAM module.



Figure 2: WB Dual Port RAM block diagram

ParametersThe WB dual port RAM shares all the WB single port RAM except the JTAG\_CONNECTDescriptionand JTAG\_INDEX parameters.