#include <stdio.h>
#include <assert.h>
#include <stdlib.h>
#include "assertion.h"
#include "binding.h"
#include "comb.h"
#include "db.h"
#include "defines.h"
#include "fsm.h"
#include "info.h"
#include "instance.h"
#include "line.h"
#include "memory.h"
#include "ovl.h"
#include "race.h"
#include "report.h"
#include "stat.h"
#include "tcl_funcs.h"
#include "toggle.h"
#include "util.h"
Functions | |
static void | report_usage () |
static void | report_parse_metrics (const char *metrics) |
bool | report_parse_args (int argc, int last_arg, const char **argv) |
Parses arguments on report command command-line. | |
void | report_gather_instance_stats (funit_inst *root) |
Recursively gathers instance statistics in each instance structure. | |
static void | report_gather_funit_stats (funit_link *head) |
void | report_print_header (FILE *ofile) |
Prints header of report. | |
static void | report_generate (FILE *ofile) |
void | report_read_cdd_and_ready (const char *ifile) |
Reads the CDD and readies the design for reporting. | |
void | report_close_cdd () |
Closes the currently loaded CDD. | |
void | report_save_cdd (const char *filename) |
Saves the currently loaded CDD as the specified filename. | |
void | report_output_exclusion_reason (FILE *ofile, int leading_spaces, const char *msg, bool header) |
Outputs the given exclusion reason to the given output stream. | |
void | command_report (int argc, int last_arg, const char **argv) |
Parses command-line for report command and performs report functionality. | |
Variables | |
char | user_msg [USER_MSG_LENGTH] |
db ** | db_list |
unsigned int | db_size |
unsigned int | curr_db |
str_link * | merge_in_head |
str_link * | merge_in_tail |
isuppl | info_suppl |
char * | cdd_message |
bool | report_line = TRUE |
bool | report_toggle = TRUE |
bool | report_combination = TRUE |
bool | report_fsm = TRUE |
bool | report_race = FALSE |
bool | report_assertion = FALSE |
bool | report_memory = FALSE |
bool | report_instance = FALSE |
bool | report_covered = FALSE |
bool | report_exclusions = FALSE |
static bool | report_gui = FALSE |
bool | report_bitwise = FALSE |
bool | flag_use_line_width = FALSE |
int | line_width = DEFAULT_LINE_WIDTH |
unsigned int | report_comb_depth = REPORT_SUMMARY |
char * | output_file = NULL |
static char * | input_db = NULL |
bool | flag_suppress_empty_funits = FALSE |
bool | flag_output_exclusion_ids = FALSE |
void command_report | ( | int | argc, | |
int | last_arg, | |||
const char ** | argv | |||
) |
Parses command-line for report command and performs report functionality.
Performs report command functionality.
argc | Number of arguments in report command-line | |
last_arg | Index of last parsed argument from list | |
argv | Arguments passed to report command to parse |
References bind_perform(), Catch_anonymous, COVERED_HEADER, db_close(), db_read(), FALSE, FATAL, free_safe, HEADER, input_db, interp, malloc_safe, output_file, print_output(), PROFILE, PROFILE_END, READ_MODE_REPORT_MOD_MERGE, READ_MODE_REPORT_NO_MERGE, report_generate(), report_gui, report_instance, report_parse_args(), strdup_safe, Throw, TRUE, Try, user_msg, and USER_MSG_LENGTH.
Referenced by main().
01081 { PROFILE(COMMAND_REPORT); 01082 01083 FILE* ofile = NULL; /* Pointer to output stream */ 01084 #ifdef HAVE_TCLTK 01085 char* covered_home = NULL; /* Pathname to Covered's home installation directory */ 01086 char* covered_browser = NULL; /* Name of browser to use for GUI help pages */ 01087 char* covered_version = NULL; /* String version of current Covered version */ 01088 char* main_file = NULL; /* Name of main TCL file to interpret */ 01089 char* user_home; /* HOME environment variable */ 01090 #endif 01091 unsigned int rv; /* Return value from snprintf calls */ 01092 bool error = FALSE; 01093 bool help_found = FALSE; 01094 01095 /* Output header information */ 01096 rv = snprintf( user_msg, USER_MSG_LENGTH, COVERED_HEADER ); 01097 assert( rv < USER_MSG_LENGTH ); 01098 print_output( user_msg, HEADER, __FILE__, __LINE__ ); 01099 01100 Try { 01101 01102 /* Parse score command-line */ 01103 if( !report_parse_args( argc, last_arg, argv ) ) { 01104 01105 if( !report_gui ) { 01106 01107 /* Open database file for reading */ 01108 if( input_db == NULL ) { 01109 01110 unsigned int rv = snprintf( user_msg, USER_MSG_LENGTH, "Database file not specified in command line" ); 01111 assert( rv < USER_MSG_LENGTH ); 01112 print_output( user_msg, FATAL, __FILE__, __LINE__ ); 01113 Throw 0; 01114 01115 } else { 01116 01117 /* Read in CDD file */ 01118 (void)db_read( input_db, (report_instance ? READ_MODE_REPORT_NO_MERGE : READ_MODE_REPORT_MOD_MERGE) ); 01119 01120 /* Perform binding */ 01121 bind_perform( TRUE, 0 ); 01122 01123 Try { 01124 01125 /* Open output stream */ 01126 if( output_file != NULL ) { 01127 ofile = fopen( output_file, "w" ); 01128 assert( ofile != NULL ); /* We should have already verified that the file is writable */ 01129 } else { 01130 ofile = stdout; 01131 } 01132 01133 /* Generate report */ 01134 report_generate( ofile ); 01135 01136 } Catch_anonymous { 01137 if( ofile != stdout ) { 01138 rv = fclose( ofile ); 01139 assert( rv == 0 ); 01140 } 01141 Throw 0; 01142 } 01143 01144 /* Close output file */ 01145 if( ofile != stdout ) { 01146 rv = fclose( ofile ); 01147 assert( rv == 0 ); 01148 } 01149 01150 } 01151 01152 #ifdef HAVE_TCLTK 01153 } else { 01154 01155 unsigned int slen; 01156 01157 Try { 01158 01159 unsigned int rv; 01160 01161 /* Initialize the Tcl/Tk interpreter */ 01162 interp = Tcl_CreateInterp(); 01163 assert( interp ); 01164 01165 if( Tcl_Init( interp ) == TCL_ERROR ) { 01166 printf( "ERROR: %s\n", interp->result ); 01167 Throw 0; 01168 } 01169 01170 if( Tk_SafeInit( interp ) == TCL_ERROR ) { 01171 printf( "ERROR: %s\n", interp->result ); 01172 Throw 0; 01173 } 01174 01175 /* Get the COVERED_HOME environment variable */ 01176 #ifndef INSTALL_DIR 01177 if( getenv( "COVERED_HOME" ) == NULL ) { 01178 print_output( "COVERED_HOME not initialized. Exiting...", FATAL, __FILE__, __LINE__ ); 01179 Throw 0; 01180 } 01181 covered_home = strdup_safe( getenv( "COVERED_HOME" ) ); 01182 #else 01183 covered_home = strdup_safe( INSTALL_DIR ); 01184 #endif 01185 01186 /* Get the COVERED_BROWSER environment variable */ 01187 #ifndef COVERED_BROWSER 01188 covered_browser = strdup_safe( getenv( "COVERED_BROWSER" ) ); 01189 #else 01190 covered_browser = strdup_safe( COVERED_BROWSER ); 01191 #endif 01192 01193 covered_version = strdup_safe( VERSION ); 01194 user_home = getenv( "HOME" ); 01195 01196 /* Initialize TCL */ 01197 tcl_func_initialize( interp, argv[0], user_home, covered_home, covered_version, covered_browser, input_db ); 01198 01199 /* Call the top-level Tcl file */ 01200 slen = strlen( covered_home ) + 30; 01201 main_file = (char*)malloc_safe( slen ); 01202 rv = snprintf( main_file, slen, "%s/scripts/main_view.tcl", covered_home ); 01203 assert( rv < slen ); 01204 rv = Tcl_EvalFile( interp, main_file ); 01205 if( rv != TCL_OK ) { 01206 rv = snprintf( user_msg, USER_MSG_LENGTH, "TCL/TK: %s\n", Tcl_ErrnoMsg( Tcl_GetErrno() ) ); 01207 assert( rv < USER_MSG_LENGTH ); 01208 print_output( user_msg, FATAL, __FILE__, __LINE__ ); 01209 Throw 0; 01210 } 01211 01212 /* Call the main-loop */ 01213 Tk_MainLoop (); 01214 01215 } Catch_anonymous { 01216 free_safe( covered_home, (strlen( covered_home ) + 1) ); 01217 free_safe( main_file, slen ); 01218 free_safe( covered_browser, (strlen( covered_browser ) + 1) ); 01219 free_safe( covered_version, (strlen( covered_version ) + 1) ); 01220 Throw 0; 01221 } 01222 01223 /* Clean Up */ 01224 free_safe( covered_home, (strlen( covered_home ) + 1) ); 01225 free_safe( main_file, slen ); 01226 free_safe( covered_browser, (strlen( covered_browser ) + 1) ); 01227 free_safe( covered_version, (strlen( covered_version ) + 1) ); 01228 #endif 01229 01230 } 01231 01232 } 01233 01234 } Catch_anonymous { 01235 error = TRUE; 01236 } 01237 01238 free_safe( output_file, (strlen( output_file ) + 1) ); 01239 free_safe( input_db, (strlen( input_db ) + 1) ); 01240 01241 /* Close the database */ 01242 db_close(); 01243 01244 if( error ) { 01245 Throw 0; 01246 } 01247 01248 PROFILE_END; 01249 01250 }
void report_close_cdd | ( | ) |
Closes the currently loaded CDD.
Closes the currently loaded CDD file.
References db_close(), PROFILE, and PROFILE_END.
00911 { PROFILE(REPORT_CLOSE_CDD); 00912 00913 db_close(); 00914 00915 PROFILE_END; 00916 00917 }
static void report_gather_funit_stats | ( | funit_link * | head | ) | [static] |
Traverses functional unit list, creating statistic structures for each of the functional units in the tree, and calculates summary coverage information.
head | Pointer to head of functional unit list to search |
References statistic_s::arc_excluded, statistic_s::arc_hit, statistic_s::arc_total, statistic_s::assert_excluded, statistic_s::assert_hit, isuppl_u::assert_ovl, statistic_s::assert_total, assertion_get_stats(), statistic_s::comb_excluded, statistic_s::comb_hit, statistic_s::comb_total, combination_get_stats(), flag_suppress_empty_funits, fsm_get_stats(), func_unit_s::fsm_head, funit_link_s::funit, statistic_s::line_excluded, line_get_stats(), statistic_s::line_hit, statistic_s::line_total, statistic_s::mem_ae_total, statistic_s::mem_cov_found, statistic_s::mem_excluded, statistic_s::mem_rd_hit, statistic_s::mem_tog01_hit, statistic_s::mem_tog10_hit, statistic_s::mem_tog_total, statistic_s::mem_wr_hit, memory_get_stats(), funit_link_s::next, ovl_is_assertion_module(), isuppl_u::part, PROFILE, PROFILE_END, race_get_stats(), func_unit_s::race_head, statistic_s::race_total, report_assertion, report_combination, report_fsm, report_line, report_memory, report_race, report_toggle, statistic_s::rtype_total, statistic_s::show, func_unit_s::stat, statistic_s::state_hit, statistic_s::state_total, statistic_create(), statistic_is_empty(), statistic_s::tog01_hit, statistic_s::tog10_hit, statistic_s::tog_cov_found, statistic_s::tog_excluded, statistic_s::tog_total, and toggle_get_stats().
Referenced by report_generate(), and report_read_cdd_and_ready().
00588 { PROFILE(REPORT_GATHER_FUNIT_STATS); 00589 00590 while( head != NULL ) { 00591 00592 statistic_create( &(head->funit->stat) ); 00593 00594 /* If this module is an OVL assertion module, don't get statistics for it */ 00595 if( (info_suppl.part.assert_ovl == 0) || !ovl_is_assertion_module( head->funit ) ) { 00596 00597 /* Get coverage results for this instance */ 00598 if( report_line ) { 00599 line_get_stats( head->funit, 00600 &(head->funit->stat->line_hit), 00601 &(head->funit->stat->line_excluded), 00602 &(head->funit->stat->line_total) ); 00603 } 00604 00605 if( report_toggle ) { 00606 toggle_get_stats( head->funit, 00607 &(head->funit->stat->tog01_hit), 00608 &(head->funit->stat->tog10_hit), 00609 &(head->funit->stat->tog_excluded), 00610 &(head->funit->stat->tog_total), 00611 &(head->funit->stat->tog_cov_found) ); 00612 } 00613 00614 if( report_combination ) { 00615 combination_get_stats( head->funit, 00616 &(head->funit->stat->comb_hit), 00617 &(head->funit->stat->comb_excluded), 00618 &(head->funit->stat->comb_total) ); 00619 } 00620 00621 if( report_fsm ) { 00622 fsm_get_stats( head->funit->fsm_head, 00623 &(head->funit->stat->state_hit), 00624 &(head->funit->stat->state_total), 00625 &(head->funit->stat->arc_hit) , 00626 &(head->funit->stat->arc_total), 00627 &(head->funit->stat->arc_excluded) ); 00628 } 00629 00630 if( report_assertion ) { 00631 assertion_get_stats( head->funit, 00632 &(head->funit->stat->assert_hit), 00633 &(head->funit->stat->assert_excluded), 00634 &(head->funit->stat->assert_total) ); 00635 } 00636 00637 if( report_memory ) { 00638 memory_get_stats( head->funit, 00639 &(head->funit->stat->mem_wr_hit), 00640 &(head->funit->stat->mem_rd_hit), 00641 &(head->funit->stat->mem_ae_total), 00642 &(head->funit->stat->mem_tog01_hit), 00643 &(head->funit->stat->mem_tog10_hit), 00644 &(head->funit->stat->mem_tog_total), 00645 &(head->funit->stat->mem_excluded), 00646 &(head->funit->stat->mem_cov_found) ); 00647 } 00648 00649 if( report_race ) { 00650 race_get_stats( head->funit->race_head, 00651 &(head->funit->stat->race_total), 00652 &(head->funit->stat->rtype_total) ); 00653 } 00654 00655 } 00656 00657 /* Set show bit */ 00658 if( flag_suppress_empty_funits ) { 00659 head->funit->stat->show = !statistic_is_empty( head->funit->stat ); 00660 } 00661 00662 head = head->next; 00663 00664 } 00665 00666 PROFILE_END; 00667 00668 }
void report_gather_instance_stats | ( | funit_inst * | root | ) |
Recursively gathers instance statistics in each instance structure.
Recursively parses instance tree, creating statistic structures for each of the instances in the tree. Calculates summary coverage information for children nodes first and parent nodes after. In this way, the parent nodes will have the accumulated information from themselves and all of their children.
root | Pointer to root of instance tree to search |
References statistic_s::arc_excluded, statistic_s::arc_hit, statistic_s::arc_total, statistic_s::assert_excluded, statistic_s::assert_hit, isuppl_u::assert_ovl, statistic_s::assert_total, assertion_get_stats(), funit_inst_s::child_head, statistic_s::comb_excluded, statistic_s::comb_hit, statistic_s::comb_total, combination_get_stats(), flag_suppress_empty_funits, fsm_get_stats(), func_unit_s::fsm_head, funit_inst_s::funit, statistic_s::line_excluded, line_get_stats(), statistic_s::line_hit, statistic_s::line_total, statistic_s::mem_ae_total, statistic_s::mem_cov_found, statistic_s::mem_excluded, statistic_s::mem_rd_hit, statistic_s::mem_tog01_hit, statistic_s::mem_tog10_hit, statistic_s::mem_tog_total, statistic_s::mem_wr_hit, memory_get_stats(), funit_inst_s::next, ovl_is_assertion_module(), isuppl_u::part, PROFILE, PROFILE_END, race_get_stats(), func_unit_s::race_head, statistic_s::race_total, report_assertion, report_combination, report_fsm, report_gather_instance_stats(), report_line, report_memory, report_race, report_toggle, statistic_s::rtype_total, statistic_s::show, func_unit_s::stat, funit_inst_s::stat, statistic_s::state_hit, statistic_s::state_total, statistic_create(), statistic_is_empty(), statistic_s::tog01_hit, statistic_s::tog10_hit, statistic_s::tog_cov_found, statistic_s::tog_excluded, statistic_s::tog_total, and toggle_get_stats().
Referenced by rank_read_cdd(), report_gather_instance_stats(), report_generate(), and report_read_cdd_and_ready().
00494 { PROFILE(REPORT_GATHER_INSTANCE_STATS); 00495 00496 funit_inst* curr; /* Pointer to current instance being evaluated */ 00497 00498 /* Create and initialize statistic structure */ 00499 statistic_create( &(root->stat) ); 00500 00501 /* Get coverage results for all children first */ 00502 curr = root->child_head; 00503 while( curr != NULL ) { 00504 report_gather_instance_stats( curr ); 00505 curr = curr->next; 00506 } 00507 00508 /* If this module is an OVL module or it isn't attached to a functional unit, don't get coverage statistics */ 00509 if( (root->funit != NULL) && ((info_suppl.part.assert_ovl == 0) || !ovl_is_assertion_module( root->funit )) ) { 00510 00511 /* Get coverage results for this instance */ 00512 if( report_line ) { 00513 line_get_stats( root->funit, 00514 &(root->stat->line_hit), 00515 &(root->stat->line_excluded), 00516 &(root->stat->line_total) ); 00517 } 00518 00519 if( report_toggle ) { 00520 toggle_get_stats( root->funit, 00521 &(root->stat->tog01_hit), 00522 &(root->stat->tog10_hit), 00523 &(root->stat->tog_excluded), 00524 &(root->stat->tog_total), 00525 &(root->stat->tog_cov_found) ); 00526 } 00527 00528 if( report_combination ) { 00529 combination_get_stats( root->funit, 00530 &(root->stat->comb_hit), 00531 &(root->stat->comb_excluded), 00532 &(root->stat->comb_total) ); 00533 } 00534 00535 if( report_fsm ) { 00536 fsm_get_stats( root->funit->fsm_head, 00537 &(root->stat->state_hit), 00538 &(root->stat->state_total), 00539 &(root->stat->arc_hit), 00540 &(root->stat->arc_total), 00541 &(root->stat->arc_excluded) ); 00542 } 00543 00544 if( report_assertion ) { 00545 assertion_get_stats( root->funit, 00546 &(root->stat->assert_hit), 00547 &(root->stat->assert_excluded), 00548 &(root->stat->assert_total) ); 00549 } 00550 00551 if( report_memory ) { 00552 memory_get_stats( root->funit, 00553 &(root->stat->mem_wr_hit), 00554 &(root->stat->mem_rd_hit), 00555 &(root->stat->mem_ae_total), 00556 &(root->stat->mem_tog01_hit), 00557 &(root->stat->mem_tog10_hit), 00558 &(root->stat->mem_tog_total), 00559 &(root->stat->mem_excluded), 00560 &(root->stat->mem_cov_found) ); 00561 } 00562 00563 /* Only get race condition statistics for this instance module if the module hasn't been gathered yet */ 00564 if( report_race && (root->funit->stat == NULL) ) { 00565 statistic_create( &(root->funit->stat) ); 00566 race_get_stats( root->funit->race_head, 00567 &(root->funit->stat->race_total), 00568 &(root->funit->stat->rtype_total) ); 00569 } 00570 00571 } 00572 00573 /* Set show bit */ 00574 if( flag_suppress_empty_funits ) { 00575 root->stat->show = !statistic_is_empty( root->stat ); 00576 } 00577 00578 PROFILE_END; 00579 00580 }
static void report_generate | ( | FILE * | ofile | ) | [static] |
anonymous | combination_report |
Generates a coverage report based on the options specified on the command line to the specified output stream.
ofile | Pointer to output stream to display report information to |
References assertion_report(), combination_report(), curr_db, fsm_report(), funit_head, inst_link_s::inst, db_s::inst_head, line_report(), memory_report(), inst_link_s::next, PROFILE, PROFILE_END, race_report(), report_assertion, report_comb_depth, report_combination, report_fsm, report_gather_funit_stats(), report_gather_instance_stats(), report_instance, report_line, report_memory, report_print_header(), report_race, REPORT_SUMMARY, report_toggle, and toggle_report().
Referenced by command_report().
00806 { PROFILE(REPORT_GENERATE); 00807 00808 report_print_header( ofile ); 00809 00810 /* Gather statistics first */ 00811 if( report_instance ) { 00812 inst_link* instl = db_list[curr_db]->inst_head; 00813 while( instl != NULL ) { 00814 report_gather_instance_stats( instl->inst ); 00815 instl = instl->next; 00816 } 00817 } else { 00818 report_gather_funit_stats( db_list[curr_db]->funit_head ); 00819 } 00820 00821 /* Call out the proper reports for the specified metrics to report */ 00822 if( report_line ) { 00823 line_report( ofile, (report_comb_depth != REPORT_SUMMARY) ); 00824 } 00825 00826 if( report_toggle ) { 00827 toggle_report( ofile, (report_comb_depth != REPORT_SUMMARY) ); 00828 } 00829 00830 if( report_memory ) { 00831 memory_report( ofile, (report_comb_depth != REPORT_SUMMARY) ); 00832 } 00833 00834 if( report_combination ) { 00835 combination_report( ofile, (report_comb_depth != REPORT_SUMMARY) ); 00836 } 00837 00838 if( report_fsm ) { 00839 fsm_report( ofile, (report_comb_depth != REPORT_SUMMARY) ); 00840 } 00841 00842 if( report_assertion ) { 00843 assertion_report( ofile, (report_comb_depth != REPORT_SUMMARY) ); 00844 } 00845 00846 if( report_race ) { 00847 race_report( ofile, (report_comb_depth != REPORT_SUMMARY) ); 00848 } 00849 00850 PROFILE_END; 00851 00852 }
void report_output_exclusion_reason | ( | FILE * | ofile, | |
int | leading_spaces, | |||
const char * | msg, | |||
bool | header | |||
) |
Outputs the given exclusion reason to the given output stream.
Outputs the given exclude report message to the specified output stream, handling the appropriate formatting.
ofile | Output file stream | |
leading_spaces | Number of leading spaces (for formatting purposes) | |
msg | Message to display (no newlines and only one space between each word) | |
header | If set to TRUE, display a header before outputting; otherwise, avoid the header |
References free_safe, gen_char_string(), line_width, malloc_safe, PROFILE, PROFILE_END, and strdup_safe.
Referenced by combination_list_missed(), exclude_print_exclusion(), exclude_resolve_reason(), fsm_display_arc_verbose(), line_display_verbose(), memory_display_verbose(), ovl_display_verbose(), report_print_header(), and toggle_display_verbose().
01017 { PROFILE(REPORT_OUTPUT_EXCLUSION_REASON); 01018 01019 char* msg_cpy; 01020 char* msg_tcpy; 01021 char* lead_sp; 01022 int curr_width; 01023 char* word; 01024 01025 /* Copy the message */ 01026 msg_cpy = strdup_safe( msg ); 01027 msg_tcpy = msg_cpy; 01028 01029 /* Allocate and populate the leading spaces string */ 01030 lead_sp = (char*)malloc_safe( leading_spaces + 1 ); 01031 gen_char_string( lead_sp, ' ', leading_spaces ); 01032 01033 /* Output message */ 01034 if( header ) { 01035 fprintf( ofile, "\n%sReason: ", lead_sp ); 01036 } else { 01037 fprintf( ofile, "\n%s", lead_sp ); 01038 } 01039 01040 curr_width = leading_spaces + 9; 01041 word = msg_cpy; 01042 while( *msg_cpy != '\0' ) { 01043 /* Get the next token */ 01044 while( (*msg_cpy != '\0') && (*msg_cpy != ' ') ) msg_cpy++; 01045 if( *msg_cpy == ' ' ) { 01046 *msg_cpy = '\0'; 01047 msg_cpy++; 01048 } 01049 if( (strlen( word ) + curr_width) > line_width ) { 01050 if( header ) { 01051 fprintf( ofile, "\n%s ", lead_sp ); 01052 } else { 01053 fprintf( ofile, "\n%s", lead_sp ); 01054 } 01055 curr_width = leading_spaces + 9; 01056 } 01057 fprintf( ofile, "%s ", word ); 01058 if( word[strlen(word)-1] == '.' ) { 01059 fprintf( ofile, " " ); 01060 } 01061 curr_width += strlen( word ) + 1; 01062 word = msg_cpy; 01063 } 01064 fprintf( ofile, "\n\n" ); 01065 01066 /* Deallocate memory */ 01067 free_safe( msg_tcpy, (strlen( msg ) + 1) ); 01068 free_safe( lead_sp, (strlen( lead_sp ) + 1) ); 01069 01070 PROFILE_END; 01071 01072 }
bool report_parse_args | ( | int | argc, | |
int | last_arg, | |||
const char ** | argv | |||
) |
Parses arguments on report command command-line.
anonymous | Throw Throw Throw Throw Throw Throw Throw Throw |
Parses the argument list for options. If a legal option is found for the report command, the appropriate action is taken for that option. If an option is found that is not allowed, an error message is reported to the user and the program terminates immediately.
argc | Number of arguments in argument list argv | |
last_arg | Index of last parsed argument from list | |
argv | Argument list passed to this program |
References Catch_anonymous, check_option_value(), DEFAULT_LINE_WIDTH, FALSE, FATAL, file_exists(), flag_output_exclusion_ids, flag_suppress_empty_funits, flag_use_line_width, free_safe, input_db, is_legal_filename(), line_width, output_file, print_output(), PROFILE, PROFILE_END, read_command_file(), report_assertion, report_bitwise, report_comb_depth, report_covered, REPORT_DETAILED, report_exclusions, report_gui, report_instance, report_memory, report_parse_args(), report_parse_metrics(), REPORT_SUMMARY, report_usage(), REPORT_VERBOSE, strdup_safe, Throw, TRUE, Try, user_msg, USER_MSG_LENGTH, and WARNING.
Referenced by command_report(), and report_parse_args().
00302 { PROFILE(REPORT_PARSE_ARGS); 00303 00304 int i; /* Loop iterator */ 00305 bool help_found = FALSE; 00306 00307 i = last_arg + 1; 00308 00309 while( (i < argc) && !help_found ) { 00310 00311 if( strncmp( "-h", argv[i], 2 ) == 0 ) { 00312 00313 report_usage(); 00314 help_found = TRUE; 00315 00316 } else if( strncmp( "-m", argv[i], 2 ) == 0 ) { 00317 00318 if( check_option_value( argc, argv, i ) ) { 00319 i++; 00320 report_parse_metrics( argv[i] ); 00321 } else { 00322 Throw 0; 00323 } 00324 00325 } else if( strncmp( "-view", argv[i], 5 ) == 0 ) { 00326 00327 #ifdef HAVE_TCLTK 00328 report_gui = TRUE; 00329 report_comb_depth = REPORT_VERBOSE; 00330 report_assertion = TRUE; 00331 report_memory = TRUE; 00332 #else 00333 print_output( "The -view option is not available with this build", FATAL, __FILE__, __LINE__ ); 00334 Throw 0; 00335 #endif 00336 00337 } else if( strncmp( "-i", argv[i], 2 ) == 0 ) { 00338 00339 report_instance = TRUE; 00340 00341 } else if( strncmp( "-c", argv[i], 2 ) == 0 ) { 00342 00343 report_covered = TRUE; 00344 00345 } else if( strncmp( "-e", argv[i], 2 ) == 0 ) { 00346 00347 report_exclusions = TRUE; 00348 00349 } else if( strncmp( "-d", argv[i], 2 ) == 0 ) { 00350 00351 if( check_option_value( argc, argv, i ) ) { 00352 i++; 00353 if( argv[i][0] == 's' ) { 00354 report_comb_depth = REPORT_SUMMARY; 00355 } else if( argv[i][0] == 'd' ) { 00356 report_comb_depth = REPORT_DETAILED; 00357 } else if( argv[i][0] == 'v' ) { 00358 report_comb_depth = REPORT_VERBOSE; 00359 } else { 00360 unsigned int rv = snprintf( user_msg, USER_MSG_LENGTH, "Unrecognized detail type: -d %s", argv[i] ); 00361 assert( rv < USER_MSG_LENGTH ); 00362 print_output( user_msg, FATAL, __FILE__, __LINE__ ); 00363 Throw 0; 00364 } 00365 } else { 00366 Throw 0; 00367 } 00368 00369 } else if( strncmp( "-o", argv[i], 2 ) == 0 ) { 00370 00371 if( check_option_value( argc, argv, i ) ) { 00372 i++; 00373 if( output_file != NULL ) { 00374 print_output( "Only one -o option is allowed on the report command-line. Using first value...", WARNING, __FILE__, __LINE__ ); 00375 } else { 00376 if( is_legal_filename( argv[i] ) ) { 00377 output_file = strdup_safe( argv[i] ); 00378 } else { 00379 unsigned int rv = snprintf( user_msg, USER_MSG_LENGTH, "Output file \"%s\" is unwritable", argv[i] ); 00380 assert( rv < USER_MSG_LENGTH ); 00381 print_output( user_msg, FATAL, __FILE__, __LINE__ ); 00382 Throw 0; 00383 } 00384 } 00385 } else { 00386 Throw 0; 00387 } 00388 00389 } else if( strncmp( "-w", argv[i], 2 ) == 0 ) { 00390 00391 flag_use_line_width = TRUE; 00392 00393 /* Check to see if user specified a line width value */ 00394 if( ((i+1) < argc) && (sscanf( argv[i+1], "%d", &line_width ) == 1) ) { 00395 i++; 00396 } else { 00397 line_width = DEFAULT_LINE_WIDTH; 00398 } 00399 00400 } else if( strncmp( "-s", argv[i], 2 ) == 0 ) { 00401 00402 flag_suppress_empty_funits = TRUE; 00403 00404 } else if( strncmp( "-b", argv[i], 2 ) == 0 ) { 00405 00406 report_bitwise = TRUE; 00407 00408 } else if( strncmp( "-f", argv[i], 2 ) == 0 ) { 00409 00410 if( check_option_value( argc, argv, i ) ) { 00411 char** arg_list = NULL; 00412 int arg_num = 0; 00413 unsigned int j; 00414 i++; 00415 Try { 00416 read_command_file( argv[i], &arg_list, &arg_num ); 00417 help_found = report_parse_args( arg_num, -1, (const char**)arg_list ); 00418 } Catch_anonymous { 00419 for( j=0; j<arg_num; j++ ) { 00420 free_safe( arg_list[j], (strlen( arg_list[j] ) + 1) ); 00421 } 00422 free_safe( arg_list, (sizeof( char* ) * arg_num) ); 00423 Throw 0; 00424 } 00425 for( j=0; j<arg_num; j++ ) { 00426 free_safe( arg_list[j], (strlen( arg_list[j] ) + 1) ); 00427 } 00428 free_safe( arg_list, (sizeof( char* ) * arg_num) ); 00429 } else { 00430 Throw 0; 00431 } 00432 00433 } else if( strncmp( "-x", argv[i], 2 ) == 0 ) { 00434 00435 flag_output_exclusion_ids = TRUE; 00436 00437 } else if( (i + 1) == argc ) { 00438 00439 if( file_exists( argv[i] ) ) { 00440 00441 input_db = strdup_safe( argv[i] ); 00442 00443 } else { 00444 00445 unsigned int rv = snprintf( user_msg, USER_MSG_LENGTH, "Cannot find %s database file for opening", argv[i] ); 00446 assert( rv < USER_MSG_LENGTH ); 00447 print_output( user_msg, FATAL, __FILE__, __LINE__ ); 00448 Throw 0; 00449 00450 } 00451 00452 } else { 00453 00454 unsigned int rv = snprintf( user_msg, USER_MSG_LENGTH, "Unknown report command option \"%s\". See \"covered -h\" for more information.", argv[i] ); 00455 assert( rv < USER_MSG_LENGTH ); 00456 print_output( user_msg, FATAL, __FILE__, __LINE__ ); 00457 Throw 0; 00458 00459 } 00460 00461 i++; 00462 00463 } 00464 00465 if( !help_found ) { 00466 00467 /* 00468 If the user has specified the -x and -c (but not -e), we are not going to be outputting exclusion IDs 00469 because covered items cannot be excluded. So... we will set flag_output_exclusion_ids to false and 00470 output a warning message. 00471 */ 00472 if( flag_output_exclusion_ids && report_covered && !report_exclusions ) { 00473 flag_output_exclusion_ids = FALSE; 00474 print_output( "The -x and -c options were specified. Covered items cannot be excluded so no exclusion IDs will be output.", WARNING, __FILE__, __LINE__ ); 00475 } 00476 00477 } 00478 00479 PROFILE_END; 00480 00481 return( help_found ); 00482 00483 }
static void report_parse_metrics | ( | const char * | metrics | ) | [static] |
Parses the specified string containing the metrics to test. If a legal metric character is found, its corresponding flag is set to TRUE. If a character is found that does not correspond to a metric, an error message is flagged to the user (a warning).
metrics | Specified metrics to calculate coverage for |
References FALSE, print_output(), PROFILE, PROFILE_END, report_assertion, report_combination, report_fsm, report_line, report_memory, report_race, report_toggle, TRUE, user_msg, USER_MSG_LENGTH, and WARNING.
Referenced by report_parse_args().
00243 { PROFILE(REPORT_PARSE_METRICS); 00244 00245 const char* ptr; /* Pointer to current character being evaluated */ 00246 00247 /* Set all flags to FALSE */ 00248 report_line = FALSE; 00249 report_toggle = FALSE; 00250 report_combination = FALSE; 00251 report_fsm = FALSE; 00252 report_race = FALSE; 00253 report_assertion = FALSE; 00254 report_memory = FALSE; 00255 00256 for( ptr=metrics; ptr<(metrics + strlen( metrics )); ptr++ ) { 00257 00258 switch( *ptr ) { 00259 case 'l' : 00260 case 'L' : report_line = TRUE; break; 00261 case 't' : 00262 case 'T' : report_toggle = TRUE; break; 00263 case 'c' : 00264 case 'C' : report_combination = TRUE; break; 00265 case 'f' : 00266 case 'F' : report_fsm = TRUE; break; 00267 case 'r' : 00268 case 'R' : report_race = TRUE; break; 00269 case 'a' : 00270 case 'A' : report_assertion = TRUE; break; 00271 case 'm' : 00272 case 'M' : report_memory = TRUE; break; 00273 default : 00274 { 00275 unsigned int rv = snprintf( user_msg, USER_MSG_LENGTH, "Unknown metric specified '%c'... Ignoring.", *ptr ); 00276 assert( rv < USER_MSG_LENGTH ); 00277 print_output( user_msg, WARNING, __FILE__, __LINE__ ); 00278 } 00279 break; 00280 } 00281 00282 } 00283 00284 PROFILE_END; 00285 00286 }
void report_print_header | ( | FILE * | ofile | ) |
Prints header of report.
Generates generic report header for all reports.
ofile | Pointer to output stream to display report information to |
References cdd_message, curr_db, isuppl_u::excl_always, isuppl_u::excl_assign, isuppl_u::excl_final, isuppl_u::excl_init, isuppl_u::excl_pragma, FALSE, flag_output_exclusion_ids, free_safe, get_relative_path(), input_db, str_link_s::next, isuppl_u::part, PROFILE, PROFILE_END, report_comb_depth, REPORT_DETAILED, report_instance, report_output_exclusion_reason(), REPORT_SUMMARY, REPORT_VERBOSE, and str_link_s::str.
Referenced by report_generate().
00675 { PROFILE(REPORT_PRINT_HEADER); 00676 00677 int i; /* Loop iterator */ 00678 00679 switch( report_comb_depth ) { 00680 case REPORT_SUMMARY : 00681 fprintf( ofile, " :::::::::::::::::::::::::::::::::::::::::::::::::::::\n" ); 00682 fprintf( ofile, " :: ::\n" ); 00683 fprintf( ofile, " :: Covered -- Verilog Coverage Summarized Report ::\n" ); 00684 fprintf( ofile, " :: ::\n" ); 00685 fprintf( ofile, " :::::::::::::::::::::::::::::::::::::::::::::::::::::\n\n\n" ); 00686 break; 00687 case REPORT_DETAILED : 00688 fprintf( ofile, " :::::::::::::::::::::::::::::::::::::::::::::::::::\n" ); 00689 fprintf( ofile, " :: ::\n" ); 00690 fprintf( ofile, " :: Covered -- Verilog Coverage Detailed Report ::\n" ); 00691 fprintf( ofile, " :: ::\n" ); 00692 fprintf( ofile, " :::::::::::::::::::::::::::::::::::::::::::::::::::\n\n\n" ); 00693 break; 00694 case REPORT_VERBOSE : 00695 fprintf( ofile, " ::::::::::::::::::::::::::::::::::::::::::::::::::\n" ); 00696 fprintf( ofile, " :: ::\n" ); 00697 fprintf( ofile, " :: Covered -- Verilog Coverage Verbose Report ::\n" ); 00698 fprintf( ofile, " :: ::\n" ); 00699 fprintf( ofile, " ::::::::::::::::::::::::::::::::::::::::::::::::::\n\n\n" ); 00700 break; 00701 default : break; 00702 } 00703 00704 fprintf( ofile, "~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n" ); 00705 fprintf( ofile, "~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ GENERAL INFORMATION ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n" ); 00706 fprintf( ofile, "~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n" ); 00707 00708 fprintf( ofile, "* Report generated from CDD file : %s\n\n", input_db ); 00709 00710 /* If the CDD contains a user-supplied message output it here, formatting it as needed. */ 00711 if( cdd_message != NULL ) { 00712 fprintf( ofile, "* User-supplied CDD message :\n" ); 00713 report_output_exclusion_reason( ofile, 4, cdd_message, FALSE ); 00714 } 00715 00716 if( report_instance ) { 00717 fprintf( ofile, "* Reported by : Instance\n\n" ); 00718 } else { 00719 fprintf( ofile, "* Reported by : Module\n\n" ); 00720 } 00721 00722 if( flag_output_exclusion_ids ) { 00723 fprintf( ofile, "* Report contains exclusion IDs (value within parenthesis preceding verbose output)\n\n" ); 00724 } 00725 00726 if( (info_suppl.part.excl_assign == 1) || 00727 (info_suppl.part.excl_always == 1) || 00728 (info_suppl.part.excl_init == 1) || 00729 (info_suppl.part.excl_final == 1) || 00730 (info_suppl.part.excl_pragma == 1) ) { 00731 fprintf( ofile, "* CDD file excludes the following block types:\n" ); 00732 if( info_suppl.part.excl_assign == 1 ) { 00733 fprintf( ofile, " assign - Continuous Assignments\n" ); 00734 } 00735 if( info_suppl.part.excl_always == 1 ) { 00736 fprintf( ofile, " always - Always Statements\n" ); 00737 } 00738 if( info_suppl.part.excl_init == 1 ) { 00739 fprintf( ofile, " initial - Initial Statements\n" ); 00740 } 00741 if( info_suppl.part.excl_final == 1 ) { 00742 fprintf( ofile, " final - Final Statements\n" ); 00743 } 00744 if( info_suppl.part.excl_pragma == 1 ) { 00745 fprintf( ofile, " pragma - Code surrounded by coverage off/on pragmas\n" ); 00746 } 00747 fprintf( ofile, "\n" ); 00748 } 00749 00750 if( merge_in_head != NULL ) { 00751 00752 if( merge_in_head == merge_in_tail ) { 00753 00754 char* file; 00755 00756 fprintf( ofile, "* Report generated from CDD file that was merged from the following files with the following leading hierarchies:\n" ); 00757 fprintf( ofile, " Filename Leading Hierarchy\n" ); 00758 fprintf( ofile, " -----------------------------------------------------------------------------------------------------------------\n" ); 00759 fprintf( ofile, " %-49.49s %-62.62s\n", input_db, db_list[curr_db]->leading_hierarchies[0] ); 00760 file = get_relative_path( merge_in_head->str ); 00761 fprintf( ofile, " %-49.49s %-62.62s\n", file, db_list[curr_db]->leading_hierarchies[1] ); 00762 free_safe( file, (strlen( file ) + 1) ); 00763 00764 if( report_instance && db_list[curr_db]->leading_hiers_differ ) { 00765 fprintf( ofile, "\n* Merged CDD files contain different leading hierarchies, will use value \"<NA>\" to represent leading hierarchy.\n\n" ); 00766 } 00767 00768 } else { 00769 00770 str_link* strl = merge_in_head; 00771 00772 fprintf( ofile, "* Report generated from CDD file that was merged from the following files:\n" ); 00773 fprintf( ofile, " Filename Leading Hierarchy\n" ); 00774 fprintf( ofile, " -----------------------------------------------------------------------------------------------------------------\n" ); 00775 00776 i = 1; 00777 while( strl != NULL ) { 00778 char* file = get_relative_path( strl->str ); 00779 fprintf( ofile, " %-49.49s %-62.62s\n", file, db_list[curr_db]->leading_hierarchies[i++] ); 00780 free_safe( file, (strlen( file ) + 1) ); 00781 strl = strl->next; 00782 } 00783 00784 if( report_instance && db_list[curr_db]->leading_hiers_differ ) { 00785 fprintf( ofile, "\n* Merged CDD files contain different leading hierarchies, will use value \"<NA>\" to represent leading hierarchy.\n\n" ); 00786 } 00787 00788 } 00789 00790 fprintf( ofile, "\n" ); 00791 00792 } 00793 00794 PROFILE_END; 00795 00796 }
void report_read_cdd_and_ready | ( | const char * | ifile | ) |
Reads the CDD and readies the design for reporting.
anonymous | db_read Throw bind_perform |
Reads in specified CDD file and gathers functional unit statistics to get ready for GUI interaction with this CDD file.
ifile | Name of CDD file to read from |
References bind_perform(), curr_db, db_read(), db_size, FATAL, funit_head, inst_link_s::inst, db_s::inst_head, inst_link_s::next, print_output(), PROFILE, PROFILE_END, READ_MODE_MERGE_INST_MERGE, READ_MODE_REPORT_MOD_MERGE, READ_MODE_REPORT_NO_MERGE, report_gather_funit_stats(), report_gather_instance_stats(), Throw, and TRUE.
00864 { PROFILE(REPORT_READ_CDD_AND_READY); 00865 00866 /* Open database file for reading */ 00867 if( (ifile == NULL) || (ifile[0] == '\0') ) { 00868 00869 print_output( "CDD file name was not specified for reading", FATAL, __FILE__, __LINE__ ); 00870 Throw 0; 00871 00872 } else { 00873 00874 inst_link* instl; 00875 bool first = (db_size == 0); 00876 00877 /* Read in database, performing instance merging */ 00878 curr_db = 0; 00879 (void)db_read( ifile, (first ? READ_MODE_REPORT_NO_MERGE : READ_MODE_MERGE_INST_MERGE) ); 00880 bind_perform( TRUE, 0 ); 00881 00882 /* Gather instance statistics */ 00883 instl = db_list[0]->inst_head; 00884 while( instl != NULL ) { 00885 report_gather_instance_stats( instl->inst ); 00886 instl = instl->next; 00887 } 00888 00889 /* Read in database again, performing module merging */ 00890 curr_db = 1; 00891 (void)db_read( ifile, READ_MODE_REPORT_MOD_MERGE ); 00892 bind_perform( TRUE, 0 ); 00893 00894 /* Now merge functional units and gather module statistics */ 00895 report_gather_funit_stats( db_list[1]->funit_head ); 00896 00897 /* Set the current database back to 0 */ 00898 curr_db = 0; 00899 00900 } 00901 00902 PROFILE_END; 00903 00904 }
void report_save_cdd | ( | const char * | filename | ) |
Saves the currently loaded CDD as the specified filename.
anonymous | db_write |
Saves the currently loaded CDD database to the given filename.
filename | Name to use for saving the currently loaded filename |
References curr_db, db_write(), FALSE, PROFILE, and PROFILE_END.
static void report_usage | ( | ) | [static] |
Displays usage information about the report command.
References DEFAULT_LINE_WIDTH.
Referenced by report_parse_args().
00194 { 00195 00196 printf( "\n" ); 00197 #ifdef HAVE_TCLTK 00198 printf( "Usage: covered report (-h | -view [<database_file>] | [<options>] <database_file>)\n" ); 00199 printf( "\n" ); 00200 printf( " -view Uses the graphical report viewer for viewing reports. If this\n" ); 00201 printf( " option is not specified, the text report will be generated.\n" ); 00202 #else 00203 printf( "Usage: covered report (-h | [<options>] <database_file>)\n" ); 00204 printf( "\n" ); 00205 #endif 00206 printf( " -h Displays this help information.\n" ); 00207 printf( "\n" ); 00208 printf( " Options:\n" ); 00209 printf( " -m [l][t][c][f][r][a][m] Type(s) of metrics to report. l=line, t=toggle, c=combinational logic,\n" ); 00210 printf( " f=FSM state/arc, r=race condition, a=assertion, m=memory. Default is ltcf.\n" ); 00211 printf( " -d (s|d|v) Level of report detail (s=summary, d=detailed, v=verbose).\n" ); 00212 printf( " Default is to display summary coverage information.\n" ); 00213 printf( " -i Provides coverage information for instances instead of module/task/function.\n" ); 00214 printf( " -c If '-d d' or '-d v' is specified, displays covered coverage points.\n" ); 00215 printf( " Default is to display uncovered results.\n" ); 00216 printf( " -e If '-d d' or '-d v' is specified, displays excluded coverage points.\n" ); 00217 printf( " Default is to not display excluded coverage points.\n" ); 00218 printf( " -o <filename> File to output report information to. Default is standard output.\n" ); 00219 printf( " -w [<line_width>] Causes expressions to be output to best-fit to the specified line\n" ); 00220 printf( " width. If the -w option is specified without a value, the default\n" ); 00221 printf( " line width of %d is used. If the -w option is not specified, all\n", DEFAULT_LINE_WIDTH ); 00222 printf( " expressions are output in the format that the user specified in the\n" ); 00223 printf( " Verilog source.\n" ); 00224 printf( " -s Suppress outputting modules/instances that do not contain any coverage metrics.\n" ); 00225 printf( " -b If combinational logic verbose output is reported and the expression is a\n" ); 00226 printf( " vector operation, this option outputs the coverage information on a bitwise basis.\n" ); 00227 printf( " -f <filename> Name of file containing additional arguments to parse.\n" ); 00228 printf( " -x Output exclusion identifiers if the '-d d' or '-d v' options are specified. The\n" ); 00229 printf( " identifiers can be used with the 'exclude' command for the purposes of\n" ); 00230 printf( " excluding/including coverage points.\n" ); 00231 printf( "\n" ); 00232 00233 }
char* cdd_message |
User-supplied message to include in the CDD database
unsigned int curr_db |
Index of current database in db_list array that is being handled.
unsigned int db_size |
Size of the db_list array.
bool flag_output_exclusion_ids = FALSE |
Outputs the exclusion ID for an output coverage point. The exclusion ID can be used by the exclude command for excluding/including coverage points.
bool flag_suppress_empty_funits = FALSE |
Suppresses functional units that do not contain any coverage information from being output to the report file.
Referenced by report_gather_funit_stats(), report_gather_instance_stats(), and report_parse_args().
bool flag_use_line_width = FALSE |
If set to a boolean value of TRUE, displays combination logic output in a by-line-width format (instead of the user specified Verilog source format).
Informational line for the CDD file.
char* input_db = NULL [static] |
Name of input CDD file to read for generating coverage report. This value must be specified to a value other than NULL for the report phase to complete properly.
Referenced by command_report(), report_parse_args(), and report_print_header().
int line_width = DEFAULT_LINE_WIDTH |
Specifies the number of characters wide that an expression will allowed to be output for if the flag_use_line_width value is set to TRUE.
Pointer to head of list containing names of the input CDD files.
Pointer to tail of list containing names of the input CDD files.
char* output_file = NULL |
Name of output file to write report contents to. If output_file is NULL, the report will be written to standard output.
Referenced by command_report(), and report_parse_args().
bool report_assertion = FALSE |
If set to a boolean value of TRUE, reports the assertion coverage for the specified database file; otherwise, omits assertion coverage from the report output.
Referenced by command_rank(), report_gather_funit_stats(), report_gather_instance_stats(), report_generate(), report_parse_args(), and report_parse_metrics().
bool report_bitwise = FALSE |
If set to a boolean value of TRUE, displays all vector combinational logic on a bitwise basis.
Referenced by combination_get_tree_stats(), combination_two_vars(), combination_unary(), and report_parse_args().
unsigned int report_comb_depth = REPORT_SUMMARY |
If set to a non-zero value, causes Covered to only generate combinational logic report information for depths up to the number specified.
Referenced by combination_calc_depth(), combination_get_missed_expr(), combination_get_tree_stats(), combination_output_expr(), combination_underline_tree(), report_generate(), report_parse_args(), and report_print_header().
bool report_combination = TRUE |
If set to a boolean value of TRUE, reports the combinational logic coverage for the specified database file; otherwise, omits combinational logic coverage from the report output.
Referenced by command_rank(), report_gather_funit_stats(), report_gather_instance_stats(), report_generate(), and report_parse_metrics().
bool report_covered = FALSE |
If set to a boolean value of TRUE, displays covered logic for a particular CDD file. By default, Covered will display uncovered logic. Must be used in conjunction with the -d v|d (verbose output) option.
bool report_exclusions = FALSE |
If set to a boolean value of TRUE, displays excluded coverage points for a particular CDD file. By default, Covered will not display excluded coverage points. This can be useful when used in conjunction with the -x option for including excluded coverage points. Must be used in conjunction with the -d v|d (verbose output) option.
bool report_fsm = TRUE |
If set to a boolean value of TRUE, reports the finite state machine coverage for the specified database file; otherwise, omits finite state machine coverage from the report output.
Referenced by command_rank(), report_gather_funit_stats(), report_gather_instance_stats(), report_generate(), and report_parse_metrics().
bool report_gui = FALSE [static] |
If set to a boolean value of TRUE, displays GUI report viewer instead of generating text report files.
Referenced by command_report(), and report_parse_args().
bool report_instance = FALSE |
If set to a boolean value of TRUE, provides a coverage information for individual functional unit instances. If set to a value of FALSE, reports coverage information on a functional unit basis, merging results from all instances of same functional unit.
bool report_line = TRUE |
If set to a boolean value of TRUE, reports the line coverage for the specified database file; otherwise, omits line coverage from the report output.
Referenced by command_rank(), report_gather_funit_stats(), report_gather_instance_stats(), report_generate(), and report_parse_metrics().
bool report_memory = FALSE |
If set to a boolean value of TRUE, reports the memory coverage for the specified database file; otherwise, omits memory coverage from the report output.
Referenced by command_rank(), report_gather_funit_stats(), report_gather_instance_stats(), report_generate(), report_parse_args(), and report_parse_metrics().
bool report_race = FALSE |
If set to a boolean value of TRUE, reports the race condition violations for the specified database file; otherwise, omits this information from the report output.
Referenced by report_gather_funit_stats(), report_gather_instance_stats(), report_generate(), and report_parse_metrics().
bool report_toggle = TRUE |
If set to a boolean value of TRUE, reports the toggle coverage for the specified database file; otherwise, omits toggle coverage from the report output.
Referenced by command_rank(), report_gather_funit_stats(), report_gather_instance_stats(), report_generate(), and report_parse_metrics().
char user_msg[USER_MSG_LENGTH] |
Holds some output that will be displayed via the print_output command. This is created globally so that memory does not need to be reallocated for each function that wishes to use it.