Crypto++ 8.7
Free C++ class library of cryptographic schemes
|
Support functions for ARM and vector operations. More...
Go to the source code of this file.
Functions | |
CRC32 checksum | |
uint32_t | CRC32B (uint32_t crc, uint8_t val) |
CRC32 checksum. More... | |
uint32_t | CRC32W (uint32_t crc, uint32_t val) |
CRC32 checksum. More... | |
uint32_t | CRC32Wx4 (uint32_t crc, const uint32_t vals[4]) |
CRC32 checksum. More... | |
CRC32-C checksum | |
uint32_t | CRC32CB (uint32_t crc, uint8_t val) |
CRC32-C checksum. More... | |
uint32_t | CRC32CW (uint32_t crc, uint32_t val) |
CRC32-C checksum. More... | |
uint32_t | CRC32CWx4 (uint32_t crc, const uint32_t vals[4]) |
CRC32-C checksum. More... | |
Polynomial multiplication | |
uint64x2_t | PMULL_00 (const uint64x2_t a, const uint64x2_t b) |
Polynomial multiplication. More... | |
uint64x2_t | PMULL_01 (const uint64x2_t a, const uint64x2_t b) |
Polynomial multiplication. More... | |
uint64x2_t | PMULL_10 (const uint64x2_t a, const uint64x2_t b) |
Polynomial multiplication. More... | |
uint64x2_t | PMULL_11 (const uint64x2_t a, const uint64x2_t b) |
Polynomial multiplication. More... | |
uint64x2_t | PMULL (const uint64x2_t a, const uint64x2_t b) |
Polynomial multiplication. More... | |
uint64x2_t | PMULL_HIGH (const uint64x2_t a, const uint64x2_t b) |
Polynomial multiplication. More... | |
uint64x2_t | VEXT_U8 (uint64x2_t a, uint64x2_t b, unsigned int c) |
Vector extraction. More... | |
template<unsigned int C> | |
uint64x2_t | VEXT_U8 (uint64x2_t a, uint64x2_t b) |
Vector extraction. More... | |
ARMv8.2 operations | |
uint64x2_t | VEOR3 (uint64x2_t a, uint64x2_t b, uint64x2_t c) |
Three-way XOR. More... | |
uint64x2_t | VXAR (uint64x2_t a, uint64x2_t b, const int c) |
XOR and rotate. More... | |
template<unsigned int C> | |
uint64x2_t | VXAR (uint64x2_t a, uint64x2_t b) |
XOR and rotate. More... | |
uint64x2_t | VRAX1 (uint64x2_t a, uint64x2_t b) |
XOR and rotate. More... | |
Support functions for ARM and vector operations.
Definition in file arm_simd.h.
|
inline |
CRC32 checksum.
crc | the starting crc value |
val | the value to checksum |
Definition at line 30 of file arm_simd.h.
|
inline |
CRC32 checksum.
crc | the starting crc value |
val | the value to checksum |
Definition at line 46 of file arm_simd.h.
|
inline |
CRC32 checksum.
crc | the starting crc value |
vals | the values to checksum |
Definition at line 62 of file arm_simd.h.
|
inline |
CRC32-C checksum.
crc | the starting crc value |
val | the value to checksum |
Definition at line 86 of file arm_simd.h.
|
inline |
CRC32-C checksum.
crc | the starting crc value |
val | the value to checksum |
Definition at line 102 of file arm_simd.h.
|
inline |
CRC32-C checksum.
crc | the starting crc value |
vals | the values to checksum |
Definition at line 118 of file arm_simd.h.
|
inline |
Polynomial multiplication.
a | the first value |
b | the second value |
PMULL_00() performs polynomial multiplication and presents the result like Intel's c = _mm_clmulepi64_si128(a, b, 0x00)
. The 0x00
indicates the low 64-bits of a
and b
are multiplied.
Definition at line 152 of file arm_simd.h.
|
inline |
Polynomial multiplication.
a | the first value |
b | the second value |
PMULL_01 performs() polynomial multiplication and presents the result like Intel's c = _mm_clmulepi64_si128(a, b, 0x01)
. The 0x01
indicates the low 64-bits of a
and high 64-bits of b
are multiplied.
Definition at line 182 of file arm_simd.h.
|
inline |
Polynomial multiplication.
a | the first value |
b | the second value |
PMULL_10() performs polynomial multiplication and presents the result like Intel's c = _mm_clmulepi64_si128(a, b, 0x10)
. The 0x10
indicates the high 64-bits of a
and low 64-bits of b
are multiplied.
Definition at line 212 of file arm_simd.h.
|
inline |
Polynomial multiplication.
a | the first value |
b | the second value |
PMULL_11() performs polynomial multiplication and presents the result like Intel's c = _mm_clmulepi64_si128(a, b, 0x11)
. The 0x11
indicates the high 64-bits of a
and b
are multiplied.
Definition at line 242 of file arm_simd.h.
|
inline |
Polynomial multiplication.
a | the first value |
b | the second value |
PMULL() performs vmull_p64(). PMULL is provided as GCC inline assembly due to Clang and lack of support for the intrinsic.
Definition at line 267 of file arm_simd.h.
|
inline |
Polynomial multiplication.
a | the first value |
b | the second value |
PMULL_HIGH() performs vmull_high_p64(). PMULL_HIGH is provided as GCC inline assembly due to Clang and lack of support for the intrinsic.
Definition at line 292 of file arm_simd.h.
|
inline |
Vector extraction.
a | the first value |
b | the second value |
c | the byte count |
VEXT_U8() extracts the first c
bytes of vector a
and the remaining bytes in b
. VEXT_U8 is provided as GCC inline assembly due to Clang and lack of support for the intrinsic.
Definition at line 319 of file arm_simd.h.
|
inline |
Vector extraction.
C | the byte count |
a | the first value |
b | the second value |
VEXT_U8() extracts the first C
bytes of vector a
and the remaining bytes in b
. VEXT_U8 is provided as GCC inline assembly due to Clang and lack of support for the intrinsic.
Definition at line 342 of file arm_simd.h.
|
inline |
Three-way XOR.
a | the first value |
b | the second value |
c | the third value |
VEOR3() performs veor3q_u64(). VEOR3 is provided as GCC inline assembly due to Clang and lack of support for the intrinsic.
VEOR3 requires ARMv8.2.
Definition at line 372 of file arm_simd.h.
|
inline |
XOR and rotate.
a | the first value |
b | the second value |
c | the third value |
VXARQ() performs vxarq_u64(). VXARQ is provided as GCC inline assembly due to Clang and lack of support for the intrinsic.
VXARQ requires ARMv8.2.
Definition at line 393 of file arm_simd.h.
|
inline |
XOR and rotate.
C | the rotate amount |
a | the first value |
b | the second value |
VXARQ() performs vxarq_u64(). VXARQ is provided as GCC inline assembly due to Clang and lack of support for the intrinsic.
VXARQ requires ARMv8.2.
Definition at line 415 of file arm_simd.h.
|
inline |
XOR and rotate.
a | the first value |
b | the second value |
VRAX1() performs vrax1q_u64(). VRAX1 is provided as GCC inline assembly due to Clang and lack of support for the intrinsic.
VRAX1 requires ARMv8.2.
Definition at line 435 of file arm_simd.h.