lists.c (unused_insn_list, [...]): New file for maintaining various types of lists.
Wed Aug 25 13:41:47 EDT 1999 Andrew MacLeod <amacleod@cygnus.com>
* lists.c (unused_insn_list, unused_expr_list): New file for
maintaining various types of lists. New statics for maintaining a
cache of available INSN_LIST and EXPR_LIST nodes.
(free_list): Static function for freeing a list of INSN/EXPR nodes.
(alloc_INSN_LIST): Function to get a free INSN_LIST node.
(alloc_EXPR_LIST): Function to get a free EXPR_LIST node.
(init_EXPR_INSN_LIST_cache): Initialize the cache lists.
(free_EXPR_LIST_list): Free an entire list of EXPR_LIST nodes.
(free_INSN_LIST_list): Free an entire list of INSN_LIST nodes.
(free_EXPR_LIST_node): Free an individual EXPR_LIST node.
(free_INSN_LIST_node): Free an individual INSN_LIST node.
* haifa-sched.c (unused_insn_list, unused_expr_list): Moved to flow.c
(free_list, alloc_INSN_LIST, alloc_EXPR_LIST): Moved to flow.c
(remove_dependence, free_pending_lists): Use new global routines.
(flush_pending_lists, sched_analyze_insn): Use new global routines.
(sched_analyze, compute_block_backward_dependences): Use new routines.
(sched_analyze_1, sched_analyze_2): Use new routines.
(schedule_insns): Use new global routines.
* rtl.h (init_EXPR_INSN_LIST_cache, free_EXPR_LIST_list): Add function
prototypes.
(free_INSN_LIST_list, free_EXPR_LIST_node): Add prototypes.
(free_INSN_LIST_node, alloc_INSN_LIST, alloc_EXPR_LIST): Add function
prototypes.
* toplev.c (rest_of_compilation): Initialize node cache.
* Makefile.in (OBJS): Add lists.o to list of object files.
(lists.o): Add dependancies.
From-SVN: r28864
1999-08-25 13:50:53 -04:00
|
|
|
/* List management for the GNU C-Compiler expander.
|
2000-02-26 08:55:09 -05:00
|
|
|
Copyright (C) 1987, 1988, 1992, 1993, 1994, 1995, 1996, 1997, 1998,
|
|
|
|
1999 Free Software Foundation, Inc.
|
lists.c (unused_insn_list, [...]): New file for maintaining various types of lists.
Wed Aug 25 13:41:47 EDT 1999 Andrew MacLeod <amacleod@cygnus.com>
* lists.c (unused_insn_list, unused_expr_list): New file for
maintaining various types of lists. New statics for maintaining a
cache of available INSN_LIST and EXPR_LIST nodes.
(free_list): Static function for freeing a list of INSN/EXPR nodes.
(alloc_INSN_LIST): Function to get a free INSN_LIST node.
(alloc_EXPR_LIST): Function to get a free EXPR_LIST node.
(init_EXPR_INSN_LIST_cache): Initialize the cache lists.
(free_EXPR_LIST_list): Free an entire list of EXPR_LIST nodes.
(free_INSN_LIST_list): Free an entire list of INSN_LIST nodes.
(free_EXPR_LIST_node): Free an individual EXPR_LIST node.
(free_INSN_LIST_node): Free an individual INSN_LIST node.
* haifa-sched.c (unused_insn_list, unused_expr_list): Moved to flow.c
(free_list, alloc_INSN_LIST, alloc_EXPR_LIST): Moved to flow.c
(remove_dependence, free_pending_lists): Use new global routines.
(flush_pending_lists, sched_analyze_insn): Use new global routines.
(sched_analyze, compute_block_backward_dependences): Use new routines.
(sched_analyze_1, sched_analyze_2): Use new routines.
(schedule_insns): Use new global routines.
* rtl.h (init_EXPR_INSN_LIST_cache, free_EXPR_LIST_list): Add function
prototypes.
(free_INSN_LIST_list, free_EXPR_LIST_node): Add prototypes.
(free_INSN_LIST_node, alloc_INSN_LIST, alloc_EXPR_LIST): Add function
prototypes.
* toplev.c (rest_of_compilation): Initialize node cache.
* Makefile.in (OBJS): Add lists.o to list of object files.
(lists.o): Add dependancies.
From-SVN: r28864
1999-08-25 13:50:53 -04:00
|
|
|
|
|
|
|
This file is part of GNU CC.
|
|
|
|
|
|
|
|
GNU CC 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 2, or (at your option)
|
|
|
|
any later version.
|
|
|
|
|
|
|
|
GNU CC 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 GNU CC; see the file COPYING. If not, write to
|
|
|
|
the Free Software Foundation, 59 Temple Place - Suite 330,
|
|
|
|
Boston, MA 02111-1307, USA. */
|
|
|
|
|
|
|
|
#include "config.h"
|
|
|
|
#include "system.h"
|
|
|
|
#include "toplev.h"
|
|
|
|
#include "rtl.h"
|
1999-09-08 07:46:28 -04:00
|
|
|
#include "ggc.h"
|
lists.c (unused_insn_list, [...]): New file for maintaining various types of lists.
Wed Aug 25 13:41:47 EDT 1999 Andrew MacLeod <amacleod@cygnus.com>
* lists.c (unused_insn_list, unused_expr_list): New file for
maintaining various types of lists. New statics for maintaining a
cache of available INSN_LIST and EXPR_LIST nodes.
(free_list): Static function for freeing a list of INSN/EXPR nodes.
(alloc_INSN_LIST): Function to get a free INSN_LIST node.
(alloc_EXPR_LIST): Function to get a free EXPR_LIST node.
(init_EXPR_INSN_LIST_cache): Initialize the cache lists.
(free_EXPR_LIST_list): Free an entire list of EXPR_LIST nodes.
(free_INSN_LIST_list): Free an entire list of INSN_LIST nodes.
(free_EXPR_LIST_node): Free an individual EXPR_LIST node.
(free_INSN_LIST_node): Free an individual INSN_LIST node.
* haifa-sched.c (unused_insn_list, unused_expr_list): Moved to flow.c
(free_list, alloc_INSN_LIST, alloc_EXPR_LIST): Moved to flow.c
(remove_dependence, free_pending_lists): Use new global routines.
(flush_pending_lists, sched_analyze_insn): Use new global routines.
(sched_analyze, compute_block_backward_dependences): Use new routines.
(sched_analyze_1, sched_analyze_2): Use new routines.
(schedule_insns): Use new global routines.
* rtl.h (init_EXPR_INSN_LIST_cache, free_EXPR_LIST_list): Add function
prototypes.
(free_INSN_LIST_list, free_EXPR_LIST_node): Add prototypes.
(free_INSN_LIST_node, alloc_INSN_LIST, alloc_EXPR_LIST): Add function
prototypes.
* toplev.c (rest_of_compilation): Initialize node cache.
* Makefile.in (OBJS): Add lists.o to list of object files.
(lists.o): Add dependancies.
From-SVN: r28864
1999-08-25 13:50:53 -04:00
|
|
|
|
cpplib.c (if_directive_nameo): Add static prototype.
* cpplib.c (if_directive_nameo): Add static prototype.
* cse.c (cse_insn): Remove unused variable `p'.
* except.c (create_rethrow_ref, push_entry,
receive_exception_label, new_eh_region_entry, find_func_region,
clear_function_eh_region, process_nestinfo): Add static prototypes.
(get_reg_for_handler): Hide definition.
(process_nestinfo): Initialize variable `extra_handlers'.
* expr.h (expand_builtin_longjmp): Add extern prototype.
* final.c (final_addr_vec_align, align_fuzz): Add static prototypes.
* function.c (prepare_function_start): Likewise.
(pop_function_context_from): Mark parameter `context' with
ATTRIBUTE_UNUSED.
(push_temp_slots_for_block, flush_addressof): Hide definition.
* gcov.c (init_arc, reverse_arcs, create_program_flow_graph,
solve_program_flow_graph, calculate_branch_probs,
function_summary, main, fancy_abort): Add prototypes.
* gen-protos.c (add_hash, parse_fn_proto, main): Likewise.
(add_hash): Constify a char*.
* ggc-common.c (ggc_mark_rtx_ptr, ggc_mark_tree_ptr,
ggc_mark_tree_varray_ptr, ggc_mark_tree_hash_table_ptr,
ggc_mark_string_ptr, ggc_mark_tree_hash_table_entry): Add prototypes.
* integrate.c (expand_inline_function_eh_labelmap): Likewise.
* lists.c (free_list, zap_lists): Likewise.
From-SVN: r29783
1999-10-03 12:28:33 -04:00
|
|
|
static void free_list PARAMS ((rtx *, rtx *));
|
|
|
|
static void zap_lists PARAMS ((void *));
|
|
|
|
|
lists.c (unused_insn_list, [...]): New file for maintaining various types of lists.
Wed Aug 25 13:41:47 EDT 1999 Andrew MacLeod <amacleod@cygnus.com>
* lists.c (unused_insn_list, unused_expr_list): New file for
maintaining various types of lists. New statics for maintaining a
cache of available INSN_LIST and EXPR_LIST nodes.
(free_list): Static function for freeing a list of INSN/EXPR nodes.
(alloc_INSN_LIST): Function to get a free INSN_LIST node.
(alloc_EXPR_LIST): Function to get a free EXPR_LIST node.
(init_EXPR_INSN_LIST_cache): Initialize the cache lists.
(free_EXPR_LIST_list): Free an entire list of EXPR_LIST nodes.
(free_INSN_LIST_list): Free an entire list of INSN_LIST nodes.
(free_EXPR_LIST_node): Free an individual EXPR_LIST node.
(free_INSN_LIST_node): Free an individual INSN_LIST node.
* haifa-sched.c (unused_insn_list, unused_expr_list): Moved to flow.c
(free_list, alloc_INSN_LIST, alloc_EXPR_LIST): Moved to flow.c
(remove_dependence, free_pending_lists): Use new global routines.
(flush_pending_lists, sched_analyze_insn): Use new global routines.
(sched_analyze, compute_block_backward_dependences): Use new routines.
(sched_analyze_1, sched_analyze_2): Use new routines.
(schedule_insns): Use new global routines.
* rtl.h (init_EXPR_INSN_LIST_cache, free_EXPR_LIST_list): Add function
prototypes.
(free_INSN_LIST_list, free_EXPR_LIST_node): Add prototypes.
(free_INSN_LIST_node, alloc_INSN_LIST, alloc_EXPR_LIST): Add function
prototypes.
* toplev.c (rest_of_compilation): Initialize node cache.
* Makefile.in (OBJS): Add lists.o to list of object files.
(lists.o): Add dependancies.
From-SVN: r28864
1999-08-25 13:50:53 -04:00
|
|
|
/* Functions for maintaining cache-able lists of EXPR_LIST and INSN_LISTs. */
|
|
|
|
|
|
|
|
/* An INSN_LIST containing all INSN_LISTs allocated but currently unused. */
|
|
|
|
static rtx unused_insn_list;
|
|
|
|
|
|
|
|
/* An EXPR_LIST containing all EXPR_LISTs allocated but currently unused. */
|
|
|
|
static rtx unused_expr_list;
|
|
|
|
|
|
|
|
|
|
|
|
/* This function will free an entire list of either EXPR_LIST or INSN_LIST
|
|
|
|
nodes. This is to be used only only lists that consist exclusively of
|
|
|
|
nodes of one type only. This is only called by free_EXPR_LIST_list
|
|
|
|
and free_INSN_LIST_list. */
|
|
|
|
static void
|
|
|
|
free_list (listp, unused_listp)
|
|
|
|
rtx *listp, *unused_listp;
|
|
|
|
{
|
|
|
|
register rtx link, prev_link;
|
|
|
|
|
|
|
|
prev_link = *listp;
|
|
|
|
link = XEXP (prev_link, 1);
|
|
|
|
|
|
|
|
while (link)
|
|
|
|
{
|
|
|
|
prev_link = link;
|
|
|
|
link = XEXP (link, 1);
|
|
|
|
}
|
|
|
|
|
|
|
|
XEXP (prev_link, 1) = *unused_listp;
|
|
|
|
*unused_listp = *listp;
|
|
|
|
*listp = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* This call is used in place of a gen_rtx_INSN_LIST. If there is a cached
|
|
|
|
node available, we'll use it, otherwise a call to gen_rtx_INSN_LIST
|
|
|
|
is made. */
|
|
|
|
rtx
|
|
|
|
alloc_INSN_LIST (val, next)
|
|
|
|
rtx val, next;
|
|
|
|
{
|
|
|
|
rtx r;
|
|
|
|
|
|
|
|
if (unused_insn_list)
|
|
|
|
{
|
|
|
|
r = unused_insn_list;
|
|
|
|
unused_insn_list = XEXP (r, 1);
|
|
|
|
XEXP (r, 0) = val;
|
|
|
|
XEXP (r, 1) = next;
|
|
|
|
PUT_REG_NOTE_KIND (r, VOIDmode);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
r = gen_rtx_INSN_LIST (VOIDmode, val, next);
|
|
|
|
|
|
|
|
return r;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* This call is used in place of a gen_rtx_EXPR_LIST. If there is a cached
|
|
|
|
node available, we'll use it, otherwise a call to gen_rtx_EXPR_LIST
|
|
|
|
is made. */
|
|
|
|
rtx
|
|
|
|
alloc_EXPR_LIST (kind, val, next)
|
|
|
|
int kind;
|
|
|
|
rtx val, next;
|
|
|
|
{
|
|
|
|
rtx r;
|
|
|
|
|
|
|
|
if (unused_expr_list)
|
|
|
|
{
|
|
|
|
r = unused_expr_list;
|
|
|
|
unused_expr_list = XEXP (r, 1);
|
|
|
|
XEXP (r, 0) = val;
|
|
|
|
XEXP (r, 1) = next;
|
|
|
|
PUT_REG_NOTE_KIND (r, kind);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
r = gen_rtx_EXPR_LIST (kind, val, next);
|
|
|
|
|
|
|
|
return r;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* This function will initialize the EXPR_LIST and INSN_LIST caches. */
|
1999-09-08 07:46:28 -04:00
|
|
|
|
|
|
|
static void
|
|
|
|
zap_lists (dummy)
|
|
|
|
void *dummy ATTRIBUTE_UNUSED;
|
|
|
|
{
|
|
|
|
unused_expr_list = NULL;
|
|
|
|
unused_insn_list = NULL;
|
|
|
|
}
|
|
|
|
|
lists.c (unused_insn_list, [...]): New file for maintaining various types of lists.
Wed Aug 25 13:41:47 EDT 1999 Andrew MacLeod <amacleod@cygnus.com>
* lists.c (unused_insn_list, unused_expr_list): New file for
maintaining various types of lists. New statics for maintaining a
cache of available INSN_LIST and EXPR_LIST nodes.
(free_list): Static function for freeing a list of INSN/EXPR nodes.
(alloc_INSN_LIST): Function to get a free INSN_LIST node.
(alloc_EXPR_LIST): Function to get a free EXPR_LIST node.
(init_EXPR_INSN_LIST_cache): Initialize the cache lists.
(free_EXPR_LIST_list): Free an entire list of EXPR_LIST nodes.
(free_INSN_LIST_list): Free an entire list of INSN_LIST nodes.
(free_EXPR_LIST_node): Free an individual EXPR_LIST node.
(free_INSN_LIST_node): Free an individual INSN_LIST node.
* haifa-sched.c (unused_insn_list, unused_expr_list): Moved to flow.c
(free_list, alloc_INSN_LIST, alloc_EXPR_LIST): Moved to flow.c
(remove_dependence, free_pending_lists): Use new global routines.
(flush_pending_lists, sched_analyze_insn): Use new global routines.
(sched_analyze, compute_block_backward_dependences): Use new routines.
(sched_analyze_1, sched_analyze_2): Use new routines.
(schedule_insns): Use new global routines.
* rtl.h (init_EXPR_INSN_LIST_cache, free_EXPR_LIST_list): Add function
prototypes.
(free_INSN_LIST_list, free_EXPR_LIST_node): Add prototypes.
(free_INSN_LIST_node, alloc_INSN_LIST, alloc_EXPR_LIST): Add function
prototypes.
* toplev.c (rest_of_compilation): Initialize node cache.
* Makefile.in (OBJS): Add lists.o to list of object files.
(lists.o): Add dependancies.
From-SVN: r28864
1999-08-25 13:50:53 -04:00
|
|
|
void
|
|
|
|
init_EXPR_INSN_LIST_cache ()
|
|
|
|
{
|
1999-10-08 14:59:27 -04:00
|
|
|
if (ggc_p)
|
1999-09-08 07:46:28 -04:00
|
|
|
{
|
1999-10-08 14:59:27 -04:00
|
|
|
static int initialized;
|
|
|
|
if (!initialized)
|
|
|
|
{
|
|
|
|
initialized = 1;
|
|
|
|
ggc_add_root (&unused_expr_list, 1, 1, zap_lists);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* No need to squish the lists across functions with GC enabled. */
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
unused_expr_list = NULL;
|
|
|
|
unused_insn_list = NULL;
|
1999-09-08 07:46:28 -04:00
|
|
|
}
|
lists.c (unused_insn_list, [...]): New file for maintaining various types of lists.
Wed Aug 25 13:41:47 EDT 1999 Andrew MacLeod <amacleod@cygnus.com>
* lists.c (unused_insn_list, unused_expr_list): New file for
maintaining various types of lists. New statics for maintaining a
cache of available INSN_LIST and EXPR_LIST nodes.
(free_list): Static function for freeing a list of INSN/EXPR nodes.
(alloc_INSN_LIST): Function to get a free INSN_LIST node.
(alloc_EXPR_LIST): Function to get a free EXPR_LIST node.
(init_EXPR_INSN_LIST_cache): Initialize the cache lists.
(free_EXPR_LIST_list): Free an entire list of EXPR_LIST nodes.
(free_INSN_LIST_list): Free an entire list of INSN_LIST nodes.
(free_EXPR_LIST_node): Free an individual EXPR_LIST node.
(free_INSN_LIST_node): Free an individual INSN_LIST node.
* haifa-sched.c (unused_insn_list, unused_expr_list): Moved to flow.c
(free_list, alloc_INSN_LIST, alloc_EXPR_LIST): Moved to flow.c
(remove_dependence, free_pending_lists): Use new global routines.
(flush_pending_lists, sched_analyze_insn): Use new global routines.
(sched_analyze, compute_block_backward_dependences): Use new routines.
(sched_analyze_1, sched_analyze_2): Use new routines.
(schedule_insns): Use new global routines.
* rtl.h (init_EXPR_INSN_LIST_cache, free_EXPR_LIST_list): Add function
prototypes.
(free_INSN_LIST_list, free_EXPR_LIST_node): Add prototypes.
(free_INSN_LIST_node, alloc_INSN_LIST, alloc_EXPR_LIST): Add function
prototypes.
* toplev.c (rest_of_compilation): Initialize node cache.
* Makefile.in (OBJS): Add lists.o to list of object files.
(lists.o): Add dependancies.
From-SVN: r28864
1999-08-25 13:50:53 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
/* This function will free up an entire list of EXPR_LIST nodes. */
|
|
|
|
void
|
|
|
|
free_EXPR_LIST_list (listp)
|
|
|
|
rtx *listp;
|
|
|
|
{
|
|
|
|
if (*listp == 0)
|
|
|
|
return;
|
|
|
|
free_list (listp, &unused_expr_list);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* This function will free up an entire list of INSN_LIST nodes. */
|
|
|
|
void
|
|
|
|
free_INSN_LIST_list (listp)
|
|
|
|
rtx *listp;
|
|
|
|
{
|
|
|
|
if (*listp == 0)
|
|
|
|
return;
|
|
|
|
free_list (listp, &unused_insn_list);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* This function will free up an individual EXPR_LIST node. */
|
|
|
|
void
|
|
|
|
free_EXPR_LIST_node (ptr)
|
|
|
|
rtx ptr;
|
|
|
|
{
|
|
|
|
XEXP (ptr, 1) = unused_expr_list;
|
|
|
|
unused_expr_list = ptr;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* This function will free up an individual INSN_LIST node. */
|
|
|
|
void
|
|
|
|
free_INSN_LIST_node (ptr)
|
|
|
|
rtx ptr;
|
|
|
|
{
|
|
|
|
XEXP (ptr, 1) = unused_insn_list;
|
|
|
|
unused_insn_list = ptr;
|
|
|
|
}
|