|
|
|
|
|
|
|
|
|
|
|
|
sc_mutex
|
|
|
sc_mutex is a predefined primitive channel intended to model the behavior of a mutual exclusion lock as used to control access to a resource shared by concurrent processes. A mutex will be in one of two exclusive states: unlocked or locked. Only one process can lock a given mutex at one time. A mutex can only be unlocked by the particular process that locked the mutex, but may be locked subsequently by a different process. |
|
|
|
|
|
sc_mutex class comes with pre-defined methods as below. |
|
|
|
|
|
- int lock() : Lock the mutex if it is free, else wait till mutex gets free.
- int unlock() : Unlock the mutex
- int trylock() : Check if mutex is free, if free then lock it else return -1.
- char* kind() : Return string "sc_mutex"
|
|
|
|
|
|
|
|
|
|
|
|
Example : sc_mutex
|
|
|
|
|
|
1 #include <systemc.h>
2
3 SC_MODULE (sc_mutex_example) {
4 sc_in<bool> clock;
5
6 sc_mutex bus;
7 int cnt;
8
9
10 void do_bus(int who) {
11 cout << "@" << sc_time_stamp() <<" Bus access by instance " << who << endl;
12 }
13
14 void do_test1() {
15 while (true) {
16 wait();
17 cout << "@" << sc_time_stamp() <<" Checking mutex intance 0"<<endl;
18 // Check if mutex is available
19 if (bus.trylock() ! = -1) {
20 cout << "@" << sc_time_stamp() <<" Got mutex for intance 0"<<endl;
21 cnt ++;
22 do_bus(0);
23 wait(2);
24 // Unlock the mutex
25 bus.unlock();
26 }
27 if (cnt >= 3) {
28 sc_stop(); // sc_stop triggers end of simulation
29 }
30 }
31 }
32
33 void do_test2() {
34 while (true) {
35 wait();
36 cout << "@" << sc_time_stamp() <<" Checking mutex intance 1"<<endl;
37 // Wait till mutex is available
38 bus.lock();
39 cout << "@" << sc_time_stamp() <<" Got mutex for intance 1"<<endl;
40 do_bus(1);
41 wait(3);
42 // Unlock the mutex
43 bus.unlock();
44 }
45 }
46
47 SC_CTOR(sc_mutex_example) {
48 cnt = 0;
49 SC_CTHREAD(do_test1,clock.pos());
50 SC_CTHREAD(do_test2,clock.pos());
51 }
52 };
53
54 int sc_main (int argc, char* argv[]) {
55 sc_clock clock ("my_clock",1,0.5);
56
57 sc_mutex_example object("wait");
58 object.clock (clock.signal());
59
60 sc_start(0); // First time called will init schedular
61 sc_start(); // Run the simulation till sc_stop is encountered
62 return 0;// Terminate simulation
63 }
You could download file sc_mutex.cpp here
|
|
|
|
|
|
Simulation Output : sc_mutex
|
|
|
|
|
|
@1 ns Checking mutex intance 1
@1 ns Got mutex for intance 1
@1 ns Bus access by instance 1
@1 ns Checking mutex intance 0
@2 ns Checking mutex intance 0
@3 ns Checking mutex intance 0
@4 ns Checking mutex intance 0
@4 ns Got mutex for intance 0
@4 ns Bus access by instance 0
@5 ns Checking mutex intance 1
@7 ns Got mutex for intance 1
@7 ns Bus access by instance 1
@7 ns Checking mutex intance 0
@8 ns Checking mutex intance 0
@9 ns Checking mutex intance 0
@10 ns Checking mutex intance 0
@10 ns Got mutex for intance 0
@10 ns Bus access by instance 0
@11 ns Checking mutex intance 1
@13 ns Got mutex for intance 1
@13 ns Bus access by instance 1
@13 ns Checking mutex intance 0
@14 ns Checking mutex intance 0
@15 ns Checking mutex intance 0
@16 ns Checking mutex intance 0
@16 ns Got mutex for intance 0
@16 ns Bus access by instance 0
@17 ns Checking mutex intance 1
SystemC: simulation stopped by user.
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Copyright © 1998-2025 |
Deepak Kumar Tala - All rights reserved |
Do you have any Comment? mail me at:deepak@asic-world.com
|
|