OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [gnu-stable/] [gcc-4.5.1/] [gcc/] [graphds.h] - Diff between revs 816 and 826

Go to most recent revision | Only display areas with differences | Details | Blame | View Log

Rev 816 Rev 826
/* Graph representation.
/* Graph representation.
   Copyright (C) 2007, 2008
   Copyright (C) 2007, 2008
   Free Software Foundation, Inc.
   Free Software Foundation, Inc.
 
 
This file is part of GCC.
This file is part of GCC.
 
 
GCC is free software; you can redistribute it and/or modify it under
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
the terms of the GNU General Public License as published by the Free
Software Foundation; either version 3, or (at your option) any later
Software Foundation; either version 3, or (at your option) any later
version.
version.
 
 
GCC is distributed in the hope that it will be useful, but WITHOUT ANY
GCC is distributed in the hope that it will be useful, but WITHOUT ANY
WARRANTY; without even the implied warranty of MERCHANTABILITY or
WARRANTY; without even the implied warranty of MERCHANTABILITY or
FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
for more details.
for more details.
 
 
You should have received a copy of the GNU General Public License
You should have received a copy of the GNU General Public License
along with GCC; see the file COPYING3.  If not see
along with GCC; see the file COPYING3.  If not see
<http://www.gnu.org/licenses/>.  */
<http://www.gnu.org/licenses/>.  */
 
 
/* Structure representing edge of a graph.  */
/* Structure representing edge of a graph.  */
 
 
struct graph_edge
struct graph_edge
{
{
  int src, dest;        /* Source and destination.  */
  int src, dest;        /* Source and destination.  */
  struct graph_edge *pred_next, *succ_next;
  struct graph_edge *pred_next, *succ_next;
                        /* Next edge in predecessor and successor lists.  */
                        /* Next edge in predecessor and successor lists.  */
  void *data;           /* Data attached to the edge.  */
  void *data;           /* Data attached to the edge.  */
};
};
 
 
/* Structure representing vertex of a graph.  */
/* Structure representing vertex of a graph.  */
 
 
struct vertex
struct vertex
{
{
  struct graph_edge *pred, *succ;
  struct graph_edge *pred, *succ;
                        /* Lists of predecessors and successors.  */
                        /* Lists of predecessors and successors.  */
  int component;        /* Number of dfs restarts before reaching the
  int component;        /* Number of dfs restarts before reaching the
                           vertex.  */
                           vertex.  */
  int post;             /* Postorder number.  */
  int post;             /* Postorder number.  */
  void *data;           /* Data attached to the vertex.  */
  void *data;           /* Data attached to the vertex.  */
};
};
 
 
/* Structure representing a graph.  */
/* Structure representing a graph.  */
 
 
struct graph
struct graph
{
{
  int n_vertices;       /* Number of vertices.  */
  int n_vertices;       /* Number of vertices.  */
  struct vertex *vertices;
  struct vertex *vertices;
                        /* The vertices.  */
                        /* The vertices.  */
  htab_t indices;       /* Fast lookup for indices.  */
  htab_t indices;       /* Fast lookup for indices.  */
};
};
 
 
struct graph *new_graph (int);
struct graph *new_graph (int);
void dump_graph (FILE *, struct graph *);
void dump_graph (FILE *, struct graph *);
struct graph_edge *add_edge (struct graph *, int, int);
struct graph_edge *add_edge (struct graph *, int, int);
void identify_vertices (struct graph *, int, int);
void identify_vertices (struct graph *, int, int);
int graphds_dfs (struct graph *, int *, int,
int graphds_dfs (struct graph *, int *, int,
                 VEC (int, heap) **, bool, bitmap);
                 VEC (int, heap) **, bool, bitmap);
int graphds_scc (struct graph *, bitmap);
int graphds_scc (struct graph *, bitmap);
void graphds_domtree (struct graph *, int, int *, int *, int *);
void graphds_domtree (struct graph *, int, int *, int *, int *);
typedef void (*graphds_edge_callback) (struct graph *, struct graph_edge *);
typedef void (*graphds_edge_callback) (struct graph *, struct graph_edge *);
void for_each_edge (struct graph *, graphds_edge_callback);
void for_each_edge (struct graph *, graphds_edge_callback);
void free_graph (struct graph *g);
void free_graph (struct graph *g);
 
 

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.