source: CIVL/README@ 04c71e3

1.23 2.0 main test-branch
Last change on this file since 04c71e3 was 574bf61, checked in by Ziqing Luo <ziqing@…>, 9 years ago

CIVL v1.7.4 release

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

  • Property mode set to 100644
File size: 10.7 KB
Line 
1 CIVL: The Concurrency Intermediate Verification Language
2 v1.7.4
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
29Si Li
30Ziqing Luo
31Stephen F. Siegel
32Wenhao Wu
33Yihao Yan
34Manchun Zheng
35
36Inactive Developers:
37John Edenhofner
38Andre Marianiello
39Michael Rogers
40Timothy K. Zirkel
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-------------------------- Updates from v1.7.3 -------------------------
50- Fixed a side-effect remover defect in Struct initialization.
51- Fixed a bug which will lead to a null pointer exception in quantified expressions.
52- Fixed a bug of making assumptions on sizeof primitive types.
53- Improved the interpretation of "unsigned char" type.
54- Improve the detection of dereferencing pointers to undefined values.
55- Fixed bugs in SARL's Interval objects.
56
57
58------------------------- Binary Installation -------------------------
59
60For most users, this will be the easiest way to install and
61use CIVL. Developers should instead follow the instructions for
62"Source Installation" below.
63
641. Install at least one of the theorem provers below.
65The more provers you install, the more precise CIVL analysis will
66be. Note that CIVL only requires the binary executable
67version of each prover; you can ignore the libraries, various
68API bindings, etc. You just need to ensure that
69each binary executable is in your PATH when you run
70"civl config". The currently supported provers are:
71
72 - CVC3, http://www.cs.nyu.edu/acsys/cvc3/download.html
73 download the latest, optimized build with static library
74 and executable for your OS. Place the executable file
75 "cvc3" in your PATH. You can discard everything else.
76 Alternatively, on some linux systems, CVC3 can be installed
77 using the package manager via "sudo apt-get install cvc3".
78 This will place cvc3 in /usr/bin.
79
80 - CVC4, http://cvc4.cs.nyu.edu/downloads/
81
82 - Z3, http://z3.codeplex.com/SourceControl/latest
83
842. Install a Java 8 SDK if you have not already. Go to
85
86 http://www.oracle.com/technetwork/java/javase/downloads/
87
88for the latest from Oracle. On linux, you can instead use
89the package manager:
90
91 sudo apt-get install openjdk-8-jdk
92
933. Download the CIVL distribution from http://vsl.cis.udel.edu/civl.
94
954. Unzip and untar the CIVL distribution file if this
96does not happen automatically. This should result in a
97folder named CIVL-TAG, where TAG is some version ID string.
98This folder contains the following:
99
100 - README : this file
101 - bin : containing one executable sh script called "civl"
102 - lib : containing civl-TAG.jar
103 - doc : containing the manual and the tutorial of CIVL
104 - emacs : CIVL-C emacs mode and its installation instructions
105 - licenses : licenses for CIVL and included libraries
106 - examples : some example CIVL programs
107
1085. You can move the CIVL folder wherever you want.
109The JAR file in the lib directory is all you need to run CIVL.
110You may also move this jar file wherever you want. You
111run CIVL by typing a command that begins
112"java -jar /path/to/civl-TAG.jar ...". For convenience
113you may instead use the shell script "civl" in bin,
114which allows you to replace "java -jar /path/to/civl-TAG.jar"
115with just "civl" on the command line. Simply edit the civl script
116to reflect the path to civl-TAG.jar and place the script
117somewhere in your PATH. Alternatively, you can just define
118an alias in your .profile, .bash_profile, or equivalent, such as
119
120alias civl='java -jar /path/to/civl-TAG.jar'
121
122In the following, we will assume that you have defined
123a command "civl" in one these ways.
124
1256. Type "civl config". This should report that it found
126the theorem provers you installed (and are in your PATH).
127It should create a file called ".sarl" in your home directory
128which you can also edit by hand.
129
130
131------------------------- Source Installation -------------------------
132
133We recommend using the Eclipse IDE for Java/EE developers.
134
1350. Install theorem provers following the directions above.
136Install Eclipse IDE for Java/EE developers if you have not already
137done so.
138
1391. Install an SVN plugin in Eclipse (such as Subversive) if you have
140 not already.
141
1422. Install prerequisite projects ABC, SARL and GMC.
143 Make sure that the three projects are put in the workspace
144 directory where CIVL will be created. Specifically:
145
146 a. Install the symbolic algebra and reasoning library SARL.
147 In Eclipse, select New Project...from SVN, use the archive
148 svn://vsl.cis.udel.edu/sarl. After entering that, open it
149 up and select the "trunk". After checking out trunk, name
150 the project "SARL". Then follow the instructions in the INSTALL
151 file for Eclipse installation. Build the sarl.jar from within
152 Eclipse by right-clicking (or ctrl-clicking) on the build.xml
153 file and selecting Run As->Ant Build.
154
155 b. Install the C front-end ABC. In Eclipse,
156 select New Project...from SVN, use the archive
157 svn://vsl.cis.udel.edu/abc. After entering that, open it
158 up and select the "trunk". After checking out trunk, name
159 the project "ABC". Then follow the instructions in the INSTALL
160 file for Eclipse installation. Build the abc.jar from within
161 Eclipse by right-clicking (or ctrl-clicking on OS X) on the
162 build.xml file and selecting Run As->Ant Build.
163
164 c. Install the generic model checking utilities package GMC.
165 In Eclipse, select New Project...from SVN, use the archive
166 svn://vsl.cis.udel.edu/gmc. After entering that, open it
167 up and select the "trunk". After checking out trunk, name
168 the project "GMC". Build the gmc.jar from within Eclipse
169 by right-clicking (or ctrl-clicking) on the build.xml file and
170 selecting Run As->Ant Build.
171
1723. From within Eclipse, select New Project...from SVN. The archive is
173 svn://vsl.cis.udel.edu/civl. After entering that, open it up and
174 select the "trunk". (It is simplest to just check out the trunk for
175 the Eclipse project.)
176
1774. Check out the trunk, and create the project using the New Java
178 Project Wizard as usual, naming it "CIVL". The .project, .classpath,
179 and other Eclipse meta-data are already in the SVN archive,
180 saving you a bunch of work.
181
1825. If you already have the VSL dependencies library, you may
183 skip this step. Otherwise, download the tgz archive of VSL
184 dependencies from http://vsl.cis.udel.edu/lib/tools/vsl_depend
185 Unzip the .tgz file and you will have the folder vsl.
186 Move vsl to /opt.
187 Note: you probably will need to use sudo for this.
188 Also, if you don't already have a directory called /opt,
189 you will have to create it with "mkdir /opt". Also, if you
190 don't want to use /opt for some reason, you can use any
191 directory you want; just modify the instructions below
192 accordingly.
193
194 Suppose that you put the .tgz file (or .tar file if your browser
195 unzipped it automatically to a .tar file) in the directory DOWNLOAD.
196 You can use the following commands:
197
198 $ cd DOWNLOAD
199 $ tar xzf YourTgzOrTarFile vsl
200 $ sudo mv vsl /opt
201
202 (Leave out the "x" in the tar command if the file was already
203 unzipped.) Now you can type "ls /opt/vsl", and the output
204 should be
205
206 README.txt lib licenses src
207
2086. If default_build.properties matches the configuration of your system,
209 then you can skip this step. Otherwise, you may need to create a file
210 build.properties in the directory containing build.xml.
211 Copy and paste the content from any file under properties, edit each
212 entry with the path configured in your system. The newly created file
213 build.properties will automatically be used by ant to to build the
214 .jar file.
215
2167. Navigate to Preferences -> Java -> Build Path -> ClassPath
217 Variables, and then select New to create a classpath variable VSL,
218 and specify its value to be /opt/vsl.
219
2208. Do a clean build. Everything should compile. Generate the civl.jar
221 by right-clicking (or ctrl-click on OS X) the build.xml file and
222 Run As->Ant Build.
223
2249. Somewhere on your system, create a plain text file containing
225 exactly the following two lines:
226
227#!/bin/sh
228java -jar /Path/To/Your/workspace/CIVL/civl.jar $@
229
230 where "/Path/To/Your/workspace" is replaced with the path
231 to your Eclipse workspace directory. Name this file "civl",
232 put it in your PATH, and make it executable (chmod ugo+x civl).
233 Alternatively, you can define an alias in your .profile,
234 .bash_profile, .bashrc, or equivalent:
235
236alias civl='java -jar /Path/To/Your/workspace/CIVL/civl.jar'
237
23810. From a terminal window, execute "civl config". This should
239 find the theorem provers in your PATH and create a file
240 .sarl in your home directory.
241
24211. In Eclipse, navigate to "Run->Run Configurations... Create a new
243 JUnit configuration."
244 Name it "CIVL Regression Tests". Select "Run all tests in the
245 selected project..." and navigate to the folder "test/regress"
246 in the CIVL project. The Test runner should be JUnit 4. Under the
247 Arguments tab, type "-ea" (without the quotes) in the VM arguments
248 area (to enable assertion checking).
249
25012. An example of how to set up a single test from within Eclipse:
251 create a new Run Configuration via the Run->Run
252 Configurations... menu. Create a new "Java Application"
253 configuration. Call it "CIVL barrier2". The Project is CIVL. The
254 main class is edu.udel.cis.vsl.civl.CIVL. Under the Arguments tab,
255 set the Program arguments to
256
257 verify examples/concurrency/barrier2.cvl
258
259 Modify the VM arguments as in the step above. You should now be
260 able to run the test by clicking "Run".
261
262
263
Note: See TracBrowser for help on using the repository browser.