source: CIVL/README@ ea8d8ce

1.23 2.0 main test-branch
Last change on this file since ea8d8ce was 944d449, checked in by Manchun Zheng <zmanchun@…>, 11 years ago

prepared for v1.3 release.

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

  • Property mode set to 100644
File size: 10.6 KB
Line 
1 CIVL: The Concurrency Intermediate Verification Language
2 v1.2
3
4------------------------------ Overview -------------------------------
5
6CIVL is a framework encompassing...
7
8 * a programming language, CIVL-C, which adds to C a number of
9 concurrency primitives, as well as the ability to define
10 functions in any scope. Together, these features make for
11 a very expressive concurrent language that can faithfully
12 represent programs using various APIs and parallel languages,
13 such as MPI, OpenMP, Pthread, CUDA, and Chapel. CIVL-C also
14 provides a number of primitives supporting verification.
15 * a model checker which uses symbolic execution to verify a
16 number of safety properties of CIVL-C programs. The model
17 checker can also be used to verify that two CIVL-C programs
18 are functionally equivalent.
19 * a number of translators from various commonly-used languages
20 and APIs to CIVL-C. (This part is still a work in progress.)
21
22CIVL is developed by the Verified Software Laboratory at the
23University of Delaware Department of Computer Science.
24For more information, visit http://vsl.cis.udel.edu/civl
25
26Developers:
27
28Matthew B. Dwyer
29John Edenhofner
30Ziqing Luo
31Andre Marianiello
32Michael Rogers
33Stephen F. Siegel
34Manchun Zheng
35Timothy K. Zirkel
36
37------------------------------- License -------------------------------
38
39CIVL is open source software distributed under the GNU
40General Public License. However, the libraries used by CIVL
41(and incorporated into the complete distribution) use various
42licenses. See directory licenses for the license of each component.
43
44-------------------------- Updates from v1.1 -------------------------
45- printing the values of input variables for assertion violations
46- improving the printing of transitions
47- improving the general transformer to be more robust by fixing the way
48 it transforms the main function
49- fixing a bug for the conversion between int and boolean
50- fixing a bug related to $elaborate and $parfor
51
52
53------------------------- Binary Installation -------------------------
54
55For most users, this will be the easiest way to install and
56use CIVL. Developers should instead follow the instructions for
57"Source Installation" below.
58
591. Install at least one of the theorem provers below.
60The more provers you install, the more precise CIVL analysis will
61be. Note that CIVL only requires the binary executable
62version of each prover; you can ignore the libraries, various
63API bindings, etc. You just need to ensure that
64each binary executable is in your PATH when you run
65"civl config". The currently supported provers are:
66
67 - CVC3, http://www.cs.nyu.edu/acsys/cvc3/download.html
68 download the latest, optimized build with static library
69 and executable for your OS. Place the executable file
70 "cvc3" in your PATH. You can discard everything else.
71 Alternatively, on some linux systems, CVC3 can be installed
72 using the package manager via "sudo apt-get install cvc3".
73 This will place cvc3 in /usr/bin.
74
75 - CVC4, http://cvc4.cs.nyu.edu/downloads/
76
77 - Z3, http://z3.codeplex.com/SourceControl/latest
78
792. Install a Java 7 SDK if you have not already. Go to
80
81 http://www.oracle.com/technetwork/java/javase/downloads/
82
83for the latest from Oracle. On linux, you can instead use
84the package manager:
85
86 sudo apt-get install openjdk-7-jdk
87
883. Download the CIVL distribution from http://vsl.cis.udel.edu/civl.
89
904. Unzip and untar the CIVL distribution file if this
91does not happen automatically. This should result in a
92folder named CIVL-TAG, where TAG is some version ID string.
93This folder contains the following:
94
95 - README : this file
96 - bin : containing one executable sh script called "civl"
97 - lib : containing civl-TAG.jar
98 - doc : containing the manual and the tutorial of CIVL
99 - emacs : CIVL-C emacs mode and its installation instructions
100 - licenses : licenses for CIVL and included libraries
101 - examples : some example CIVL programs
102
1035. You can move the CIVL folder wherever you want.
104The JAR file in the lib directory is all you need to run CIVL.
105You may also move this jar file wherever you want. You
106run CIVL by typing a command that begins
107"java -jar /path/to/civl-TAG.jar ...". For convenience
108you may instead use the shell script "civl" in bin,
109which allows you to replace "java -jar /path/to/civl-TAG.jar"
110with just "civl" on the command line. Simply edit the civl script
111to reflect the path to civl-TAG.jar and place the script
112somewhere in your PATH. Alternatively, you can just define
113an alias in your .profile, .bash_profile, or equivalent, such as
114
115alias civl='java -jar /path/to/civl-TAG.jar'
116
117In the following, we will assume that you have defined
118a command "civl" in one these ways.
119
1206. Type "civl config". This should report that it found
121the theorem provers you installed (and are in your PATH).
122It should create a file called ".sarl" in your home directory
123which you can also edit by hand.
124
125
126------------------------- Source Installation -------------------------
127
128We recommend using the Eclipse IDE for Java/EE developers.
129
1300. Install theorem provers following the directions above.
131Install Eclipse IDE for Java/EE developers if you have not already
132done so.
133
1341. Install an SVN plugin in Eclipse (such as Subversive) if you have
135 not already.
136
1372. Install prerequisite projects ABC, SARL and GMC.
138 Make sure that the three projects are put in the workspace
139 directory where CIVL will be created. Specifically:
140
141 a. Install the symbolic algebra and reasoning library SARL.
142 In Eclipse, select New Project...from SVN, use the archive
143 svn://vsl.cis.udel.edu/sarl. After entering that, open it
144 up and select the "trunk". After checking out trunk, name
145 the project "SARL". Then follow the instructions in the INSTALL
146 file for Eclipse installation. Build the sarl.jar from within
147 Eclipse by right-clicking (or ctrl-clicking) on the build.xml
148 file and selecting Run As->Ant Build.
149
150 b. Install the C front-end ABC. In Eclipse,
151 select New Project...from SVN, use the archive
152 svn://vsl.cis.udel.edu/abc. After entering that, open it
153 up and select the "trunk". After checking out trunk, name
154 the project "ABC". Then follow the instructions in the INSTALL
155 file for Eclipse installation. Build the abc.jar from within
156 Eclipse by right-clicking (or ctrl-clicking on OS X) on the
157 build.xml file and selecting Run As->Ant Build.
158
159 c. Install the generic model checking utilities package GMC.
160 In Eclipse, select New Project...from SVN, use the archive
161 svn://vsl.cis.udel.edu/gmc. After entering that, open it
162 up and select the "trunk". After checking out trunk, name
163 the project "GMC". Build the gmc.jar from within Eclipse
164 by right-clicking (or ctrl-clicking) on the build.xml file and
165 selecting Run As->Ant Build.
166
1673. From within Eclipse, select New Project...from SVN. The archive is
168 svn://vsl.cis.udel.edu/civl. After entering that, open it up and
169 select the "trunk". (It is simplest to just check out the trunk for
170 the Eclipse project.)
171
1724. Check out the trunk, and create the project using the New Java
173 Project Wizard as usual, naming it "CIVL". The .project, .classpath,
174 and other Eclipse meta-data are already in the SVN archive,
175 saving you a bunch of work.
176
1775. If you already have the VSL dependencies library, you may
178 skip this step. Otherwise, download the tgz archive of VSL
179 dependencies from http://vsl.cis.udel.edu/lib/tools/vsl_depend
180 Unzip the .tgz file and you will have the folder vsl.
181 Move vsl to /opt.
182 Note: you probably will need to use sudo for this.
183 Also, if you don't already have a directory called /opt,
184 you will have to create it with "mkdir /opt". Also, if you
185 don't want to use /opt for some reason, you can use any
186 directory you want; just modify the instructions below
187 accordingly.
188
189 Suppose that you put the .tgz file (or .tar file if your browser
190 unzipped it automatically to a .tar file) in the directory DOWNLOAD.
191 You can use the following commands:
192
193 $ cd DOWNLOAD
194 $ tar xzf YourTgzOrTarFile vsl
195 $ sudo mv vsl /opt
196
197 (Leave out the "x" in the tar command if the file was already
198 unzipped.) Now you can type "ls /opt/vsl", and the output
199 should be
200
201 README.txt lib licenses src
202
2036. If default_build.properties matches the configuration of your system,
204 then you can skip this step. Otherwise, you may need to create a file
205 build.properties in the directory containing build.xml.
206 Copy and paste the content from any file under properties, edit each
207 entry with the path configured in your system. The newly created file
208 build.properties will automatically be used by ant to to build the
209 .jar file.
210
2117. Navigate to Preferences -> Java -> Build Path -> ClassPath
212 Variables, and then select New to create a classpath variable VSL,
213 and specify its value to be /opt/vsl.
214
2158. Do a clean build. Everything should compile. Generate the civl.jar
216 by right-clicking (or ctrl-click on OS X) the build.xml file and
217 Run As->Ant Build.
218
2199. Somewhere on your system, create a plain text file containing
220 exactly the following two lines:
221
222#!/bin/sh
223java -jar /Path/To/Your/workspace/CIVL/civl.jar $@
224
225 where "/Path/To/Your/workspace" is replaced with the path
226 to your Eclipse workspace directory. Name this file "civl",
227 put it in your PATH, and make it executable (chmod ugo+x civl).
228 Alternatively, you can define an alias in your .profile,
229 .bash_profile, .bashrc, or equivalent:
230
231alias civl='java -jar /Path/To/Your/workspace/CIVL/civl.jar'
232
23310. From a terminal window, execute "civl config". This should
234 find the theorem provers in your PATH and create a file
235 .sarl in your home directory.
236
23711. In Eclipse, navigate to "Run->Run Configurations... Create a new
238 JUnit configuration."
239 Name it "CIVL Regression Tests". Select "Run all tests in the
240 selected project..." and navigate to the folder "test/regress"
241 in the CIVL project. The Test runner should be JUnit 4. Under the
242 Arguments tab, type "-ea" (without the quotes) in the VM arguments
243 area (to enable assertion checking).
244
24512. An example of how to set up a single test from within Eclipse:
246 create a new Run Configuration via the Run->Run
247 Configurations... menu. Create a new "Java Application"
248 configuration. Call it "CIVL barrier2". The Project is CIVL. The
249 main class is edu.udel.cis.vsl.civl.CIVL. Under the Arguments tab,
250 set the Program arguments to
251
252 verify examples/concurrency/barrier2.cvl
253
254 Modify the VM arguments as in the step above. You should now be
255 able to run the test by clicking "Run".
256
Note: See TracBrowser for help on using the repository browser.