1.23
2.0
main
test-branch
| Line | |
|---|
| 1 | /* Commandline execution:
|
|---|
| 2 | * civl verify locksGood.cvl
|
|---|
| 3 | * */
|
|---|
| 4 | _Bool lock0 = 0;
|
|---|
| 5 | _Bool lock1 = 0;
|
|---|
| 6 |
|
|---|
| 7 | void proc0() {
|
|---|
| 8 | $atomic {
|
|---|
| 9 | while (1) {
|
|---|
| 10 | $when (!lock0) lock0=1;
|
|---|
| 11 | $when (!lock1) lock1=1;
|
|---|
| 12 | lock0=0;
|
|---|
| 13 | lock1=0;
|
|---|
| 14 | }
|
|---|
| 15 | }
|
|---|
| 16 | }
|
|---|
| 17 |
|
|---|
| 18 | void proc1() {
|
|---|
| 19 | $atomic {
|
|---|
| 20 | while (1) {
|
|---|
| 21 | $when (!lock0) lock0=1;
|
|---|
| 22 | $when (!lock1) lock1=1;
|
|---|
| 23 | lock0=0;
|
|---|
| 24 | lock1=0;
|
|---|
| 25 | }
|
|---|
| 26 | }
|
|---|
| 27 | }
|
|---|
| 28 |
|
|---|
| 29 | void main() {
|
|---|
| 30 | $spawn proc0();
|
|---|
| 31 | $spawn proc1();
|
|---|
| 32 | }
|
|---|
Note:
See
TracBrowser
for help on using the repository browser.