react-native-quick-crypto 1.1.0 → 1.1.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/android/build.gradle +5 -1
- package/cpp/argon2/HybridArgon2.cpp +10 -3
- package/cpp/blake3/HybridBlake3.cpp +5 -3
- package/cpp/cipher/CCMCipher.cpp +29 -16
- package/cpp/cipher/CCMCipher.hpp +2 -4
- package/cpp/cipher/ChaCha20Cipher.cpp +14 -18
- package/cpp/cipher/ChaCha20Cipher.hpp +2 -4
- package/cpp/cipher/ChaCha20Poly1305Cipher.cpp +34 -23
- package/cpp/cipher/ChaCha20Poly1305Cipher.hpp +2 -4
- package/cpp/cipher/GCMCipher.cpp +14 -15
- package/cpp/cipher/HybridCipher.cpp +39 -36
- package/cpp/cipher/HybridCipher.hpp +17 -1
- package/cpp/cipher/HybridRsaCipher.cpp +74 -29
- package/cpp/cipher/OCBCipher.cpp +4 -3
- package/cpp/cipher/XChaCha20Poly1305Cipher.cpp +14 -13
- package/cpp/cipher/XSalsa20Cipher.cpp +72 -6
- package/cpp/cipher/XSalsa20Cipher.hpp +25 -3
- package/cpp/cipher/XSalsa20Poly1305Cipher.cpp +21 -25
- package/cpp/dh/HybridDiffieHellman.cpp +29 -0
- package/cpp/ec/HybridEcKeyPair.cpp +35 -33
- package/cpp/ec/HybridEcKeyPair.hpp +3 -7
- package/cpp/ecdh/HybridECDH.cpp +23 -0
- package/cpp/ed25519/HybridEdKeyPair.cpp +73 -117
- package/cpp/ed25519/HybridEdKeyPair.hpp +5 -9
- package/cpp/hash/HybridHash.cpp +5 -7
- package/cpp/hkdf/HybridHkdf.cpp +6 -4
- package/cpp/hmac/HybridHmac.cpp +4 -6
- package/cpp/kmac/HybridKmac.cpp +4 -4
- package/cpp/mldsa/HybridMlDsaKeyPair.cpp +37 -49
- package/cpp/mlkem/HybridMlKemKeyPair.cpp +39 -43
- package/cpp/pbkdf2/HybridPbkdf2.cpp +7 -8
- package/cpp/rsa/HybridRsaKeyPair.cpp +5 -8
- package/cpp/rsa/HybridRsaKeyPair.hpp +4 -7
- package/cpp/scrypt/HybridScrypt.cpp +6 -4
- package/cpp/sign/HybridSignHandle.cpp +25 -68
- package/cpp/sign/HybridVerifyHandle.cpp +23 -60
- package/cpp/utils/HybridUtils.cpp +183 -43
- package/cpp/utils/HybridUtils.hpp +9 -2
- package/cpp/utils/QuickCryptoUtils.hpp +72 -0
- package/lib/commonjs/argon2.js +51 -2
- package/lib/commonjs/argon2.js.map +1 -1
- package/lib/commonjs/cipher.js +109 -11
- package/lib/commonjs/cipher.js.map +1 -1
- package/lib/commonjs/dsa.js +8 -2
- package/lib/commonjs/dsa.js.map +1 -1
- package/lib/commonjs/hash.js +15 -5
- package/lib/commonjs/hash.js.map +1 -1
- package/lib/commonjs/hkdf.js +33 -6
- package/lib/commonjs/hkdf.js.map +1 -1
- package/lib/commonjs/hmac.js +15 -5
- package/lib/commonjs/hmac.js.map +1 -1
- package/lib/commonjs/keys/publicCipher.js +10 -4
- package/lib/commonjs/keys/publicCipher.js.map +1 -1
- package/lib/commonjs/random.js +11 -2
- package/lib/commonjs/random.js.map +1 -1
- package/lib/commonjs/rsa.js +12 -5
- package/lib/commonjs/rsa.js.map +1 -1
- package/lib/commonjs/scrypt.js +47 -6
- package/lib/commonjs/scrypt.js.map +1 -1
- package/lib/commonjs/subtle.js +76 -5
- package/lib/commonjs/subtle.js.map +1 -1
- package/lib/commonjs/utils/cipher.js +18 -7
- package/lib/commonjs/utils/cipher.js.map +1 -1
- package/lib/commonjs/utils/conversion.js +33 -9
- package/lib/commonjs/utils/conversion.js.map +1 -1
- package/lib/commonjs/utils/timingSafeEqual.js +7 -2
- package/lib/commonjs/utils/timingSafeEqual.js.map +1 -1
- package/lib/commonjs/x509certificate.js +6 -6
- package/lib/commonjs/x509certificate.js.map +1 -1
- package/lib/module/argon2.js +51 -2
- package/lib/module/argon2.js.map +1 -1
- package/lib/module/cipher.js +109 -11
- package/lib/module/cipher.js.map +1 -1
- package/lib/module/dsa.js +8 -2
- package/lib/module/dsa.js.map +1 -1
- package/lib/module/hash.js +15 -5
- package/lib/module/hash.js.map +1 -1
- package/lib/module/hkdf.js +33 -6
- package/lib/module/hkdf.js.map +1 -1
- package/lib/module/hmac.js +15 -5
- package/lib/module/hmac.js.map +1 -1
- package/lib/module/keys/publicCipher.js +10 -4
- package/lib/module/keys/publicCipher.js.map +1 -1
- package/lib/module/random.js +11 -2
- package/lib/module/random.js.map +1 -1
- package/lib/module/rsa.js +11 -4
- package/lib/module/rsa.js.map +1 -1
- package/lib/module/scrypt.js +47 -6
- package/lib/module/scrypt.js.map +1 -1
- package/lib/module/subtle.js +76 -5
- package/lib/module/subtle.js.map +1 -1
- package/lib/module/utils/cipher.js +18 -7
- package/lib/module/utils/cipher.js.map +1 -1
- package/lib/module/utils/conversion.js +33 -9
- package/lib/module/utils/conversion.js.map +1 -1
- package/lib/module/utils/timingSafeEqual.js +8 -3
- package/lib/module/utils/timingSafeEqual.js.map +1 -1
- package/lib/module/x509certificate.js +6 -6
- package/lib/module/x509certificate.js.map +1 -1
- package/lib/typescript/argon2.d.ts.map +1 -1
- package/lib/typescript/cipher.d.ts +2 -2
- package/lib/typescript/cipher.d.ts.map +1 -1
- package/lib/typescript/dsa.d.ts.map +1 -1
- package/lib/typescript/hash.d.ts +2 -2
- package/lib/typescript/hash.d.ts.map +1 -1
- package/lib/typescript/hkdf.d.ts.map +1 -1
- package/lib/typescript/hmac.d.ts +2 -2
- package/lib/typescript/hmac.d.ts.map +1 -1
- package/lib/typescript/index.d.ts +1 -1
- package/lib/typescript/index.d.ts.map +1 -1
- package/lib/typescript/keys/publicCipher.d.ts.map +1 -1
- package/lib/typescript/random.d.ts.map +1 -1
- package/lib/typescript/rsa.d.ts.map +1 -1
- package/lib/typescript/scrypt.d.ts.map +1 -1
- package/lib/typescript/specs/utils.nitro.d.ts +0 -2
- package/lib/typescript/specs/utils.nitro.d.ts.map +1 -1
- package/lib/typescript/subtle.d.ts.map +1 -1
- package/lib/typescript/utils/cipher.d.ts +13 -1
- package/lib/typescript/utils/cipher.d.ts.map +1 -1
- package/lib/typescript/utils/conversion.d.ts +9 -6
- package/lib/typescript/utils/conversion.d.ts.map +1 -1
- package/lib/typescript/utils/timingSafeEqual.d.ts.map +1 -1
- package/lib/typescript/x509certificate.d.ts.map +1 -1
- package/nitrogen/generated/shared/c++/HybridUtilsSpec.cpp +0 -2
- package/nitrogen/generated/shared/c++/HybridUtilsSpec.hpp +0 -3
- package/package.json +37 -5
- package/src/argon2.ts +80 -2
- package/src/cipher.ts +139 -15
- package/src/dsa.ts +11 -2
- package/src/hash.ts +17 -7
- package/src/hkdf.ts +44 -6
- package/src/hmac.ts +17 -7
- package/src/keys/publicCipher.ts +10 -4
- package/src/random.ts +11 -2
- package/src/rsa.ts +18 -4
- package/src/scrypt.ts +73 -6
- package/src/specs/utils.nitro.ts +0 -2
- package/src/subtle.ts +90 -8
- package/src/utils/cipher.ts +30 -8
- package/src/utils/conversion.ts +58 -20
- package/src/utils/timingSafeEqual.ts +8 -3
- package/src/x509certificate.ts +5 -6
- package/deps/blake3/.cargo/config.toml +0 -2
- package/deps/blake3/.git-blame-ignore-revs +0 -2
- package/deps/blake3/.github/workflows/build_b3sum.py +0 -38
- package/deps/blake3/.github/workflows/ci.yml +0 -491
- package/deps/blake3/.github/workflows/tag.yml +0 -43
- package/deps/blake3/.github/workflows/upload_github_release_asset.py +0 -73
- package/deps/blake3/CONTRIBUTING.md +0 -31
- package/deps/blake3/Cargo.toml +0 -135
- package/deps/blake3/b3sum/Cargo.lock +0 -513
- package/deps/blake3/b3sum/Cargo.toml +0 -26
- package/deps/blake3/b3sum/README.md +0 -72
- package/deps/blake3/b3sum/src/main.rs +0 -564
- package/deps/blake3/b3sum/src/unit_tests.rs +0 -235
- package/deps/blake3/b3sum/tests/cli_tests.rs +0 -680
- package/deps/blake3/b3sum/what_does_check_do.md +0 -176
- package/deps/blake3/benches/bench.rs +0 -623
- package/deps/blake3/build.rs +0 -389
- package/deps/blake3/c/CMakeLists.txt +0 -383
- package/deps/blake3/c/CMakePresets.json +0 -73
- package/deps/blake3/c/Makefile.testing +0 -82
- package/deps/blake3/c/blake3-config.cmake.in +0 -14
- package/deps/blake3/c/blake3_avx2.c +0 -326
- package/deps/blake3/c/blake3_avx2_x86-64_unix.S +0 -1815
- package/deps/blake3/c/blake3_avx2_x86-64_windows_gnu.S +0 -1817
- package/deps/blake3/c/blake3_avx2_x86-64_windows_msvc.asm +0 -1828
- package/deps/blake3/c/blake3_avx512.c +0 -1388
- package/deps/blake3/c/blake3_avx512_x86-64_unix.S +0 -4824
- package/deps/blake3/c/blake3_avx512_x86-64_windows_gnu.S +0 -2615
- package/deps/blake3/c/blake3_avx512_x86-64_windows_msvc.asm +0 -2634
- package/deps/blake3/c/blake3_c_rust_bindings/Cargo.toml +0 -32
- package/deps/blake3/c/blake3_c_rust_bindings/README.md +0 -4
- package/deps/blake3/c/blake3_c_rust_bindings/benches/bench.rs +0 -477
- package/deps/blake3/c/blake3_c_rust_bindings/build.rs +0 -253
- package/deps/blake3/c/blake3_c_rust_bindings/cross_test.sh +0 -31
- package/deps/blake3/c/blake3_c_rust_bindings/src/lib.rs +0 -333
- package/deps/blake3/c/blake3_c_rust_bindings/src/test.rs +0 -696
- package/deps/blake3/c/blake3_sse2.c +0 -566
- package/deps/blake3/c/blake3_sse2_x86-64_unix.S +0 -2291
- package/deps/blake3/c/blake3_sse2_x86-64_windows_gnu.S +0 -2332
- package/deps/blake3/c/blake3_sse2_x86-64_windows_msvc.asm +0 -2350
- package/deps/blake3/c/blake3_sse41.c +0 -560
- package/deps/blake3/c/blake3_sse41_x86-64_unix.S +0 -2028
- package/deps/blake3/c/blake3_sse41_x86-64_windows_gnu.S +0 -2069
- package/deps/blake3/c/blake3_sse41_x86-64_windows_msvc.asm +0 -2089
- package/deps/blake3/c/blake3_tbb.cpp +0 -37
- package/deps/blake3/c/dependencies/CMakeLists.txt +0 -3
- package/deps/blake3/c/dependencies/tbb/CMakeLists.txt +0 -28
- package/deps/blake3/c/example.c +0 -36
- package/deps/blake3/c/example_tbb.c +0 -57
- package/deps/blake3/c/libblake3.pc.in +0 -12
- package/deps/blake3/c/main.c +0 -166
- package/deps/blake3/c/test.py +0 -97
- package/deps/blake3/media/B3.svg +0 -70
- package/deps/blake3/media/BLAKE3.svg +0 -85
- package/deps/blake3/media/speed.svg +0 -1474
- package/deps/blake3/reference_impl/Cargo.toml +0 -8
- package/deps/blake3/reference_impl/README.md +0 -14
- package/deps/blake3/reference_impl/reference_impl.rs +0 -374
- package/deps/blake3/src/ffi_avx2.rs +0 -65
- package/deps/blake3/src/ffi_avx512.rs +0 -169
- package/deps/blake3/src/ffi_neon.rs +0 -82
- package/deps/blake3/src/ffi_sse2.rs +0 -126
- package/deps/blake3/src/ffi_sse41.rs +0 -126
- package/deps/blake3/src/guts.rs +0 -60
- package/deps/blake3/src/hazmat.rs +0 -704
- package/deps/blake3/src/io.rs +0 -64
- package/deps/blake3/src/join.rs +0 -92
- package/deps/blake3/src/lib.rs +0 -1835
- package/deps/blake3/src/platform.rs +0 -587
- package/deps/blake3/src/portable.rs +0 -198
- package/deps/blake3/src/rust_avx2.rs +0 -474
- package/deps/blake3/src/rust_sse2.rs +0 -775
- package/deps/blake3/src/rust_sse41.rs +0 -766
- package/deps/blake3/src/test.rs +0 -1049
- package/deps/blake3/src/traits.rs +0 -227
- package/deps/blake3/src/wasm32_simd.rs +0 -794
- package/deps/blake3/test_vectors/Cargo.toml +0 -19
- package/deps/blake3/test_vectors/cross_test.sh +0 -25
- package/deps/blake3/test_vectors/src/bin/generate.rs +0 -4
- package/deps/blake3/test_vectors/src/lib.rs +0 -350
- package/deps/blake3/test_vectors/test_vectors.json +0 -217
- package/deps/blake3/tools/compiler_version/Cargo.toml +0 -7
- package/deps/blake3/tools/compiler_version/build.rs +0 -6
- package/deps/blake3/tools/compiler_version/src/main.rs +0 -27
- package/deps/blake3/tools/instruction_set_support/Cargo.toml +0 -6
- package/deps/blake3/tools/instruction_set_support/src/main.rs +0 -10
- package/deps/blake3/tools/release.md +0 -16
- package/deps/ncrypto/.bazelignore +0 -4
- package/deps/ncrypto/.bazelrc +0 -1
- package/deps/ncrypto/.bazelversion +0 -1
- package/deps/ncrypto/.clang-format +0 -111
- package/deps/ncrypto/.github/workflows/bazel.yml +0 -58
- package/deps/ncrypto/.github/workflows/commitlint.yml +0 -16
- package/deps/ncrypto/.github/workflows/linter.yml +0 -38
- package/deps/ncrypto/.github/workflows/macos.yml +0 -43
- package/deps/ncrypto/.github/workflows/release-please.yml +0 -16
- package/deps/ncrypto/.github/workflows/ubuntu.yml +0 -128
- package/deps/ncrypto/.github/workflows/visual-studio.yml +0 -49
- package/deps/ncrypto/.python-version +0 -1
- package/deps/ncrypto/.release-please-manifest.json +0 -3
- package/deps/ncrypto/BUILD.bazel +0 -44
- package/deps/ncrypto/CHANGELOG.md +0 -37
- package/deps/ncrypto/CMakeLists.txt +0 -79
- package/deps/ncrypto/MODULE.bazel +0 -16
- package/deps/ncrypto/MODULE.bazel.lock +0 -461
- package/deps/ncrypto/cmake/CPM.cmake +0 -1225
- package/deps/ncrypto/cmake/ncrypto-flags.cmake +0 -17
- package/deps/ncrypto/ncrypto.pc.in +0 -10
- package/deps/ncrypto/patches/0001-Expose-libdecrepit-so-NodeJS-can-use-it-for-ncrypto.patch +0 -28
- package/deps/ncrypto/pyproject.toml +0 -38
- package/deps/ncrypto/release-please-config.json +0 -11
- package/deps/ncrypto/src/CMakeLists.txt +0 -40
- package/deps/ncrypto/tests/BUILD.bazel +0 -11
- package/deps/ncrypto/tests/CMakeLists.txt +0 -7
- package/deps/ncrypto/tests/basic.cpp +0 -856
- package/deps/ncrypto/tools/run-clang-format.sh +0 -42
- package/deps/simdutf/.clang-format +0 -4
- package/deps/simdutf/.github/ISSUE_TEMPLATE/bug_report.md +0 -62
- package/deps/simdutf/.github/ISSUE_TEMPLATE/config.yml +0 -1
- package/deps/simdutf/.github/ISSUE_TEMPLATE/feature_request.md +0 -35
- package/deps/simdutf/.github/ISSUE_TEMPLATE/standard-issue-template.md +0 -29
- package/deps/simdutf/.github/pull_request_template.md +0 -51
- package/deps/simdutf/.github/workflows/aarch64.yml +0 -39
- package/deps/simdutf/.github/workflows/alpine.yml +0 -27
- package/deps/simdutf/.github/workflows/amalgamation_demos.yml +0 -34
- package/deps/simdutf/.github/workflows/armv7.yml +0 -32
- package/deps/simdutf/.github/workflows/atomic_fuzz.yml +0 -25
- package/deps/simdutf/.github/workflows/cifuzz.yml +0 -37
- package/deps/simdutf/.github/workflows/clangformat.yml +0 -36
- package/deps/simdutf/.github/workflows/debian-latestcxxstandards.yml +0 -40
- package/deps/simdutf/.github/workflows/debian.yml +0 -33
- package/deps/simdutf/.github/workflows/documentation.yml +0 -36
- package/deps/simdutf/.github/workflows/emscripten.yml +0 -19
- package/deps/simdutf/.github/workflows/loongarch64-gcc-14.2.yml +0 -39
- package/deps/simdutf/.github/workflows/macos-latest.yml +0 -29
- package/deps/simdutf/.github/workflows/msys2-clang.yml +0 -48
- package/deps/simdutf/.github/workflows/msys2.yml +0 -50
- package/deps/simdutf/.github/workflows/ppc64le.yml +0 -29
- package/deps/simdutf/.github/workflows/rvv-1024-clang-18.yml +0 -35
- package/deps/simdutf/.github/workflows/rvv-128-clang-17.yml +0 -35
- package/deps/simdutf/.github/workflows/rvv-256-gcc-14.yml +0 -31
- package/deps/simdutf/.github/workflows/s390x.yml +0 -29
- package/deps/simdutf/.github/workflows/selective-amalgamation.yml +0 -29
- package/deps/simdutf/.github/workflows/typos.yml +0 -19
- package/deps/simdutf/.github/workflows/ubuntu22-cxx20.yml +0 -30
- package/deps/simdutf/.github/workflows/ubuntu22.yml +0 -32
- package/deps/simdutf/.github/workflows/ubuntu22_gcc12.yml +0 -27
- package/deps/simdutf/.github/workflows/ubuntu22sani.yml +0 -29
- package/deps/simdutf/.github/workflows/ubuntu24-cxxstandards.yml +0 -34
- package/deps/simdutf/.github/workflows/ubuntu24-unsignedchar.yml +0 -34
- package/deps/simdutf/.github/workflows/ubuntu24.yml +0 -32
- package/deps/simdutf/.github/workflows/ubuntu24sani.yml +0 -36
- package/deps/simdutf/.github/workflows/ubuntu24sani_clang.yml +0 -29
- package/deps/simdutf/.github/workflows/vs17-arm-ci.yml +0 -21
- package/deps/simdutf/.github/workflows/vs17-ci-cxx20.yml +0 -41
- package/deps/simdutf/.github/workflows/vs17-ci.yml +0 -41
- package/deps/simdutf/.github/workflows/vs17-clang-ci.yml +0 -41
- package/deps/simdutf/.github/workflows/vs17-cxxstandards.yml +0 -36
- package/deps/simdutf/AI_USAGE_POLICY.md +0 -56
- package/deps/simdutf/AUTHORS +0 -6
- package/deps/simdutf/CMakeLists.txt +0 -231
- package/deps/simdutf/CONTRIBUTING.md +0 -214
- package/deps/simdutf/CONTRIBUTORS +0 -1
- package/deps/simdutf/Doxyfile +0 -2584
- package/deps/simdutf/Makefile.crosscompile +0 -54
- package/deps/simdutf/README-RVV.md +0 -16
- package/deps/simdutf/SECURITY.md +0 -8
- package/deps/simdutf/benchmarks/CMakeLists.txt +0 -101
- package/deps/simdutf/benchmarks/alignment.cpp +0 -150
- package/deps/simdutf/benchmarks/base64/CMakeLists.txt +0 -30
- package/deps/simdutf/benchmarks/base64/benchmark_base64.cpp +0 -875
- package/deps/simdutf/benchmarks/base64/libbase64_spaces.h +0 -49
- package/deps/simdutf/benchmarks/base64/node_base64.h +0 -227
- package/deps/simdutf/benchmarks/base64/openssl3_base64.h +0 -334
- package/deps/simdutf/benchmarks/benchmark.cpp +0 -65
- package/deps/simdutf/benchmarks/benchmark_to_well_formed_utf16.cpp +0 -347
- package/deps/simdutf/benchmarks/competition/.clang-format-ignore +0 -5
- package/deps/simdutf/benchmarks/competition/CppCon2018/utf_utils.cpp +0 -1276
- package/deps/simdutf/benchmarks/competition/CppCon2018/utf_utils.h +0 -595
- package/deps/simdutf/benchmarks/competition/README.md +0 -7
- package/deps/simdutf/benchmarks/competition/hoehrmann/hoehrmann.h +0 -91
- package/deps/simdutf/benchmarks/competition/inoue2008/inoue_utf8_to_utf16.h +0 -444
- package/deps/simdutf/benchmarks/competition/inoue2008/inoue_utf8_to_utf16_tables.h +0 -13183
- package/deps/simdutf/benchmarks/competition/inoue2008/script.py +0 -73
- package/deps/simdutf/benchmarks/competition/llvm/ConvertUTF.cpp +0 -738
- package/deps/simdutf/benchmarks/competition/llvm/ConvertUTF.h +0 -293
- package/deps/simdutf/benchmarks/competition/u8u16/COPYRIGHT +0 -8
- package/deps/simdutf/benchmarks/competition/u8u16/Makefile +0 -44
- package/deps/simdutf/benchmarks/competition/u8u16/OSL3.0.txt +0 -169
- package/deps/simdutf/benchmarks/competition/u8u16/Profiling/BOM_Profiler.h +0 -148
- package/deps/simdutf/benchmarks/competition/u8u16/Profiling/i386_timer.h +0 -45
- package/deps/simdutf/benchmarks/competition/u8u16/Profiling/ppc_timer.c +0 -34
- package/deps/simdutf/benchmarks/competition/u8u16/README +0 -56
- package/deps/simdutf/benchmarks/competition/u8u16/config/config_defs.h +0 -43
- package/deps/simdutf/benchmarks/competition/u8u16/config/g4_config.h +0 -27
- package/deps/simdutf/benchmarks/competition/u8u16/config/mmx_config.h +0 -16
- package/deps/simdutf/benchmarks/competition/u8u16/config/p4_config.h +0 -18
- package/deps/simdutf/benchmarks/competition/u8u16/config/p4_ideal_config.h +0 -16
- package/deps/simdutf/benchmarks/competition/u8u16/config/spu_config.h +0 -28
- package/deps/simdutf/benchmarks/competition/u8u16/config/ssse3_config.h +0 -20
- package/deps/simdutf/benchmarks/competition/u8u16/iconv_u8u16.c +0 -2
- package/deps/simdutf/benchmarks/competition/u8u16/lib/altivec_simd.h +0 -440
- package/deps/simdutf/benchmarks/competition/u8u16/lib/libgen/make_basic_ops.py +0 -121
- package/deps/simdutf/benchmarks/competition/u8u16/lib/libgen/make_half_operand_versions.py +0 -158
- package/deps/simdutf/benchmarks/competition/u8u16/lib/libgen/make_test.py +0 -270
- package/deps/simdutf/benchmarks/competition/u8u16/lib/mmx_simd.h +0 -141
- package/deps/simdutf/benchmarks/competition/u8u16/lib/mmx_simd_basic.h +0 -216
- package/deps/simdutf/benchmarks/competition/u8u16/lib/mmx_simd_built_in.h +0 -119
- package/deps/simdutf/benchmarks/competition/u8u16/lib/mmx_simd_modified.h +0 -2430
- package/deps/simdutf/benchmarks/competition/u8u16/lib/outline.txt +0 -39
- package/deps/simdutf/benchmarks/competition/u8u16/lib/spu_simd.h +0 -421
- package/deps/simdutf/benchmarks/competition/u8u16/lib/sse_simd.h +0 -836
- package/deps/simdutf/benchmarks/competition/u8u16/lib/stdint.h +0 -222
- package/deps/simdutf/benchmarks/competition/u8u16/libu8u16_BE.c +0 -4
- package/deps/simdutf/benchmarks/competition/u8u16/libu8u16_LE.c +0 -5
- package/deps/simdutf/benchmarks/competition/u8u16/proto/u8u16.py +0 -390
- package/deps/simdutf/benchmarks/competition/u8u16/src/Makefile +0 -18
- package/deps/simdutf/benchmarks/competition/u8u16/src/bytelex.h +0 -448
- package/deps/simdutf/benchmarks/competition/u8u16/src/charsets/ASCII_EBCDIC.h +0 -284
- package/deps/simdutf/benchmarks/competition/u8u16/src/libu8u16.c +0 -1975
- package/deps/simdutf/benchmarks/competition/u8u16/src/libu8u16.pdf +0 -0
- package/deps/simdutf/benchmarks/competition/u8u16/src/libu8u16.w +0 -2263
- package/deps/simdutf/benchmarks/competition/u8u16/src/multiliteral.h +0 -239
- package/deps/simdutf/benchmarks/competition/u8u16/src/u8u16.c +0 -232
- package/deps/simdutf/benchmarks/competition/u8u16/src/x8x16.c +0 -194
- package/deps/simdutf/benchmarks/competition/u8u16/src/xml_error.c +0 -193
- package/deps/simdutf/benchmarks/competition/u8u16/src/xml_error.h +0 -167
- package/deps/simdutf/benchmarks/competition/u8u16/src/xmldecl.c +0 -288
- package/deps/simdutf/benchmarks/competition/u8u16/src/xmldecl.h +0 -117
- package/deps/simdutf/benchmarks/competition/u8u16/u8u16_g4.c +0 -2
- package/deps/simdutf/benchmarks/competition/u8u16/u8u16_mmx.c +0 -2
- package/deps/simdutf/benchmarks/competition/u8u16/u8u16_p4.c +0 -3
- package/deps/simdutf/benchmarks/competition/u8u16/u8u16_p4_ideal.c +0 -2
- package/deps/simdutf/benchmarks/competition/u8u16/u8u16_spu.c +0 -2
- package/deps/simdutf/benchmarks/competition/u8u16/u8u16_ssse3.c +0 -3
- package/deps/simdutf/benchmarks/competition/u8u16/x8x16_p4.c +0 -2
- package/deps/simdutf/benchmarks/competition/utf8lut/LICENSE +0 -23
- package/deps/simdutf/benchmarks/competition/utf8lut/data/test_minimal.txt +0 -44
- package/deps/simdutf/benchmarks/competition/utf8lut/readme.md +0 -106
- package/deps/simdutf/benchmarks/competition/utf8lut/scripts/build_clang_corr_tests.cmd +0 -11
- package/deps/simdutf/benchmarks/competition/utf8lut/scripts/build_clang_corr_tests.sh +0 -13
- package/deps/simdutf/benchmarks/competition/utf8lut/scripts/build_gcc_corr_tests.sh +0 -13
- package/deps/simdutf/benchmarks/competition/utf8lut/scripts/build_gcc_example.sh +0 -13
- package/deps/simdutf/benchmarks/competition/utf8lut/scripts/build_gcc_file_conv.sh +0 -14
- package/deps/simdutf/benchmarks/competition/utf8lut/scripts/build_gcc_iconv_lib.sh +0 -11
- package/deps/simdutf/benchmarks/competition/utf8lut/scripts/build_gcc_iconv_sample.sh +0 -8
- package/deps/simdutf/benchmarks/competition/utf8lut/scripts/build_mingw_corr_tests.cmd +0 -12
- package/deps/simdutf/benchmarks/competition/utf8lut/scripts/build_mingw_example.cmd +0 -13
- package/deps/simdutf/benchmarks/competition/utf8lut/scripts/build_mingw_file_conv.cmd +0 -14
- package/deps/simdutf/benchmarks/competition/utf8lut/scripts/build_mingw_iconv_lib.cmd +0 -11
- package/deps/simdutf/benchmarks/competition/utf8lut/scripts/build_mingw_iconv_sample.cmd +0 -8
- package/deps/simdutf/benchmarks/competition/utf8lut/scripts/build_msvc_corr_tests.cmd +0 -11
- package/deps/simdutf/benchmarks/competition/utf8lut/scripts/build_msvc_example.cmd +0 -12
- package/deps/simdutf/benchmarks/competition/utf8lut/scripts/build_msvc_file_conv.cmd +0 -13
- package/deps/simdutf/benchmarks/competition/utf8lut/scripts/build_msvc_iconv_lib.cmd +0 -10
- package/deps/simdutf/benchmarks/competition/utf8lut/scripts/build_msvc_iconv_sample.cmd +0 -9
- package/deps/simdutf/benchmarks/competition/utf8lut/scripts/html_table.py +0 -25
- package/deps/simdutf/benchmarks/competition/utf8lut/scripts/measure.py +0 -94
- package/deps/simdutf/benchmarks/competition/utf8lut/scripts/resize.py +0 -20
- package/deps/simdutf/benchmarks/competition/utf8lut/scripts/wipe_all.cmd +0 -2
- package/deps/simdutf/benchmarks/competition/utf8lut/scripts/wipe_interm.cmd +0 -1
- package/deps/simdutf/benchmarks/competition/utf8lut/src/base/CustomMemcpy.h +0 -75
- package/deps/simdutf/benchmarks/competition/utf8lut/src/base/PerfDefs.h +0 -47
- package/deps/simdutf/benchmarks/competition/utf8lut/src/base/Timing.cpp +0 -17
- package/deps/simdutf/benchmarks/competition/utf8lut/src/base/Timing.h +0 -76
- package/deps/simdutf/benchmarks/competition/utf8lut/src/buffer/AllProcessors.cpp +0 -35
- package/deps/simdutf/benchmarks/competition/utf8lut/src/buffer/BaseBufferProcessor.cpp +0 -117
- package/deps/simdutf/benchmarks/competition/utf8lut/src/buffer/BaseBufferProcessor.h +0 -210
- package/deps/simdutf/benchmarks/competition/utf8lut/src/buffer/BufferDecoder.h +0 -158
- package/deps/simdutf/benchmarks/competition/utf8lut/src/buffer/BufferEncoder.h +0 -104
- package/deps/simdutf/benchmarks/competition/utf8lut/src/buffer/ProcessorPlugins.h +0 -334
- package/deps/simdutf/benchmarks/competition/utf8lut/src/buffer/ProcessorSelector.h +0 -186
- package/deps/simdutf/benchmarks/competition/utf8lut/src/core/DecoderLut.cpp +0 -140
- package/deps/simdutf/benchmarks/competition/utf8lut/src/core/DecoderLut.h +0 -42
- package/deps/simdutf/benchmarks/competition/utf8lut/src/core/DecoderProcess.h +0 -100
- package/deps/simdutf/benchmarks/competition/utf8lut/src/core/Dfa.h +0 -57
- package/deps/simdutf/benchmarks/competition/utf8lut/src/core/EncoderLut.cpp +0 -85
- package/deps/simdutf/benchmarks/competition/utf8lut/src/core/EncoderLut.h +0 -27
- package/deps/simdutf/benchmarks/competition/utf8lut/src/core/EncoderProcess.h +0 -126
- package/deps/simdutf/benchmarks/competition/utf8lut/src/core/ProcessTrivial.h +0 -108
- package/deps/simdutf/benchmarks/competition/utf8lut/src/iconv/iconv.cpp +0 -139
- package/deps/simdutf/benchmarks/competition/utf8lut/src/iconv/iconv.h +0 -74
- package/deps/simdutf/benchmarks/competition/utf8lut/src/message/MessageConverter.cpp +0 -65
- package/deps/simdutf/benchmarks/competition/utf8lut/src/message/MessageConverter.h +0 -91
- package/deps/simdutf/benchmarks/competition/utf8lut/src/tests/CorrectnessTests.cpp +0 -772
- package/deps/simdutf/benchmarks/competition/utf8lut/src/tests/Example.cpp +0 -12
- package/deps/simdutf/benchmarks/competition/utf8lut/src/tests/FileConverter.cpp +0 -486
- package/deps/simdutf/benchmarks/competition/utf8lut/src/tests/iconv_sample.c +0 -162
- package/deps/simdutf/benchmarks/competition/utf8lut/src/utf8lut.h +0 -15
- package/deps/simdutf/benchmarks/competition/utf8sse4/fromutf8-sse.cpp +0 -292
- package/deps/simdutf/benchmarks/competition/utfcpp/LICENSE +0 -23
- package/deps/simdutf/benchmarks/competition/utfcpp/README.md +0 -1503
- package/deps/simdutf/benchmarks/competition/utfcpp/source/utf8/checked.h +0 -335
- package/deps/simdutf/benchmarks/competition/utfcpp/source/utf8/core.h +0 -338
- package/deps/simdutf/benchmarks/competition/utfcpp/source/utf8/cpp11.h +0 -103
- package/deps/simdutf/benchmarks/competition/utfcpp/source/utf8/cpp17.h +0 -103
- package/deps/simdutf/benchmarks/competition/utfcpp/source/utf8/unchecked.h +0 -274
- package/deps/simdutf/benchmarks/competition/utfcpp/source/utf8.h +0 -34
- package/deps/simdutf/benchmarks/dataset/README.md +0 -155
- package/deps/simdutf/benchmarks/dataset/emoji.txt +0 -204
- package/deps/simdutf/benchmarks/dataset/scripts/utf8type.py +0 -40
- package/deps/simdutf/benchmarks/dataset/wikipedia_mars/Makefile +0 -80
- package/deps/simdutf/benchmarks/dataset/wikipedia_mars/convert_to_utf6.py +0 -20
- package/deps/simdutf/benchmarks/find/CMakeLists.txt +0 -6
- package/deps/simdutf/benchmarks/find/findbenchmark.cpp +0 -63
- package/deps/simdutf/benchmarks/find/findbenchmarker.h +0 -46
- package/deps/simdutf/benchmarks/shortbench.cpp +0 -555
- package/deps/simdutf/benchmarks/src/CMakeLists.txt +0 -52
- package/deps/simdutf/benchmarks/src/apple_arm_events.h +0 -1104
- package/deps/simdutf/benchmarks/src/benchmark.cpp +0 -3899
- package/deps/simdutf/benchmarks/src/benchmark.h +0 -317
- package/deps/simdutf/benchmarks/src/benchmark_base.cpp +0 -144
- package/deps/simdutf/benchmarks/src/benchmark_base.h +0 -98
- package/deps/simdutf/benchmarks/src/cmdline.cpp +0 -176
- package/deps/simdutf/benchmarks/src/cmdline.h +0 -35
- package/deps/simdutf/benchmarks/src/event_counter.h +0 -162
- package/deps/simdutf/benchmarks/src/linux-perf-events.h +0 -104
- package/deps/simdutf/benchmarks/stream.cpp +0 -209
- package/deps/simdutf/benchmarks/threaded.cpp +0 -123
- package/deps/simdutf/cmake/CPM.cmake +0 -1363
- package/deps/simdutf/cmake/JoinPaths.cmake +0 -23
- package/deps/simdutf/cmake/add_cpp_test.cmake +0 -68
- package/deps/simdutf/cmake/simdutf-config.cmake.in +0 -2
- package/deps/simdutf/cmake/simdutf-flags.cmake +0 -26
- package/deps/simdutf/cmake/toolchains-ci/riscv64-linux-gnu.cmake +0 -4
- package/deps/simdutf/cmake/toolchains-dev/README.md +0 -32
- package/deps/simdutf/cmake/toolchains-dev/aarch64.cmake +0 -14
- package/deps/simdutf/cmake/toolchains-dev/loongarch64.cmake +0 -22
- package/deps/simdutf/cmake/toolchains-dev/powerpc64.cmake +0 -16
- package/deps/simdutf/cmake/toolchains-dev/powerpc64le.cmake +0 -16
- package/deps/simdutf/cmake/toolchains-dev/riscv64.cmake +0 -16
- package/deps/simdutf/cmake/toolchains-dev/rvv-spike.cmake +0 -38
- package/deps/simdutf/doc/avx512.png +0 -0
- package/deps/simdutf/doc/logo.png +0 -0
- package/deps/simdutf/doc/logo.svg +0 -165
- package/deps/simdutf/doc/node2023.png +0 -0
- package/deps/simdutf/doc/shortinput.md +0 -78
- package/deps/simdutf/doc/utf16utf8.png +0 -0
- package/deps/simdutf/doc/utf8utf16.png +0 -0
- package/deps/simdutf/doc/widelogo.png +0 -0
- package/deps/simdutf/doxygen.py +0 -50
- package/deps/simdutf/fuzz/.clang-format +0 -9
- package/deps/simdutf/fuzz/CMakeLists.txt +0 -45
- package/deps/simdutf/fuzz/README.md +0 -168
- package/deps/simdutf/fuzz/atomic_base64.cpp +0 -448
- package/deps/simdutf/fuzz/base64.cpp +0 -278
- package/deps/simdutf/fuzz/build.sh +0 -83
- package/deps/simdutf/fuzz/conversion.cpp +0 -669
- package/deps/simdutf/fuzz/helpers/.clang-format-ignore +0 -1
- package/deps/simdutf/fuzz/helpers/common.h +0 -135
- package/deps/simdutf/fuzz/helpers/nameof.hpp +0 -1258
- package/deps/simdutf/fuzz/main.cpp +0 -72
- package/deps/simdutf/fuzz/minimize_and_cleanse.sh +0 -87
- package/deps/simdutf/fuzz/misc.cpp +0 -216
- package/deps/simdutf/fuzz/random_fuzz.sh +0 -154
- package/deps/simdutf/fuzz/roundtrip.cpp +0 -588
- package/deps/simdutf/fuzz/safe_conversion.cpp +0 -104
- package/deps/simdutf/riscv/Dockerfile +0 -16
- package/deps/simdutf/riscv/README.md +0 -24
- package/deps/simdutf/riscv/remove-docker-station +0 -8
- package/deps/simdutf/riscv/run-docker-station +0 -31
- package/deps/simdutf/scripts/.flake8 +0 -2
- package/deps/simdutf/scripts/Makefile +0 -2
- package/deps/simdutf/scripts/README_ADD_FUNCTION.md +0 -49
- package/deps/simdutf/scripts/add_function.py +0 -330
- package/deps/simdutf/scripts/amalgamation_tests.py +0 -156
- package/deps/simdutf/scripts/base64/Makefile +0 -2
- package/deps/simdutf/scripts/base64/README.md +0 -2
- package/deps/simdutf/scripts/base64/avx512.py +0 -76
- package/deps/simdutf/scripts/base64/neon_decode.py +0 -143
- package/deps/simdutf/scripts/base64/neon_generate_lut.py +0 -101
- package/deps/simdutf/scripts/base64/sse.py +0 -252
- package/deps/simdutf/scripts/base64/sseregular.py +0 -160
- package/deps/simdutf/scripts/base64/sseurl.py +0 -283
- package/deps/simdutf/scripts/base64/table.py +0 -59
- package/deps/simdutf/scripts/base64bench_print.py +0 -145
- package/deps/simdutf/scripts/benchmark-all.py +0 -119
- package/deps/simdutf/scripts/benchmark_print.py +0 -324
- package/deps/simdutf/scripts/check_feature_macros.py +0 -156
- package/deps/simdutf/scripts/check_typos.sh +0 -13
- package/deps/simdutf/scripts/clang_format.sh +0 -35
- package/deps/simdutf/scripts/clang_format_docker.sh +0 -38
- package/deps/simdutf/scripts/common.py +0 -24
- package/deps/simdutf/scripts/compilation_benchmark.py +0 -55
- package/deps/simdutf/scripts/compile_many_variations.sh +0 -64
- package/deps/simdutf/scripts/create_latex_table.py +0 -62
- package/deps/simdutf/scripts/docker/Dockerfile +0 -14
- package/deps/simdutf/scripts/docker/Makefile +0 -9
- package/deps/simdutf/scripts/docker/README.md +0 -30
- package/deps/simdutf/scripts/docker/llvm.gpg +0 -0
- package/deps/simdutf/scripts/ppc64_convert_utf16_to_utf8.py +0 -155
- package/deps/simdutf/scripts/prepare_doxygen.sh +0 -21
- package/deps/simdutf/scripts/release.py +0 -197
- package/deps/simdutf/scripts/shortinputplots.py +0 -97
- package/deps/simdutf/scripts/sse_convert_utf16_to_utf8.py +0 -422
- package/deps/simdutf/scripts/sse_convert_utf32_to_utf16.py +0 -105
- package/deps/simdutf/scripts/sse_utf8_utf16_decode.py +0 -186
- package/deps/simdutf/scripts/sse_validate_utf16le_proof.py +0 -137
- package/deps/simdutf/scripts/sse_validate_utf16le_testcases.py +0 -129
- package/deps/simdutf/scripts/table.py +0 -207
- package/deps/simdutf/scripts/tests/new.txt +0 -33
- package/deps/simdutf/scripts/tests/old.txt +0 -33
- package/deps/simdutf/scripts/tests/results.txt +0 -272
- package/deps/simdutf/simdutf.pc.in +0 -11
- package/deps/simdutf/singleheader/.flake8 +0 -2
- package/deps/simdutf/singleheader/CMakeLists.txt +0 -64
- package/deps/simdutf/singleheader/README-dev.md +0 -81
- package/deps/simdutf/singleheader/README.md +0 -19
- package/deps/simdutf/singleheader/amalgamate.py +0 -513
- package/deps/simdutf/singleheader/amalgamation_demo.c +0 -59
- package/deps/simdutf/singleheader/amalgamation_demo.cpp +0 -54
- package/deps/simdutf/singleheader/test-features.py +0 -262
- package/deps/simdutf/src/CMakeLists.txt +0 -78
- package/deps/simdutf/tests/CMakeLists.txt +0 -483
- package/deps/simdutf/tests/atomic_base64_tests.cpp +0 -2845
- package/deps/simdutf/tests/base64_tests.cpp +0 -3617
- package/deps/simdutf/tests/basic_fuzzer.cpp +0 -805
- package/deps/simdutf/tests/bele_tests.cpp +0 -182
- package/deps/simdutf/tests/constexpr_base64_tests.cpp +0 -387
- package/deps/simdutf/tests/convert_latin1_to_utf16be_tests.cpp +0 -52
- package/deps/simdutf/tests/convert_latin1_to_utf16le_tests.cpp +0 -80
- package/deps/simdutf/tests/convert_latin1_to_utf32_tests.cpp +0 -66
- package/deps/simdutf/tests/convert_latin1_to_utf8_tests.cpp +0 -120
- package/deps/simdutf/tests/convert_utf16_to_utf8_safe_tests.cpp +0 -203
- package/deps/simdutf/tests/convert_utf16_to_utf8_with_replacement_tests.cpp +0 -276
- package/deps/simdutf/tests/convert_utf16be_to_latin1_tests.cpp +0 -109
- package/deps/simdutf/tests/convert_utf16be_to_latin1_tests_with_errors.cpp +0 -136
- package/deps/simdutf/tests/convert_utf16be_to_utf32_tests.cpp +0 -193
- package/deps/simdutf/tests/convert_utf16be_to_utf32_with_errors_tests.cpp +0 -381
- package/deps/simdutf/tests/convert_utf16be_to_utf8_tests.cpp +0 -259
- package/deps/simdutf/tests/convert_utf16be_to_utf8_with_errors_tests.cpp +0 -266
- package/deps/simdutf/tests/convert_utf16le_to_latin1_tests.cpp +0 -148
- package/deps/simdutf/tests/convert_utf16le_to_latin1_tests_with_errors.cpp +0 -176
- package/deps/simdutf/tests/convert_utf16le_to_utf32_tests.cpp +0 -213
- package/deps/simdutf/tests/convert_utf16le_to_utf32_with_errors_tests.cpp +0 -318
- package/deps/simdutf/tests/convert_utf16le_to_utf8_tests.cpp +0 -343
- package/deps/simdutf/tests/convert_utf16le_to_utf8_with_errors_tests.cpp +0 -271
- package/deps/simdutf/tests/convert_utf32_to_latin1_tests.cpp +0 -111
- package/deps/simdutf/tests/convert_utf32_to_latin1_with_errors_tests.cpp +0 -96
- package/deps/simdutf/tests/convert_utf32_to_utf16be_tests.cpp +0 -148
- package/deps/simdutf/tests/convert_utf32_to_utf16be_with_errors_tests.cpp +0 -192
- package/deps/simdutf/tests/convert_utf32_to_utf16le_tests.cpp +0 -166
- package/deps/simdutf/tests/convert_utf32_to_utf16le_with_errors_tests.cpp +0 -215
- package/deps/simdutf/tests/convert_utf32_to_utf8_tests.cpp +0 -181
- package/deps/simdutf/tests/convert_utf32_to_utf8_with_errors_tests.cpp +0 -261
- package/deps/simdutf/tests/convert_utf8_to_latin1_tests.cpp +0 -516
- package/deps/simdutf/tests/convert_utf8_to_latin1_with_errors_tests.cpp +0 -579
- package/deps/simdutf/tests/convert_utf8_to_utf16be_tests.cpp +0 -412
- package/deps/simdutf/tests/convert_utf8_to_utf16be_with_errors_tests.cpp +0 -480
- package/deps/simdutf/tests/convert_utf8_to_utf16le_tests.cpp +0 -671
- package/deps/simdutf/tests/convert_utf8_to_utf16le_with_errors_tests.cpp +0 -455
- package/deps/simdutf/tests/convert_utf8_to_utf32_tests.cpp +0 -1204
- package/deps/simdutf/tests/convert_utf8_to_utf32_with_errors_tests.cpp +0 -337
- package/deps/simdutf/tests/convert_valid_utf16be_to_latin1_tests.cpp +0 -37
- package/deps/simdutf/tests/convert_valid_utf16be_to_utf32_tests.cpp +0 -97
- package/deps/simdutf/tests/convert_valid_utf16be_to_utf8_tests.cpp +0 -126
- package/deps/simdutf/tests/convert_valid_utf16le_to_latin1_tests.cpp +0 -71
- package/deps/simdutf/tests/convert_valid_utf16le_to_utf32_tests.cpp +0 -122
- package/deps/simdutf/tests/convert_valid_utf16le_to_utf8_tests.cpp +0 -244
- package/deps/simdutf/tests/convert_valid_utf32_to_latin1_tests.cpp +0 -49
- package/deps/simdutf/tests/convert_valid_utf32_to_utf16be_tests.cpp +0 -92
- package/deps/simdutf/tests/convert_valid_utf32_to_utf16le_tests.cpp +0 -114
- package/deps/simdutf/tests/convert_valid_utf32_to_utf8_tests.cpp +0 -109
- package/deps/simdutf/tests/convert_valid_utf8_to_latin1_tests.cpp +0 -84
- package/deps/simdutf/tests/convert_valid_utf8_to_utf16be_tests.cpp +0 -124
- package/deps/simdutf/tests/convert_valid_utf8_to_utf16le_tests.cpp +0 -221
- package/deps/simdutf/tests/convert_valid_utf8_to_utf32_tests.cpp +0 -155
- package/deps/simdutf/tests/count_utf16be.cpp +0 -64
- package/deps/simdutf/tests/count_utf16le.cpp +0 -61
- package/deps/simdutf/tests/count_utf8.cpp +0 -87
- package/deps/simdutf/tests/detect_encodings_tests.cpp +0 -312
- package/deps/simdutf/tests/embed/valid_utf8.txt +0 -1
- package/deps/simdutf/tests/embed_tests.cpp +0 -22
- package/deps/simdutf/tests/find_tests.cpp +0 -77
- package/deps/simdutf/tests/fixed_string_tests.cpp +0 -153
- package/deps/simdutf/tests/helpers/CMakeLists.txt +0 -25
- package/deps/simdutf/tests/helpers/compiletime_conversions.h +0 -222
- package/deps/simdutf/tests/helpers/fixed_string.h +0 -267
- package/deps/simdutf/tests/helpers/random_int.cpp +0 -30
- package/deps/simdutf/tests/helpers/random_int.h +0 -39
- package/deps/simdutf/tests/helpers/random_utf16.cpp +0 -123
- package/deps/simdutf/tests/helpers/random_utf16.h +0 -52
- package/deps/simdutf/tests/helpers/random_utf32.cpp +0 -41
- package/deps/simdutf/tests/helpers/random_utf32.h +0 -40
- package/deps/simdutf/tests/helpers/random_utf8.cpp +0 -93
- package/deps/simdutf/tests/helpers/random_utf8.h +0 -36
- package/deps/simdutf/tests/helpers/test.cpp +0 -231
- package/deps/simdutf/tests/helpers/test.h +0 -193
- package/deps/simdutf/tests/helpers/transcode_test_base.cpp +0 -1257
- package/deps/simdutf/tests/helpers/transcode_test_base.h +0 -683
- package/deps/simdutf/tests/helpers/utf16.h +0 -27
- package/deps/simdutf/tests/installation_tests/find/CMakeLists.txt +0 -43
- package/deps/simdutf/tests/installation_tests/from_fetch/CMakeLists.txt +0 -47
- package/deps/simdutf/tests/internal_tests.cpp +0 -27
- package/deps/simdutf/tests/null_safety_tests.cpp +0 -94
- package/deps/simdutf/tests/random_fuzzer.cpp +0 -779
- package/deps/simdutf/tests/readme_tests.cpp +0 -274
- package/deps/simdutf/tests/reference/CMakeLists.txt +0 -23
- package/deps/simdutf/tests/reference/decode_utf16.h +0 -81
- package/deps/simdutf/tests/reference/decode_utf32.h +0 -47
- package/deps/simdutf/tests/reference/encode_latin1.cpp +0 -1
- package/deps/simdutf/tests/reference/encode_latin1.h +0 -32
- package/deps/simdutf/tests/reference/encode_utf16.cpp +0 -49
- package/deps/simdutf/tests/reference/encode_utf16.h +0 -20
- package/deps/simdutf/tests/reference/encode_utf32.cpp +0 -1
- package/deps/simdutf/tests/reference/encode_utf32.h +0 -36
- package/deps/simdutf/tests/reference/encode_utf8.cpp +0 -1
- package/deps/simdutf/tests/reference/encode_utf8.h +0 -40
- package/deps/simdutf/tests/reference/validate_utf16.cpp +0 -60
- package/deps/simdutf/tests/reference/validate_utf16.h +0 -14
- package/deps/simdutf/tests/reference/validate_utf16_to_latin1.cpp +0 -35
- package/deps/simdutf/tests/reference/validate_utf16_to_latin1.h +0 -13
- package/deps/simdutf/tests/reference/validate_utf32.cpp +0 -27
- package/deps/simdutf/tests/reference/validate_utf32.h +0 -12
- package/deps/simdutf/tests/reference/validate_utf32_to_latin1.cpp +0 -27
- package/deps/simdutf/tests/reference/validate_utf32_to_latin1.h +0 -12
- package/deps/simdutf/tests/reference/validate_utf8.cpp +0 -82
- package/deps/simdutf/tests/reference/validate_utf8.h +0 -11
- package/deps/simdutf/tests/reference/validate_utf8_to_latin1.cpp +0 -43
- package/deps/simdutf/tests/reference/validate_utf8_to_latin1.h +0 -12
- package/deps/simdutf/tests/select_implementation.cpp +0 -43
- package/deps/simdutf/tests/simdutf_c_tests.cpp +0 -244
- package/deps/simdutf/tests/span_tests.cpp +0 -401
- package/deps/simdutf/tests/special_tests.cpp +0 -559
- package/deps/simdutf/tests/straight_c_test.c +0 -187
- package/deps/simdutf/tests/text_encoding_tests.cpp +0 -77
- package/deps/simdutf/tests/to_well_formed_utf16_tests.cpp +0 -377
- package/deps/simdutf/tests/utf8_length_from_utf16_tests.cpp +0 -202
- package/deps/simdutf/tests/validate_ascii_basic_tests.cpp +0 -165
- package/deps/simdutf/tests/validate_ascii_with_errors_tests.cpp +0 -77
- package/deps/simdutf/tests/validate_utf16be_basic_tests.cpp +0 -175
- package/deps/simdutf/tests/validate_utf16be_with_errors_tests.cpp +0 -188
- package/deps/simdutf/tests/validate_utf16le_basic_tests.cpp +0 -268
- package/deps/simdutf/tests/validate_utf16le_with_errors_tests.cpp +0 -274
- package/deps/simdutf/tests/validate_utf32_basic_tests.cpp +0 -92
- package/deps/simdutf/tests/validate_utf32_with_errors_tests.cpp +0 -114
- package/deps/simdutf/tests/validate_utf8_basic_tests.cpp +0 -178
- package/deps/simdutf/tests/validate_utf8_brute_force_tests.cpp +0 -88
- package/deps/simdutf/tests/validate_utf8_puzzler_tests.cpp +0 -33
- package/deps/simdutf/tests/validate_utf8_with_errors_tests.cpp +0 -228
- package/deps/simdutf/tools/CMakeLists.txt +0 -85
- package/deps/simdutf/tools/fastbase64.cpp +0 -250
- package/deps/simdutf/tools/sutf.cpp +0 -556
- package/deps/simdutf/tools/sutf.h +0 -40
- package/lib/tsconfig.tsbuildinfo +0 -1
|
@@ -1,39 +0,0 @@
|
|
|
1
|
-
Outline:
|
|
2
|
-
|
|
3
|
-
The Portable SIMD Library with Inductive Doubling Support
|
|
4
|
-
|
|
5
|
-
Robert D. Cameron and Dan Lin
|
|
6
|
-
|
|
7
|
-
I. Rationale
|
|
8
|
-
II. Definition of the SIMD Operations
|
|
9
|
-
a. Power of Two Field Widths
|
|
10
|
-
b. Binary Operations with Half-Operand Modifiers
|
|
11
|
-
c. Value Generation
|
|
12
|
-
d. Shifts with Immediate Operands
|
|
13
|
-
e. simd_if
|
|
14
|
-
f. aligned and nonaligned loads/stores
|
|
15
|
-
III. Implementation Alternatives
|
|
16
|
-
a. Inline Functions vs. Macros
|
|
17
|
-
- Macros necessary for cases requiring literal
|
|
18
|
-
numeric constants: value generation, immed. shifts
|
|
19
|
-
- Inline functions used elsewhere, for readability,
|
|
20
|
-
error checking, compiler performance
|
|
21
|
-
b. Defining mappings to built-ins
|
|
22
|
-
- Using processor-specific intrinsics
|
|
23
|
-
- operations requiring adjustments
|
|
24
|
-
- not a direct mapping between idealized and intrinsic
|
|
25
|
-
- ex simd_pack_16 for mmx
|
|
26
|
-
c. Simulation for non-native field widths
|
|
27
|
-
- direct bit calculation: field width 2
|
|
28
|
-
- small field definitions in terms of double-size fields
|
|
29
|
-
- large field definitions in terms of half-size fields
|
|
30
|
-
- optimizations
|
|
31
|
-
d. Simulation for Half-Operand Modifications
|
|
32
|
-
- direct nonoptimized strategy
|
|
33
|
-
- optimizations
|
|
34
|
-
IV. MultiPlatform Architecture
|
|
35
|
-
V. Test Suite/Simulator
|
|
36
|
-
VI. Future Directions
|
|
37
|
-
- additional operations
|
|
38
|
-
- compiler integration
|
|
39
|
-
|
|
@@ -1,421 +0,0 @@
|
|
|
1
|
-
/* Idealized SIMD Operations with Cell BE SPE implementations.
|
|
2
|
-
Copyright (C) 2008, Robert D. Cameron
|
|
3
|
-
Licensed to International Characters Inc.
|
|
4
|
-
under the Academic Free License version 3.0.
|
|
5
|
-
*/
|
|
6
|
-
|
|
7
|
-
/*------------------------------------------------------------*/
|
|
8
|
-
|
|
9
|
-
#include <limits.h>
|
|
10
|
-
#include <stdio.h>
|
|
11
|
-
#include "spu_intrinsics.h"
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
//typedef qword SIMD_type;
|
|
15
|
-
#define SIMD_type qword
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
/*------------------------------------------------------------*/
|
|
19
|
-
/* I. SIMD bitwise logical operations */
|
|
20
|
-
|
|
21
|
-
#define simd_or(b1, b2) si_or(b1, b2)
|
|
22
|
-
#define simd_and(b1, b2) si_and(b1, b2)
|
|
23
|
-
#define simd_xor(b1, b2) si_xor(b1, b2)
|
|
24
|
-
#define simd_nor(b1, b2) si_nor(b1, b2)
|
|
25
|
-
#define simd_andc(b1, b2) si_andc(b1, b2)
|
|
26
|
-
#define simd_if(cond, then_val, else_val) si_selb(else_val, then_val, cond)
|
|
27
|
-
#define simd_not(x) si_nor(x, x)
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
#define simd_eq_8(a, b) si_ceqb(a, b)
|
|
31
|
-
#define simd_eq_16(a, b) si_ceqh(a, b)
|
|
32
|
-
#define simd_eq_32(a, b) si_ceq(a, b)
|
|
33
|
-
|
|
34
|
-
/* Unsigned gt comparisons */
|
|
35
|
-
#define simd_gt_8(a, b) si_clgtb(a, b)
|
|
36
|
-
#define simd_gt_16(a, b) si_clgth(a, b)
|
|
37
|
-
#define simd_gt_32(a, b) si_clgt(a, b)
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
/* splat constants */
|
|
42
|
-
|
|
43
|
-
#define simd_const_8(n) ((SIMD_type) spu_splats((signed char) (n)))
|
|
44
|
-
|
|
45
|
-
#define simd_const_16(n) ((SIMD_type) spu_splats((signed short) (n)))
|
|
46
|
-
|
|
47
|
-
#define simd_const_32(n) ((SIMD_type) spu_splats((signed int) (n)))
|
|
48
|
-
|
|
49
|
-
#define simd_const_4(n) ((SIMD_type) spu_splats((unsigned char) ((n&0xF)*0x11)))
|
|
50
|
-
|
|
51
|
-
#define simd_const_2(n) ((SIMD_type) spu_splats((unsigned char) ((n&0x3)*0x55)))
|
|
52
|
-
|
|
53
|
-
#define simd_const_1(n) (n==0 ? simd_const_8(0): simd_const_8(-1))
|
|
54
|
-
|
|
55
|
-
#define simd_himask_2 simd_const_2(2)
|
|
56
|
-
#define simd_himask_4 simd_const_4(0xC)
|
|
57
|
-
#define simd_himask_8 simd_const_8(-16)
|
|
58
|
-
#define simd_himask_16 simd_const_16(-256)
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
/* Idealized arithmetic operations with direct implementation by built-in
|
|
62
|
-
operations for SPU. */
|
|
63
|
-
|
|
64
|
-
static inline SIMD_type simd_add_16(SIMD_type a, SIMD_type b) {
|
|
65
|
-
return (SIMD_type) si_ah(a, b);
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
#define simd_add_32(a, b) si_a(a,b)
|
|
69
|
-
#define simd_sub_16(a, b) si_sfh(b,a)
|
|
70
|
-
#define simd_sub_32(a, b) si_sf(b,a)
|
|
71
|
-
|
|
72
|
-
/* Additional arithmetic operations. */
|
|
73
|
-
|
|
74
|
-
static inline SIMD_type simd_add_8(SIMD_type a, SIMD_type b) {
|
|
75
|
-
return simd_if(simd_himask_16,
|
|
76
|
-
simd_add_16(a, simd_and(b, simd_himask_16)),
|
|
77
|
-
simd_add_16(a, b));
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
#define simd_sub_8(a, b) \
|
|
81
|
-
simd_if(simd_himask_16,\
|
|
82
|
-
simd_sub_16(a, si_and(b, simd_himask_16)),\
|
|
83
|
-
simd_sub_16(a, b))
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
/* Idealized shift operations with direct implementation by built-in
|
|
87
|
-
operations for SPU. */
|
|
88
|
-
|
|
89
|
-
/*Technically, the original simd_sll specification required the following masking,
|
|
90
|
-
but we provide more efficient versions without masking and rely on the programmer
|
|
91
|
-
not to exceed the fieldwidth.
|
|
92
|
-
#define simd_sll_16(r, shft) si_shlh(r, simd_and(simd_const_16(0xF),shft))
|
|
93
|
-
#define simd_sll_32(r, shft) si_shl(r, simd_and(simd_const_32(0x1F),shft))*/
|
|
94
|
-
#define simd_sll_16(r, shft) si_shlh(r, shft)
|
|
95
|
-
#define simd_sll_32(r, shft) si_shl(r, shft)
|
|
96
|
-
#define simd_slli_16(r, shft) si_shlhi(r, shft)
|
|
97
|
-
#define simd_slli_32(r, shft) si_shli(r, shft)
|
|
98
|
-
|
|
99
|
-
#define simd_rotl_16(r, shft) si_roth(r, shft)
|
|
100
|
-
#define simd_rotl_32(r, shft) si_rot(r, shft)
|
|
101
|
-
#define simd_rotli_16(r, shft) si_rothi(r, shft)
|
|
102
|
-
#define simd_rotli_32(r, shft) si_roti((r, shft)
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
#define simd_srl_16(r, shft) si_rothm(r, -shft)
|
|
106
|
-
#define simd_srl_32(r, shft) si_rotm(r, -shft)
|
|
107
|
-
#define simd_srli_16(r, shft) si_rothmi(r, -shft)
|
|
108
|
-
#define simd_srli_32(r, shft) si_rotmi(r, -shft)
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
#ifndef simd_sll_8
|
|
112
|
-
inline SIMD_type simd_sll_8(SIMD_type a,SIMD_type b){
|
|
113
|
-
return simd_if(simd_himask_16, simd_sll_16(simd_and(a,simd_himask_16),simd_and(simd_const_8(7),simd_srli_16(b,8)))
|
|
114
|
-
,simd_sll_16(a,simd_and(b,simd_const_16(7))));}
|
|
115
|
-
#endif
|
|
116
|
-
#ifndef simd_srl_8
|
|
117
|
-
inline SIMD_type simd_srl_8(SIMD_type a,SIMD_type b){
|
|
118
|
-
return simd_if(simd_himask_16, simd_srl_16(a,simd_and(simd_const_8(7),simd_srli_16(b,8)))
|
|
119
|
-
,simd_srl_16(simd_andc(a,simd_himask_16),simd_and(b,simd_const_16(7))));}
|
|
120
|
-
#endif
|
|
121
|
-
#ifndef simd_rotl_8
|
|
122
|
-
inline SIMD_type simd_rotl_8(SIMD_type a,SIMD_type b){
|
|
123
|
-
return simd_or(simd_sll_8(a,b),simd_srl_8(a,simd_sub_8(simd_const_8(8),b)));}
|
|
124
|
-
#endif
|
|
125
|
-
|
|
126
|
-
/* Additional shift operations. */
|
|
127
|
-
|
|
128
|
-
#define sl_bytealign(r, shft) \
|
|
129
|
-
((shft) % 8 == 0 ? r : si_shlqbii(r, shft))
|
|
130
|
-
|
|
131
|
-
#define simd_slli_128(r, shft) \
|
|
132
|
-
((shft) < 8 ? sl_bytealign(r, shft):\
|
|
133
|
-
si_shlqbyi(sl_bytealign(r, (shft) % 8), (shft) >> 3))
|
|
134
|
-
|
|
135
|
-
#define sr_bytealign(r, shft) \
|
|
136
|
-
((shft) % 8 == 0 ? r : si_rotqmbii(r, 8-shft))
|
|
137
|
-
|
|
138
|
-
#define simd_srli_128(r, shft) \
|
|
139
|
-
((shft) < 8 ? sr_bytealign(r, shft):\
|
|
140
|
-
si_rotqmbyi(sr_bytealign(r, (shft) % 8), (16 - ((shft) >> 3))))
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
#define simd_sll_128(r, shft) si_shlqbybi(si_shlqbi(r, shft), shft)
|
|
144
|
-
|
|
145
|
-
static inline SIMD_type simd_srl_128(SIMD_type r, SIMD_type shft) {
|
|
146
|
-
return si_rotqmbi(si_rotqmbybi(r, si_from_int(7-si_to_int(shft))), si_from_int(-si_to_int(shft)));
|
|
147
|
-
}
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
#define simd_slli_8(r, shft) simd_and(simd_slli_16(r, shft), simd_const_8((255<<shft)&255))
|
|
151
|
-
#define simd_srli_8(r, shft) simd_and(simd_srli_16(r, shft), simd_const_8(255>>shft))
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
#define sisd_sll(r, shft) simd_sll_128(r, shft)
|
|
155
|
-
#define sisd_srl(r, shft) simd_srl_128(r, shft)
|
|
156
|
-
#define sisd_slli(r, shft) simd_slli_128(r, shft)
|
|
157
|
-
#define sisd_srli(r, shft) simd_srli_128(r, shft)
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
#define simd_mergeh_8(v1, v2) si_shufb(v1, v2, (qword) ((vec_uchar16){0,16,1,17,2,18,3,19,4,20,5,21,6,22,7,23}))
|
|
162
|
-
#define simd_mergel_8(v1, v2) si_shufb(v1, v2, (qword) ((vec_uchar16){8,24,9,25,10,26,11,27,12,28,13,29,14,30,15,31}))
|
|
163
|
-
|
|
164
|
-
#define simd_pack_16(v1, v2) si_shufb(v1, v2, (qword) ((vec_uchar16){1,3,5,7,9,11,13,15,17,19,21,23,25,27,29,31}))
|
|
165
|
-
#define simd_pack_32(v1, v2) si_shufb(v1, v2, (qword) ((vec_uchar16){2,3,6,7,10,11,14,15,18,19,22,23,26,27,30,31}))
|
|
166
|
-
|
|
167
|
-
#define simd_pack_16_ll(a, b) simd_pack_16(a, b)
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
#ifndef ALTIVEC_USE_EVEN_INDICES
|
|
171
|
-
#define simd_pack_16_hh(a, b) \
|
|
172
|
-
simd_pack_16(simd_srli_16(a, 8), simd_srli_16(b, 8))
|
|
173
|
-
#endif
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
#ifdef ALTIVEC_USE_EVEN_INDICES
|
|
177
|
-
#define even_byte_indices ((qword) ((vec_uchar16){0,2,4,6,8,10,12,14,16,18,20,22,24,26,28,30}))
|
|
178
|
-
#define simd_pack_16_hh(a, b) si_shufb(a, b, even_byte_indices)
|
|
179
|
-
#endif
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
#define sisd_from_int(n) si_from_int(n)
|
|
184
|
-
#define sisd_to_int(n) si_to_int(n)
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
#define sisd_store_aligned(r, addr) *((SIMD_type *) (addr)) = r
|
|
190
|
-
#define sisd_load_aligned(addr) ((SIMD_type) *((SIMD_type *) (addr)))
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
#define last_byte_per_word ((SIMD_type) ((vec_uchar16){3,7,11,15,0,0,0,0,0,0,0,0,0,0,0,0}))
|
|
196
|
-
|
|
197
|
-
static inline int bitblock_bit_count(SIMD_type v) {
|
|
198
|
-
SIMD_type bits_per_byte = si_cntb(v);
|
|
199
|
-
SIMD_type bits_per_word = si_sumb(bits_per_byte, simd_const_8(0));
|
|
200
|
-
return sisd_to_int(si_sumb(si_shufb(bits_per_word, simd_const_8(0), last_byte_per_word),
|
|
201
|
-
simd_const_8(0)));
|
|
202
|
-
}
|
|
203
|
-
|
|
204
|
-
static inline int bitblock_has_bit(SIMD_type v) {
|
|
205
|
-
int mask = sisd_to_int(si_gbb(simd_eq_8(v, simd_const_8(0))));
|
|
206
|
-
return mask != 0xFFFF;
|
|
207
|
-
}
|
|
208
|
-
|
|
209
|
-
static inline int simd_any_sign_bit_8(SIMD_type v) {
|
|
210
|
-
return sisd_to_int(si_gbb(si_cgtb(simd_const_8(0), v))) != 0;
|
|
211
|
-
}
|
|
212
|
-
|
|
213
|
-
static inline int simd_all_eq_8 (SIMD_type v1, SIMD_type v2){
|
|
214
|
-
int mask = sisd_to_int(si_gbb(simd_eq_8(v1,v2)));
|
|
215
|
-
return mask == 0xFFFF;
|
|
216
|
-
}
|
|
217
|
-
|
|
218
|
-
static inline int count_forward_zeroes(SIMD_type v) {
|
|
219
|
-
SIMD_type u32_zeroes = si_clz(v);
|
|
220
|
-
/* Compress the 4 counts of zeroes into the first 4 bytes. */
|
|
221
|
-
SIMD_type u8_zeroes = si_shufb(u32_zeroes, u32_zeroes, last_byte_per_word);
|
|
222
|
-
/* Which of the words were all zeroes (counts = 32)? */
|
|
223
|
-
SIMD_type u8_mask = simd_gt_8(simd_const_8(32), u8_zeroes);
|
|
224
|
-
SIMD_type cnt_initial = si_clz(u8_mask);
|
|
225
|
-
return sisd_to_int(si_sumb(simd_srl_32(u8_zeroes, sisd_from_int(24 - sisd_to_int(cnt_initial))), simd_const_8(0)));
|
|
226
|
-
}
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
void print_bit_block(char * var_name, SIMD_type v) {
|
|
232
|
-
union {SIMD_type vec; unsigned char elems[16];} x;
|
|
233
|
-
x.vec = v;
|
|
234
|
-
int i;
|
|
235
|
-
printf("%20s = ", var_name);
|
|
236
|
-
for (i = 0; i < 16; i++) {
|
|
237
|
-
printf("%02X ", x.elems[i]);
|
|
238
|
-
}
|
|
239
|
-
printf("\n");
|
|
240
|
-
}
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
static inline SIMD_type simd_add_2(SIMD_type a, SIMD_type b)
|
|
244
|
-
{
|
|
245
|
-
SIMD_type c1 = simd_xor(a,b);
|
|
246
|
-
SIMD_type borrow = simd_and(a,b);
|
|
247
|
-
SIMD_type c2 = simd_xor(c1,(sisd_slli(borrow,1)));
|
|
248
|
-
return simd_if(simd_himask_2,c2,c1);
|
|
249
|
-
}
|
|
250
|
-
#define simd_add_4(a, b)\
|
|
251
|
-
simd_if(simd_himask_8, simd_add_8(simd_and(a,simd_himask_8),simd_and(b,simd_himask_8))\
|
|
252
|
-
,simd_add_8(simd_andc(a,simd_himask_8),simd_andc(b,simd_himask_8)))
|
|
253
|
-
|
|
254
|
-
#define simd_srli_2(r, sh)\
|
|
255
|
-
simd_and(sisd_srli(r,sh),simd_const_2(3>>sh))
|
|
256
|
-
|
|
257
|
-
#define simd_srli_4(r, sh)\
|
|
258
|
-
simd_and(sisd_srli(r,sh),simd_const_4(15>>sh))
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
#define simd_add_2_xx(a, b) simd_add_2(a, b)
|
|
262
|
-
#define simd_add_2_xl(a, b) simd_add_2(a, simd_andc(b, simd_himask_2))
|
|
263
|
-
#define simd_add_2_xh(a, b) simd_add_2(a, simd_srli_2(b, 1))
|
|
264
|
-
#define simd_add_2_lx(a, b) simd_add_2(simd_andc(a, simd_himask_2), b)
|
|
265
|
-
#define simd_add_2_ll(a, b) simd_add_2(simd_andc(a, simd_himask_2), simd_andc(b, simd_himask_2))
|
|
266
|
-
#define simd_add_2_lh(a, b) simd_add_2(simd_andc(a, simd_himask_2), simd_srli_2(b, 1))
|
|
267
|
-
#define simd_add_2_hx(a, b) simd_add_2(simd_srli_2(a, 1), b)
|
|
268
|
-
#define simd_add_2_hl(a, b) simd_add_2(simd_srli_2(a, 1), simd_andc(b, simd_himask_2))
|
|
269
|
-
#define simd_add_2_hh(a, b) simd_add_2(simd_srli_2(a, 1), simd_srli_2(b, 1))
|
|
270
|
-
#define simd_add_4_xx(a, b) simd_add_4(a, b)
|
|
271
|
-
#define simd_add_4_xl(a, b) simd_add_4(a, simd_andc(b, simd_himask_4))
|
|
272
|
-
#define simd_add_4_xh(a, b) simd_add_4(a, simd_srli_4(b, 2))
|
|
273
|
-
#define simd_add_4_lx(a, b) simd_add_4(simd_andc(a, simd_himask_4), b)
|
|
274
|
-
#define simd_add_4_ll(a, b) simd_add_4(simd_andc(a, simd_himask_4), simd_andc(b, simd_himask_4))
|
|
275
|
-
#define simd_add_4_lh(a, b) simd_add_4(simd_andc(a, simd_himask_4), simd_srli_4(b, 2))
|
|
276
|
-
#define simd_add_4_hx(a, b) simd_add_4(simd_srli_4(a, 2), b)
|
|
277
|
-
#define simd_add_4_hl(a, b) simd_add_4(simd_srli_4(a, 2), simd_andc(b, simd_himask_4))
|
|
278
|
-
#define simd_add_4_hh(a, b) simd_add_4(simd_srli_4(a, 2), simd_srli_4(b, 2))
|
|
279
|
-
#define simd_add_8_xx(a, b) simd_add_8(a, b)
|
|
280
|
-
#define simd_add_8_xl(a, b) simd_add_8(a, simd_andc(b, simd_himask_8))
|
|
281
|
-
#define simd_add_8_xh(a, b) simd_add_8(a, simd_srli_8(b, 4))
|
|
282
|
-
#define simd_add_8_lx(a, b) simd_add_8(simd_andc(a, simd_himask_8), b)
|
|
283
|
-
#define simd_add_8_ll(a, b) simd_add_8(simd_andc(a, simd_himask_8), simd_andc(b, simd_himask_8))
|
|
284
|
-
#define simd_add_8_lh(a, b) simd_add_8(simd_andc(a, simd_himask_8), simd_srli_8(b, 4))
|
|
285
|
-
#define simd_add_8_hx(a, b) simd_add_8(simd_srli_8(a, 4), b)
|
|
286
|
-
#define simd_add_8_hl(a, b) simd_add_8(simd_srli_8(a, 4), simd_andc(b, simd_himask_8))
|
|
287
|
-
#define simd_add_8_hh(a, b) simd_add_8(simd_srli_8(a, 4), simd_srli_8(b, 4))
|
|
288
|
-
|
|
289
|
-
#define simd_pack_2(a,b)\
|
|
290
|
-
simd_pack_4(simd_if(simd_himask_2,sisd_srli(a,1),a),\
|
|
291
|
-
simd_if(simd_himask_2,sisd_srli(b,1),b))
|
|
292
|
-
#define simd_pack_4(a,b)\
|
|
293
|
-
simd_pack_8(simd_if(simd_himask_4,sisd_srli(a,2),a),\
|
|
294
|
-
simd_if(simd_himask_4,sisd_srli(b,2),b))
|
|
295
|
-
#define simd_pack_8(a,b)\
|
|
296
|
-
simd_pack_16(simd_if(simd_himask_8,sisd_srli(a,4),a),\
|
|
297
|
-
simd_if(simd_himask_8,sisd_srli(b,4),b))
|
|
298
|
-
#define simd_pack_2_xx(a, b) simd_pack_2(a, b)
|
|
299
|
-
#define simd_pack_2_xl(a, b) simd_pack_2(a, b)
|
|
300
|
-
#define simd_pack_2_xh(a, b) simd_pack_2(a, simd_srli_2(b, 1))
|
|
301
|
-
#define simd_pack_2_lx(a, b) simd_pack_2(a, b)
|
|
302
|
-
#define simd_pack_2_ll(a, b) simd_pack_2(a, b)
|
|
303
|
-
#define simd_pack_2_lh(a, b) simd_pack_2(a, simd_srli_2(b, 1))
|
|
304
|
-
#define simd_pack_2_hx(a, b) simd_pack_2(simd_srli_2(a, 1), b)
|
|
305
|
-
#define simd_pack_2_hl(a, b) simd_pack_2(simd_srli_2(a, 1), b)
|
|
306
|
-
#define simd_pack_2_hh(a, b) simd_pack_2(simd_srli_2(a, 1), simd_srli_2(b, 1))
|
|
307
|
-
#define simd_pack_4_xx(a, b) simd_pack_4(a, b)
|
|
308
|
-
#define simd_pack_4_xl(a, b) simd_pack_4(a, b)
|
|
309
|
-
#define simd_pack_4_xh(a, b) simd_pack_4(a, simd_srli_4(b, 2))
|
|
310
|
-
#define simd_pack_4_lx(a, b) simd_pack_4(a, b)
|
|
311
|
-
#define simd_pack_4_ll(a, b) simd_pack_4(a, b)
|
|
312
|
-
#define simd_pack_4_lh(a, b) simd_pack_4(a, simd_srli_4(b, 2))
|
|
313
|
-
#define simd_pack_4_hx(a, b) simd_pack_4(simd_srli_4(a, 2), b)
|
|
314
|
-
#define simd_pack_4_hl(a, b) simd_pack_4(simd_srli_4(a, 2), b)
|
|
315
|
-
#define simd_pack_4_hh(a, b) simd_pack_4(simd_srli_4(a, 2), simd_srli_4(b, 2))
|
|
316
|
-
#define simd_pack_8_xx(a, b) simd_pack_8(a, b)
|
|
317
|
-
#define simd_pack_8_xl(a, b) simd_pack_8(a, b)
|
|
318
|
-
#define simd_pack_8_xh(a, b) simd_pack_8(a, simd_srli_8(b, 4))
|
|
319
|
-
#define simd_pack_8_lx(a, b) simd_pack_8(a, b)
|
|
320
|
-
#define simd_pack_8_ll(a, b) simd_pack_8(a, b)
|
|
321
|
-
#define simd_pack_8_lh(a, b) simd_pack_8(a, simd_srli_8(b, 4))
|
|
322
|
-
#define simd_pack_8_hx(a, b) simd_pack_8(simd_srli_8(a, 4), b)
|
|
323
|
-
#define simd_pack_8_hl(a, b) simd_pack_8(simd_srli_8(a, 4), b)
|
|
324
|
-
#define simd_pack_8_hh(a, b) simd_pack_8(simd_srli_8(a, 4), simd_srli_8(b, 4))
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
#define simd_permute(a, b, index) si_shufb(a, b, simd_and(index, simd_const_8(31)))
|
|
328
|
-
|
|
329
|
-
#define LONG_BIT 32
|
|
330
|
-
|
|
331
|
-
#define cfzl __builtin_clzl
|
|
332
|
-
|
|
333
|
-
// Future improvement: use the si_clz for simultaneous counting.
|
|
334
|
-
|
|
335
|
-
/*
|
|
336
|
-
static inline int count_forward_zeroes(SIMD_type bits) {
|
|
337
|
-
union {SIMD_type vec; unsigned long elems[sizeof(SIMD_type)/sizeof(long)];} v;
|
|
338
|
-
v.vec = bits;
|
|
339
|
-
if (v.elems[0] != 0) return cfzl(v.elems[0]);
|
|
340
|
-
else if (v.elems[1] != 0) return LONG_BIT + cfzl(v.elems[1]);
|
|
341
|
-
#if LONG_BIT < 64
|
|
342
|
-
else if (v.elems[2] != 0) return 2*LONG_BIT + cfzl(v.elems[2]);
|
|
343
|
-
else if (v.elems[3] != 0) return 3*LONG_BIT + cfzl(v.elems[3]);
|
|
344
|
-
#endif
|
|
345
|
-
else return 8*sizeof(SIMD_type);
|
|
346
|
-
}
|
|
347
|
-
*/
|
|
348
|
-
|
|
349
|
-
static inline SIMD_type vec_lvsl(int a, unsigned char *b)
|
|
350
|
-
{
|
|
351
|
-
return (SIMD_type) simd_add_16((SIMD_type)spu_splats((unsigned char)((a + (int)(b)) & 0xF)),
|
|
352
|
-
(SIMD_type)((vec_uchar16){0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15}));
|
|
353
|
-
}
|
|
354
|
-
|
|
355
|
-
static inline SIMD_type vec_lvsr(int a, unsigned char *b)
|
|
356
|
-
{
|
|
357
|
-
return (SIMD_type) simd_sub_16((SIMD_type)((vec_uchar16){16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31}),
|
|
358
|
-
(SIMD_type)spu_splats((unsigned char)((a + (int)(b)) & 0xF)));
|
|
359
|
-
}
|
|
360
|
-
|
|
361
|
-
static inline SIMD_type vec_ld(int a, unsigned char *b)
|
|
362
|
-
{
|
|
363
|
-
return (*((SIMD_type *)(((int)b)+a)));
|
|
364
|
-
}
|
|
365
|
-
|
|
366
|
-
static inline void vec_st(SIMD_type a, int b, SIMD_type *c)
|
|
367
|
-
{
|
|
368
|
-
*((SIMD_type *)((unsigned char *)(c)+b)) = a;
|
|
369
|
-
}
|
|
370
|
-
|
|
371
|
-
|
|
372
|
-
#define vec_lvsl1(x) vec_lvsl(x, (unsigned char *) 0)
|
|
373
|
-
#define vec_lvsr1(x) vec_lvsr(x, (unsigned char *) 0)
|
|
374
|
-
|
|
375
|
-
#define vec_splat(r, i) spu_splats(spu_extract(r, i))
|
|
376
|
-
|
|
377
|
-
#define vec_stl vec_st
|
|
378
|
-
|
|
379
|
-
|
|
380
|
-
static inline
|
|
381
|
-
SIMD_type simd_sub_2(SIMD_type a, SIMD_type b)
|
|
382
|
-
{
|
|
383
|
-
SIMD_type c1 = simd_xor(a,b);
|
|
384
|
-
SIMD_type borrow = simd_andc(b,a);
|
|
385
|
-
SIMD_type c2 = simd_xor(c1,(sisd_slli(borrow,1)));
|
|
386
|
-
return simd_if(simd_himask_2,c2,c1);
|
|
387
|
-
}
|
|
388
|
-
|
|
389
|
-
#ifndef simd_sll_4
|
|
390
|
-
inline SIMD_type simd_sll_4(SIMD_type a,SIMD_type b){
|
|
391
|
-
return simd_if(simd_himask_8, simd_sll_8(simd_and(a,simd_himask_8),simd_and(simd_const_4(3),simd_srli_8(b,4)))
|
|
392
|
-
,simd_sll_8(a,simd_and(b,simd_const_8(3))));}
|
|
393
|
-
#endif
|
|
394
|
-
|
|
395
|
-
#ifndef simd_srl_4
|
|
396
|
-
inline SIMD_type simd_srl_4(SIMD_type a,SIMD_type b){
|
|
397
|
-
return simd_if(simd_himask_8, simd_srl_8(a,simd_and(simd_const_4(3),simd_srli_8(b,4)))
|
|
398
|
-
,simd_srl_8(simd_andc(a,simd_himask_8),simd_and(b,simd_const_8(3))));}
|
|
399
|
-
#endif
|
|
400
|
-
|
|
401
|
-
#ifndef simd_sub_4
|
|
402
|
-
inline SIMD_type simd_sub_4(SIMD_type a,SIMD_type b){
|
|
403
|
-
return simd_if(simd_himask_8, simd_sub_8(simd_and(a,simd_himask_8),simd_and(b,simd_himask_8))
|
|
404
|
-
,simd_sub_8(simd_andc(a,simd_himask_8),simd_andc(b,simd_himask_8)));}
|
|
405
|
-
#endif
|
|
406
|
-
|
|
407
|
-
static inline
|
|
408
|
-
SIMD_type simd_rotl_2(SIMD_type a, SIMD_type b)
|
|
409
|
-
{
|
|
410
|
-
SIMD_type c1 = simd_or((simd_andc(a,b)),(simd_and(b,sisd_srli(a,1))));
|
|
411
|
-
SIMD_type c2 = simd_or((simd_andc(a,(sisd_slli(b,1)))),(simd_and((sisd_slli(b,1)),(sisd_slli(a,1)))));
|
|
412
|
-
return simd_if(simd_himask_2,c2,c1);
|
|
413
|
-
}
|
|
414
|
-
|
|
415
|
-
#ifndef simd_rotl_4
|
|
416
|
-
inline SIMD_type simd_rotl_4(SIMD_type a,SIMD_type b){
|
|
417
|
-
return simd_or(simd_sll_4(a,b),simd_srl_4(a,simd_sub_4(simd_const_4(4),b)));}
|
|
418
|
-
#endif
|
|
419
|
-
|
|
420
|
-
|
|
421
|
-
|