diff options
author | rsandifo <rsandifo@138bc75d-0d04-0410-961f-82ee72b054a4> | 2014-06-15 07:33:04 +0000 |
---|---|---|
committer | rsandifo <rsandifo@138bc75d-0d04-0410-961f-82ee72b054a4> | 2014-06-15 07:33:04 +0000 |
commit | f83d4fdc0cc80ddff64eb3400827d16785c0abc8 (patch) | |
tree | ade4c61474f0cf78ce51f16f74ba9dd522d0d440 /gcc/ira.c | |
parent | f8d8375042bce47a20a4027e165d4316d427baa6 (diff) | |
download | gcc-f83d4fdc0cc80ddff64eb3400827d16785c0abc8.tar.gz |
gcc/
* df.h (df_single_def, df_single_use): New functions.
* ira.c (find_moveable_pseudos): Use them.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@211681 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/ira.c')
-rw-r--r-- | gcc/ira.c | 23 |
1 files changed, 11 insertions, 12 deletions
diff --git a/gcc/ira.c b/gcc/ira.c index bbb20562b10..41988fde9f6 100644 --- a/gcc/ira.c +++ b/gcc/ira.c @@ -4437,20 +4437,19 @@ find_moveable_pseudos (void) if (NONDEBUG_INSN_P (insn)) { df_insn_info *insn_info = DF_INSN_INFO_GET (insn); - df_ref *u_rec, *d_rec; df_ref def, use; uid_luid[INSN_UID (insn)] = i++; - u_rec = DF_INSN_INFO_USES (insn_info); - d_rec = DF_INSN_INFO_DEFS (insn_info); - if (d_rec[0] != NULL && d_rec[1] == NULL - && u_rec[0] != NULL && u_rec[1] == NULL - && DF_REF_REGNO (*u_rec) == DF_REF_REGNO (*d_rec) - && !bitmap_bit_p (&set, DF_REF_REGNO (*u_rec)) + def = df_single_def (insn_info); + use = df_single_use (insn_info); + if (use + && def + && DF_REF_REGNO (use) == DF_REF_REGNO (def) + && !bitmap_bit_p (&set, DF_REF_REGNO (use)) && rtx_moveable_p (&PATTERN (insn), OP_IN)) { - unsigned regno = DF_REF_REGNO (*u_rec); + unsigned regno = DF_REF_REGNO (use); bitmap_set_bit (moveable, regno); bitmap_set_bit (&set, regno); bitmap_set_bit (&used, regno); @@ -4487,16 +4486,16 @@ find_moveable_pseudos (void) FOR_BB_INSNS (bb, insn) if (NONDEBUG_INSN_P (insn)) { + df_insn_info *insn_info = DF_INSN_INFO_GET (insn); rtx def_insn, closest_use, note; - df_ref *def_rec, def, use; + df_ref def, use; unsigned regno; bool all_dominated, all_local; enum machine_mode mode; - def_rec = DF_INSN_DEFS (insn); + def = df_single_def (insn_info); /* There must be exactly one def in this insn. */ - def = *def_rec; - if (!def || def_rec[1] || !single_set (insn)) + if (!def || !single_set (insn)) continue; /* This must be the only definition of the reg. We also limit which modes we deal with so that we can assume we can generate |