Message ID | 20230321111056.78121-2-kmatsui@cs.washington.edu |
---|---|
State | Superseded |
Headers |
Return-Path: <gcc-patches-bounces+patchwork=sourceware.org@gcc.gnu.org> 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 9295A385084C for <patchwork@sourceware.org>; Tue, 21 Mar 2023 11:11:48 +0000 (GMT) DKIM-Filter: OpenDKIM Filter v2.11.0 sourceware.org 9295A385084C DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gcc.gnu.org; s=default; t=1679397108; bh=0N4XSuw4JG1boQUaMMb4OrG6A7HTAHuqL4EqGOySO+4=; h=To:Cc:Subject:Date:In-Reply-To:References:List-Id: List-Unsubscribe:List-Archive:List-Post:List-Help:List-Subscribe: From:Reply-To:From; b=H4upJggaEFz3gG6L9q2J1IdAj/V+ujYjRBXbTqWFbQzjGOkK8LdQ95uTHjUZ1GMUG TM3KqQKyET6YADO24i2u1B9bWRraZfqL2nSMxxiFp2mW9h2upUVyM4PWk61c+Dkq4E i+sMWSm4q9gjRiQBx5xc0PtDhn0DG697OsWXANiY= X-Original-To: gcc-patches@gcc.gnu.org Delivered-To: gcc-patches@gcc.gnu.org Received: from mx0b-00641c01.pphosted.com (mx0b-00641c01.pphosted.com [205.220.177.146]) by sourceware.org (Postfix) with ESMTPS id 43F383858D37; Tue, 21 Mar 2023 11:11:20 +0000 (GMT) DMARC-Filter: OpenDMARC Filter v1.4.2 sourceware.org 43F383858D37 Received: from pps.filterd (m0247476.ppops.net [127.0.0.1]) by mx0a-00641c01.pphosted.com (8.17.1.19/8.17.1.19) with ESMTP id 32LB6D5I017011; Tue, 21 Mar 2023 11:11:19 GMT Received: from mxout22.s.uw.edu (mxout22.s.uw.edu [128.95.242.222]) by mx0a-00641c01.pphosted.com (PPS) with ESMTPS id 3peuwvmxcv-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Tue, 21 Mar 2023 11:11:19 +0000 Received: from smtp.washington.edu (smtp.washington.edu [140.142.234.157]) by mxout22.s.uw.edu (8.14.4+UW20.07/8.14.4+UW22.04) with ESMTP id 32LBBE2m023411 (version=TLSv1/SSLv3 cipher=DHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Tue, 21 Mar 2023 04:11:14 -0700 X-Auth-Received: from localhost.localdomain ([10.154.74.245]) (authenticated authid=kmatsui) by smtp.washington.edu (8.16.1+UW21.10/8.14.4+UW19.10) with ESMTPSA id 32LBB2ci005196 (version=TLSv1.2 cipher=DHE-RSA-AES128-GCM-SHA256 bits=128 verify=NOT); Tue, 21 Mar 2023 04:11:14 -0700 X-UW-Orig-Sender: kmatsui@smtp.washington.edu To: gcc-patches@gcc.gnu.org Cc: libstdc++@gcc.gnu.org, ppalka@redhat.com, Ken Matsui <kmatsui@cs.washington.edu> Subject: [PATCH 2/2] libstdc++: use new built-in trait __add_const Date: Tue, 21 Mar 2023 04:10:56 -0700 Message-Id: <20230321111056.78121-2-kmatsui@cs.washington.edu> X-Mailer: git-send-email 2.40.0 In-Reply-To: <20230321111056.78121-1-kmatsui@cs.washington.edu> References: <20230321111056.78121-1-kmatsui@cs.washington.edu> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Proofpoint-ORIG-GUID: FhIgn7atXTvVUBnx8sjZlynPYsC_q7X- X-Proofpoint-GUID: FhIgn7atXTvVUBnx8sjZlynPYsC_q7X- X-Proofpoint-Virus-Version: vendor=baseguard engine=ICAP:2.0.254,Aquarius:18.0.942,Hydra:6.0.573,FMLib:17.11.170.22 definitions=2023-03-21_08,2023-03-21_01,2023-02-09_01 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 bulkscore=0 lowpriorityscore=0 phishscore=0 impostorscore=0 mlxscore=0 suspectscore=0 priorityscore=1501 mlxlogscore=986 spamscore=0 malwarescore=0 adultscore=0 clxscore=1015 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.12.0-2303150002 definitions=main-2303210086 X-Spam-Status: No, score=-14.6 required=5.0 tests=BAYES_00, GIT_PATCH_0, KAM_DMARC_STATUS, RCVD_IN_DNSWL_LOW, SPF_HELO_NONE, SPF_PASS, TXREP autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) 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 <gcc-patches.gcc.gnu.org> List-Unsubscribe: <https://gcc.gnu.org/mailman/options/gcc-patches>, <mailto:gcc-patches-request@gcc.gnu.org?subject=unsubscribe> List-Archive: <https://gcc.gnu.org/pipermail/gcc-patches/> List-Post: <mailto:gcc-patches@gcc.gnu.org> List-Help: <mailto:gcc-patches-request@gcc.gnu.org?subject=help> List-Subscribe: <https://gcc.gnu.org/mailman/listinfo/gcc-patches>, <mailto:gcc-patches-request@gcc.gnu.org?subject=subscribe> From: Ken Matsui via Gcc-patches <gcc-patches@gcc.gnu.org> Reply-To: Ken Matsui <kmatsui@cs.washington.edu> Errors-To: gcc-patches-bounces+patchwork=sourceware.org@gcc.gnu.org Sender: "Gcc-patches" <gcc-patches-bounces+patchwork=sourceware.org@gcc.gnu.org> |
Series |
[1/2] c++: implement __add_const built-in trait
|
|
Commit Message
Ken Matsui
March 21, 2023, 11:10 a.m. UTC
This patch lets libstdc++ use new built-in trait __add_const. libstdc++-v3/ChangeLog: * include/std/type_traits (add_const): Use __add_const built-in trait. --- libstdc++-v3/include/std/type_traits | 6 ++++++ 1 file changed, 6 insertions(+)
Comments
On Tue, 21 Mar 2023, Ken Matsui via Libstdc++ wrote: > /// add_const > +#if __has_builtin(__add_const) > + template<typename _Tp> > + struct add_const > + { using type = __add_const(_Tp); }; > +#else > template<typename _Tp> > struct add_const > { using type = _Tp const; }; > +#endif Is that really better? You asked elsewhere if you should measure for each patch, and I think that at least for such a trivial case, you need to demonstrate that there is a point. The drawbacks are obvious: more code in libstdc++, non-standard, and more builtins in the compiler. Using builtins makes more sense for complicated traits where you can save several instantiations. Now that you have done a couple simple cases to see how it works, I think you should concentrate on the more complicated cases.
On Tue, 21 Mar 2023 at 11:21, Marc Glisse via Libstdc++ < libstdc++@gcc.gnu.org> wrote: > On Tue, 21 Mar 2023, Ken Matsui via Libstdc++ wrote: > > > /// add_const > > +#if __has_builtin(__add_const) > > + template<typename _Tp> > > + struct add_const > > + { using type = __add_const(_Tp); }; > > +#else > > template<typename _Tp> > > struct add_const > > { using type = _Tp const; }; > > +#endif > > Is that really better? You asked elsewhere if you should measure for each > patch, and I think that at least for such a trivial case, you need to > demonstrate that there is a point. The drawbacks are obvious: more code in > libstdc++, non-standard, and more builtins in the compiler. > Right, this one isn't even getting rid of any partial specializations, but it is giving the preprocessor more work to do. Adding the extra built-ins to the compiler makes the compiler (very slightly) bigger and slower, so a real benchmark would require comparing an unpatched gcc (without the new built-in) to a patched gcc and patched libstdc++ sources. > > Using builtins makes more sense for complicated traits where you can save > several instantiations. Now that you have done a couple simple cases to > see how it works, I think you should concentrate on the more complicated > cases. > > -- > Marc Glisse > >
Thank you for your information. Although it matches my intuition, I sent this patch because I was unsure my intuition was correct. As Jonathan pointed out, there appear to be several implementation errors. The benchmark result for this trait is kind of trivial, so I will implement the other traits I want to implement and then come back here. Thank you all for your help. On Tue, Mar 21, 2023 at 4:25 AM Jonathan Wakely <jwakely@redhat.com> wrote: > > > On Tue, 21 Mar 2023 at 11:21, Marc Glisse via Libstdc++ < > libstdc++@gcc.gnu.org> wrote: > >> On Tue, 21 Mar 2023, Ken Matsui via Libstdc++ wrote: >> >> > /// add_const >> > +#if __has_builtin(__add_const) >> > + template<typename _Tp> >> > + struct add_const >> > + { using type = __add_const(_Tp); }; >> > +#else >> > template<typename _Tp> >> > struct add_const >> > { using type = _Tp const; }; >> > +#endif >> >> Is that really better? You asked elsewhere if you should measure for each >> patch, and I think that at least for such a trivial case, you need to >> demonstrate that there is a point. The drawbacks are obvious: more code >> in >> libstdc++, non-standard, and more builtins in the compiler. >> > > Right, this one isn't even getting rid of any partial specializations, but > it is giving the preprocessor more work to do. > > Adding the extra built-ins to the compiler makes the compiler (very > slightly) bigger and slower, so a real benchmark would require comparing an > unpatched gcc (without the new built-in) to a patched gcc and patched > libstdc++ sources. > > > >> >> Using builtins makes more sense for complicated traits where you can save >> several instantiations. Now that you have done a couple simple cases to >> see how it works, I think you should concentrate on the more complicated >> cases. >> >> -- >> Marc Glisse >> >>
diff --git a/libstdc++-v3/include/std/type_traits b/libstdc++-v3/include/std/type_traits index 2bd607a8b8f..1ac75a928c3 100644 --- a/libstdc++-v3/include/std/type_traits +++ b/libstdc++-v3/include/std/type_traits @@ -1560,9 +1560,15 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION #endif /// add_const +#if __has_builtin(__add_const) + template<typename _Tp> + struct add_const + { using type = __add_const(_Tp); }; +#else template<typename _Tp> struct add_const { using type = _Tp const; }; +#endif /// add_volatile template<typename _Tp>