source: CIVL/README@ 54ea077

1.23 2.0 main test-branch
Last change on this file since 54ea077 was 5db102f, checked in by Wenhao Wu <wuwenhao@…>, 6 years ago

Testing authz for wuwenhao

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

  • Property mode set to 100644
File size: 10.9 KB
RevLine 
[c7a0783]1 CIVL: The Concurrency Intermediate Verification Language
[040d64f]2 v1.20
[c7a0783]3
4------------------------------ Overview -------------------------------
5
[3783023]6CIVL is a framework encompassing...
[c7a0783]7
8 * a programming language, CIVL-C, which adds to C a number of
[9e3a674]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,
[dcde04a]13 such as MPI, OpenMP, Pthread, CUDA, and Chapel. CIVL-C also
14 provides a number of primitives supporting verification.
[9e3a674]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.
[c7a0783]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
[c7cef4b]26Active Developers:
[5af87592]27Matthew B. Dwyer
[9381b33]28Mitchell Gerrard
[5af87592]29Ziqing Luo
[c7a0783]30Stephen F. Siegel
[c7cef4b]31Wenhao Wu
32
33Inactive Developers:
34John Edenhofner
35Andre Marianiello
36Michael Rogers
[5af87592]37Timothy K. Zirkel
[8a2a9d2]38Si Li
39Manchun Zheng
[4619d67]40Yihao Yan
[c7a0783]41
[8d0a007]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
[040d64f]49-------------------------- Updates from v1.19 -------------------------
50-- 1. added new language primitives:
51 1.1 $local_start() and $local_end()
52 An execution of the statements in between of this pair, including this pair themselves,
53 is NOT ONLY uninterruptable BUT ALSO purely local to the view of the verifier.
54 1.2 $read_set_push() and $read_set_pop() (the correspondence for write set has already been supported)
55 This pair of primitives can be used to turn on/off the capturing of read set during execution.
56-- 2. added Fortran support for translating basic Fortran features into CIVL-AST
57 (see: https://vsl.cis.udel.edu/trac/civl/wiki/FortranTransformations)
58-- 3. added simple Fortran verification examples (edited)
59
[ae48dce]60
[8d0a007]61------------------------- Binary Installation -------------------------
[c7a0783]62
[be6d877]63For most users, this will be the easiest way to install and
64use CIVL. Developers should instead follow the instructions for
[bb733f2]65"Source Installation" below.
[583119f]66
[be6d877]671. Install at least one of the theorem provers below.
[536af01]68The more provers you install, the more precise CIVL analysis will
[be6d877]69be. Note that CIVL only requires the binary executable
70version of each prover; you can ignore the libraries, various
71API bindings, etc. You just need to ensure that
72each binary executable is in your PATH when you run
73"civl config". The currently supported provers are:
[bb733f2]74
[be6d877]75 - CVC3, http://www.cs.nyu.edu/acsys/cvc3/download.html
76 download the latest, optimized build with static library
77 and executable for your OS. Place the executable file
78 "cvc3" in your PATH. You can discard everything else.
79 Alternatively, on some linux systems, CVC3 can be installed
80 using the package manager via "sudo apt-get install cvc3".
81 This will place cvc3 in /usr/bin.
82
83 - CVC4, http://cvc4.cs.nyu.edu/downloads/
84
85 - Z3, http://z3.codeplex.com/SourceControl/latest
[bb733f2]86
[20b16d5]872. Install a Java 8 SDK if you have not already. Go to
[bb733f2]88
89 http://www.oracle.com/technetwork/java/javase/downloads/
90
91for the latest from Oracle. On linux, you can instead use
92the package manager:
93
[20b16d5]94 sudo apt-get install openjdk-8-jdk
[bb733f2]95
[be6d877]963. Download the CIVL distribution from http://vsl.cis.udel.edu/civl.
[bb733f2]97
[be6d877]984. Unzip and untar the CIVL distribution file if this
99does not happen automatically. This should result in a
100folder named CIVL-TAG, where TAG is some version ID string.
101This folder contains the following:
[c7a0783]102
[6f2b49d]103 - README : this file
104 - bin : containing one executable sh script called "civl"
105 - lib : containing civl-TAG.jar
106 - doc : containing the manual and the tutorial of CIVL
[bb733f2]107 - emacs : CIVL-C emacs mode and its installation instructions
[c7a0783]108 - licenses : licenses for CIVL and included libraries
109 - examples : some example CIVL programs
110
[536af01]1115. You can move the CIVL folder wherever you want.
112The JAR file in the lib directory is all you need to run CIVL.
113You may also move this jar file wherever you want. You
114run CIVL by typing a command that begins
115"java -jar /path/to/civl-TAG.jar ...". For convenience
116you may instead use the shell script "civl" in bin,
117which allows you to replace "java -jar /path/to/civl-TAG.jar"
118with just "civl" on the command line. Simply edit the civl script
119to reflect the path to civl-TAG.jar and place the script
120somewhere in your PATH. Alternatively, you can just define
121an alias in your .profile, .bash_profile, or equivalent, such as
[583119f]122
[536af01]123alias civl='java -jar /path/to/civl-TAG.jar'
[583119f]124
[536af01]125In the following, we will assume that you have defined
126a command "civl" in one these ways.
127
1286. Type "civl config". This should report that it found
[be6d877]129the theorem provers you installed (and are in your PATH).
130It should create a file called ".sarl" in your home directory
131which you can also edit by hand.
[bb733f2]132
133
[8d0a007]134------------------------- Source Installation -------------------------
135
136We recommend using the Eclipse IDE for Java/EE developers.
137
[be6d877]1380. Install theorem provers following the directions above.
[bb733f2]139Install Eclipse IDE for Java/EE developers if you have not already
140done so.
141
[83c054c]1421. Install an SVN plugin in Eclipse (such as Subversive) if you have
143 not already.
144
1452. Install prerequisite projects ABC, SARL and GMC.
[8d0a007]146 Make sure that the three projects are put in the workspace
[536af01]147 directory where CIVL will be created. Specifically:
[8d0a007]148
[ae48dce]149 a. Install the symbolic algebra and reasoning library SARL.
150 In Eclipse, select New Project...from SVN, use the archive
151 svn://vsl.cis.udel.edu/sarl. After entering that, open it
152 up and select the "trunk". After checking out trunk, name
153 the project "SARL". Then follow the instructions in the INSTALL
154 file for Eclipse installation. Build the sarl.jar from within
155 Eclipse by right-clicking (or ctrl-clicking) on the build.xml
156 file and selecting Run As->Ant Build.
157
158 b. Install the C front-end ABC. In Eclipse,
[8d0a007]159 select New Project...from SVN, use the archive
160 svn://vsl.cis.udel.edu/abc. After entering that, open it
161 up and select the "trunk". After checking out trunk, name
162 the project "ABC". Then follow the instructions in the INSTALL
163 file for Eclipse installation. Build the abc.jar from within
164 Eclipse by right-clicking (or ctrl-clicking on OS X) on the
165 build.xml file and selecting Run As->Ant Build.
166
[ae48dce]167 c. Install the generic model checking utilities package GMC.
[8d0a007]168 In Eclipse, select New Project...from SVN, use the archive
169 svn://vsl.cis.udel.edu/gmc. After entering that, open it
170 up and select the "trunk". After checking out trunk, name
171 the project "GMC". Build the gmc.jar from within Eclipse
172 by right-clicking (or ctrl-clicking) on the build.xml file and
173 selecting Run As->Ant Build.
174
[83c054c]1753. From within Eclipse, select New Project...from SVN. The archive is
[148cbce]176 svn://vsl.cis.udel.edu/civl. After entering that, open it up and
177 select the "trunk". (It is simplest to just check out the trunk for
178 the Eclipse project.)
[8d0a007]179
[83c054c]1804. Check out the trunk, and create the project using the New Java
[148cbce]181 Project Wizard as usual, naming it "CIVL". The .project, .classpath,
[be6d877]182 and other Eclipse meta-data are already in the SVN archive,
183 saving you a bunch of work.
[8d0a007]184
[83c054c]1855. If you already have the VSL dependencies library, you may
[be6d877]186 skip this step. Otherwise, download the tgz archive of VSL
[003a8b3]187 dependencies from http://vsl.cis.udel.edu/lib/tools/vsl_depend
[8d0a007]188 Unzip the .tgz file and you will have the folder vsl.
[536af01]189 Move vsl to /opt.
190 Note: you probably will need to use sudo for this.
[8d0a007]191 Also, if you don't already have a directory called /opt,
[536af01]192 you will have to create it with "mkdir /opt". Also, if you
193 don't want to use /opt for some reason, you can use any
194 directory you want; just modify the instructions below
195 accordingly.
[8d0a007]196
197 Suppose that you put the .tgz file (or .tar file if your browser
[85b7e48]198 unzipped it automatically to a .tar file) in the directory DOWNLOAD.
[8d0a007]199 You can use the following commands:
200
[85b7e48]201 $ cd DOWNLOAD
[8d0a007]202 $ tar xzf YourTgzOrTarFile vsl
203 $ sudo mv vsl /opt
204
[be6d877]205 (Leave out the "x" in the tar command if the file was already
206 unzipped.) Now you can type "ls /opt/vsl", and the output
207 should be
[8d0a007]208
209 README.txt lib licenses src
210
[83c054c]2116. If default_build.properties matches the configuration of your system,
[c1c00b6]212 then you can skip this step. Otherwise, you may need to create a file
[be6d877]213 build.properties in the directory containing build.xml.
[c1c00b6]214 Copy and paste the content from any file under properties, edit each
215 entry with the path configured in your system. The newly created file
[536af01]216 build.properties will automatically be used by ant to to build the
217 .jar file.
[8d0a007]218
[83c054c]2197. Navigate to Preferences -> Java -> Build Path -> ClassPath
[8d0a007]220 Variables, and then select New to create a classpath variable VSL,
[be6d877]221 and specify its value to be /opt/vsl.
[8d0a007]222
[83c054c]2238. Do a clean build. Everything should compile. Generate the civl.jar
[8d0a007]224 by right-clicking (or ctrl-click on OS X) the build.xml file and
[be6d877]225 Run As->Ant Build.
226
[e8576bf]2279. Shortcuts for running CIVL
228
229 Somewhere on your system, create a plain text file containing
[be6d877]230 exactly the following two lines:
231
232#!/bin/sh
233java -jar /Path/To/Your/workspace/CIVL/civl.jar $@
234
235 where "/Path/To/Your/workspace" is replaced with the path
236 to your Eclipse workspace directory. Name this file "civl",
237 put it in your PATH, and make it executable (chmod ugo+x civl).
238
23910. From a terminal window, execute "civl config". This should
240 find the theorem provers in your PATH and create a file
241 .sarl in your home directory.
242
24311. In Eclipse, navigate to "Run->Run Configurations... Create a new
244 JUnit configuration."
245 Name it "CIVL Regression Tests". Select "Run all tests in the
246 selected project..." and navigate to the folder "test/regress"
247 in the CIVL project. The Test runner should be JUnit 4. Under the
248 Arguments tab, type "-ea" (without the quotes) in the VM arguments
249 area (to enable assertion checking).
250
25112. An example of how to set up a single test from within Eclipse:
[8d0a007]252 create a new Run Configuration via the Run->Run
253 Configurations... menu. Create a new "Java Application"
254 configuration. Call it "CIVL barrier2". The Project is CIVL. The
255 main class is edu.udel.cis.vsl.civl.CIVL. Under the Arguments tab,
[be6d877]256 set the Program arguments to
257
258 verify examples/concurrency/barrier2.cvl
259
260 Modify the VM arguments as in the step above. You should now be
261 able to run the test by clicking "Run".
[536af01]262
Note: See TracBrowser for help on using the repository browser.