-
Notifications
You must be signed in to change notification settings - Fork 150
/
Copy pathprime_signature_test.cc
100 lines (84 loc) · 2.83 KB
/
prime_signature_test.cc
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
// Copyright 2011-2024 Google LLC
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// https://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
#include "third_party/zynamics/bindiff/prime_signature.h"
#include <cmath>
#include <cstdint>
#ifdef BINDIFF_GOOGLE
#include "testing/base/public/benchmark.h"
#endif
#include "gmock/gmock.h"
#include "gtest/gtest.h"
#include "third_party/absl/container/flat_hash_set.h"
namespace security::bindiff {
namespace {
using ::testing::Eq;
using ::testing::Ne;
using ::testing::SizeIs;
TEST(PrimeSignatureTest, IPow32MathEdgeCases) {
// Zero exponent
EXPECT_THAT(IPow32(0, 0), Eq(1)); // Per definition
EXPECT_THAT(IPow32(1, 0), Eq(1));
EXPECT_THAT(IPow32(1181, 0), Eq(1));
EXPECT_THAT(IPow32(1299299, 0), Eq(1));
// Unity
EXPECT_THAT(IPow32(1, 2), Eq(1));
EXPECT_THAT(IPow32(1, 4), Eq(1));
EXPECT_THAT(IPow32(1, 400), Eq(1));
}
TEST(PrimeSignatureTest, IPow32NonOverflow) {
EXPECT_THAT(IPow32(2, 4), Eq(16));
EXPECT_THAT(IPow32(12, 2), Eq(144));
EXPECT_THAT(IPow32(953, 3), Eq(865523177));
}
TEST(PrimeSignatureTest, IPow32Overflow) {
EXPECT_THAT(IPow32(953, 48), Eq(1629949057));
EXPECT_THAT(IPow32(1296829, 3600), Eq(454359873));
}
TEST(PrimeSignatureTest, GetPrimeDistinctX86Mnemonics) {
// A few X86 instructions. Make sure they don't map to the same value.
absl::flat_hash_set<uint32_t> distinct_mnemonics = {
GetPrime("add"), GetPrime("sub"),
GetPrime("xor"), GetPrime("aeskeygenassist"),
GetPrime("mov"), GetPrime("vfnmsubss"),
};
EXPECT_THAT(distinct_mnemonics, SizeIs(6));
}
TEST(PrimeSignatureTest, GetPrimeCheckCollision) {
// b/124334881: These should not have the same hash
EXPECT_THAT(GetPrime("ITTEE NETEE NE"), Ne(GetPrime("ITETT LSETT LS")));
}
#ifdef BINDIFF_GOOGLE
void BM_IPow32(::benchmark::State& state) {
const uint32_t exp = state.range(0);
uint32_t base = 102345;
for (const auto _ : state) {
::testing::DoNotOptimize(base);
const auto result = IPow32(base, exp);
::testing::DoNotOptimize(result);
}
}
void BM_pow(::benchmark::State& state) {
const uint32_t exp = state.range(0);
uint32_t base = 102345;
for (const auto _ : state) {
::testing::DoNotOptimize(base);
const auto result = pow(base, exp);
::testing::DoNotOptimize(result);
}
}
BENCHMARK(BM_pow)->DenseRange(0, 64);
BENCHMARK(BM_IPow32)->DenseRange(0, 64);
#endif
} // namespace
} // namespace security::bindiff