From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (qmail 8978 invoked by alias); 3 Jun 2014 09:33:44 -0000 Mailing-List: contact gcc-patches-help@gcc.gnu.org; run by ezmlm Precedence: bulk List-Id: List-Archive: List-Post: List-Help: Sender: gcc-patches-owner@gcc.gnu.org Received: (qmail 8911 invoked by uid 89); 3 Jun 2014 09:33:44 -0000 Authentication-Results: sourceware.org; auth=none X-Virus-Found: No X-Spam-SWARE-Status: No, score=-1.7 required=5.0 tests=AWL,BAYES_00,FREEMAIL_FROM,RCVD_IN_DNSWL_LOW,SPF_PASS autolearn=ham version=3.3.2 X-HELO: mail-wi0-f173.google.com Received: from mail-wi0-f173.google.com (HELO mail-wi0-f173.google.com) (209.85.212.173) by sourceware.org (qpsmtpd/0.93/v0.84-503-g423c35a) with (AES128-SHA encrypted) ESMTPS; Tue, 03 Jun 2014 09:33:42 +0000 Received: by mail-wi0-f173.google.com with SMTP id bs8so6043435wib.0 for ; Tue, 03 Jun 2014 02:33:39 -0700 (PDT) MIME-Version: 1.0 X-Received: by 10.180.183.131 with SMTP id em3mr30613024wic.56.1401788019430; Tue, 03 Jun 2014 02:33:39 -0700 (PDT) Received: by 10.194.219.97 with HTTP; Tue, 3 Jun 2014 02:33:39 -0700 (PDT) In-Reply-To: <20140603071327.GB20877@msticlxl57.ims.intel.com> References: <20140603071327.GB20877@msticlxl57.ims.intel.com> Date: Tue, 03 Jun 2014 09:33:00 -0000 Message-ID: Subject: Re: [PATCH, Pointer Bounds Checker 24/x] PRE From: Richard Biener To: Ilya Enkovich Cc: GCC Patches Content-Type: text/plain; charset=UTF-8 X-IsSubscribed: yes X-SW-Source: 2014-06/txt/msg00200.txt.bz2 On Tue, Jun 3, 2014 at 9:13 AM, Ilya Enkovich wrote: > Hi, > > This patch preserves CALL_WITH_BOUNDS flag for calls during PRE. Ok. Richard. > Bootstrapped and tested on linux-x86_64. > > Thanks, > Ilya > -- > gcc/ > > 2014-06-03 Ilya Enkovich > > * tree-ssa-pre.c (create_component_ref_by_pieces_1): Store > CALL_WITH_BOUNDS_P for calls. > (copy_reference_ops_from_call): Restore CALL_WITH_BOUNDS_P > flag. > > > diff --git a/gcc/tree-ssa-pre.c b/gcc/tree-ssa-pre.c > index 1e55356..d5b9f3b 100644 > --- a/gcc/tree-ssa-pre.c > +++ b/gcc/tree-ssa-pre.c > @@ -2579,6 +2579,8 @@ create_component_ref_by_pieces_1 (basic_block block, vn_reference_t ref, > (TREE_CODE (fn) == FUNCTION_DECL > ? build_fold_addr_expr (fn) : fn), > nargs, args); > + if (currop->op2 == integer_one_node) > + CALL_WITH_BOUNDS_P (folded) = true; > free (args); > if (sc) > CALL_EXPR_STATIC_CHAIN (folded) = sc; > diff --git a/gcc/tree-ssa-sccvn.c b/gcc/tree-ssa-sccvn.c > index f7ec8b6..e83d9dc 100644 > --- a/gcc/tree-ssa-sccvn.c > +++ b/gcc/tree-ssa-sccvn.c > @@ -1124,6 +1124,8 @@ copy_reference_ops_from_call (gimple call, > temp.opcode = CALL_EXPR; > temp.op0 = gimple_call_fn (call); > temp.op1 = gimple_call_chain (call); > + if (gimple_call_with_bounds_p (call)) > + temp.op2 = integer_one_node; > temp.off = -1; > result->safe_push (temp); >