quick.gif

space2.gif

space2.gif

space2.gif

space2.gif

space2.gif

space2.gif

space2.gif

   

space.gif

   

space.gif

  ../images/main/bulllet_4dots_orange.gif Clocks

Clocks are special objects in SystemC. They are used for generating clocks, that are used for synchronizing the events in SystemC models link in any other HDL.

   

space.gif

A clock object has a number of data members to store clock settings, and methods to perform clock actions. To create a clock object use the following syntax:

   

space.gif

sc_clock clock("my_clock", 10, 0.5, 1, false);

   

space.gif

../images/systemc/clock.gif
   

space.gif

This declaration will create a clock object named clock with a period of 10 time units, a duty cycle of 50%, the first edge will occur at 1 time units, and the first value will be false. All of these arguments have default values except for the clock name. The period defaults to 1, the duty cycle to 0.5, the first edge to 0, and the first value to true.

   

space.gif

Typically clocks are created at the top level of the design in the testbench and passed down through the module hierarchy to the rest of the design.

   

space.gif

When binding the clock to a port the designer must use the clock signal generated by the clock object to map to a port. This done by using the signal method of the clock object.

   

space.gif

For SC_CTHREAD processes the clock object is directly mapped to the clock input of the process and the signal() method is not required.

   

space.gif

   

space.gif

  ../images/main/bullet_star_pink.gif Example : Clocks

Below example is same as what we saw in last page, only difference is we have replaced the manual clock with sc_clock signal and used clock.signal() method at port binding.

   

space.gif


   1 #include <systemc.h>
   2 
   3 SC_MODULE (some_block) {
   4   sc_in<bool>   clock;
   5   sc_in<sc_bit> data;
   6   sc_in<sc_bit> reset;
   7   sc_in<sc_bit> inv;
   8   sc_out<sc_bit> out;
   9 
  10   void body () {
  11     if (reset.read() == 1) {
  12       out = sc_bit(0);
  13     } else if (inv.read() == 1) {
  14       out = ~out.read();
  15     } else {
  16       out.write(data.read());
  17     }
  18   }
  19    
  20   SC_CTOR(some_block) {
  21     SC_METHOD(body);
  22       sensitive << clock.pos();
  23   }
  24 };
  25 
  26 
  27 SC_MODULE (signal_bind) {
  28   sc_in<bool> clock;
  29 
  30   sc_signal<sc_bit> data;
  31   sc_signal<sc_bit> reset;
  32   sc_signal<sc_bit> inv;
  33   sc_signal<sc_bit> out;
  34   some_block *block;
  35   int  done;
  36 
  37   void do_test() {
  38     while (true) {
  39       wait();
  40       if (done == 0) {
  41         cout << "@" << sc_time_stamp() <<" Starting test"<<endl;
  42         wait();
  43         wait();
  44         inv = sc_bit('0');
  45         data = sc_bit('0');
  46         cout << "@" << sc_time_stamp() <<" Driving 0 all inputs"<<endl;
  47         // Assert reset
  48         reset = sc_bit('1');
  49         cout << "@" << sc_time_stamp() <<" Asserting reset"<<endl;
  50         // Deassert reset
  51         wait();
  52         wait();
  53         reset = sc_bit('0');
  54         cout << "@" << sc_time_stamp() <<" De-Asserting reset"<<endl;
  55         // Assert data
  56         wait();
  57         wait();
  58         cout << "@" << sc_time_stamp() <<" Asserting data"<<endl;
  59         data = sc_bit('1');
  60         wait();
  61         wait();
  62         cout << "@" << sc_time_stamp() <<" Asserting inv"<<endl;
  63         inv = sc_bit('1');
  64         wait();
  65         wait();
  66         cout << "@" << sc_time_stamp() <<" De-Asserting inv"<<endl;
  67         inv = sc_bit('0');
  68         wait();
  69         wait();
  70         done = 1;
  71       }
  72     }
  73   }
  74 
  75   void monitor() {
  76     cout << "@" << sc_time_stamp() << " data :" << data 
  77       << " reset :" << reset << " inv :" 
  78       << inv << " out :" << out <<endl;
  79   }
  80 
  81   SC_CTOR(signal_bind) {
  82     block = new some_block("SOME_BLOCK");
  83     block->clock       (clock)  ;
  84     block->data        (data)   ;
  85     block->reset       (reset)  ;
  86     block->inv         (inv)    ;
  87     block->out         (out)    ;
  88     done = 0;
  89                            
  90     SC_CTHREAD(do_test,clock.pos());
  91     SC_METHOD(monitor);
  92       sensitive << data << reset << inv << out;
  93   }
  94   
  95 }; 
  96 
  97 
  98 int sc_main (int argc, char* argv[]) {
  99   sc_clock clock ("my_clock",1,0.5);
 100 
 101   signal_bind  object("SIGNAL_BIND");
 102     object.clock (clock.signal());
 103   sc_trace_file *wf = sc_create_vcd_trace_file("clock");
 104     sc_trace(wf, object.clock, "clock");
 105     sc_trace(wf, object.reset, "reset");
 106     sc_trace(wf, object.data, "data");
 107     sc_trace(wf, object.inv, "inv");
 108     sc_trace(wf, object.out, "out");
 109 
 110   sc_start(100);
 111   sc_close_vcd_trace_file(wf);
 112       
 113   cout<<"Terminating Simulation"<<endl;
 114   return 0;// Terminate simulation
 115 }
You could download file clock.cpp here
   

space.gif

  ../images/main/bullet_star_pink.gif Simulation Output : Clocks
   

space.gif

              SystemC 2.0.1 --- Oct  6 2006 19:17:37
         Copyright (c) 1996-2002 by all Contributors
                     ALL RIGHTS RESERVED
 @0 s data :0 reset :0 inv :0 out :0
 WARNING: Default time step is used for VCD tracing.
 @1 ns Starting test
 @3 ns Driving 0 all inputs
 @3 ns Asserting reset
 @3 ns data :0 reset :1 inv :0 out :0
 @5 ns De-Asserting reset
 @5 ns data :0 reset :0 inv :0 out :0
 @7 ns Asserting data
 @7 ns data :1 reset :0 inv :0 out :0
 @8 ns data :1 reset :0 inv :0 out :1
 @9 ns Asserting inv
 @9 ns data :1 reset :0 inv :1 out :1
 @10 ns data :1 reset :0 inv :1 out :0
 @11 ns De-Asserting inv
 @11 ns data :1 reset :0 inv :0 out :1
 Terminating Simulation
   

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