|
|
|

|
|
|
|
|
|

|
|
 |
Memory Modeling
|
|
|
To help modeling of memory, Verilog provides support for two dimensions arrays. Behavioral models of memories are modeled by declaring an array of register variables; any word in the array may be accessed using an index into the array. A temporary variable is required to access a discrete bit within the array. |
|
|

|
|
 |
Syntax
|
|
|
reg [wordsize:0] array_name [0:arraysize] |
|
|

|
|
 |
Examples
|
|
|

|
|
 |
Declaration
|
|
|
reg [7:0] my_memory [0:255]; |
|
|

|
|
|
Here [7:0] is the memory width and [0:255] is the memory depth with the following parameters: |
|
|
- Width : 8 bits, little endian
- Depth : 256, address 0 corresponds to location 0 in the array.
|
|
|

|
|
 |
Storing Values
|
|
|
my_memory[address] = data_in; |
|
|

|
|
|
|
|
|

|
|
 |
Reading Values
|
|
|
data_out = my_memory[address]; |
|
|

|
|
 |
Bit Read
|
|
|
Sometimes there may be need to read just one bit. Unfortunately Verilog does not allow to read or write only one bit: the workaround for such a problem is as shown below. |
|
|

|
|
|
data_out = my_memory[address]; |
|
|

|
|
|
data_out_it_0 = data_out[0]; |
|
|

|
|
 |
Initializing Memories
|
|
|
A memory array may be initialized by reading memory pattern file from disk and storing it on the memory array. To do this, we use system tasks $readmemb and $readmemh. $readmemb is used for binary representation of memory content and $readmemh for hex representation. |
|
|

|
|
 |
Syntax
|
|
|
$readmemh("file_name",mem_array,start_addr,stop_addr); |
|
|
Note : start_addr and stop_addr are optional. |
|
|

|
|
 |
Example - Simple memory
|
|
|

|
|
|
1 module memory();
2 reg [7:0] my_memory [0:255];
3
4 initial begin
5 $readmemh("memory.list", my_memory);
6 end
7 endmodule
You could download file memory.v here
|
|
|

|
|
 |
Example - Memory.list file
|
|
|

|
|
|
1 //Comments are allowed
2 1100_1100 // This is first address i.e 8'h00
3 1010_1010 // This is second address i.e 8'h01
4 @ 55 // Jump to new address 8'h55
5 0101_1010 // This is address 8'h55
6 0110_1001 // This is address 8'h56
You could download file memory.list here
|
|
|

|
|
|
$readmemh system task can also be used for reading testbench vectors. I will cover this in detail in the test bench section ... when I find time. |
|
|

|
|
|
Refer to the examples section for more details on different types of memories. |
|
|

|
|
|

|
|
|

|
|
|
|
|
|

|
|
|
|
|
|

|
|
Copyright © 1998-2025 |
Deepak Kumar Tala - All rights reserved |
Do you have any Comment? mail me at:deepak@asic-world.com
|
|