|  | 
|  |  | 
 |  
|  |  |  |  
|  |  | 
 |  
|  |  | SystemC TxGen Header File |  
|  |  | 
 |  
|  |  | 
  1 #ifndef MEMORY_TXGEN_H
  2 #define MEMORY_TXGEN_H
  3 
  4 #include "systemc.h"
  5 #include "scv.h"
  6 #include "mem_t.h"
  7 #include "mem_t_ext.h"
  8 
  9 SC_MODULE (memory_txGen) {
 10   sc_in<bool>          clk;   // Clock input
 11   sc_out<sc_uint<8> >  addr;  // Address output
 12   sc_out<bool>         wr;    // Write enable
 13   sc_out<bool>         cs;    // Chip select
 14   sc_out<sc_uint<32> > wdata; // Write data
 15   sc_in<sc_uint<32> >  rdata; // Read data
 16   sc_out<bool>         done;  // Testing done
 17 
 18   void test(); // Method which implements test
 19 
 20   SC_CTOR(memory_txGen) {
 21     SC_CTHREAD(test,clk.pos());
 22   }
 23 };
 24 
 25 #endif
You could download file memory_txGen.h here |  
|  |  | 
 |  
|  |  |  |  
|  |  | 
 |  
|  |  | SystemC TxGen Body |  
|  |  | 
 |  
|  |  | 
  1 #include "memory_txGen.h"
  2 
  3 void memory_txGen::test() {
  4   scv_smart_ptr  <mem_t > object;
  5   int error = 0;
  6   // Drive low on all signals input to DUT
  7   addr  = 0;
  8   wr    = 0;
  9   cs    = 0;
 10   wdata = 0; 
 11   done  = 0;
 12   wait(1); // wait for one clock
 13   cout<<"@"<<sc_time_stamp()<<" Starting the memory write/read test"<<endl;
 14   for(int i = 0; i < 10;i++) {
 15     // Get the next random address and data object
 16     object->next();
 17     //------------------------------------------
 18     //  Do Memory Write
 19     //------------------------------------------
 20     // Drive the addess
 21     addr  = object->addr.read();
 22     // Drive the data
 23     wdata = object->data.read();
 24     // Drive Chip Select
 25     cs    = 1;
 26     // Drive write enable
 27     wr    = 1;
 28     cout<<"@"<<sc_time_stamp()<<" Writing address : "<< object->addr <<endl;
 29     wait(1); // Wait for one clock
 30     cs    = 0; // Deassert chip select
 31     wr    = 0; // Deassert write enable
 32     wait(1); // Wait for one clock
 33     //------------------------------------------
 34     //  Do Memory Read from Same Address
 35     //------------------------------------------
 36     cs    = 1; // Assert the chip select
 37     cout<<"@"<<sc_time_stamp()<<" Reading address : "<< object->addr <<endl;
 38     wait(1);
 39     // Compare the data written with read data
 40     if (rdata  ! = wdata) {
 41       error ++; // If error increment counter
 42       cout<<"@"<<sc_time_stamp()<<" Error : Write data : " << 
 43         wdata << " Read data : " << rdata << endl;
 44     } else {
 45       cout<<"@"<<sc_time_stamp()<<" Match : Write data : " << 
 46         wdata << " Read data : " << rdata << endl;
 47     }
 48     cs    = 0; // Deassert the chip selct
 49     wait(1);
 50   }
 51   // Request for simulation termination
 52   if (error > 0) {
 53     cout << "=======================================" << endl;
 54     cout << " SIMULATION FAILED" << endl;
 55     cout << "=======================================" << endl;
 56   } else {
 57     cout << "=======================================" << endl;
 58     cout << " SIMULATION PASSED" << endl;
 59     cout << "=======================================" << endl;
 60   }
 61   done = 1;
 62   // Just wait for few cycles
 63   wait(100);
 64 }
You could download file memory_txGen.cpp here |  
|  |  | 
 |  
|  |  | SystemC Exports |  
|  |  | 
 |  
|  |  | 
  1 #ifndef MEMORY_TB_EXPORTS_H
  2 #define MEMORY_TB_EXPORTS_H
  3 
  4 #ifdef __cplusplus
  5 extern "C" {
  6 #endif
  7 
  8 void init_sc     ();
  9 void exit_sc     ();
 10 void sample_hdl  (void *Invector);
 11 void drive_hdl   (void *Outvector);
 12 void advance_sim (unsigned long simtime);
 13 void exec_sc     (void *invector, void *outvector, unsigned long simtime);
 14 
 15 #ifdef __cplusplus
 16 }
 17 #endif
 18 
 19 #endif
You could download file memory_tb_exports.h here |  
|  |  | 
 |  
|  |  | 
 |  
|  |  | 
 |  
|  |  |  |  
|  |  | 
 |  |  | 
|  
 |  
 |  
 | 
| 
 | 
|    |  
| Copyright © 1998-2025 |  
| Deepak Kumar Tala - All rights reserved |  
| Do you have any Comment? mail me at:deepak@asic-world.com
 |  |