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 Signal Binding

Each port should be bound to a single signal. When reading a ports, the variable assigned to the port must have the same type as the port type.

   

space.gif

When ports are bound to other signals or ports, both types must match.

   

space.gif

   

space.gif

  ../images/main/bullet_star_pink.gif Example : Signal 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 int sc_main (int argc, char* argv[]) {
  97   sc_signal<bool> clock;
  98   int i;
  99 
 100   signal_bind  object("SIGNAL_BIND");
 101     object.clock (clock);
 102   sc_trace_file *wf = sc_create_vcd_trace_file("signal_bind");
 103     sc_trace(wf, object.clock, "clock");
 104     sc_trace(wf, object.reset, "reset");
 105     sc_trace(wf, object.data, "data");
 106     sc_trace(wf, object.inv, "inv");
 107     sc_trace(wf, object.out, "out");
 108 
 109   sc_start(0);
 110   for(i=0;i<100;i++) {
 111     if (object.done == 0) {
 112       clock = 0; 
 113       sc_start(1);
 114       clock = 1; 
 115       sc_start(1);
 116     }
 117   }
 118   sc_close_vcd_trace_file(wf);
 119       
 120   cout<<"Terminating Simulation"<<endl;
 121   return 0;// Terminate simulation
 122 }
You could download file signal_bind.cpp here
   

space.gif

  ../images/main/bullet_star_pink.gif Simulation Output : Signal Binding
   

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.
 @3 ns Starting test
 @7 ns Driving 0 all inputs
 @7 ns Asserting reset
 @7 ns data :0 reset :1 inv :0 out :0
 @11 ns De-Asserting reset
 @11 ns data :0 reset :0 inv :0 out :0
 @15 ns Asserting data
 @15 ns data :1 reset :0 inv :0 out :0
 @17 ns data :1 reset :0 inv :0 out :1
 @19 ns Asserting inv
 @19 ns data :1 reset :0 inv :1 out :1
 @21 ns data :1 reset :0 inv :1 out :0
 @23 ns De-Asserting inv
 @23 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