Merge pull request #994 from simdjson/issue976
Fix for issue 976 (something like 32-bit support)
This commit is contained in:
commit
3a064535ae
42
.drone.yml
42
.drone.yml
|
@ -1,4 +1,46 @@
|
||||||
kind: pipeline
|
kind: pipeline
|
||||||
|
name: i386-gcc # we do not support 32-bit systems, but we run tests
|
||||||
|
platform: { os: linux, arch: amd64 }
|
||||||
|
steps:
|
||||||
|
- name: Build and Test
|
||||||
|
image: i386/ubuntu
|
||||||
|
environment:
|
||||||
|
CC: gcc
|
||||||
|
CXX: g++
|
||||||
|
BUILD_FLAGS: -- -j
|
||||||
|
CMAKE_FLAGS: -DSIMDJSON_BUILD_STATIC=ON
|
||||||
|
CTEST_FLAGS: -j4 --output-on-failure -E checkperf
|
||||||
|
commands:
|
||||||
|
- apt-get update -qq
|
||||||
|
- apt-get install -y g++ cmake gcc
|
||||||
|
- mkdir build
|
||||||
|
- cd build
|
||||||
|
- cmake $CMAKE_FLAGS ..
|
||||||
|
- cmake --build . $BUILD_FLAGS
|
||||||
|
- ctest $CTEST_FLAGS
|
||||||
|
---
|
||||||
|
kind: pipeline
|
||||||
|
name: i386-clang # we do not support 32-bit systems, but we run tests
|
||||||
|
platform: { os: linux, arch: amd64 }
|
||||||
|
steps:
|
||||||
|
- name: Build and Test
|
||||||
|
image: i386/ubuntu
|
||||||
|
environment:
|
||||||
|
CC: clang-6.0
|
||||||
|
CXX: clang++-6.0
|
||||||
|
BUILD_FLAGS: -- -j
|
||||||
|
CMAKE_FLAGS: -DSIMDJSON_BUILD_STATIC=ON
|
||||||
|
CTEST_FLAGS: -j4 --output-on-failure -E checkperf
|
||||||
|
commands:
|
||||||
|
- apt-get update -qq
|
||||||
|
- apt-get install -y clang++-6.0 cmake
|
||||||
|
- mkdir build
|
||||||
|
- cd build
|
||||||
|
- cmake $CMAKE_FLAGS ..
|
||||||
|
- cmake --build . $BUILD_FLAGS
|
||||||
|
- ctest $CTEST_FLAGS
|
||||||
|
---
|
||||||
|
kind: pipeline
|
||||||
name: gcc9
|
name: gcc9
|
||||||
platform: { os: linux, arch: amd64 }
|
platform: { os: linux, arch: amd64 }
|
||||||
steps:
|
steps:
|
||||||
|
|
|
@ -81,14 +81,14 @@ really_inline T tape_ref::next_tape_value() const noexcept {
|
||||||
}
|
}
|
||||||
|
|
||||||
really_inline uint32_t internal::tape_ref::get_string_length() const noexcept {
|
really_inline uint32_t internal::tape_ref::get_string_length() const noexcept {
|
||||||
uint64_t string_buf_index = size_t(tape_value());
|
size_t string_buf_index = size_t(tape_value());
|
||||||
uint32_t len;
|
uint32_t len;
|
||||||
memcpy(&len, &doc->string_buf[string_buf_index], sizeof(len));
|
memcpy(&len, &doc->string_buf[string_buf_index], sizeof(len));
|
||||||
return len;
|
return len;
|
||||||
}
|
}
|
||||||
|
|
||||||
really_inline const char * internal::tape_ref::get_c_str() const noexcept {
|
really_inline const char * internal::tape_ref::get_c_str() const noexcept {
|
||||||
uint64_t string_buf_index = size_t(tape_value());
|
size_t string_buf_index = size_t(tape_value());
|
||||||
return reinterpret_cast<const char *>(&doc->string_buf[string_buf_index + sizeof(uint32_t)]);
|
return reinterpret_cast<const char *>(&doc->string_buf[string_buf_index + sizeof(uint32_t)]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -4,6 +4,7 @@
|
||||||
#include <cstddef>
|
#include <cstddef>
|
||||||
#include <cstdint>
|
#include <cstdint>
|
||||||
#include <cstdlib>
|
#include <cstdlib>
|
||||||
|
#include <cfloat>
|
||||||
|
|
||||||
|
|
||||||
#ifdef _MSC_VER
|
#ifdef _MSC_VER
|
||||||
|
@ -37,24 +38,28 @@
|
||||||
|
|
||||||
#if defined(__x86_64__) || defined(_M_AMD64)
|
#if defined(__x86_64__) || defined(_M_AMD64)
|
||||||
#define SIMDJSON_IS_X86_64 1
|
#define SIMDJSON_IS_X86_64 1
|
||||||
#endif
|
#elif defined(__aarch64__) || defined(_M_ARM64)
|
||||||
#if defined(__aarch64__) || defined(_M_ARM64)
|
|
||||||
#define SIMDJSON_IS_ARM64 1
|
#define SIMDJSON_IS_ARM64 1
|
||||||
|
#else
|
||||||
|
#define SIMDJSON_IS_32BITS 1
|
||||||
|
|
||||||
|
// We do not support 32-bit platforms, but it can be
|
||||||
|
// handy to identify them.
|
||||||
|
#if defined(_M_IX86) || defined(__i386__)
|
||||||
|
#define SIMDJSON_IS_X86_32BITS 1
|
||||||
|
#elif defined(__arm__) || defined(_M_ARM)
|
||||||
|
#define SIMDJSON_IS_ARM_32BITS 1
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if (!defined(SIMDJSON_IS_X86_64)) && (!defined(SIMDJSON_IS_ARM64))
|
#endif // defined(__x86_64__) || defined(_M_AMD64)
|
||||||
#ifdef SIMDJSON_REGULAR_VISUAL_STUDIO
|
|
||||||
#pragma message("The simdjson library is designed\
|
#ifdef SIMDJSON_IS_32BITS
|
||||||
for 64-bit processors and it seems that you are not \
|
#pragma message("The simdjson library is designed \
|
||||||
|
for 64-bit processors and it seems that you are not \
|
||||||
compiling for a known 64-bit platform. All fast kernels \
|
compiling for a known 64-bit platform. All fast kernels \
|
||||||
will be disabled and performance may be poor. Please \
|
will be disabled and performance may be poor. Please \
|
||||||
use a 64-bit target such as x64 or 64-bit ARM.")
|
use a 64-bit target such as x64 or 64-bit ARM.")
|
||||||
#else
|
#endif // SIMDJSON_IS_32BITS
|
||||||
#error "The simdjson library is designed\
|
|
||||||
for 64-bit processors. It seems that you are not \
|
|
||||||
compiling for a known 64-bit platform."
|
|
||||||
#endif
|
|
||||||
#endif // (!defined(SIMDJSON_IS_X86_64)) && (!defined(SIMDJSON_IS_ARM64))
|
|
||||||
|
|
||||||
// this is almost standard?
|
// this is almost standard?
|
||||||
#undef STRINGIFY_IMPLEMENTATION_
|
#undef STRINGIFY_IMPLEMENTATION_
|
||||||
|
@ -74,6 +79,15 @@ compiling for a known 64-bit platform."
|
||||||
#define SIMDJSON_IMPLEMENTATION_WESTMERE 0
|
#define SIMDJSON_IMPLEMENTATION_WESTMERE 0
|
||||||
#endif // SIMDJSON_IS_ARM64
|
#endif // SIMDJSON_IS_ARM64
|
||||||
|
|
||||||
|
// Our fast kernels require 64-bit systems.
|
||||||
|
//
|
||||||
|
// On 32-bit x86, we lack 64-bit popcnt, lzcnt, blsr instructions.
|
||||||
|
// Furthermore, the number of SIMD registers is reduced.
|
||||||
|
//
|
||||||
|
// On 32-bit ARM, we would have smaller registers.
|
||||||
|
//
|
||||||
|
// The simdjson users should still have the fallback kernel. It is
|
||||||
|
// slower, but it should run everywhere.
|
||||||
#if SIMDJSON_IS_X86_64
|
#if SIMDJSON_IS_X86_64
|
||||||
#ifndef SIMDJSON_IMPLEMENTATION_HASWELL
|
#ifndef SIMDJSON_IMPLEMENTATION_HASWELL
|
||||||
#define SIMDJSON_IMPLEMENTATION_HASWELL 1
|
#define SIMDJSON_IMPLEMENTATION_HASWELL 1
|
||||||
|
@ -84,7 +98,7 @@ compiling for a known 64-bit platform."
|
||||||
#define SIMDJSON_IMPLEMENTATION_ARM64 0
|
#define SIMDJSON_IMPLEMENTATION_ARM64 0
|
||||||
#endif // SIMDJSON_IS_X86_64
|
#endif // SIMDJSON_IS_X86_64
|
||||||
|
|
||||||
// we are going to use runtime dispatch
|
// We are going to use runtime dispatch.
|
||||||
#ifdef SIMDJSON_IS_X86_64
|
#ifdef SIMDJSON_IS_X86_64
|
||||||
#ifdef __clang__
|
#ifdef __clang__
|
||||||
// clang does not have GCC push pop
|
// clang does not have GCC push pop
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
/* auto-generated on Tue 23 Jun 2020 20:51:12 EDT. Do not edit! */
|
/* auto-generated on Fri Jun 26 15:35:58 UTC 2020. Do not edit! */
|
||||||
|
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
#include "simdjson.h"
|
#include "simdjson.h"
|
||||||
|
@ -43,3 +43,4 @@ int main(int argc, char *argv[]) {
|
||||||
}
|
}
|
||||||
return EXIT_SUCCESS;
|
return EXIT_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
/* auto-generated on Tue 23 Jun 2020 20:51:12 EDT. Do not edit! */
|
/* auto-generated on Fri Jun 26 15:35:58 UTC 2020. Do not edit! */
|
||||||
/* begin file src/simdjson.cpp */
|
/* begin file src/simdjson.cpp */
|
||||||
#include "simdjson.h"
|
#include "simdjson.h"
|
||||||
|
|
||||||
|
@ -934,9 +934,8 @@ struct value128 {
|
||||||
uint64_t high;
|
uint64_t high;
|
||||||
};
|
};
|
||||||
|
|
||||||
#if defined(SIMDJSON_REGULAR_VISUAL_STUDIO) && \
|
#ifdef SIMDJSON_IS_32BITS // _umul128 for x86, arm
|
||||||
!defined(_M_X64) && !defined(_M_ARM64)// _umul128 for x86, arm
|
// this is a slow emulation routine for 32-bit
|
||||||
// this is a slow emulation routine for 32-bit Windows
|
|
||||||
//
|
//
|
||||||
static inline uint64_t __emulu(uint32_t x, uint32_t y) {
|
static inline uint64_t __emulu(uint32_t x, uint32_t y) {
|
||||||
return x * (uint64_t)y;
|
return x * (uint64_t)y;
|
||||||
|
@ -955,7 +954,7 @@ static inline uint64_t _umul128(uint64_t ab, uint64_t cd, uint64_t *hi) {
|
||||||
|
|
||||||
really_inline value128 full_multiplication(uint64_t value1, uint64_t value2) {
|
really_inline value128 full_multiplication(uint64_t value1, uint64_t value2) {
|
||||||
value128 answer;
|
value128 answer;
|
||||||
#ifdef SIMDJSON_REGULAR_VISUAL_STUDIO
|
#if defined(SIMDJSON_REGULAR_VISUAL_STUDIO) || defined(SIMDJSON_IS_32BITS)
|
||||||
#ifdef _M_ARM64
|
#ifdef _M_ARM64
|
||||||
// ARM64 has native support for 64-bit multiplications, no need to emultate
|
// ARM64 has native support for 64-bit multiplications, no need to emultate
|
||||||
answer.high = __umulh(value1, value2);
|
answer.high = __umulh(value1, value2);
|
||||||
|
@ -963,7 +962,7 @@ really_inline value128 full_multiplication(uint64_t value1, uint64_t value2) {
|
||||||
#else
|
#else
|
||||||
answer.low = _umul128(value1, value2, &answer.high); // _umul128 not available on ARM64
|
answer.low = _umul128(value1, value2, &answer.high); // _umul128 not available on ARM64
|
||||||
#endif // _M_ARM64
|
#endif // _M_ARM64
|
||||||
#else // SIMDJSON_REGULAR_VISUAL_STUDIO
|
#else // defined(SIMDJSON_REGULAR_VISUAL_STUDIO) || defined(SIMDJSON_IS_32BITS)
|
||||||
__uint128_t r = ((__uint128_t)value1) * value2;
|
__uint128_t r = ((__uint128_t)value1) * value2;
|
||||||
answer.low = uint64_t(r);
|
answer.low = uint64_t(r);
|
||||||
answer.high = uint64_t(r >> 64);
|
answer.high = uint64_t(r >> 64);
|
||||||
|
@ -7826,7 +7825,7 @@ really_inline bool add_overflow(uint64_t value1, uint64_t value2,
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef SIMDJSON_REGULAR_VISUAL_STUDIO
|
#if defined(SIMDJSON_REGULAR_VISUAL_STUDIO) || defined(SIMDJSON_IS_32BITS)
|
||||||
#pragma intrinsic(_umul128)
|
#pragma intrinsic(_umul128)
|
||||||
#endif
|
#endif
|
||||||
really_inline bool mul_overflow(uint64_t value1, uint64_t value2,
|
really_inline bool mul_overflow(uint64_t value1, uint64_t value2,
|
||||||
|
@ -11114,7 +11113,7 @@ really_inline bool add_overflow(uint64_t value1, uint64_t value2,
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef SIMDJSON_REGULAR_VISUAL_STUDIO
|
#if defined(SIMDJSON_REGULAR_VISUAL_STUDIO) || defined(SIMDJSON_IS_32BITS)
|
||||||
#pragma intrinsic(_umul128)
|
#pragma intrinsic(_umul128)
|
||||||
#endif
|
#endif
|
||||||
really_inline bool mul_overflow(uint64_t value1, uint64_t value2,
|
really_inline bool mul_overflow(uint64_t value1, uint64_t value2,
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
/* auto-generated on Tue 23 Jun 2020 20:51:12 EDT. Do not edit! */
|
/* auto-generated on Fri Jun 26 15:35:58 UTC 2020. Do not edit! */
|
||||||
/* begin file include/simdjson.h */
|
/* begin file include/simdjson.h */
|
||||||
#ifndef SIMDJSON_H
|
#ifndef SIMDJSON_H
|
||||||
#define SIMDJSON_H
|
#define SIMDJSON_H
|
||||||
|
@ -91,13 +91,14 @@
|
||||||
|
|
||||||
#if defined(__x86_64__) || defined(_M_AMD64)
|
#if defined(__x86_64__) || defined(_M_AMD64)
|
||||||
#define SIMDJSON_IS_X86_64 1
|
#define SIMDJSON_IS_X86_64 1
|
||||||
#endif
|
#elif defined(__aarch64__) || defined(_M_ARM64)
|
||||||
#if defined(__aarch64__) || defined(_M_ARM64)
|
|
||||||
#define SIMDJSON_IS_ARM64 1
|
#define SIMDJSON_IS_ARM64 1
|
||||||
|
#else
|
||||||
|
#define SIMDJSON_IS_32BITS 1
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if (!defined(SIMDJSON_IS_X86_64)) && (!defined(SIMDJSON_IS_ARM64))
|
#ifdef SIMDJSON_IS_32BITS
|
||||||
#ifdef SIMDJSON_REGULAR_VISUAL_STUDIO
|
#if defined(SIMDJSON_REGULAR_VISUAL_STUDIO) || defined(__GNUC__)
|
||||||
#pragma message("The simdjson library is designed\
|
#pragma message("The simdjson library is designed\
|
||||||
for 64-bit processors and it seems that you are not \
|
for 64-bit processors and it seems that you are not \
|
||||||
compiling for a known 64-bit platform. All fast kernels \
|
compiling for a known 64-bit platform. All fast kernels \
|
||||||
|
@ -108,7 +109,7 @@ use a 64-bit target such as x64 or 64-bit ARM.")
|
||||||
for 64-bit processors. It seems that you are not \
|
for 64-bit processors. It seems that you are not \
|
||||||
compiling for a known 64-bit platform."
|
compiling for a known 64-bit platform."
|
||||||
#endif
|
#endif
|
||||||
#endif // (!defined(SIMDJSON_IS_X86_64)) && (!defined(SIMDJSON_IS_ARM64))
|
#endif // SIMDJSON_IS_32BITS
|
||||||
|
|
||||||
// this is almost standard?
|
// this is almost standard?
|
||||||
#undef STRINGIFY_IMPLEMENTATION_
|
#undef STRINGIFY_IMPLEMENTATION_
|
||||||
|
@ -2632,7 +2633,6 @@ inline error_code dom_parser_implementation::allocate(size_t capacity, size_t ma
|
||||||
|
|
||||||
#endif // SIMDJSON_INTERNAL_DOM_PARSER_IMPLEMENTATION_H
|
#endif // SIMDJSON_INTERNAL_DOM_PARSER_IMPLEMENTATION_H
|
||||||
/* end file include/simdjson/internal/dom_parser_implementation.h */
|
/* end file include/simdjson/internal/dom_parser_implementation.h */
|
||||||
#include <optional>
|
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <atomic>
|
#include <atomic>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
@ -4008,21 +4008,42 @@ public:
|
||||||
*/
|
*/
|
||||||
inline simdjson_result<object> get_object() const noexcept;
|
inline simdjson_result<object> get_object() const noexcept;
|
||||||
/**
|
/**
|
||||||
* Cast this element to a string.
|
* Cast this element to a null-terminated C string.
|
||||||
|
*
|
||||||
|
* The string is guaranteed to be valid UTF-8.
|
||||||
*
|
*
|
||||||
* Equivalent to get<const char *>().
|
* The get_c_str() function is equivalent to get<const char *>().
|
||||||
|
*
|
||||||
|
* The length of the string is given by get_string_length(). Because JSON strings
|
||||||
|
* may contain null characters, it may be incorrect to use strlen to determine the
|
||||||
|
* string length.
|
||||||
*
|
*
|
||||||
* @returns An pointer to a null-terminated string. This string is stored in the parser and will
|
* It is possible to get a single string_view instance which represents both the string
|
||||||
|
* content and its length: see get_string().
|
||||||
|
*
|
||||||
|
* @returns A pointer to a null-terminated UTF-8 string. This string is stored in the parser and will
|
||||||
* be invalidated the next time it parses a document or when it is destroyed.
|
* be invalidated the next time it parses a document or when it is destroyed.
|
||||||
* Returns INCORRECT_TYPE if the JSON element is not a string.
|
* Returns INCORRECT_TYPE if the JSON element is not a string.
|
||||||
*/
|
*/
|
||||||
inline simdjson_result<const char *> get_c_str() const noexcept;
|
inline simdjson_result<const char *> get_c_str() const noexcept;
|
||||||
/**
|
/**
|
||||||
* Cast this element to a string.
|
* Gives the length in bytes of the string.
|
||||||
|
*
|
||||||
|
* It is possible to get a single string_view instance which represents both the string
|
||||||
|
* content and its length: see get_string().
|
||||||
|
*
|
||||||
|
* @returns A string length in bytes.
|
||||||
|
* Returns INCORRECT_TYPE if the JSON element is not a string.
|
||||||
|
*/
|
||||||
|
inline simdjson_result<size_t> get_string_length() const noexcept;
|
||||||
|
/**
|
||||||
|
* Cast this element to a string.
|
||||||
|
*
|
||||||
|
* The string is guaranteed to be valid UTF-8.
|
||||||
*
|
*
|
||||||
* Equivalent to get<std::string_view>().
|
* Equivalent to get<std::string_view>().
|
||||||
*
|
*
|
||||||
* @returns A string. The string is stored in the parser and will be invalidated the next time it
|
* @returns An UTF-8 string. The string is stored in the parser and will be invalidated the next time it
|
||||||
* parses a document or when it is destroyed.
|
* parses a document or when it is destroyed.
|
||||||
* Returns INCORRECT_TYPE if the JSON element is not a string.
|
* Returns INCORRECT_TYPE if the JSON element is not a string.
|
||||||
*/
|
*/
|
||||||
|
@ -4199,7 +4220,9 @@ public:
|
||||||
inline operator bool() const noexcept(false);
|
inline operator bool() const noexcept(false);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Read this element as a null-terminated string.
|
* Read this element as a null-terminated UTF-8 string.
|
||||||
|
*
|
||||||
|
* Be mindful that JSON allows strings to contain null characters.
|
||||||
*
|
*
|
||||||
* Does *not* convert other types to a string; requires that the JSON type of the element was
|
* Does *not* convert other types to a string; requires that the JSON type of the element was
|
||||||
* an actual string.
|
* an actual string.
|
||||||
|
@ -4210,7 +4233,7 @@ public:
|
||||||
inline explicit operator const char*() const noexcept(false);
|
inline explicit operator const char*() const noexcept(false);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Read this element as a null-terminated string.
|
* Read this element as a null-terminated UTF-8 string.
|
||||||
*
|
*
|
||||||
* Does *not* convert other types to a string; requires that the JSON type of the element was
|
* Does *not* convert other types to a string; requires that the JSON type of the element was
|
||||||
* an actual string.
|
* an actual string.
|
||||||
|
@ -4410,6 +4433,7 @@ public:
|
||||||
really_inline simdjson_result<dom::array> get_array() const noexcept;
|
really_inline simdjson_result<dom::array> get_array() const noexcept;
|
||||||
really_inline simdjson_result<dom::object> get_object() const noexcept;
|
really_inline simdjson_result<dom::object> get_object() const noexcept;
|
||||||
really_inline simdjson_result<const char *> get_c_str() const noexcept;
|
really_inline simdjson_result<const char *> get_c_str() const noexcept;
|
||||||
|
really_inline simdjson_result<size_t> get_string_length() const noexcept;
|
||||||
really_inline simdjson_result<std::string_view> get_string() const noexcept;
|
really_inline simdjson_result<std::string_view> get_string() const noexcept;
|
||||||
really_inline simdjson_result<int64_t> get_int64() const noexcept;
|
really_inline simdjson_result<int64_t> get_int64() const noexcept;
|
||||||
really_inline simdjson_result<uint64_t> get_uint64() const noexcept;
|
really_inline simdjson_result<uint64_t> get_uint64() const noexcept;
|
||||||
|
@ -5820,6 +5844,10 @@ really_inline simdjson_result<const char *> simdjson_result<dom::element>::get_c
|
||||||
if (error()) { return error(); }
|
if (error()) { return error(); }
|
||||||
return first.get_c_str();
|
return first.get_c_str();
|
||||||
}
|
}
|
||||||
|
really_inline simdjson_result<size_t> simdjson_result<dom::element>::get_string_length() const noexcept {
|
||||||
|
if (error()) { return error(); }
|
||||||
|
return first.get_string_length();
|
||||||
|
}
|
||||||
really_inline simdjson_result<std::string_view> simdjson_result<dom::element>::get_string() const noexcept {
|
really_inline simdjson_result<std::string_view> simdjson_result<dom::element>::get_string() const noexcept {
|
||||||
if (error()) { return error(); }
|
if (error()) { return error(); }
|
||||||
return first.get_string();
|
return first.get_string();
|
||||||
|
@ -5960,6 +5988,15 @@ inline simdjson_result<const char *> element::get_c_str() const noexcept {
|
||||||
return INCORRECT_TYPE;
|
return INCORRECT_TYPE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
inline simdjson_result<size_t> element::get_string_length() const noexcept {
|
||||||
|
switch (tape.tape_ref_type()) {
|
||||||
|
case internal::tape_type::STRING: {
|
||||||
|
return tape.get_string_length();
|
||||||
|
}
|
||||||
|
default:
|
||||||
|
return INCORRECT_TYPE;
|
||||||
|
}
|
||||||
|
}
|
||||||
inline simdjson_result<std::string_view> element::get_string() const noexcept {
|
inline simdjson_result<std::string_view> element::get_string() const noexcept {
|
||||||
switch (tape.tape_ref_type()) {
|
switch (tape.tape_ref_type()) {
|
||||||
case internal::tape_type::STRING:
|
case internal::tape_type::STRING:
|
||||||
|
@ -7610,14 +7647,14 @@ really_inline T tape_ref::next_tape_value() const noexcept {
|
||||||
}
|
}
|
||||||
|
|
||||||
really_inline uint32_t internal::tape_ref::get_string_length() const noexcept {
|
really_inline uint32_t internal::tape_ref::get_string_length() const noexcept {
|
||||||
uint64_t string_buf_index = size_t(tape_value());
|
size_t string_buf_index = size_t(tape_value());
|
||||||
uint32_t len;
|
uint32_t len;
|
||||||
memcpy(&len, &doc->string_buf[string_buf_index], sizeof(len));
|
memcpy(&len, &doc->string_buf[size_t(string_buf_index)], sizeof(len));
|
||||||
return len;
|
return len;
|
||||||
}
|
}
|
||||||
|
|
||||||
really_inline const char * internal::tape_ref::get_c_str() const noexcept {
|
really_inline const char * internal::tape_ref::get_c_str() const noexcept {
|
||||||
uint64_t string_buf_index = size_t(tape_value());
|
size_t string_buf_index = size_t(tape_value());
|
||||||
return reinterpret_cast<const char *>(&doc->string_buf[string_buf_index + sizeof(uint32_t)]);
|
return reinterpret_cast<const char *>(&doc->string_buf[string_buf_index + sizeof(uint32_t)]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -13,7 +13,15 @@ really_inline double compute_float_64(int64_t power, uint64_t i, bool negative,
|
||||||
// It was described in
|
// It was described in
|
||||||
// Clinger WD. How to read floating point numbers accurately.
|
// Clinger WD. How to read floating point numbers accurately.
|
||||||
// ACM SIGPLAN Notices. 1990
|
// ACM SIGPLAN Notices. 1990
|
||||||
|
#ifndef FLT_EVAL_METHOD
|
||||||
|
#error "FLT_EVAL_METHOD should be defined, please include cfloat."
|
||||||
|
#endif
|
||||||
|
#if (FLT_EVAL_METHOD != 1) && (FLT_EVAL_METHOD != 0)
|
||||||
|
// We cannot be certain that x/y is rounded to nearest.
|
||||||
|
if (0 <= power && power <= 22 && i <= 9007199254740991) {
|
||||||
|
#else
|
||||||
if (-22 <= power && power <= 22 && i <= 9007199254740991) {
|
if (-22 <= power && power <= 22 && i <= 9007199254740991) {
|
||||||
|
#endif
|
||||||
// convert the integer into a double. This is lossless since
|
// convert the integer into a double. This is lossless since
|
||||||
// 0 <= i <= 2^53 - 1.
|
// 0 <= i <= 2^53 - 1.
|
||||||
double d = double(i);
|
double d = double(i);
|
||||||
|
|
|
@ -58,7 +58,7 @@ really_inline bool add_overflow(uint64_t value1, uint64_t value2,
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef SIMDJSON_REGULAR_VISUAL_STUDIO
|
#if defined(SIMDJSON_REGULAR_VISUAL_STUDIO) || defined(SIMDJSON_IS_32BITS)
|
||||||
#pragma intrinsic(_umul128)
|
#pragma intrinsic(_umul128)
|
||||||
#endif
|
#endif
|
||||||
really_inline bool mul_overflow(uint64_t value1, uint64_t value2,
|
really_inline bool mul_overflow(uint64_t value1, uint64_t value2,
|
||||||
|
|
|
@ -317,9 +317,8 @@ struct value128 {
|
||||||
uint64_t high;
|
uint64_t high;
|
||||||
};
|
};
|
||||||
|
|
||||||
#if defined(SIMDJSON_REGULAR_VISUAL_STUDIO) && \
|
#ifdef SIMDJSON_IS_32BITS // _umul128 for x86, arm
|
||||||
!defined(_M_X64) && !defined(_M_ARM64)// _umul128 for x86, arm
|
// this is a slow emulation routine for 32-bit
|
||||||
// this is a slow emulation routine for 32-bit Windows
|
|
||||||
//
|
//
|
||||||
static inline uint64_t __emulu(uint32_t x, uint32_t y) {
|
static inline uint64_t __emulu(uint32_t x, uint32_t y) {
|
||||||
return x * (uint64_t)y;
|
return x * (uint64_t)y;
|
||||||
|
@ -338,7 +337,7 @@ static inline uint64_t _umul128(uint64_t ab, uint64_t cd, uint64_t *hi) {
|
||||||
|
|
||||||
really_inline value128 full_multiplication(uint64_t value1, uint64_t value2) {
|
really_inline value128 full_multiplication(uint64_t value1, uint64_t value2) {
|
||||||
value128 answer;
|
value128 answer;
|
||||||
#ifdef SIMDJSON_REGULAR_VISUAL_STUDIO
|
#if defined(SIMDJSON_REGULAR_VISUAL_STUDIO) || defined(SIMDJSON_IS_32BITS)
|
||||||
#ifdef _M_ARM64
|
#ifdef _M_ARM64
|
||||||
// ARM64 has native support for 64-bit multiplications, no need to emultate
|
// ARM64 has native support for 64-bit multiplications, no need to emultate
|
||||||
answer.high = __umulh(value1, value2);
|
answer.high = __umulh(value1, value2);
|
||||||
|
@ -346,7 +345,7 @@ really_inline value128 full_multiplication(uint64_t value1, uint64_t value2) {
|
||||||
#else
|
#else
|
||||||
answer.low = _umul128(value1, value2, &answer.high); // _umul128 not available on ARM64
|
answer.low = _umul128(value1, value2, &answer.high); // _umul128 not available on ARM64
|
||||||
#endif // _M_ARM64
|
#endif // _M_ARM64
|
||||||
#else // SIMDJSON_REGULAR_VISUAL_STUDIO
|
#else // defined(SIMDJSON_REGULAR_VISUAL_STUDIO) || defined(SIMDJSON_IS_32BITS)
|
||||||
__uint128_t r = ((__uint128_t)value1) * value2;
|
__uint128_t r = ((__uint128_t)value1) * value2;
|
||||||
answer.low = uint64_t(r);
|
answer.low = uint64_t(r);
|
||||||
answer.high = uint64_t(r >> 64);
|
answer.high = uint64_t(r >> 64);
|
||||||
|
|
|
@ -1,5 +1,9 @@
|
||||||
#ifndef SIMDJSON_SIMDPRUNE_TABLES_H
|
#ifndef SIMDJSON_SIMDPRUNE_TABLES_H
|
||||||
#define SIMDJSON_SIMDPRUNE_TABLES_H
|
#define SIMDJSON_SIMDPRUNE_TABLES_H
|
||||||
|
|
||||||
|
|
||||||
|
#if SIMDJSON_IMPLEMENTATION_ARM64 || SIMDJSON_IMPLEMENTATION_HASWELL || SIMDJSON_IMPLEMENTATION_WESTMERE
|
||||||
|
|
||||||
#include <cstdint>
|
#include <cstdint>
|
||||||
|
|
||||||
namespace simdjson { // table modified and copied from
|
namespace simdjson { // table modified and copied from
|
||||||
|
@ -127,4 +131,6 @@ static const uint64_t thintable_epi8[256] = {
|
||||||
|
|
||||||
} // namespace simdjson
|
} // namespace simdjson
|
||||||
|
|
||||||
|
|
||||||
|
#endif // SIMDJSON_IMPLEMENTATION_ARM64 || SIMDJSON_IMPLEMENTATION_HASWELL || SIMDJSON_IMPLEMENTATION_WESTMERE
|
||||||
#endif // SIMDJSON_SIMDPRUNE_TABLES_H
|
#endif // SIMDJSON_SIMDPRUNE_TABLES_H
|
||||||
|
|
|
@ -66,7 +66,7 @@ really_inline bool add_overflow(uint64_t value1, uint64_t value2,
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef SIMDJSON_REGULAR_VISUAL_STUDIO
|
#if defined(SIMDJSON_REGULAR_VISUAL_STUDIO) || defined(SIMDJSON_IS_32BITS)
|
||||||
#pragma intrinsic(_umul128)
|
#pragma intrinsic(_umul128)
|
||||||
#endif
|
#endif
|
||||||
really_inline bool mul_overflow(uint64_t value1, uint64_t value2,
|
really_inline bool mul_overflow(uint64_t value1, uint64_t value2,
|
||||||
|
|
Loading…
Reference in New Issue