X-Git-Url: https://oss.titaniummirror.com/gitweb?a=blobdiff_plain;f=gcc%2Fprofile.h;fp=gcc%2Fprofile.h;h=fe3c2f997b710390d1d2e529050751670165ce11;hb=6fed43773c9b0ce596dca5686f37ac3fc0fa11c0;hp=0000000000000000000000000000000000000000;hpb=27b11d56b743098deb193d510b337ba22dc52e5c;p=msp430-gcc.git diff --git a/gcc/profile.h b/gcc/profile.h new file mode 100644 index 00000000..fe3c2f99 --- /dev/null +++ b/gcc/profile.h @@ -0,0 +1,47 @@ +/* Header file for minimum-cost maximal flow routines used to smooth basic + block and edge frequency counts. + Copyright (C) 2008 + Free Software Foundation, Inc. + Contributed by Paul Yuan (yingbo.com@gmail.com) + and Vinodha Ramasamy (vinodha@google.com). + +This file is part of GCC. +GCC is free software; you can redistribute it and/or modify it under +the terms of the GNU General Public License as published by the Free +Software Foundation; either version 3, or (at your option) any later +version. + +GCC is distributed in the hope that it will be useful, but WITHOUT ANY +WARRANTY; without even the implied warranty of MERCHANTABILITY or +FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License +for more details. + +You should have received a copy of the GNU General Public License +along with GCC; see the file COPYING3. If not see +. */ + +#ifndef PROFILE_H +#define PROFILE_H + +/* Additional information about edges. */ +struct edge_info +{ + unsigned int count_valid:1; + + /* Is on the spanning tree. */ + unsigned int on_tree:1; + + /* Pretend this edge does not exist (it is abnormal and we've + inserted a fake to compensate). */ + unsigned int ignore:1; +}; + +#define EDGE_INFO(e) ((struct edge_info *) (e)->aux) + +/* Smoothes the initial assigned basic block and edge counts using + a minimum cost flow algorithm. */ +extern void mcf_smooth_cfg (void); + +extern gcov_type sum_edge_counts (VEC (edge, gc) *edges); + +#endif /* PROFILE_H */