From patchwork Wed Nov 17 16:03:21 2021 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Patchwork-Submitter: Frederik Harwath X-Patchwork-Id: 47826 Return-Path: X-Original-To: patchwork@sourceware.org Delivered-To: patchwork@sourceware.org Received: from server2.sourceware.org (localhost [IPv6:::1]) by sourceware.org (Postfix) with ESMTP id 35168385843D for ; Wed, 17 Nov 2021 16:17:12 +0000 (GMT) X-Original-To: gcc-patches@gcc.gnu.org Delivered-To: gcc-patches@gcc.gnu.org Received: from esa1.mentor.iphmx.com (esa1.mentor.iphmx.com [68.232.129.153]) by sourceware.org (Postfix) with ESMTPS id 74BD2385AC32 for ; Wed, 17 Nov 2021 16:04:34 +0000 (GMT) DMARC-Filter: OpenDMARC Filter v1.4.1 sourceware.org 74BD2385AC32 Authentication-Results: sourceware.org; dmarc=none (p=none dis=none) header.from=codesourcery.com Authentication-Results: sourceware.org; spf=pass smtp.mailfrom=mentor.com IronPort-SDR: sYTHKwmdbhTcfIcg19LryPB1G7PEWrrPVrK3RmJR3Feea+nk9FqkgS3Vcui/j/kunLrhNPQcjs p/ln8d+6wreWOE7nb9HWQjsnwVCwBVxj5IFkLRvOkvyveJ9f3iHSGgjABeU2/95q18PFs63BGH gHVlcLjQ1wu4pkmfCsOW8Cx6HIdjf1eLU2ZQyrfmBhGn3zLCnIwS9rW2rdpEjJL7af1511pDb8 r+rfYwBaD3S5zKq8Oay1vh9So35Q6wPLVqT5OGrTZNnHAxDcCDynPhBxJOjgyT6IWLqDTjI6Kx Fhm4U7262WQDNcnjalK+0oRT X-IronPort-AV: E=Sophos;i="5.87,241,1631606400"; d="scan'208";a="71081306" Received: from orw-gwy-01-in.mentorg.com ([192.94.38.165]) by esa1.mentor.iphmx.com with ESMTP; 17 Nov 2021 08:04:34 -0800 IronPort-SDR: AR2EIAEvqqT0TJjii+rUpUtHcgmG8QgP54x5IWmmcp5LAL85os/ij9bxxOw9zejBmtsO8fQ9yb aoAndnv8Twi4DfOCTdNMUkP00ayi+euPg6XYy/3K/S/QMko8RZQpEYxXdf8b2RltSyd5iTRGKQ mKeR91WkFFUmzMxem+dbSs5sf1Mf0syFYz3MjmsCggxhD+7u+LuM54uH+oZpXkoICOAGfbAVdv hH97qJG5kt17Ay8lciGXuRa1LGdBidcwYKbeKwgQVrqL2dbVsrt3wJ3QbSJwrdGNOxsr5Cr4ks jpk= From: Frederik Harwath To: Subject: [OG11][committed][PATCH 13/22] Add function for printing a single OMP_CLAUSE Date: Wed, 17 Nov 2021 17:03:21 +0100 Message-ID: <20211117160330.20029-13-frederik@codesourcery.com> X-Mailer: git-send-email 2.33.0 In-Reply-To: <20211117160330.20029-1-frederik@codesourcery.com> References: <20211117160330.20029-1-frederik@codesourcery.com> MIME-Version: 1.0 X-Originating-IP: [137.202.0.90] X-ClientProxiedBy: svr-ies-mbx-15.mgc.mentorg.com (139.181.222.15) To SVR-IES-MBX-04.mgc.mentorg.com (139.181.222.4) X-Spam-Status: No, score=-12.5 required=5.0 tests=BAYES_00, GIT_PATCH_0, HEADER_FROM_DIFFERENT_DOMAINS, KAM_DMARC_STATUS, SPF_HELO_PASS, SPF_PASS, TXREP autolearn=ham autolearn_force=no version=3.4.4 X-Spam-Checker-Version: SpamAssassin 3.4.4 (2020-01-24) on server2.sourceware.org X-BeenThere: gcc-patches@gcc.gnu.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: Gcc-patches mailing list List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: gcc-patches-bounces+patchwork=sourceware.org@gcc.gnu.org Sender: "Gcc-patches" Commit 89f4f339130c ("For 'OMP_CLAUSE' in 'dump_generic_node', dump the whole OMP clause chain") changed the dumping behavior for OMP_CLAUSEs. The old behavior is required for a follow-up commit ("openacc: Add data optimization pass") that optimizes single OMP_CLAUSEs. gcc/ChangeLog: * tree-pretty-print.c (print_omp_clause_to_str): Add new function. * tree-pretty-print.h (print_omp_clause_to_str): Add declaration. --- gcc/tree-pretty-print.c | 11 +++++++++++ gcc/tree-pretty-print.h | 1 + 2 files changed, 12 insertions(+) -- 2.33.0 ----------------- Siemens Electronic Design Automation GmbH; Anschrift: Arnulfstraße 201, 80634 München; Gesellschaft mit beschränkter Haftung; Geschäftsführer: Thomas Heurung, Frank Thürauf; Sitz der Gesellschaft: München; Registergericht München, HRB 106955 diff --git a/gcc/tree-pretty-print.c b/gcc/tree-pretty-print.c index d769cd8f07c5..2e0255176c76 100644 --- a/gcc/tree-pretty-print.c +++ b/gcc/tree-pretty-print.c @@ -1402,6 +1402,17 @@ dump_omp_clause (pretty_printer *pp, tree clause, int spc, dump_flags_t flags) } } +/* Print the single clause at the top of the clause chain C to a string and + return it. Note that print_generic_expr_to_str prints the whole clause chain + instead. The caller must free the returned memory. */ + +char * +print_omp_clause_to_str (tree c) +{ + pretty_printer pp; + dump_omp_clause (&pp, c, 0, TDF_VOPS|TDF_MEMSYMS); + return xstrdup (pp_formatted_text (&pp)); +} /* Dump chain of OMP clauses. diff --git a/gcc/tree-pretty-print.h b/gcc/tree-pretty-print.h index cafe9aa95989..3368cb9f1544 100644 --- a/gcc/tree-pretty-print.h +++ b/gcc/tree-pretty-print.h @@ -41,6 +41,7 @@ extern void print_generic_expr (FILE *, tree, dump_flags_t = TDF_NONE); extern char *print_generic_expr_to_str (tree); extern void dump_omp_clauses (pretty_printer *, tree, int, dump_flags_t, bool = true); +extern char *print_omp_clause_to_str (tree); extern void dump_omp_atomic_memory_order (pretty_printer *, enum omp_memory_order); extern void dump_omp_loop_non_rect_expr (pretty_printer *, tree, int,