Commit d9214e53 by Richard Henderson Committed by Richard Henderson

sched-deps.c (sched_analyze_insn): Force volatile memory reads to be output before a branch.

        * sched-deps.c (sched_analyze_insn): Force volatile memory reads
        to be output before a branch.

From-SVN: r42358
parent b161c505
2001-05-20 Richard Henderson <rth@redhat.com> 2001-05-20 Richard Henderson <rth@redhat.com>
* sched-deps.c (sched_analyze_insn): Force volatile memory reads
to be output before a branch.
2001-05-20 Richard Henderson <rth@redhat.com>
* Makefile.in (dwarf2asm.o): Depend on $(TREE_H). * Makefile.in (dwarf2asm.o): Depend on $(TREE_H).
2001-05-20 Richard Henderson <rth@redhat.com> 2001-05-20 Richard Henderson <rth@redhat.com>
......
...@@ -1044,12 +1044,25 @@ sched_analyze_insn (deps, x, insn, loop_notes) ...@@ -1044,12 +1044,25 @@ sched_analyze_insn (deps, x, insn, loop_notes)
CLEAR_REG_SET (&tmp); CLEAR_REG_SET (&tmp);
/* All memory writes and volatile reads must happen before the
jump. Non-volatile reads must happen before the jump iff
the result is needed by the above register used mask. */
pending = deps->pending_write_insns; pending = deps->pending_write_insns;
pending_mem = deps->pending_write_mems; pending_mem = deps->pending_write_mems;
while (pending) while (pending)
{ {
add_dependence (insn, XEXP (pending, 0), REG_DEP_OUTPUT); add_dependence (insn, XEXP (pending, 0), REG_DEP_OUTPUT);
pending = XEXP (pending, 1);
pending_mem = XEXP (pending_mem, 1);
}
pending = deps->pending_read_insns;
pending_mem = deps->pending_read_mems;
while (pending)
{
if (MEM_VOLATILE_P (XEXP (pending_mem, 0)))
add_dependence (insn, XEXP (pending, 0), REG_DEP_OUTPUT);
pending = XEXP (pending, 1); pending = XEXP (pending, 1);
pending_mem = XEXP (pending_mem, 1); pending_mem = XEXP (pending_mem, 1);
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment