diff options
author | Bernd Schmidt <bernds@cygnus.co.uk> | 2000-03-14 18:36:18 +0000 |
---|---|---|
committer | Bernd Schmidt <crux@gcc.gnu.org> | 2000-03-14 18:36:18 +0000 |
commit | eab5c70a03b09cdff6668c76fde6337e486dcdb4 (patch) | |
tree | 096b43f896f53dc9a7da616fc0b4de3800ddcee1 /gcc/cselib.h | |
parent | 4bdf01f2105ab88bb5ce4ea1bfeae1675482a9b0 (diff) | |
download | gcc-eab5c70a03b09cdff6668c76fde6337e486dcdb4.zip gcc-eab5c70a03b09cdff6668c76fde6337e486dcdb4.tar.gz gcc-eab5c70a03b09cdff6668c76fde6337e486dcdb4.tar.bz2 |
Add cselib; use it in loop and reload_cse_regs
From-SVN: r32538
Diffstat (limited to 'gcc/cselib.h')
-rw-r--r-- | gcc/cselib.h | 66 |
1 files changed, 66 insertions, 0 deletions
diff --git a/gcc/cselib.h b/gcc/cselib.h new file mode 100644 index 0000000..879b9c6 --- /dev/null +++ b/gcc/cselib.h @@ -0,0 +1,66 @@ +/* Common subexpression elimination for GNU compiler. + Copyright (C) 1987, 88, 89, 92-7, 1998, 1999 Free Software Foundation, Inc. + +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. */ + +/* Describe a value. */ +typedef struct cselib_val_struct +{ + /* The hash value. */ + unsigned int value; + union + { + /* A VALUE rtx that points back to this structure. */ + rtx val_rtx; + /* Used to keep a list of free cselib_val structures. */ + struct cselib_val_struct *next_free; + } u; + + /* All rtl expressions that hold this value at the current time during a + scan. */ + struct elt_loc_list *locs; + /* If this value is used as an address, points to a list of values that + use it as an address in a MEM. */ + struct elt_list *addr_list; +} cselib_val; + +/* A list of rtl expressions that hold the same value. */ +struct elt_loc_list +{ + /* Next element in the list. */ + struct elt_loc_list *next; + /* An rtl expression that holds the value. */ + rtx loc; + /* The insn that made the equivalence. */ + rtx setting_insn; +}; + +/* A list of cselib_val structures. */ +struct elt_list +{ + struct elt_list *next; + cselib_val *elt; +}; + +extern cselib_val *cselib_lookup PARAMS ((rtx, enum machine_mode, int)); +extern void cselib_update_varray_sizes PARAMS ((void)); +extern void cselib_init PARAMS ((void)); +extern void cselib_finish PARAMS ((void)); +extern void cselib_process_insn PARAMS ((rtx)); +extern int rtx_equal_for_cselib_p PARAMS ((rtx, rtx)); +extern int references_value_p PARAMS ((rtx, int)); |