LCOV - code coverage report
Current view: top level - gcc - tree-ssa-loop.h Coverage Total Hit
Test: gcc.info Lines: 100.0 % 5 5
Test Date: 2026-02-28 14:20:25 Functions: - 0 0
Legend: Lines:     hit not hit

            Line data    Source code
       1              : /* Header file for SSA loop optimizations.
       2              :    Copyright (C) 2013-2026 Free Software Foundation, Inc.
       3              : 
       4              : This file is part of GCC.
       5              : 
       6              : GCC is free software; you can redistribute it and/or modify it under
       7              : the terms of the GNU General Public License as published by the Free
       8              : Software Foundation; either version 3, or (at your option) any later
       9              : version.
      10              : 
      11              : GCC is distributed in the hope that it will be useful, but WITHOUT ANY
      12              : WARRANTY; without even the implied warranty of MERCHANTABILITY or
      13              : FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
      14              :  for more details.
      15              : 
      16              : You should have received a copy of the GNU General Public License
      17              : along with GCC; see the file COPYING3.  If not see
      18              : <http://www.gnu.org/licenses/>.  */
      19              : 
      20              : #ifndef GCC_TREE_SSA_LOOP_H
      21              : #define GCC_TREE_SSA_LOOP_H
      22              : 
      23              : 
      24              : /* Affine iv.  */
      25              : 
      26              : struct affine_iv
      27              : {
      28              :   /* Iv = BASE + STEP * i.  */
      29              :   tree base, step;
      30              : 
      31              :   /* True if this iv does not overflow.  */
      32              :   bool no_overflow;
      33              : };
      34              : 
      35              : /* Description of number of iterations of a loop.  All the expressions inside
      36              :    the structure can be evaluated at the end of the loop's preheader
      37              :    (and due to ssa form, also anywhere inside the body of the loop).  */
      38              : 
      39     62684974 : class tree_niter_desc
      40              : {
      41              : public:
      42              :   tree assumptions;     /* The boolean expression.  If this expression evaluates
      43              :                            to false, then the other fields in this structure
      44              :                            should not be used; there is no guarantee that they
      45              :                            will be correct.  */
      46              :   tree may_be_zero;     /* The boolean expression.  If it evaluates to true,
      47              :                            the loop will exit in the first iteration (i.e.
      48              :                            its latch will not be executed), even if the niter
      49              :                            field says otherwise.  */
      50              :   tree niter;           /* The expression giving the number of iterations of
      51              :                            a loop (provided that assumptions == true and
      52              :                            may_be_zero == false), more precisely the number
      53              :                            of executions of the latch of the loop.  */
      54              :   widest_int max;       /* The upper bound on the number of iterations of
      55              :                            the loop.  If niter is constant, then these values
      56              :                            must agree.  */
      57              : 
      58              :   /* The simplified shape of the exit condition.  This information is used by
      59              :      loop unrolling.  If CMP is ERROR_MARK, then the loop cannot be unrolled.
      60              :      Otherwise, the loop exits if CONTROL CMP BOUND is false, where CMP is one
      61              :      of NE_EXPR, LT_EXPR, or GT_EXPR, and CONTROL.STEP is positive if CMP is
      62              :      LT_EXPR and negative if CMP is GT_EXPR.  */
      63              :   affine_iv control;
      64              :   tree bound;
      65              :   enum tree_code cmp;
      66              : };
      67              : 
      68              : extern bool for_each_index (tree *, bool (*) (tree, tree *, void *), void *);
      69              : extern char *get_lsm_tmp_name (tree ref, unsigned n, const char *suffix = NULL);
      70              : extern unsigned tree_num_loop_insns (class loop *, struct eni_weights *);
      71              : 
      72              : /* Returns the loop of the statement STMT.  */
      73              : 
      74              : inline class loop *
      75    276653615 : loop_containing_stmt (gimple *stmt)
      76              : {
      77    281460233 :   basic_block bb = gimple_bb (stmt);
      78    276653615 :   if (!bb)
      79              :     return NULL;
      80              : 
      81    276483815 :   return bb->loop_father;
      82              : }
      83              : 
      84              : #endif /* GCC_TREE_SSA_LOOP_H */
        

Generated by: LCOV version 2.4-beta

LCOV profile is generated on x86_64 machine using following configure options: configure --disable-bootstrap --enable-coverage=opt --enable-languages=c,c++,fortran,go,jit,lto,rust,m2 --enable-host-shared. GCC test suite is run with the built compiler.