|
|
|
|
|
|
|
|
|
|
|
|
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. |
|
|
|
|
|
When ports are bound to other signals or ports, both types must match. |
|
|
|
|
|
|
|
|
|
|
|
Example : Signal Binding
|
|
|
|
|
|
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
|
|
|
|
|
|
Simulation Output : Signal Binding
|
|
|
|
|
|
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
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Copyright © 1998-2025 |
Deepak Kumar Tala - All rights reserved |
Do you have any Comment? mail me at:deepak@asic-world.com
|
|