Commit f8981d1c by Alexandre Oliva Committed by Alexandre Oliva

tree-cfg.c (gimple_redirect_edge_and_branch): Create the decl label for the new…

tree-cfg.c (gimple_redirect_edge_and_branch): Create the decl label for the new dest block on demand.

* tree-cfg.c (gimple_redirect_edge_and_branch) <case GIMPLE_ASM>:
Create the decl label for the new dest block on demand.  Require
a fallthrough edge if no asm labels were redirected.

From-SVN: r154213
parent a81f2330
2009-11-16 Alexandre Oliva <aoliva@redhat.com>
* tree-cfg.c (gimple_redirect_edge_and_branch) <case GIMPLE_ASM>:
Create the decl label for the new dest block on demand. Require
a fallthrough edge if no asm labels were redirected.
2009-11-16 Uros Bizjak <ubizjak@gmail.com>
* config/i386/i386.md (cbranchsi4): Use nonimmediate_operand for
......@@ -4666,14 +4666,23 @@ gimple_redirect_edge_and_branch (edge e, basic_block dest)
case GIMPLE_ASM:
{
int i, n = gimple_asm_nlabels (stmt);
tree label = gimple_block_label (dest);
tree label = NULL;
for (i = 0; i < n; ++i)
{
tree cons = gimple_asm_label_op (stmt, i);
if (label_to_block (TREE_VALUE (cons)) == e->dest)
TREE_VALUE (cons) = label;
{
if (!label)
label = gimple_block_label (dest);
TREE_VALUE (cons) = label;
}
}
/* If we didn't find any label matching the former edge in the
asm labels, we must be redirecting the fallthrough
edge. */
gcc_assert (label || (e->flags & EDGE_FALLTHRU));
}
break;
......
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