Bitcoin Core
31.0.0
P2P Digital Currency
Loading...
Searching...
No Matches
src
test
fuzz
eval_script.cpp
Go to the documentation of this file.
1
// Copyright (c) 2009-present The Bitcoin Core developers
2
// Distributed under the MIT software license, see the accompanying
3
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
4
5
#include <
pubkey.h
>
6
#include <
script/interpreter.h
>
7
#include <
test/fuzz/FuzzedDataProvider.h
>
8
#include <
test/fuzz/fuzz.h
>
9
10
#include <limits>
11
12
FUZZ_TARGET
(
eval_script
)
13
{
14
FuzzedDataProvider
fuzzed_data_provider
(buffer.data(), buffer.size());
15
const
auto
flags
=
script_verify_flags::from_int
(
fuzzed_data_provider
.
ConsumeIntegral
<
script_verify_flags::value_type
>());
16
const
std::vector<uint8_t>
script_bytes
= [&] {
17
if
(
fuzzed_data_provider
.
remaining_bytes
() != 0) {
18
return
fuzzed_data_provider
.
ConsumeRemainingBytes
<
uint8_t
>();
19
}
else
{
20
// Avoid UBSan warning:
21
// test/fuzz/FuzzedDataProvider.h:212:17: runtime error: null pointer passed as argument 1, which is declared to never be null
22
// /usr/include/string.h:43:28: note: nonnull attribute specified here
23
return
std::vector<uint8_t>();
24
}
25
}();
26
const
CScript
script
(
script_bytes
.begin(),
script_bytes
.end());
27
for
(
const
auto
sig_version
: {
SigVersion::BASE
,
SigVersion::WITNESS_V0
}) {
28
std::vector<std::vector<unsigned char>> stack;
29
(
void
)
EvalScript
(stack,
script
,
flags
,
BaseSignatureChecker
(),
sig_version
,
nullptr
);
30
}
31
}
FuzzedDataProvider.h
flags
int flags
Definition
bitcoin-tx.cpp:529
BaseSignatureChecker
Definition
interpreter.h:275
CScript
Serialized script, used inside transaction inputs and outputs.
Definition
script.h:405
FuzzedDataProvider
Definition
FuzzedDataProvider.h:32
FuzzedDataProvider::remaining_bytes
size_t remaining_bytes()
Definition
FuzzedDataProvider.h:85
FuzzedDataProvider::ConsumeRemainingBytes
std::vector< T > ConsumeRemainingBytes()
Definition
FuzzedDataProvider.h:129
FuzzedDataProvider::ConsumeIntegral
T ConsumeIntegral()
Definition
FuzzedDataProvider.h:195
script_verify_flags::value_type
uint64_t value_type
Definition
verify_flags.h:17
script_verify_flags::from_int
static constexpr script_verify_flags from_int(value_type f)
Definition
verify_flags.h:35
fuzz.h
FUZZ_TARGET
#define FUZZ_TARGET(...)
Definition
fuzz.h:35
EvalScript
bool EvalScript(std::vector< std::vector< unsigned char > > &stack, const CScript &script, script_verify_flags flags, const BaseSignatureChecker &checker, SigVersion sigversion, ScriptExecutionData &execdata, ScriptError *serror)
Definition
interpreter.cpp:407
interpreter.h
SigVersion::BASE
@ BASE
Bare scripts and BIP16 P2SH-wrapped redeemscripts.
SigVersion::WITNESS_V0
@ WITNESS_V0
Witness v0 (P2WPKH and P2WSH); see BIP 141.
script
Definition
parsing.cpp:13
pubkey.h
Ticks
constexpr auto Ticks(Dur2 d)
Helper to count the seconds of a duration/time_point.
Definition
time.h:73
fuzzed_data_provider
FuzzedDataProvider & fuzzed_data_provider
Definition
fees.cpp:38
Generated on Thu Apr 16 2026 09:42:38 for Bitcoin Core by
1.10.0