+Wed Jul 18 18:35:01 CEST 2001 Jan Hubicka <jh@suse.cz>
+
+ * cse.c (delete_trivially_dead_insns): Delete the libcall block
+ when return value is unused.
+
Wed Jul 18 18:28:16 CEST 2001 Jan Hubicka <jh@suse.cz>
* gcse.c (pre_insert_copy_insn): Call update_ld_motion_stores.
static bool
set_live_p (set, insn, counts)
rtx set;
- rtx insn;
+ rtx insn ATTRIBUTE_UNUSED;
int *counts;
{
#ifdef HAVE_cc0
if (find_reg_note (insn, REG_RETVAL, NULL_RTX))
{
in_libcall = 1;
- live_insn = 1;
- dead_libcall = dead_libcall_p (insn);
+ /* If the insn storing return value is dead, whole libcall is dead.
+ Otherwise attempt to eliminate libcall by doing an direct
+ operation. */
+ if (!insn_live_p (insn, counts))
+ {
+ live_insn = 0;
+ dead_libcall = 1;
+ }
+ else
+ {
+ live_insn = 1;
+ dead_libcall = dead_libcall_p (insn);
+ }
}
else if (in_libcall)
live_insn = ! dead_libcall;
if (find_reg_note (insn, REG_RETVAL, NULL_RTX))
{
in_libcall = 1;
- live_insn = 1;
- dead_libcall = dead_libcall_p (insn);
+ /* If the insn storing return value is dead, whole libcall is dead.
+ Otherwise attempt to eliminate libcall by doing an direct
+ operation. */
+ if (!insn_live_p (insn, counts))
+ {
+ live_insn = 0;
+ dead_libcall = 1;
+ }
+ else
+ {
+ live_insn = 1;
+ dead_libcall = dead_libcall_p (insn);
+ }
}
else if (in_libcall)
live_insn = ! dead_libcall;