llvm-project/libc/fuzzing/stdlib/StringParserOutputDiff.h
Michael Jones 87c016078a [libc] add atof, strtof and strtod
Add the string to floating point conversion functions.
Long doubles aren't supported yet, but floats and doubles are. The
primary algorithm used is the Eisel-Lemire ParseNumberF64 algorithm,
with the Simple Decimal Conversion algorithm as backup.

Links for more information on the algorithms:

Number Parsing at a Gigabyte per Second, Software: Practice and
Experience 51 (8), 2021 (https://arxiv.org/abs/2101.11408)
https://nigeltao.github.io/blog/2020/eisel-lemire.html
https://nigeltao.github.io/blog/2020/parse-number-f64-simple.html

Differential Revision: https://reviews.llvm.org/D109261
2021-10-18 16:10:03 -07:00

36 lines
1.1 KiB
C++

//===-- Template to diff single-input-single-output functions ---*- C++ -*-===//
//
// 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
//
//===----------------------------------------------------------------------===//
#ifndef LLVM_LIBC_FUZZING_STDLIB_STRING_PARSER_OUTPUT_DIFF_H
#define LLVM_LIBC_FUZZING_STDLIB_STRING_PARSER_OUTPUT_DIFF_H
#include "fuzzing/math/Compare.h"
#include <stddef.h>
#include <stdint.h>
template <typename T> using StringInputSingleOutputFunc = T (*)(const char *);
template <typename T>
void StringParserOutputDiff(StringInputSingleOutputFunc<T> func1,
StringInputSingleOutputFunc<T> func2,
const uint8_t *data, size_t size) {
if (size < sizeof(T))
return;
const char *x = reinterpret_cast<const char *>(data);
T result1 = func1(x);
T result2 = func2(x);
if (!ValuesEqual(result1, result2))
__builtin_trap();
}
#endif // LLVM_LIBC_FUZZING_STDLIB_STRING_PARSER_OUTPUT_DIFF_H