source: CIVL/README@ 50931db

1.23 2.0 main test-branch
Last change on this file since 50931db was 327da8c, checked in by Manchun Zheng <zmanchun@…>, 11 years ago

preparing for release 1.4

git-svn-id: svn://vsl.cis.udel.edu/civl/trunk@2529 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.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
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.3 -------------------------
45- adding new option -collectOutput for printing the output
46- adding new system functions for rectangular domain and regular range
47- improving naming conventions for transformers and libraries
48- fixing bugs for string literal initializing an array,
49 simplifying states by reasoning the path conditions, etc.
50
51------------------------- Binary Installation -------------------------
52
53For most users, this will be the easiest way to install and
54use CIVL. Developers should instead follow the instructions for
55"Source Installation" below.
56
571. Install at least one of the theorem provers below.
58The more provers you install, the more precise CIVL analysis will
59be. Note that CIVL only requires the binary executable
60version of each prover; you can ignore the libraries, various
61API bindings, etc. You just need to ensure that
62each binary executable is in your PATH when you run
63"civl config". The currently supported provers are:
64
65 - CVC3, http://www.cs.nyu.edu/acsys/cvc3/download.html
66 download the latest, optimized build with static library
67 and executable for your OS. Place the executable file
68 "cvc3" in your PATH. You can discard everything else.
69 Alternatively, on some linux systems, CVC3 can be installed
70 using the package manager via "sudo apt-get install cvc3".
71 This will place cvc3 in /usr/bin.
72
73 - CVC4, http://cvc4.cs.nyu.edu/downloads/
74
75 - Z3, http://z3.codeplex.com/SourceControl/latest
76
772. Install a Java 7 SDK if you have not already. Go to
78
79 http://www.oracle.com/technetwork/java/javase/downloads/
80
81for the latest from Oracle. On linux, you can instead use
82the package manager:
83
84 sudo apt-get install openjdk-7-jdk
85
863. Download the CIVL distribution from http://vsl.cis.udel.edu/civl.
87
884. Unzip and untar the CIVL distribution file if this
89does not happen automatically. This should result in a
90folder named CIVL-TAG, where TAG is some version ID string.
91This folder contains the following:
92
93 - README : this file
94 - bin : containing one executable sh script called "civl"
95 - lib : containing civl-TAG.jar
96 - doc : containing the manual and the tutorial of CIVL
97 - emacs : CIVL-C emacs mode and its installation instructions
98 - licenses : licenses for CIVL and included libraries
99 - examples : some example CIVL programs
100
1015. You can move the CIVL folder wherever you want.
102The JAR file in the lib directory is all you need to run CIVL.
103You may also move this jar file wherever you want. You
104run CIVL by typing a command that begins
105"java -jar /path/to/civl-TAG.jar ...". For convenience
106you may instead use the shell script "civl" in bin,
107which allows you to replace "java -jar /path/to/civl-TAG.jar"
108with just "civl" on the command line. Simply edit the civl script
109to reflect the path to civl-TAG.jar and place the script
110somewhere in your PATH. Alternatively, you can just define
111an alias in your .profile, .bash_profile, or equivalent, such as
112
113alias civl='java -jar /path/to/civl-TAG.jar'
114
115In the following, we will assume that you have defined
116a command "civl" in one these ways.
117
1186. Type "civl config". This should report that it found
119the theorem provers you installed (and are in your PATH).
120It should create a file called ".sarl" in your home directory
121which you can also edit by hand.
122
123
124------------------------- Source Installation -------------------------
125
126We recommend using the Eclipse IDE for Java/EE developers.
127
1280. Install theorem provers following the directions above.
129Install Eclipse IDE for Java/EE developers if you have not already
130done so.
131
1321. Install an SVN plugin in Eclipse (such as Subversive) if you have
133 not already.
134
1352. Install prerequisite projects ABC, SARL and GMC.
136 Make sure that the three projects are put in the workspace
137 directory where CIVL will be created. Specifically:
138
139 a. Install the symbolic algebra and reasoning library SARL.
140 In Eclipse, select New Project...from SVN, use the archive
141 svn://vsl.cis.udel.edu/sarl. After entering that, open it
142 up and select the "trunk". After checking out trunk, name
143 the project "SARL". Then follow the instructions in the INSTALL
144 file for Eclipse installation. Build the sarl.jar from within
145 Eclipse by right-clicking (or ctrl-clicking) on the build.xml
146 file and selecting Run As->Ant Build.
147
148 b. Install the C front-end ABC. In Eclipse,
149 select New Project...from SVN, use the archive
150 svn://vsl.cis.udel.edu/abc. After entering that, open it
151 up and select the "trunk". After checking out trunk, name
152 the project "ABC". Then follow the instructions in the INSTALL
153 file for Eclipse installation. Build the abc.jar from within
154 Eclipse by right-clicking (or ctrl-clicking on OS X) on the
155 build.xml file and selecting Run As->Ant Build.
156
157 c. Install the generic model checking utilities package GMC.
158 In Eclipse, select New Project...from SVN, use the archive
159 svn://vsl.cis.udel.edu/gmc. After entering that, open it
160 up and select the "trunk". After checking out trunk, name
161 the project "GMC". Build the gmc.jar from within Eclipse
162 by right-clicking (or ctrl-clicking) on the build.xml file and
163 selecting Run As->Ant Build.
164
1653. From within Eclipse, select New Project...from SVN. The archive is
166 svn://vsl.cis.udel.edu/civl. After entering that, open it up and
167 select the "trunk". (It is simplest to just check out the trunk for
168 the Eclipse project.)
169
1704. Check out the trunk, and create the project using the New Java
171 Project Wizard as usual, naming it "CIVL". The .project, .classpath,
172 and other Eclipse meta-data are already in the SVN archive,
173 saving you a bunch of work.
174
1755. If you already have the VSL dependencies library, you may
176 skip this step. Otherwise, download the tgz archive of VSL
177 dependencies from http://vsl.cis.udel.edu/lib/tools/vsl_depend
178 Unzip the .tgz file and you will have the folder vsl.
179 Move vsl to /opt.
180 Note: you probably will need to use sudo for this.
181 Also, if you don't already have a directory called /opt,
182 you will have to create it with "mkdir /opt". Also, if you
183 don't want to use /opt for some reason, you can use any
184 directory you want; just modify the instructions below
185 accordingly.
186
187 Suppose that you put the .tgz file (or .tar file if your browser
188 unzipped it automatically to a .tar file) in the directory DOWNLOAD.
189 You can use the following commands:
190
191 $ cd DOWNLOAD
192 $ tar xzf YourTgzOrTarFile vsl
193 $ sudo mv vsl /opt
194
195 (Leave out the "x" in the tar command if the file was already
196 unzipped.) Now you can type "ls /opt/vsl", and the output
197 should be
198
199 README.txt lib licenses src
200
2016. If default_build.properties matches the configuration of your system,
202 then you can skip this step. Otherwise, you may need to create a file
203 build.properties in the directory containing build.xml.
204 Copy and paste the content from any file under properties, edit each
205 entry with the path configured in your system. The newly created file
206 build.properties will automatically be used by ant to to build the
207 .jar file.
208
2097. Navigate to Preferences -> Java -> Build Path -> ClassPath
210 Variables, and then select New to create a classpath variable VSL,
211 and specify its value to be /opt/vsl.
212
2138. Do a clean build. Everything should compile. Generate the civl.jar
214 by right-clicking (or ctrl-click on OS X) the build.xml file and
215 Run As->Ant Build.
216
2179. Somewhere on your system, create a plain text file containing
218 exactly the following two lines:
219
220#!/bin/sh
221java -jar /Path/To/Your/workspace/CIVL/civl.jar $@
222
223 where "/Path/To/Your/workspace" is replaced with the path
224 to your Eclipse workspace directory. Name this file "civl",
225 put it in your PATH, and make it executable (chmod ugo+x civl).
226 Alternatively, you can define an alias in your .profile,
227 .bash_profile, .bashrc, or equivalent:
228
229alias civl='java -jar /Path/To/Your/workspace/CIVL/civl.jar'
230
23110. From a terminal window, execute "civl config". This should
232 find the theorem provers in your PATH and create a file
233 .sarl in your home directory.
234
23511. In Eclipse, navigate to "Run->Run Configurations... Create a new
236 JUnit configuration."
237 Name it "CIVL Regression Tests". Select "Run all tests in the
238 selected project..." and navigate to the folder "test/regress"
239 in the CIVL project. The Test runner should be JUnit 4. Under the
240 Arguments tab, type "-ea" (without the quotes) in the VM arguments
241 area (to enable assertion checking).
242
24312. An example of how to set up a single test from within Eclipse:
244 create a new Run Configuration via the Run->Run
245 Configurations... menu. Create a new "Java Application"
246 configuration. Call it "CIVL barrier2". The Project is CIVL. The
247 main class is edu.udel.cis.vsl.civl.CIVL. Under the Arguments tab,
248 set the Program arguments to
249
250 verify examples/concurrency/barrier2.cvl
251
252 Modify the VM arguments as in the step above. You should now be
253 able to run the test by clicking "Run".
254
Note: See TracBrowser for help on using the repository browser.