| Message ID | 20260325192357.1284741-1-adhemerval.zanella@linaro.org (mailing list archive) |
|---|---|
| Headers |
Return-Path: <libc-alpha-bounces~patchwork=sourceware.org@sourceware.org> X-Original-To: patchwork@sourceware.org Delivered-To: patchwork@sourceware.org Received: from vm01.sourceware.org (localhost [127.0.0.1]) by sourceware.org (Postfix) with ESMTP id BB05A4B9DB54 for <patchwork@sourceware.org>; Wed, 25 Mar 2026 19:25:05 +0000 (GMT) DKIM-Filter: OpenDKIM Filter v2.11.0 sourceware.org BB05A4B9DB54 Authentication-Results: sourceware.org; dkim=pass (2048-bit key, unprotected) header.d=linaro.org header.i=@linaro.org header.a=rsa-sha256 header.s=google header.b=yIbtM8LP X-Original-To: libc-alpha@sourceware.org Delivered-To: libc-alpha@sourceware.org Received: from mail-vk1-xa2a.google.com (mail-vk1-xa2a.google.com [IPv6:2607:f8b0:4864:20::a2a]) by sourceware.org (Postfix) with ESMTPS id 552164BA2E09 for <libc-alpha@sourceware.org>; Wed, 25 Mar 2026 19:24:03 +0000 (GMT) DMARC-Filter: OpenDMARC Filter v1.4.2 sourceware.org 552164BA2E09 Authentication-Results: sourceware.org; dmarc=pass (p=none dis=none) header.from=linaro.org Authentication-Results: sourceware.org; spf=pass smtp.mailfrom=linaro.org ARC-Filter: OpenARC Filter v1.0.0 sourceware.org 552164BA2E09 Authentication-Results: server2.sourceware.org; arc=none smtp.remote-ip=2607:f8b0:4864:20::a2a ARC-Seal: i=1; a=rsa-sha256; d=sourceware.org; s=key; t=1774466643; cv=none; b=i2i+EDr6rABgobvvo3KXLbHXyrIFrO/JZbar/Cni232xMB1CGgE456xfWLmC8l7pxgo3c8BGfR+GzzAM9z9d8i5rwyjtjub9uzspo70S424OmYVcWNSv2mitz8Xd1u8o4pd/jSuGkoqBzYYlTluKzTVeIt2oJHtiMB2rPujcOhI= ARC-Message-Signature: i=1; a=rsa-sha256; d=sourceware.org; s=key; t=1774466643; c=relaxed/simple; bh=BUA+K26j4+jdpQQqnkVXWWXJmlVTSIZPntCHbX8VsWM=; h=DKIM-Signature:From:To:Subject:Date:Message-ID:MIME-Version; b=pLNsBdLrwlDu/kyljLGj2wvmVL1dvSiP3RC5wdwDffnrPgm7EDl5NO4XrhPnyot4HjW0VfqkndoJjPSy3k7PFOVTM+uzqioyTTpbQ5qXsZU50XEdYj+YjobM7dD8rO3eA7pAFyfE66b7AkxmuTnkR3QQ3oDa+kV27WEB0Ve3VoI= ARC-Authentication-Results: i=1; server2.sourceware.org DKIM-Filter: OpenDKIM Filter v2.11.0 sourceware.org 552164BA2E09 Received: by mail-vk1-xa2a.google.com with SMTP id 71dfb90a1353d-56a8e0ea02aso327228e0c.0 for <libc-alpha@sourceware.org>; Wed, 25 Mar 2026 12:24:03 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; t=1774466642; x=1775071442; darn=sourceware.org; h=content-transfer-encoding:mime-version:message-id:date:subject:cc :to:from:from:to:cc:subject:date:message-id:reply-to; bh=wojavWFzzMSZREqY+GKUfoE/CqOlyzhbBtWJOICwRGM=; b=yIbtM8LPsys6EO1epQ1+fTShkTeLiUcdpLahSi1HmxXSCCTMyRHKJbBJaq3fgr/6k0 zmaR+p2t+Xa9po2LaexPbpVM2AKMBgZKBbnP9bTSgt7JncCYgL7G9pmZu2mmSeoGVC9u OgtRAg0s7EnhjuWLbhVtmIn5mhVW2B2MKuN6n/OvTEaCqALQOV28tl6JViJSUVxL0Fng C7CbHG7VBpSNazGsWIscjQs2oLgjWisCRMi7YaaRfoljcejS3UprrAI0NapToKN1P7h0 aE/7CAwWvY2MnrxBvHp4eKa1ld2n+bbh0Qs5IsdvbQJPcLXqBR4a4bCfzbULUAZmEHnE 0Y6w== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20251104; t=1774466642; x=1775071442; h=content-transfer-encoding:mime-version:message-id:date:subject:cc :to:from:x-gm-gg:x-gm-message-state:from:to:cc:subject:date :message-id:reply-to; bh=wojavWFzzMSZREqY+GKUfoE/CqOlyzhbBtWJOICwRGM=; b=CfNrfSRhaEABw+IKJ/YcJWoWFx8H/XwI/zfRBz6ZjffjyMI9lcSSHgnz9B0DMHAYx2 fRJOgGyutlFG73oZsJuRsSSKfQWyiOlDHSSIOoVb0xk1mfG02lMgHdsWSLjB9eNR0h8N nqet31Vfaeg81E8iEBYUaXHwr4/GgcL8wuTBEkX5GJujKeSRZ3/PmjSlk0XFo6Bmrswb slQEUPoKgvFAoKilgMq/9oioLy0LcADCiA+kKFAiNNorO7tRITFzRO+affqh3VURddVN EfHPnySc2LmNZ+1YxVfMFkx2abHwANZgmztriEpENInV0Sp2+Ljwd8xlYtKaP04D6VQy +Gow== X-Gm-Message-State: AOJu0Yz+ZHCmCuNv4t8d0lp2ce2P+DhTDnk4V6YvPByVlqhsbv4C7YaS EO45tvh2h3FtZdot6YxhWXrVRQ5BagmdWnTuBr6w9VBiF0Nd2nTHpTKt0yUMgGKTWOIZvgPPSFs u2NAF X-Gm-Gg: ATEYQzwaQByOgTbV/dAhPN5Des6scrkTd2zHQd2/yNyi6PYkRp5VfVyk89Q3/sSGzVH T4R/B5Bw3y27VH8k7/xMQi+htintdgBFfMbjLF096KtpqyPp5rfgevIcIK0TL9Y1VTeyrzfZrUw rwh+uEsRlZ1LeC60YcdLrNv2s5FcKd/HEKzzLastIMYM70ySH5E8lf+th++UUqsscz1IWAAS3Sf a8SXddR5A1mWjwwGk8KAFwNv/0FzBdHfraK9vPJ+veWc6HuisRuweU3TDKpgxUqo15ZE9mBsfZE PNMxyDIuD0Cealo7y0qDY8DpdDMaiZtGyqMJON5jogrlqoPSauIaRbCQBJHcX/3sp3dX3stUq7S s8CQXS79lVHGKkbdO8cyMNNCwNSH39mxm54nP8UfE8LqSpDzciYyx4ygnGLjKy4KNcW4sSZL5CC 9qxl9K/ZQbCunQMSidXkAA/RK99FWo/2tYlyKf3Ei9g6xsQg== X-Received: by 2002:a05:6122:5004:b0:56c:da22:6919 with SMTP id 71dfb90a1353d-56d220890b9mr2139681e0c.10.1774466642300; Wed, 25 Mar 2026 12:24:02 -0700 (PDT) Received: from mandiga.. ([2804:1b3:a7c1:90ea:f31d:ca7d:f8dd:c20b]) by smtp.gmail.com with ESMTPSA id 71dfb90a1353d-56d31d394fcsm1040021e0c.12.2026.03.25.12.24.00 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 25 Mar 2026 12:24:01 -0700 (PDT) From: Adhemerval Zanella <adhemerval.zanella@linaro.org> To: libc-alpha@sourceware.org Cc: Paul Zimmermann <Paul.Zimmermann@inria.fr>, DJ Delorie <dj@redhat.com> Subject: [PATCH 0/8] Add sinf/cosf/sincosf CORE-MATH implementations Date: Wed, 25 Mar 2026 16:22:18 -0300 Message-ID: <20260325192357.1284741-1-adhemerval.zanella@linaro.org> X-Mailer: git-send-email 2.43.0 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-5.2 required=5.0 tests=BAYES_00, DKIM_SIGNED, DKIM_VALID, DKIM_VALID_AU, DKIM_VALID_EF, RCVD_IN_DNSWL_NONE, SPF_HELO_NONE, SPF_PASS, TXREP, URIBL_BLOCKED autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on sourceware.org X-BeenThere: libc-alpha@sourceware.org X-Mailman-Version: 2.1.30 Precedence: list List-Id: Libc-alpha mailing list <libc-alpha.sourceware.org> List-Unsubscribe: <https://sourceware.org/mailman/options/libc-alpha>, <mailto:libc-alpha-request@sourceware.org?subject=unsubscribe> List-Archive: <https://sourceware.org/pipermail/libc-alpha/> List-Post: <mailto:libc-alpha@sourceware.org> List-Help: <mailto:libc-alpha-request@sourceware.org?subject=help> List-Subscribe: <https://sourceware.org/mailman/listinfo/libc-alpha>, <mailto:libc-alpha-request@sourceware.org?subject=subscribe> Errors-To: libc-alpha-bounces~patchwork=sourceware.org@sourceware.org |
| Series |
Add sinf/cosf/sincosf CORE-MATH implementations
|
|
Message
Adhemerval Zanella Netto
March 25, 2026, 7:22 p.m. UTC
This patchset adds the optimized and correctly rounded cosf, sinf, and
sincosf from CORE-MATH [1]. The patch adds new input ranges for the
benchtests based on feedback from SPECcpu2017 usage.
The performance is similar, with some gains and some regressions. The
x86_64-v1 shows some performance regression because the CORE-MATH
implementation relies on roundeven. The x86_64v2 and forward provide
a specific instruction, and x86_64 already provides an FMA ifunc variant.
[1] https://gitlab.inria.fr/core-math/core-math
Adhemerval Zanella (8):
benchtest: Redefine cosf ranges
benchtest: Redefine sinf ranges
benchtest: Redefine sincosf ranges
math: Use sinf from CORE-MATH
math: Use cosf from CORE-MATH
math: Use sincosf from CORE-MATH
math: Consolidate common definitions for cosf/sinf/tanf/sincosf
math: Remove unused definitions for sinf/cosf/sincosf implementation
SHARED-FILES | 6 +
benchtests/cosf-inputs | 5409 ++++++-----
benchtests/sincosf-inputs | 8309 ++++++-----------
benchtests/sinf-inputs | 7919 ++++++----------
math/Makefile | 2 +
math/auto-libm-test-in | 1 +
math/auto-libm-test-out-sincos | 25 +
sysdeps/ieee754/flt-32/libm-test-ulps | 36 +
sysdeps/ieee754/flt-32/reduce_aux.h | 38 +-
.../flt-32/reduce_aux_data.c} | 37 +-
sysdeps/ieee754/flt-32/s_cosf.c | 160 +-
sysdeps/ieee754/flt-32/s_sincosf.c | 191 +-
sysdeps/ieee754/flt-32/s_sincosf.h | 95 -
sysdeps/ieee754/flt-32/s_sincosf_common.c | 90 +
sysdeps/ieee754/flt-32/s_sincosf_common.h | 63 +
sysdeps/ieee754/flt-32/s_sincosf_data.c | 157 +-
sysdeps/ieee754/flt-32/s_sincosf_data.h | 64 +
sysdeps/ieee754/flt-32/s_sinf.c | 164 +-
sysdeps/ieee754/flt-32/s_tanf.c | 65 +-
sysdeps/ieee754/flt-32/sincosf_poly.h | 87 -
sysdeps/x86/fpu/sincosf_poly.h | 111 -
21 files changed, 9752 insertions(+), 13277 deletions(-)
rename sysdeps/{x86/fpu/s_sincosf_data.c => ieee754/flt-32/reduce_aux_data.c} (58%)
delete mode 100644 sysdeps/ieee754/flt-32/s_sincosf.h
create mode 100644 sysdeps/ieee754/flt-32/s_sincosf_common.c
create mode 100644 sysdeps/ieee754/flt-32/s_sincosf_common.h
create mode 100644 sysdeps/ieee754/flt-32/s_sincosf_data.h
delete mode 100644 sysdeps/ieee754/flt-32/sincosf_poly.h
delete mode 100644 sysdeps/x86/fpu/sincosf_poly.h