aboutsummaryrefslogtreecommitdiffstats
path: root/docs/misc/coverage.markdown
blob: 9a88c899b831c6671e17a2ae45c85eeed3e542ea (plain)
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
# Coverage support for Xen

Coverare support allow you to get coverage information from Xen execution.
You can see how many times a line is executed.

Some compilers have specific options that enable the collection of this
information. Every basic block in the code will be instrumented by the compiler
to compute these statistics. It should not be used in production as it slows
down your hypervisor.

## Enable coverage

Test coverage support can be turned on compiling Xen with the `coverage` option set
to `y`.

Something like:

    cd xen
    make coverage=y

(or change your `.config` file).

## Extract coverage data

The way GCC and other tools deal with coverage information is to use some files
created during build phase (.gcno) and some files produced by executing the
*program* (.gcda). The program in this case is Xen but Xen cannot write files
so the way you can use coverage from Xen is extract coverage data from Xen and
then split these information into files.

To extract data you use a simple utility called `xencov`. Mainly `xencore`
allows you to do 3 operations:

* `xencov read` extract data
* `xencov reset` reset all coverage counters
* `xencov read-reset` extract data and reset counters at the same time.

Another utility (`xencov_split`) is used to split extracted data file into files
needed by userspace tools.

## Split coverage data

Once you extracted data from Xen, it is time to create files which the coverage tools
can understand. To do it you need to run `xencov_split` utility.

The utility just takes an input file and splits the blob into gcc .gcda files
in the same directory that you execute the script. As file names are generated
relative to the current directory, it could be a good idea to run the script
from `/` on your build machine.

Code for splitting the blob is put in another utility for some reason:
* It is simpler to maintain a high level script than a C program;
* You don't need to execute on the Xen host so you just need to copy the file to
  your development box (you usually need development files anyway).

## Possible use

**This section is just an example on how to use these tools!**

This example assumes you compiled Xen from `~/xen-unstable` and installed into
the host. **Consider that if you even recompile Xen you are not able to use
blob extracted from xencov!**

* Ensure the `lcov` package is installed
* From the Xen host machine extract the coverage blob

        cd /root
        xencov read coverage.dat

* Copy the extracted blob to your dev machine

        cd ~
        scp root@myhost:coverage.dat

* Extract the coverage information

        (cd / && xencov_split ~/coverage.dat)

* Produce coverage html output

        cd ~/xen-unstable
        rm -rf cov.info cov
        geninfo -o cov.info xen
        mkdir cov
        genhtml -o cov cov.info

* See output in a browser

        firefox cov/index.html