[libc-commits] [libc] a9d8843 - [libc] Fuzz tests for acos and atan (#147843)

via libc-commits libc-commits at lists.llvm.org
Thu Jul 10 09:28:32 PDT 2025


Author: sribee8
Date: 2025-07-10T16:28:29Z
New Revision: a9d8843d71d647afad8c1908406d210a15e5feb7

URL: https://github.com/llvm/llvm-project/commit/a9d8843d71d647afad8c1908406d210a15e5feb7
DIFF: https://github.com/llvm/llvm-project/commit/a9d8843d71d647afad8c1908406d210a15e5feb7.diff

LOG: [libc] Fuzz tests for acos and atan (#147843)

created fuzz tests for acos and atan

---------

Co-authored-by: Sriya Pratipati <sriyap at google.com>

Added: 
    libc/fuzzing/math/acos_fuzz.cpp
    libc/fuzzing/math/atan_fuzz.cpp

Modified: 
    libc/fuzzing/math/CMakeLists.txt

Removed: 
    


################################################################################
diff  --git a/libc/fuzzing/math/CMakeLists.txt b/libc/fuzzing/math/CMakeLists.txt
index d8df31e87a648..78187e10453d6 100644
--- a/libc/fuzzing/math/CMakeLists.txt
+++ b/libc/fuzzing/math/CMakeLists.txt
@@ -71,6 +71,15 @@ add_libc_fuzzer(
     libc.src.math.sin
 )
 
+add_libc_fuzzer(
+  acos_fuzz
+  NEED_MPFR
+  SRCS
+    acos_fuzz.cpp
+  DEPENDS
+    libc.src.math.acos
+)
+
 add_libc_fuzzer(
   cos_fuzz
   NEED_MPFR
@@ -80,6 +89,15 @@ add_libc_fuzzer(
     libc.src.math.cos
 )
 
+add_libc_fuzzer(
+  atan_fuzz
+  NEED_MPFR
+  SRCS
+    atan_fuzz.cpp
+  DEPENDS
+    libc.src.math.atan
+)
+
 add_libc_fuzzer(
   tan_fuzz
   NEED_MPFR

diff  --git a/libc/fuzzing/math/acos_fuzz.cpp b/libc/fuzzing/math/acos_fuzz.cpp
new file mode 100644
index 0000000000000..d2b5456026839
--- /dev/null
+++ b/libc/fuzzing/math/acos_fuzz.cpp
@@ -0,0 +1,38 @@
+//===-- acos_fuzz.cpp -----------------------------------------------------===//
+//
+// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
+// See https://llvm.org/LICENSE.txt for license information.
+// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
+//
+//===----------------------------------------------------------------------===//
+///
+/// Fuzzing test for llvm-libc acos implementation.
+///
+//===----------------------------------------------------------------------===//
+
+#include "src/math/acos.h"
+#include "utils/MPFRWrapper/mpfr_inc.h"
+#include <math.h>
+
+extern "C" int LLVMFuzzerTestOneInput(double x) {
+  // remove NaN and inf and values outside accepted range
+  if (isnan(x) || isinf(x) || x > 1 || x < -1)
+    return 0;
+  // signed zeros already tested in unit tests
+  if (signbit(x) && x == 0.0)
+    return 0;
+  mpfr_t input;
+  mpfr_init2(input, 53);
+  mpfr_set_d(input, x, MPFR_RNDN);
+  int output = mpfr_acos(input, input, MPFR_RNDN);
+  mpfr_subnormalize(input, output, MPFR_RNDN);
+  double to_compare = mpfr_get_d(input, MPFR_RNDN);
+
+  double result = LIBC_NAMESPACE::acos(x);
+
+  if (result != to_compare)
+    __builtin_trap();
+
+  mpfr_clear(input);
+  return 0;
+}

diff  --git a/libc/fuzzing/math/atan_fuzz.cpp b/libc/fuzzing/math/atan_fuzz.cpp
new file mode 100644
index 0000000000000..3b485786e3a63
--- /dev/null
+++ b/libc/fuzzing/math/atan_fuzz.cpp
@@ -0,0 +1,38 @@
+//===-- atan_fuzz.cpp -----------------------------------------------------===//
+//
+// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
+// See https://llvm.org/LICENSE.txt for license information.
+// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
+//
+//===----------------------------------------------------------------------===//
+///
+/// Fuzzing test for llvm-libc atan implementation.
+///
+//===----------------------------------------------------------------------===//
+
+#include "src/math/atan.h"
+#include "utils/MPFRWrapper/mpfr_inc.h"
+#include <math.h>
+
+extern "C" int LLVMFuzzerTestOneInput(double x) {
+  // remove NaN and inf
+  if (isnan(x) || isinf(x))
+    return 0;
+  // signed zeros already tested in unit tests
+  if (signbit(x) && x == 0.0)
+    return 0;
+  mpfr_t input;
+  mpfr_init2(input, 53);
+  mpfr_set_d(input, x, MPFR_RNDN);
+  int output = mpfr_atan(input, input, MPFR_RNDN);
+  mpfr_subnormalize(input, output, MPFR_RNDN);
+  double to_compare = mpfr_get_d(input, MPFR_RNDN);
+
+  double result = LIBC_NAMESPACE::atan(x);
+
+  if (result != to_compare)
+    __builtin_trap();
+
+  mpfr_clear(input);
+  return 0;
+}


        


More information about the libc-commits mailing list