diff options
author | Jeff Law <law@redhat.com> | 2011-06-16 15:52:00 -0600 |
---|---|---|
committer | Jeff Law <law@gcc.gnu.org> | 2011-06-16 15:52:00 -0600 |
commit | 361b51c08030935d78a64228551afaa65106b773 (patch) | |
tree | 3d01a6665a2ef3a33f6ed1eb847b76b1948a165d /gcc/testsuite/gcc.dg/builtin-object-size-1.c | |
parent | 67a7c837e95e85c607e55d2b72bfd4da43f0dd16 (diff) | |
download | gcc-361b51c08030935d78a64228551afaa65106b773.zip gcc-361b51c08030935d78a64228551afaa65106b773.tar.gz gcc-361b51c08030935d78a64228551afaa65106b773.tar.bz2 |
tree-ssa-threadupdate.c (struct redirection_data): New field intermediate_edge.
* tree-ssa-threadupdate.c (struct redirection_data): New field
intermediate_edge.
(THREAD_TARGET2): Define.
(redirection_data_eq): Also check that the intermediate edge is
equal.
(lookup_redirection_data): Drop useless argument. Extract the
outgoing_edge and intermediate edge from E. Callers updated.
(copy_phi_args, update_destination_phis): New functions.
(fix_duplicate_block_edges): Likewise.
(create_edge_and_update_destination_phis): Duplicate all the edges
hung off e->aux. Use copy_phi_args.
(create_duplicates): Use fix_duplicate_block_edges.
(fixup_template_block): Likewise.
(redirect_edges): If necessary, redirect the joiner block's incoming
edge to the duplicate of the joiner block.
(thread_block): Don't muck up loops when threading through a joiner
block.
(thread_through_loop_header): Handle threading through a joiner
block.
(mark_threaded_blocks, register_jump_thread): Likewise.
* tree-flow.h (register_jump_thread): Add new argument. Callers
updated.
* tree-ssa-threadedge.c (phi_args_equal_on_edges): New function.
(thread_across_edge): Handle threading through a joiner block.
* gcc.dg/builtin-object-size-1.c: Update to handle changes from
improved jump threading.
* gcc.dg/builtin-object-size-2.c: Likewise.
* gcc.dg/tree-ssa/20030728-1.c: Likewise.
From-SVN: r175114
Diffstat (limited to 'gcc/testsuite/gcc.dg/builtin-object-size-1.c')
-rw-r--r-- | gcc/testsuite/gcc.dg/builtin-object-size-1.c | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/gcc/testsuite/gcc.dg/builtin-object-size-1.c b/gcc/testsuite/gcc.dg/builtin-object-size-1.c index 404b711..13ebeb1 100644 --- a/gcc/testsuite/gcc.dg/builtin-object-size-1.c +++ b/gcc/testsuite/gcc.dg/builtin-object-size-1.c @@ -64,7 +64,11 @@ test1 (void *q, int x) r = malloc (30); else r = calloc (2, 16); - if (__builtin_object_size (r, 0) != 2 * 16) + /* We may duplicate this test onto the two exit paths. On one path + the size will be 32, the other it will be 30. If we don't duplicate + this test, then the size will be 32. */ + if (__builtin_object_size (r, 0) != 2 * 16 + && __builtin_object_size (r, 0) != 30) abort (); if (x < 20) r = malloc (30); |