source: CIVL/examples/concurrency/diningBad.cvl@ dccd621

1.23 2.0 main test-branch
Last change on this file since dccd621 was 0baeebd, checked in by Ziqing Luo <ziqing@…>, 11 years ago

cleaned up examples

git-svn-id: svn://vsl.cis.udel.edu/civl/trunk@1776 fb995dde-84ed-4084-dfe6-e5aef3e2452c

  • Property mode set to 100644
File size: 863 bytes
RevLine 
[72c01cc]1/* Dining philosophers, standard version, which deadlocks.
2 *
[9fb69d3]3 * civl verify -inputB=4 diningBad.cvl
4 * or (if you want to find the minimal counterexample)
5 * civl verify -inputB=4 diningBad.cvl -min
[72c01cc]6 */
[e6b02c8]7#include <civlc.cvh>
[72c01cc]8
[0baeebd]9$input int B = 4; // upper bound on number of philosophers
10$input int n; // number of philosophers
[72c01cc]11$assume 2<=n && n<=B;
12
[4e1d3c7]13int forks[n]; // Each fork will be on the table (0) or in a hand (1).
[72c01cc]14
15void dine(int id) {
16 int left = id;
17 int right = (id + 1) % n;
18
19 while (1) {
[4e1d3c7]20 $when (forks[left] == 0) forks[left] = 1;
21 $when (forks[right] == 0) forks[right] = 1;
[72c01cc]22 forks[right] = 0;
23 forks[left] = 0;
24 }
25}
26
27void main() {
[48bfab9]28 $proc philosophers[n];
29
[4e1d3c7]30 for (int i = 0; i < n; i++) forks[i] = 0;
[48bfab9]31 for (int i = 0; i < n; i++)
32 philosophers[i] = $spawn dine(i);
33 for (int i = 0; i < n; i++)
34 $wait(philosophers[i]);
[72c01cc]35}
Note: See TracBrowser for help on using the repository browser.