/* * Copyright (C) 2018-present ScyllaDB */ /* * SPDX-License-Identifier: AGPL-3.0-or-later * */ #pragma once #include #if defined(__x86_64__) || defined(__i386__) #include #include // Performs a carry-less multiplication of two integers. inline uint64_t clmul_u32(uint32_t p1, uint32_t p2) { __m128i p = _mm_set_epi64x(p1, p2); p = _mm_clmulepi64_si128(p, p, 0x01); return _mm_extract_epi64(p, 0); } inline uint64_t clmul(uint32_t p1, uint32_t p2) { return clmul_u32(p1, p2); } #elif defined(__aarch64__) #include // Performs a carry-less multiplication of two integers. inline uint64_t clmul_u32(uint32_t p1, uint32_t p2) { return vmull_p64(p1, p2); } inline uint64_t clmul(uint32_t p1, uint32_t p2) { return clmul_u32(p1, p2); } #endif