
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
36 lines
1.1 KiB
C++
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
|