-
Notifications
You must be signed in to change notification settings - Fork 27
/
Copy pathREADME
94 lines (64 loc) · 2.65 KB
/
README
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
Kitsune - Dynamic Updating System
=================================
Update
------
Tested with "The OCaml toplevel, version 4.00.1".
Newer versions of Ocaml (ex: 4.02) might cause infinite loops with the code generator due to the version of Cil that we use.
Getting Started
---------------
1. Build the Kitsune runtime and compiler/transformation generator:
(in Kitsune root directory)
make
2. Build tests in the test/* directories. Most of these tests
manually initiate an update by calling kitsune_signal_update() rather
than having the user manually initiating the update.
3. Manually initiating an update normally works as follows:
Starting the initial version:
(kitsune root)/bin/driver (version 0).so (args)
To update that process, run:
(kitsune root)/bin/doupd (vN PID) (version N+1).so
Currently, the runtime prints the pid of the running process to
stdout, which can be used in the call to doupd. (Note that multiple
calls to doupd may be needed for programs that fork, like vsftpd.)
If Kitsune was built for benchmarking, then a benchmarking result
filename is expected by driver between the shared library and its
arguments. [We plan to streamline this later.]
4. Building and updating redis (as an example):
(build kitsune with threading)
cd examples/redis
make
- builds versions of redis from 2.0.0 -> 2.0.4
../../bin/driver redis-2.0.0/redis-server.so
- starts the redis server under kitsune
(in another terminal)
../../bin/doupd PID redis-2.0.1/redis-server.so
- you can get PID from the original terminal or just use `pidof
driver` in place of PID in this line (assuming you aren't running
other things under Kitsune simultaneously)
When a program is updated with Kitsune, it generates a log file that
can be found in /tmp/ekiden/PROG.PID (where PROG is the program name
and PID is its pid).
5. Learning Kitsune: currently the tests/ are the best way to see how
the kitsune tools work.
Overview of the Kitsune Repository
----------------------------------
src/
- contains the Kitsune runtime source code
tools/
- contains the Kitsune compiler and transformation generator
tools/ocaml-src/
- Kitsune specific code
tools/ocaml-src/cil
- Kitsune code linked with cil for compilation
tools/ocaml-src/tools
- xfgen-related code
tools/ocaml-src/common
- code shared between the compiler and xfgen
bin/
- contains the externally used Kitsune header files and the
compiled library
tests/
- a variety of tests ensuring correct behavior in the runtime
library and compilation tools. These tests provide a good way to
see how the parts of the system work together, and the compilation
process for updating.