source: CIVL/README@ 55e649b

1.23 2.0 main test-branch
Last change on this file since 55e649b was 85b7e48, checked in by Stephen Siegel <siegel@…>, 12 years ago

Updates/corrections to CIVL's README.

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

  • Property mode set to 100644
File size: 9.0 KB
Line 
1 CIVL: The Concurrency Intermediate Verification Language
2 v 0.14
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, CUDA, and Chapel. CIVL-C also provides
14 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
29Ziqing Luo
30Michael Rogers
31Stephen F. Siegel
32Manchun Zheng
33Timothy K. Zirkel
34
35------------------------------- License -------------------------------
36
37CIVL is open source software distributed under the GNU
38General Public License. However, the libraries used by CIVL
39(and incorporated into the complete distribution) use various
40licenses. See directory licenses for the license of each component.
41
42-------------------------- Updates from v 0.13 -------------------------
43
441. New command line options added:
45 "-D": support macros defined in command line;
46 "-ast": print the AST of input program
47 "-preproc": print the result of preprocessing the input program
482. Supported compiling and linking multiple programs for verification;
493. New command line specification:
50 civl (show | verify | replay | run) [options] filename+
51 or civl (compare | replay) [common options] \
52 -spec [spec options] filename+ \
53 -impl [impl options] filename+
54 or civl gui
55 or civl help [command]
56
57 For more information, type "civl help".
58
59
60------------------------- Binary Installation -------------------------
61
62For most users, this will be the easiest way to install and use CIVL.
63
641. Install a Java 7 SDK if you have not already. Go to
65http://www.oracle.com/technetwork/java/javase/downloads/ for the
66latest from Oracle. On linux, you can optionally sudo apt-get install
67openjdk-7-jdk.
68
692. If you already have the VSL dependencies library, you may
70skip this step. Otherwise, download the archive of VSL
71dependencies from http://vsl.cis.udel.edu/tools/vsl_depend,
72choosing the version for your OS type (32-bit linux,
7364-bit linux, or 64-bit OS X). Unzip and untar the
74downloaded .tgz file and you will have a folder named "vsl".
75If you do not already have a directory /opt, create one with
76"mkdir /opt". Move vsl into /opt. Use sudo as needed.
77
783. Download the CIVL distribution from http://vsl.cis.udel.edu/civl.
79
804. Unzip and untar the downloaded file if this does not happen
81automatically. This should result in a folder named
82CIVL-TAG, where TAG is some version id string. This folder
83contains the following:
84
85 - README : this file
86 - bin : containing one executable sh script called "civl"
87 - lib : containing civl-TAG.jar
88 - doc : containing the manual and the tutorial of CIVL
89 - emacs : CIVL-C emacs mode and its installation guideline
90 - licenses : licenses for CIVL and included libraries
91 - examples : some example CIVL programs
92
935. Move CIVL-TAG into /opt.
94
956. Put the civl script in your path however you like to put things
96in your path. Either move it to a directory in your path,
97or create a symlink to it, or edit your .profile or equivalent
98to put it in your path.
99
100------------------------- Source Installation -------------------------
101
102We recommend using the Eclipse IDE for Java/EE developers.
103
1041. Install an SVN plugin in Eclipse (such as Subversive) if you have
105 not already.
106
1072. Install prerequisite projects ABC, SARL and GMC.
108 Make sure that the three projects are put in the workspace
109 directory where CIVL will be put.
110
111 a. Install the symbolic algebra and reasoning library SARL.
112 In Eclipse, select New Project...from SVN, use the archive
113 svn://vsl.cis.udel.edu/sarl. After entering that, open it
114 up and select the "trunk". After checking out trunk, name
115 the project "SARL". Then follow the instructions in the INSTALL
116 file for Eclipse installation. Build the sarl.jar from within
117 Eclipse by right-clicking (or ctrl-clicking) on the build.xml
118 file and selecting Run As->Ant Build.
119
120 b. Install the C front-end ABC. In Eclipse,
121 select New Project...from SVN, use the archive
122 svn://vsl.cis.udel.edu/abc. After entering that, open it
123 up and select the "trunk". After checking out trunk, name
124 the project "ABC". Then follow the instructions in the INSTALL
125 file for Eclipse installation. Build the abc.jar from within
126 Eclipse by right-clicking (or ctrl-clicking on OS X) on the
127 build.xml file and selecting Run As->Ant Build.
128
129 c. Install the generic model checking utilities package GMC.
130 In Eclipse, select New Project...from SVN, use the archive
131 svn://vsl.cis.udel.edu/gmc. After entering that, open it
132 up and select the "trunk". After checking out trunk, name
133 the project "GMC". Build the gmc.jar from within Eclipse
134 by right-clicking (or ctrl-clicking) on the build.xml file and
135 selecting Run As->Ant Build.
136
1373. From within Eclipse, select New Project...from SVN. The archive is
138 svn://vsl.cis.udel.edu/civl. After entering that, open it up and
139 select the "trunk". (It is simplest to just check out the trunk for
140 the Eclipse project.)
141
1424. Check out the trunk, and create the project using the New Java
143 Project Wizard as usual, naming it "CIVL". The .project, .classpath,
144 and other Eclipse meta-data are already in the SVN archive, saving you
145 a bunch of work.
146
1475. If you already have the VSL dependencies library, you may
148 skip this step. Download the tgz archive of VSL dependencies from
149 http://vsl.cis.udel.edu/tools/vsl_depend, choosing the right .tgz
150 according to your platform:
151
152 vsl_linux32-1.0.tgz - 32-bit linux
153 vsl_linux64-1.0.tgz - 64-bit linux
154 vsl_osx64-1.0.tgz - 64-bit osx
155
156 Unzip the .tgz file and you will have the folder vsl.
157 Move vsl to /opt (you might need to use sudo for this.
158 Also, if you don't already have a directory called /opt,
159 you will have to create it with mkdir /opt).
160
161 Suppose that you put the .tgz file (or .tar file if your browser
162 unzipped it automatically to a .tar file) in the directory DOWNLOAD.
163 You can use the following commands:
164
165 $ cd DOWNLOAD
166 $ tar xzf YourTgzOrTarFile vsl
167 $ sudo mv vsl /opt
168
169 (Leave out the "x" in the tar command if the file was already unzipped.)
170 Now you can type "ls /opt/vsl", and the output should be
171
172 README.txt lib licenses src
173
1746. If default_build.properties matches the configuration of your system,
175 then you can skip this step. Otherwise, you may need to create a file
176 build.properties in the directory where build.xml is in.
177 Copy and paste the content from any file under properties, edit each
178 entry with the path configured in your system. The newly created file
179 build.properties will automatically be used by ant to to build the .jar file.
180
1817. Navigate to Preferences -> Java -> Build Path -> ClassPath
182 Variables, and then select New to create a classpath variable VSL,
183 and specify its value to be /opt/vsl. Navigate to Preferences -> Run/Debug
184 -> String Substitution -> New, and then define an entry vsl_lib and
185 set its value to be /opt/vsl/lib.
186
1878. Do a clean build. Everything should compile. Generate the civl.jar
188 by right-clicking (or ctrl-click on OS X) the build.xml file and
189 Run As->Ant Build.
190
1919. Go to Run->Run Configurations... Create a new JUnit configuration.
192 Name it CIVL Tests. Select "Run all tests in the selected project..."
193 and navigate to the folder "test/regress" in the CIVL project.
194 The Test runner should be JUnit 4. Under the Arguments tab, type
195 "-ea" (without the quotes) in the VM arguments area (to enable assertion
196 checking). Under the Environment tab, create an entry
197 DYLD_LIBRARY_PATH (OS X) or LD_LIBRARY_PATH (linux),
198 specify its value by clicking Variables and choose vsl_lib from the list,
199 or you may type ${vsl_lib} in the value entry.
200
20110. An example of how to set up a single test from within Eclipse:
202 create a new Run Configuration via the Run->Run
203 Configurations... menu. Create a new "Java Application"
204 configuration. Call it "CIVL barrier2". The Project is CIVL. The
205 main class is edu.udel.cis.vsl.civl.CIVL. Under the Arguments tab,
206 set the Program arguments to "verify examples/concurrency/barrier2.cvl"
207 (without the quotes). Modify the VM arguments and the Environment
208 as in the step above. You should now be able to run the test by
209 clicking "Run".
Note: See TracBrowser for help on using the repository browser.