quick.gif

space2.gif

space2.gif

space2.gif

space2.gif

space2.gif

space2.gif

space2.gif

   

space.gif

   

space.gif

  ../images/main/bullet_star_pink.gif Verilog DUT
   

space.gif


  1 // Simple Verilog Memory Model
  2 module memory(
  3 address,     // Address bus port
  4 data_in,     // Data input port
  5 data_out,    // Data output port
  6 read_write,  // Read/Write Enable
  7 chip_en      // Chip select
  8 );
  9 
 10 input [7:0] address;
 11 input [31:0] data_in;
 12 output [31:0] data_out;
 13 input read_write, chip_en;
 14 
 15 reg [31:0] mem [0:255];
 16 
 17 always @ (address or data_in or read_write or chip_en)
 18 if (read_write == 1 && chip_en == 1) begin
 19   mem[address] = data_in;
 20 end
 21 
 22 assign data_out = (read_write == 0 && chip_en == 1) ? mem[address] : 0;
 23 
 24 endmodule
 25 
 26 // Top level testbench code
 27 module tb();
 28 
 29 // All the signals that need to be driven from
 30 // SystemC testbench needs be declared as reg
 31 reg [7:0] addr;
 32 reg [31:0] wdata;
 33 wire [31:0] rdata;
 34 reg         wr;
 35 reg         cs;
 36 reg         clk;
 37 
 38 // Connect the Verilog Memory DUT
 39 memory dut (addr,wdata,rdata,wr,cs);
 40 
 41 initial begin
 42   clk = 0;
 43   // Connect the systemC testbench here
 44   $memory_tb(clk,rdata,addr,wr,cs,wdata);
 45   $dumpfile("memory.vcd");
 46   $dumpvars();
 47 end
 48 // Clock generator
 49 always  #1  clk = ~clk;
 50 
 51 endmodule
You could download file memory.v here
   

space.gif

   

space.gif

  ../images/main/bullet_star_pink.gif SystemC Mem Type
   

space.gif


  1 #ifndef MEM_T_H
  2 #define MEM_T_H
  3 
  4 class mem_t {
  5   public:
  6     mem_t () {}
  7     virtual ~mem_t() {}
  8 
  9     sc_uint<8>      addr;
 10     sc_uint<32>     data;
 11 
 12     // Define an assign operator
 13     mem_t& operator=(const mem_t& rhs) {
 14       addr=rhs.addr; 
 15       data=rhs.data; 
 16       return *this;
 17     }
 18 
 19     // Define a comparison operator
 20     friend bool operator==(const mem_t& a, const mem_t& b) {
 21       if (a.addr  ! = b.addr) {return false;}
 22       if (a.data  ! = b.data) {return false;}
 23       return true;
 24     }
 25 
 26     // Define ostream method to print data
 27     friend ostream& operator<< (ostream& os, const mem_t& mem) {
 28       os << " Address : " << mem.addr << " Data : " << mem.data;
 29       return os;
 30     }
 31 };
 32 
 33 #endif
You could download file mem_t.h here
   

space.gif

  ../images/main/bullet_star_pink.gif SystemC Mem Type Extension
   

space.gif


  1 #ifndef MEM_T_EXT_H
  2 #define MEM_T_EXT_H
  3 
  4 SCV_EXTENSIONS(mem_t) {
  5   public:
  6     scv_extensions< sc_uint<8> > addr;
  7     scv_extensions< sc_uint<32> > data;
  8     SCV_EXTENSIONS_CTOR(mem_t) {
  9       SCV_FIELD(addr);
 10       SCV_FIELD(data);
 11     }
 12 };
 13 
 14 #endif
You could download file mem_t_ext.h here
   

space.gif

   

space.gif

   

space.gif

   

space.gif

space2.gif

space2.gif

space2.gif

space2.gif

space2.gif

  

Copyright © 1998-2025

Deepak Kumar Tala - All rights reserved

Do you have any Comment? mail me at:deepak@asic-world.com