source: CIVL/README@ 7c2a4aa

1.23 2.0 main test-branch
Last change on this file since 7c2a4aa was 8a2a9d2, checked in by Ziqing Luo <ziqing@…>, 8 years ago

commit for release of v1.13

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

  • Property mode set to 100644
File size: 11.0 KB
Line 
1 CIVL: The Concurrency Intermediate Verification Language
2 v1.13
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
26Active Developers:
27Matthew B. Dwyer
28Mitchell Gerrard
29Ziqing Luo
30Stephen F. Siegel
31Wenhao Wu
32Yihao Yan
33
34Inactive Developers:
35John Edenhofner
36Andre Marianiello
37Michael Rogers
38Timothy K. Zirkel
39Si Li
40Manchun Zheng
41
42------------------------------- License -------------------------------
43
44CIVL is open source software distributed under the GNU
45General Public License. However, the libraries used by CIVL
46(and incorporated into the complete distribution) use various
47licenses. See directory licenses for the license of each component.
48
49
50-------------------------- Updates from v1.12 -------------------------
51- Fixed the int-to-pointer casting bug
52- Fixed the typedef definition bug in compare mode
53- Fixed the file system incorrect file reference bug in compare mode
54- Fixed a bug in IntervalUnionSet, which arose when there were multiple infinite intervals
55- Fixed a bug related to the sign of Ranges
56- Fixed a bug in IntervalUnion Factory, which arose when interval union sets are empty
57- Improved the simplifier for all symbolic expressions by re-implementing with new designs.
58- Highly optimized probabilistic evaluation for boolean expression "polynomial == 0"
59- The pragma that triggers the parsing of ACSL now is changed to "#pragma CIVL ACSL"
60
61
62------------------------- Binary Installation -------------------------
63
64For most users, this will be the easiest way to install and
65use CIVL. Developers should instead follow the instructions for
66"Source Installation" below.
67
681. Install at least one of the theorem provers below.
69The more provers you install, the more precise CIVL analysis will
70be. Note that CIVL only requires the binary executable
71version of each prover; you can ignore the libraries, various
72API bindings, etc. You just need to ensure that
73each binary executable is in your PATH when you run
74"civl config". The currently supported provers are:
75
76 - CVC3, http://www.cs.nyu.edu/acsys/cvc3/download.html
77 download the latest, optimized build with static library
78 and executable for your OS. Place the executable file
79 "cvc3" in your PATH. You can discard everything else.
80 Alternatively, on some linux systems, CVC3 can be installed
81 using the package manager via "sudo apt-get install cvc3".
82 This will place cvc3 in /usr/bin.
83
84 - CVC4, http://cvc4.cs.nyu.edu/downloads/
85
86 - Z3, http://z3.codeplex.com/SourceControl/latest
87
882. Install a Java 8 SDK if you have not already. Go to
89
90 http://www.oracle.com/technetwork/java/javase/downloads/
91
92for the latest from Oracle. On linux, you can instead use
93the package manager:
94
95 sudo apt-get install openjdk-8-jdk
96
973. Download the CIVL distribution from http://vsl.cis.udel.edu/civl.
98
994. Unzip and untar the CIVL distribution file if this
100does not happen automatically. This should result in a
101folder named CIVL-TAG, where TAG is some version ID string.
102This folder contains the following:
103
104 - README : this file
105 - bin : containing one executable sh script called "civl"
106 - lib : containing civl-TAG.jar
107 - doc : containing the manual and the tutorial of CIVL
108 - emacs : CIVL-C emacs mode and its installation instructions
109 - licenses : licenses for CIVL and included libraries
110 - examples : some example CIVL programs
111
1125. You can move the CIVL folder wherever you want.
113The JAR file in the lib directory is all you need to run CIVL.
114You may also move this jar file wherever you want. You
115run CIVL by typing a command that begins
116"java -jar /path/to/civl-TAG.jar ...". For convenience
117you may instead use the shell script "civl" in bin,
118which allows you to replace "java -jar /path/to/civl-TAG.jar"
119with just "civl" on the command line. Simply edit the civl script
120to reflect the path to civl-TAG.jar and place the script
121somewhere in your PATH. Alternatively, you can just define
122an alias in your .profile, .bash_profile, or equivalent, such as
123
124alias civl='java -jar /path/to/civl-TAG.jar'
125
126In the following, we will assume that you have defined
127a command "civl" in one these ways.
128
1296. Type "civl config". This should report that it found
130the theorem provers you installed (and are in your PATH).
131It should create a file called ".sarl" in your home directory
132which you can also edit by hand.
133
134
135------------------------- Source Installation -------------------------
136
137We recommend using the Eclipse IDE for Java/EE developers.
138
1390. Install theorem provers following the directions above.
140Install Eclipse IDE for Java/EE developers if you have not already
141done so.
142
1431. Install an SVN plugin in Eclipse (such as Subversive) if you have
144 not already.
145
1462. Install prerequisite projects ABC, SARL and GMC.
147 Make sure that the three projects are put in the workspace
148 directory where CIVL will be created. Specifically:
149
150 a. Install the symbolic algebra and reasoning library SARL.
151 In Eclipse, select New Project...from SVN, use the archive
152 svn://vsl.cis.udel.edu/sarl. After entering that, open it
153 up and select the "trunk". After checking out trunk, name
154 the project "SARL". Then follow the instructions in the INSTALL
155 file for Eclipse installation. Build the sarl.jar from within
156 Eclipse by right-clicking (or ctrl-clicking) on the build.xml
157 file and selecting Run As->Ant Build.
158
159 b. Install the C front-end ABC. In Eclipse,
160 select New Project...from SVN, use the archive
161 svn://vsl.cis.udel.edu/abc. After entering that, open it
162 up and select the "trunk". After checking out trunk, name
163 the project "ABC". Then follow the instructions in the INSTALL
164 file for Eclipse installation. Build the abc.jar from within
165 Eclipse by right-clicking (or ctrl-clicking on OS X) on the
166 build.xml file and selecting Run As->Ant Build.
167
168 c. Install the generic model checking utilities package GMC.
169 In Eclipse, select New Project...from SVN, use the archive
170 svn://vsl.cis.udel.edu/gmc. After entering that, open it
171 up and select the "trunk". After checking out trunk, name
172 the project "GMC". Build the gmc.jar from within Eclipse
173 by right-clicking (or ctrl-clicking) on the build.xml file and
174 selecting Run As->Ant Build.
175
1763. From within Eclipse, select New Project...from SVN. The archive is
177 svn://vsl.cis.udel.edu/civl. After entering that, open it up and
178 select the "trunk". (It is simplest to just check out the trunk for
179 the Eclipse project.)
180
1814. Check out the trunk, and create the project using the New Java
182 Project Wizard as usual, naming it "CIVL". The .project, .classpath,
183 and other Eclipse meta-data are already in the SVN archive,
184 saving you a bunch of work.
185
1865. If you already have the VSL dependencies library, you may
187 skip this step. Otherwise, download the tgz archive of VSL
188 dependencies from http://vsl.cis.udel.edu/lib/tools/vsl_depend
189 Unzip the .tgz file and you will have the folder vsl.
190 Move vsl to /opt.
191 Note: you probably will need to use sudo for this.
192 Also, if you don't already have a directory called /opt,
193 you will have to create it with "mkdir /opt". Also, if you
194 don't want to use /opt for some reason, you can use any
195 directory you want; just modify the instructions below
196 accordingly.
197
198 Suppose that you put the .tgz file (or .tar file if your browser
199 unzipped it automatically to a .tar file) in the directory DOWNLOAD.
200 You can use the following commands:
201
202 $ cd DOWNLOAD
203 $ tar xzf YourTgzOrTarFile vsl
204 $ sudo mv vsl /opt
205
206 (Leave out the "x" in the tar command if the file was already
207 unzipped.) Now you can type "ls /opt/vsl", and the output
208 should be
209
210 README.txt lib licenses src
211
2126. If default_build.properties matches the configuration of your system,
213 then you can skip this step. Otherwise, you may need to create a file
214 build.properties in the directory containing build.xml.
215 Copy and paste the content from any file under properties, edit each
216 entry with the path configured in your system. The newly created file
217 build.properties will automatically be used by ant to to build the
218 .jar file.
219
2207. Navigate to Preferences -> Java -> Build Path -> ClassPath
221 Variables, and then select New to create a classpath variable VSL,
222 and specify its value to be /opt/vsl.
223
2248. Do a clean build. Everything should compile. Generate the civl.jar
225 by right-clicking (or ctrl-click on OS X) the build.xml file and
226 Run As->Ant Build.
227
2289. Somewhere on your system, create a plain text file containing
229 exactly the following two lines:
230
231#!/bin/sh
232java -jar /Path/To/Your/workspace/CIVL/civl.jar $@
233
234 where "/Path/To/Your/workspace" is replaced with the path
235 to your Eclipse workspace directory. Name this file "civl",
236 put it in your PATH, and make it executable (chmod ugo+x civl).
237 Alternatively, you can define an alias in your .profile,
238 .bash_profile, .bashrc, or equivalent:
239
240alias civl='java -jar /Path/To/Your/workspace/CIVL/civl.jar'
241
24210. From a terminal window, execute "civl config". This should
243 find the theorem provers in your PATH and create a file
244 .sarl in your home directory.
245
24611. In Eclipse, navigate to "Run->Run Configurations... Create a new
247 JUnit configuration."
248 Name it "CIVL Regression Tests". Select "Run all tests in the
249 selected project..." and navigate to the folder "test/regress"
250 in the CIVL project. The Test runner should be JUnit 4. Under the
251 Arguments tab, type "-ea" (without the quotes) in the VM arguments
252 area (to enable assertion checking).
253
25412. An example of how to set up a single test from within Eclipse:
255 create a new Run Configuration via the Run->Run
256 Configurations... menu. Create a new "Java Application"
257 configuration. Call it "CIVL barrier2". The Project is CIVL. The
258 main class is edu.udel.cis.vsl.civl.CIVL. Under the Arguments tab,
259 set the Program arguments to
260
261 verify examples/concurrency/barrier2.cvl
262
263 Modify the VM arguments as in the step above. You should now be
264 able to run the test by clicking "Run".
265
266
267
Note: See TracBrowser for help on using the repository browser.