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.
Definition
interpreter.h:202
SigVersion::WITNESS_V0
@ WITNESS_V0
Witness v0 (P2WPKH and P2WSH); see BIP 141.
Definition
interpreter.h:203
script
Definition
parsing.cpp:13
pubkey.h
Generated on
for Bitcoin Core by
1.16.1