54 #include <gtest/gtest.h>
59 #include "../../test/abi_test.h"
60 #include "../../test/file_test.h"
61 #include "../../test/test_util.h"
62 #include "../aes/internal.h"
66 TEST(GCMTest, TestVectors) {
72 ASSERT_TRUE(t->GetBytes(&additional_data,
"AdditionalData"));
89 if (!additional_data.empty()) {
97 std::vector<uint8_t> got_tag(
tag.size());
104 if (!additional_data.empty()) {
122 #if defined(SUPPORTS_ABI_TEST) && !defined(OPENSSL_NO_ASM)
128 static const size_t kBlockCounts[] = {1, 2, 3, 4, 5, 6, 7, 8, 15, 16, 31, 32};
137 alignas(16)
u128 Htable[16];
138 #if defined(GHASH_ASM_X86) || defined(GHASH_ASM_X86_64)
139 if (gcm_ssse3_capable()) {
142 for (
size_t blocks : kBlockCounts) {
150 for (
size_t blocks : kBlockCounts) {
154 #if defined(GHASH_ASM_X86_64)
155 if (((OPENSSL_ia32cap_get()[1] >> 22) & 0x41) == 0x41) {
158 for (
size_t blocks : kBlockCounts) {
168 memset(&gcm, 0,
sizeof(gcm));
175 for (
size_t blocks : kBlockCounts) {
182 for (
size_t blocks : kBlockCounts) {
190 #endif // GHASH_ASM_X86_64
192 #endif // GHASH_ASM_X86 || GHASH_ASM_X86_64
194 #if defined(GHASH_ASM_ARM)
195 if (gcm_neon_capable()) {
198 for (
size_t blocks : kBlockCounts) {
203 if (gcm_pmull_capable()) {
206 for (
size_t blocks : kBlockCounts) {
210 #endif // GHASH_ASM_ARM
212 #if defined(GHASH_ASM_PPC64LE)
213 if (CRYPTO_is_PPC64LE_vcrypto_capable()) {
216 for (
size_t blocks : kBlockCounts) {
220 #endif // GHASH_ASM_PPC64LE
222 #endif // SUPPORTS_ABI_TEST && !OPENSSL_NO_ASM