Visible to Intel only — GUID: GUID-2B837E96-077E-4183-878D-00A25968752C
Visible to Intel only — GUID: GUID-2B837E96-077E-4183-878D-00A25968752C
Code Coverage Tool
The code coverage tool provides software developers with a view of how much application code is exercised when a specific workload is applied to the application. To determine which code is used, the code coverage tool uses Profile-guided Optimization (PGO) options and optimizations. The major features of the code coverage tool are listed below:
Visually presenting code coverage information for an application with a customizable code coverage coloring scheme
Displaying dynamic execution counts of each basic block of the application
Providing differential coverage, or comparison, profile data for two runs of an application
The information about using the code coverage tool is separated into the following sections:
The tool analyzes static profile information generated by the compiler, as well as dynamic profile information generated by running an instrumented form of the application binaries on the workload. The tool can generate an HTML-formatted report and export data in both text-, and XML-formatted files. The reports can be further customized to show color-coded, annotated, source-code listings that distinguish between used and unused code.
The code coverage tool is available on all supported Intel architectures on Linux*, Windows*, and macOS operating systems.
You can use the tool in a number of ways to improve development efficiency, reduce defects, and increase application performance:
During the project testing phase, the tool can measure the overall quality of testing by showing how much code is actually tested.
When applied to the profile of a performance workload, the code coverage tool can reveal how well the workload exercises the critical code in an application. High coverage of performance-critical modules is essential to taking full advantage of the Profile-Guided Optimizations that Intel Compilers offer.
The tool provides an option useful for both coverage and performance tuning, enabling developers to display the dynamic execution count for each basic block of the application.
The code coverage tool can compare the profile of two different application runs. This feature can help locate portions of the code in an application that are unrevealed during testing but are exercised when the application is used outside the test space, for example, when used by a customer.
Code Coverage Tool Requirements
To run the code coverage tool on an application, you must have following items:
The application sources.
The .spi file generated by the Intel® compiler when compiling the application for the instrumented binaries using the -prof-gen=srcpos (Linux and macOS) or /Qprof-gen:srcpos (Windows) option.
NOTE:Use the –[Q]prof-gen:srcpos option if you intend to use the collected data for code coverage and profile feedback. If you are only interested in using the instrumentation for code coverage, use the /Qcov-gen option. Using the /Qcov-gen option saves time and improves performance. This option can be used only on Windows platform for all architectures.
A pgopti.dpi file that contains the results of merging the dynamic profile information (.dyn) files, which is most easily generated by the profmerge tool. This file is also generated implicitly by the Intel® compilers when compiling an application with [Q]prof-use options with available .dyn and .dpi files.
Use the Tool
The tool uses the following syntax:
codecov [-codecov_option]
where -codecov_option is one or more optional parameters specifying the tool option passed to the tool. The available tool options are listed in the code coverage tools Options section. If you do not use any additional tool options, the tool will provide the top-level code coverage for the entire application.
In general, you must perform the following steps to use the code coverage tool:
Compile the application using -prof-gen=srcpos (Linux and macOS) or /Qprof-gen:srcpos (Windows), and/or /Qcov-gen (Windows) option.
This step generates an instrumented executable and a corresponding static profile information (pgopti.spi) file when the [Q]prof-gen=srcpos option is used. When the /Qcov-gen option is used, minimum instrumentation only for code coverage and generation of .spi file is enabled.
NOTE:You can specify both the /Qprof-gen=srcpos and /Qcov-gen options on the command line. The higher level of instrumentation needed for profile feedback is enabled along with the profile option for generating the .spi file, regardless of the order the options are specified on the command line.
Run the instrumented application.
This step creates the dynamic profile information (.dyn) file. Each time you run the instrumented application, the compiler generates a unique .dyn file either in the current directory or the directory specified in by the -prof-dir (Linux or macOS) or /Qprof-dir (Windows) option, or PROF_DIR environment variable. On Windows, you can use the /Qcov-dir or COV_DIR environment variable. These have the same meaning as /Qprof-dir and PROF_DIR.
Use the profmerge tool to merge all the .dyn files into one .dpi (pgopti.dpi) file.
This step consolidates results from all runs and represents the total profile information for the application, generates an optimized binary, and creates the dpi file needed by the code coverage tool.
You can use the profmerge tool to merge the .dyn files into a .dpi file without recompiling the application. The profmerge tool can also merge multiple .dpi files into one .dpi file using the profmerge -a option. Select an alternate name for the output .dpi file using the profmerge -prof_dpi option.
CAUTION:The profmerge tool merges all .dyn files that exist in the given directory. Confirm that unrelated .dyn files, which may remain from unrelated runs, are not present. Otherwise, the profile information will be skewed with invalid profile data, which can result in misleading coverage information and adverse performance of the optimized code.
Run the code coverage tool. The valid syntax and tool options are shown below.
This step creates a report or exported data as specified. If no other options are specified, the code coverage tool creates a single HTML file (CODE_COVERAGE.HTML) and a sub-directory (CodeCoverage) in the current directory. Open the file in a web browser to view the reports.
Windows* only: Unlike the compiler options, which are preceded by forward slash ("/"), the tool options are preceded by a hyphen ("-").
The code coverage tool allows you to name the project and specify paths to specific, necessary files. The following example demonstrates how to name a project and specify .dpi and .spi files to use:
codecov -prj myProject -spi pgopti.spi -dpi pgopti.dpi
The tool can add a contact name and generate an email link for that contact at the bottom of each HTML page. This provides a way to send an electronic message to the named contact. The following example demonstrates how to add specify a contact and the email links:
codecov -prj myProject -mname JoeSmith -maddr js@company.com
The following example demonstrates how to use the tool to specify the project name, specify the dynamic profile information file, and specify the output format and file name:
codecov -prj test1 -dpi test1.dpi -txtbcvrg test1_bcvrg.txt
Code Coverage Tool Options
Option |
Default |
Description |
---|---|---|
-bcolorcolor |
#FFFF99 |
Specifies the HTML color name for code in the uncovered blocks. |
-beginblkdsblstring |
Specifies the comment that marks the beginning of the code fragment to be ignored by the coverage tool. |
|
-blockcounts |
When used with -txtlcov, reports individual bloc counts for lines that involved multiple blocks. |
|
-ccolorcolor |
#FFFFFF |
Specifies the HTML color name or code of the covered code. |
-compfile |
Specifies the file name that contains the list of files being (or not) displayed. |
|
-counts |
Generates dynamic execution counts. |
|
-demang |
Demangles both function names and their arguments. |
|
-dpifile |
pgopti.dpi |
Specifies the file name of the dynamic profile information file (.dpi). |
-endblkdsblstring |
Specifies the comment that marks the end of the code fragment to be ignored by the coverage tool. |
|
-fcolorcolor |
#FFCCCC |
Specifies the HTML color name for code of the uncovered functions. |
-help, -h |
Prints tool option descriptions. |
|
-icolorcolor |
#FFFFFF |
Specifies the HTML color name or code of the information lines, such as basic-block markers and dynamic counts. |
-include-nonexec |
Block details will also be listed for functions that did not execute, when used with -xmlbcvrg[full] or -txtbcvrg[full] options. |
|
-maddrstring |
Nobody |
Sets the email address of the web-page owner |
-mnamestring |
Nobody |
Sets the name of the web-page owner. |
-nopartial |
Treats partially covered code as fully covered code. |
|
-nopmeter |
Turns off the progress meter. The meter is enabled by default. |
|
-nounwind |
Ignores compiler-generated unwind handlers for exception handling cleanup when computing and displaying basic block coverage. |
|
-onelinedsblstring |
Specifies the comment that marks individual lines of code or the whole functions to be ignored by the coverage tool. |
|
-pcolorcolor |
#FAFAD2 |
Specifies the HTML color name or code of the partially covered code. |
-prjstring |
Sets the project name. |
|
-ref |
Finds the differential coverage with respect to ref_dpi_file. |
|
-showdirnames |
Displays the full path name for source files in the HTML report, instead of just the base filename. |
|
-spifile |
pgopti.spi |
Specifies the file name of the static profile information file (.spi). |
-srcrootdir |
Specifies a different top level project directory than was used during compiler instrumentation run to use for relative paths to source files in place of absolute paths.
NOTE:
In order for the substitution to take place, the sources need to be compiled with one of the following options: [Q]prof-src-root, [Q]prof-src-root-cwd. This option specifies the base directory that is to be treated as the project root directory. An example of use is: C:> ifort -Qprof-gen:srcpos -Qprof-src-root c:\workspaces\orig_project_dir test1.f90 test2.f90 C:> test1.exe C:> profmerge C:> cd \workspaces\ C:> mv orig_project_dir new_project_dir C:> cd new_project_dir\src C:> codecov -srcroot C:\workspaces\new_project_dir Now, "C:\workspaces\new_project_dir" will be substituted for "c:\workspaces\orig_project_dir" when looking for the source files. For use of [Q]prof-src-root, [Q]prof-src-root-cwd options, refer to prof-src-root/Qprof-src-root, prof-src-root-cwd/Qprof-src-root-cwd |
|
-txtbcvrgfile |
Export block-coverage for covered functions as text format. The file parameter must be in the form of a valid file name. |
|
-txtbcvrgfullfile |
Export block-coverage for entire application in text and HTML formats. The file parameter must be in the form of a valid file name. |
|
-txtdcgfile |
Generates the dynamic call-graph information in text format. The file parameter must be in the form of a valid file name. |
|
-txtfcvrgfile |
Export function coverage for covered function in text format. The file parameter must by in the form of a valid file name. |
|
-txtlcovfile |
Generates line coverage in text format output files, instead of block coverage in HTML output files. |
|
-ucolorcolor |
#FFFFFF |
Specifies the HTML color name or code of the unknown code. |
-xcolorcolor |
#90EE90 |
Specifies the HTML color of the code ignored. |
-xmlbcvrgfile |
Export the block-coverage for the covered function in XML format. The file parameter must by in the form of a valid file name. |
|
-xmlbcvrgfullfile |
Export function coverage for entire application in XML format in addition to HTML output. The file parameter must be in the form of a valid file name. |
|
-xmlfcvrgfile |
Export function coverage for covered function in XML format. The file parameter must be in the form of a valid file name. |
Visually Present Code Coverage for an Application
Based on the profile information collected from running the instrumented binaries when testing an application, the Intel® compiler will create HTML-formatted reports using the code coverage tool. These reports indicate portions of the source code that were or were not exercised by the tests. When applied to the profile of the performance workloads, the code coverage information shows how well the training workload covers the application's critical code. High coverage of performance-critical modules is essential to taking full advantage of the profile-guided optimizations.
The code coverage tool can create two levels of coverage:
Top level (for a group of selected modules)
Individual module source views
Top-Level Coverage
The top-level coverage reports the overall code coverage of the modules that were selected. The following options are provided:
Select the modules of interest.
For the selected modules, the tool generates a list with their coverage information. The information includes the total number of functions and blocks in a module and the portions that were covered.
By clicking on the title of columns in the reported tables, the lists may be sorted in ascending or descending order based on:
Basic-block coverage
Function coverage
Function name
By default, the code coverage tool generates a single HTML file (CODE_COVERAGE.HTML) and a subdirectory (CodeCoverage) in the current directory. The HTML file defines a frameset to display all of the other generated reports. Open the HTML file in a web-browser. The tool places all other generated report files in a CodeCoverage subdirectory.
If you choose to generate the html-formatted version of the report, you can view coverage source of that particular module directly from a browser. The following figure shows the top-level coverage report.
The coverage tool creates a frame set that allows quick browsing through the code to identify uncovered code. The top frame displays the list of uncovered functions while the bottom frame displays the list of covered functions. For uncovered functions, the total number of basic blocks of each function is also displayed. For covered functions, both the total number of blocks and the number of covered blocks as well as their ratio (that is, the coverage rate) are displayed.
For example, 66.67(4/6) indicates that four out of the six blocks of the corresponding function were covered. The block coverage rate of that function is thus 66.67%. These lists can be sorted based on the coverage rate, number of blocks, or function names. Function names are linked to the position in source view where the function body starts. With one click you can see the least-covered function in the list, and with another click you can see the body of the function. You can scroll down in the source view and browse through the function body.
Individual Module Source View
Within the individual module source views, the tool provides the list of uncovered functions as well as the list of covered functions. The lists are reported in two distinct frames that provide easy navigation of the source code. The lists can be sorted based on:
Number of blocks within uncovered functions
Block coverage in the case of covered functions
Function names
Set the Coloring Scheme for the Code Coverage
The tool provides a visible coloring distinction of the following coverage categories: covered code, uncovered basic blocks, uncovered functions, partially covered code, and unknown code. The default colors that the tool uses for presenting the coverage information are shown in the tables that follows:
Category |
Default |
Description |
---|---|---|
Covered code |
#FFFFFF |
Indicates code was exercised by the tests. You can override the default color with the -ccolor tool option. |
Uncovered basic block |
#FFFF99 |
Indicates the basic blocks that were not exercised by any of the tests. However, these blocks were within functions that were executed during the tests. You can override the default color with the -bcolor tool option. |
Uncovered function |
#FFCCCC |
Indicates functions that were never called during the tests. You can override the default color with the -fcolor tool option. |
Partially covered code |
#FAFAD2 |
Indicates that more than one basic block was generated for the code at this position. Some of the blocks were covered and some were not. You can override the default color with the -pcolor tool option. |
Ignored code |
#90EE90 |
Indicates code that was specifically marked to be ignored. You can override this default color using the -xcolor tool option. |
Information lines |
#FFFFFF |
Indicates basic-block markers and dynamic counts. You can override the default color with the -icolor tool option. |
Unknown |
#FFFFFF |
Indicates that no code was generated for this source line. Most probably, the source at this position is a comment, a header-file inclusion, or a variable declaration. You can override the default color with the -ucolor tool option. |
The default colors can be customized to be any valid HTML color name or hexadecimal value using the options mentioned for each coverage category in the table above.
For code coverage colored presentation, the coverage tool uses the following heuristic: source characters are scanned until reaching a position in the source that is indicated by the profile information as the beginning of a basic block. If the profile information for that basic block indicates that a coverage category changes, then the tool changes the color corresponding to the coverage condition of that portion of the code, and the coverage tool inserts the appropriate color change in the HTML-formatted report files.
You need to interpret the colors in the context of the code. For example, comment lines that follow a basic block that was never executed would be colored in the same color as the uncovered blocks.
Dynamic Counters
The coverage tool can be configured to generate the information about the dynamic execution counts. This ability can display the dynamic execution count of each basic block of the application and is useful for both coverage and performance tuning.
The custom configuration requires using the -counts option. The counts information is displayed under the code after a "^" sign precisely under the source position where the corresponding basic block begins.
If more than one basic block is generated for the code at a source position (for example, for macros), then the total number of such blocks and the number of the blocks that were executed are also displayed in front of the execution count. For example, line 11 in the following example code is an IF statement:
11 IF ((N .EQ. 1).OR. (N .EQ. 0)) ^ 10 (1/2) 12 PRINT N ^ 7
The coverage lines under code lines 11 and 12 contain the following information:
The IF statement in line 11 was executed 10 times.
Two basic blocks were generated for the IF statement in line 11.
Only one of the two blocks was executed, resulting in the partial coverage color.
Only seven out of the ten times variable n had a value of 0 or 1.
In certain situations, it may be desirable to consider all the blocks generated for a single source position as one entity. In such cases, it is necessary to assume that all blocks generated for one source position are covered when at least one of the blocks is covered. This assumption can be configured with the -nopartial option. When this option is specified, decision coverage is disabled, and the related statistics are adjusted accordingly. The code lines 11 and 12 indicate that the print statement in line 12 was covered. However, only one of the conditions in line 11 was ever true. With the -nopartial option, the tool treats the partially covered code (like the code on line 11) as covered.
Differential Coverage
Using the code coverage tool, you can compare the profiles from two runs of an application: a reference run, and a new run identifying the code that is covered by the new run but not covered by the reference run. Use this feature to find the portion of the applications code that is not covered by the applications tests but is executed when the application is run by a customer. It can also be used to find the incremental coverage impact of newly added tests to an applications test space.
Generate Reference Data
Create the dynamic profile information for the reference data, which can be used in differential coverage reporting later, by using the -ref option. The following command demonstrates a typical command for generating the reference data:
codecov -prj Project_Name -dpi customer.dpi -ref appTests.dpi
The coverage statistics of a differential-coverage run shows the percentage of the code exercised on a new run but missed in the reference run. In such cases, the tool shows only the modules that included the code that was not covered. Keep this in mind when viewing the coloring scheme in the source views.
The code with the same coverage property (covered or not covered) on both runs is considered covered code. Otherwise, if the new run indicates that the code was executed, while in the reference run the code was not executed, then the code is treated as uncovered. Alternately, if the code is covered in the reference run but not covered in the new run, the differential-coverage source view shows the code as covered.
Run Differential Coverage
To run the code coverage tool for differential coverage, you must have the application sources, the .spi file, and the .dpi file, as described in the code coverage tool Requirements section (above).
Once the required files are available, enter a command similar to the following to begin the process of differential coverage analysis:
codecov -prj Project_Name -spi pgopti.spi -dpi pgopti.dpi
Specify the .dpi and .spi files using the -spi and -dpi options.
Exclude Code from Coverage Analysis
The code coverage tool allows you to exclude portions of your code from coverage analysis. This ability can be useful during development; for example, certain portions of code might include functions used for debugging only. The test case should not include tests for functionality that will be unavailable in the final application.
Another example of code that can be excluded is code that might be designed to deal with internal errors unlikely to occur in the application. In such cases, lack of a test case is preferred. You may want to ignore infeasible (dead) code in the coverage analysis. The code coverage tool provides several options for marking portions of the code infeasible and ignoring the code at the file level, function level, line level, and arbitrary code boundaries indicated by user-specific comments. The following sections explain how to exclude code at different levels.
Include and Exclude Coverage at the File Level
The code coverage tool provides the ability to selectively include or exclude files for analysis. Create a component file and add the appropriate string values that indicate the file and directory name for code you want included or excluded. Pass the file name as a parameter of the -comp option. The following example shows the general command:
codecov -comp file
where file is the name of a text file containing strings that act as file/directory name masks for including and excluding file-level analysis. For example, assume the following:
You want to include all files with the string "source" in the file name or directory name.
You create a component text file named myComp.txt with the selective inclusion string "source".
Once you have a component file, enter a command similar to the following:
codecov -comp myComp.txt
In this example, filenames with string "source" (like source1.f and source2.f) and all files within directories where the directory name contains the string "source" (like source/file1.f and source2\file2.f ) are included in the analysis.
To exclude files or directories, add the tilde (~) prefix to the string. You can specify inclusion and exclusion in the same component file. For example, assume you want to analyze all individual files or files in a directory where the file/directory name includes the string "source", and you want to exclude all individual files and files in directories where the file/directory name includes the string "skip". You add content similar to the following to the component file (myComp.txt) and pass it to the -comp option:
source ~skip
Entering the codecov -comp myComp.txt command with both instructions in the component file, myComp.txt, instructs the tool to:
Include files with filename containing "source" (like source1.f and source2.f)
Include all files in directories with the directory name containing "source" (like source/file1.f and source2\file2.f )
Exclude all files with filename containing "skip" (like skipthis1.f and skipthis2.f)
Exclude all files in directories with the directory name containing "skip" (like skipthese1\debug1.f and skipthese2\debug2.f)
Exclude Coverage at the Line and Function Level
You can mark individual lines for exclusion by passing string values to the -onelinedsbl option. For example, assume that you have some code similar to the following:
print*, "ERROR: n = ", n ! NO_COVER print*, " n2 = ", n2 ! INF IA-32 architecture
If you wanted to exclude all functions marked with the comments NO_COVER or INF IA-32 architecture, you would enter a command similar to the following:
codecov -onelinedsbl NO_COVER -onelinedsbl "INF IA-32 architecture"
You can specify multiple exclusion strings simultaneously, and you can specify any string values for the markers; however, you must remember the following guidelines when using this option:
Inline comments must occur at the end of the statement.
The string must be a part of an inline comment.
An entire function can be excluded from coverage analysis using the same methods. For example, the following function will be ignored from the coverage analysis when you issue example command shown above:
subroutine dumpInfo (n) integer n ! NO_COVER ... end subroutine
Additionally, you can use the code coverage tool to color the infeasible code with any valid HTML color code by combining the -onelinedsbl and -xcolor options. The following example commands demonstrate the combination:
codecov -onelinedsbl INF -xcolor lightgreen codecov -onelinedsbl INF -xcolor #CCFFCC
Exclude Code by Defining Arbitrary Boundaries
The code coverage tool provides the ability to arbitrarily exclude code from coverage analysis. This feature is most useful where the excluded code either occur inside of a function or spans several functions.
Use the -beginblkdsbl and -endblkdsbl options to mark the beginning and end (respectively) of any arbitrarily defined boundary to exclude code from analysis. Remember the following guidelines when using these options:
Inline comments must occur at the end of the statement.
The string must be a part of an inline comment.
For example assume that you have the following code:
integer n, n2 n = 123 n2 = n*n if (n2 .lt. 0) then ! /* BINF */ print*, "ERROR: n = ", n print*, " n2 = ", n2 ! // EINF else if (n2 .eq. 0) then print*, "zero: n = ", n, " n2 = ", n2 else print*, "positive: n = ", n, " n2 = ", n2 endif end
The following example commands demonstrate how to use the -beginblkdsbl option to mark the beginning and the -endblkdsbl option to mark the end of code to exclude from the sample shown above:
codecov -xcolor #ccFFCC -beginblkdsbl BINF -endblkdsbl EINF codecov -xcolor #ccFFCC -beginblkdsbl "BEGIN_INF" -endblkdsbl "END_INF"
Notice that you can combine these options in combination with the -xcolor option.
Export Coverage Data
The code coverage tool provides specific options to extract coverage data from the dynamic profile information (.dpi files) that result from running instrumented application binaries under various workloads. The tool can export the coverage data in various formats for post-processing and direct loading into databases: the default HTML, text, and XML. You can choose to export data at the function and basic block levels.
There are two basic methods for exporting the data: quick export and combined export. Each method has associated options supported by the tool
Quick export: The first method is to export the data coverage to text- or XML-formatted files without generating the default HTML report. The application sources need not be present for this method. The code coverage tool creates reports and provides statistics only about the portions of the application executed. The resulting analysis and reporting occurs quickly, which makes it practical to apply the coverage tool to the dynamic profile information (the .dpi file) for every test case in a given test space instead of applying the tool to the profile of individual test suites or the merge of all test suites. The -xmlfcvrg, -txtfcvrg, -xmlbcvrg and -txtbcvrg options support the first method.
Combined export: The second method is to generate the default HTML and simultaneously export the data to text- and XML-formatted files. This process is slower than first method since the application sources are parsed and reports generated. The -xmlbcvrgfull and -txtbcvrgfull options support the second method.
These export methods provide the means to quickly extend the code coverage reporting capabilities by supplying consistently formatted output from the code coverage tool. You can extend these by creating additional reporting tools on top of these report files.
Quick Export
The profile of covered functions of an application can be exported quickly using the -xmlfcvrg, -txtfcvrg, -xmlbcvrg, and -txtbcvrg options. When using any of these options, specify the output file that will contain the coverage report. For example, enter a command similar to the following to generate a report of covered functions in XML formatted output:
codecov -prj test1 -dpi test1.dpi -xmlfcvrg test1_fcvrg.xml
The resulting report will show how many times each function was executed and the total number of blocks of each function, together with the number of covered blocks and the block coverage of each function. The following example shows some of the content of a typical XML report:
<PROJECT name = "test1"> <MODULE name = "D:\SAMPLE.F"> <FUNCTION name="f0" freq="2"> <BLOCKS total="6" covered="5" coverage="83.33%"></BLOCKS> </FUNCTION> ... </MODULE> <MODULE name = "D:\SAMPLE2.F"> ... </MODULE> </PROJECT>
In the above example, we note that function f0, which is defined in file sample.f, has been executed twice. It has a total number of six basic blocks, five of which are executed, resulting in an 83.33% basic block coverage.
You can also export the data in text format using the -txtfcvrg option. The generated text report, using this option, for the above example would be similar to the following example:
Covered Functions in File: "D:\SAMPLE.F" "f0" 2 6 5 83.33 "f1" 1 6 4 66.67 "f2" 1 6 3 50.00 ...
In the text formatted version of the report, the each line of the report should be read in the following manner:
Column 1 |
Column 2 |
Column 3 |
Column 4 |
Column 5 |
---|---|---|---|---|
Function name |
Execution frequency |
Line number of the start of the function definition |
Column number of the start of the function definition |
Percentage of basic-block coverage of the function |
Additionally, the tool supports exporting the block level coverage data using the -xmlbcvrg option. For example, enter a command similar to the following to generate a report of covered blocks in XML formatted output:
codecov -prj test1 -dpi test1.dpi -xmlbcvrg test1_bcvrg.xml
The example command shown above would generate XML-formatted results similar to the following:
<PROJECT name = "test1"> <MODULE name = "D:\SAMPLE.cF90"> <FUNCTION name="f0" freq="2"> ... <BLOCK line="11" col="2"> <INSTANCE id="1" freq="1"> </INSTANCE> </BLOCK> <BLOCK line="12" col="3"> <INSTANCE id="1" freq="2"> </INSTANCE> <INSTANCE id="2" freq="1"> </INSTANCE> </BLOCK>
In the sample report, notice that one basic block is generated for the code in function f0 at the line 11, column 2 of the file sample.f90. This particular block has been executed only once. Also notice that there are two basic blocks generated for the code that starts at line 12, column 3 of file. One of these blocks, which has id = 1, has been executed two times, while the other block has been executed only once. A similar report in text format can be generated through the -txtbcvrg option.
Combined Exports
The code coverage tool has also the capability of exporting coverage data in the default HTML format while simultaneously generating the text- and XML-formatted reports.
Use the -xmlbcvrgfull and -txtbcvrgfull options to generate reports in all supported formats in a single run. These options export the basic-block level coverage data while simultaneously generating the HTML reports. These options generate more complete reports since they include analysis on functions that were not executed at all. However, exporting the coverage data using these options requires access to application source files and take much longer to run.
Dynamic Call Graphs
Using the -txtdcg option the tool can provide detailed information about the dynamic call graphs in an application. Specify an output file for the dynamic call-graph report. The resulting call graph report contains information about the percentage of static and dynamic calls (direct, indirect, and virtual) at the application, module, and function levels.