Bitcoin Core 28.99.0
P2P Digital Currency
load_external.cpp
Go to the documentation of this file.
1// Copyright (c) 2022 The Bitcoin Core developers
2// Distributed under the MIT software license, see the accompanying
3// file COPYING or https://www.opensource.org/licenses/mit-license.php.
4
5#include <bench/bench.h>
6#include <bench/data/block413567.raw.h>
7#include <chainparams.h>
8#include <flatfile.h>
9#include <node/blockstorage.h>
10#include <span.h>
11#include <streams.h>
13#include <uint256.h>
14#include <util/fs.h>
15#include <validation.h>
16
17#include <cstdint>
18#include <cstdio>
19#include <map>
20#include <memory>
21#include <stdexcept>
22#include <vector>
23
37{
38 const auto testing_setup{MakeNoLogFileContext<const TestingSetup>(ChainType::MAIN)};
39
40 // Create a single block as in the blocks files (magic bytes, block size,
41 // block data) as a stream object.
42 const fs::path blkfile{testing_setup.get()->m_path_root / "blk.dat"};
43 DataStream ss{};
44 auto params{testing_setup->m_node.chainman->GetParams()};
45 ss << params.MessageStart();
46 ss << static_cast<uint32_t>(benchmark::data::block413567.size());
47 // We can't use the streaming serialization (ss << benchmark::data::block413567)
48 // because that first writes a compact size.
49 ss << Span{benchmark::data::block413567};
50
51 // Create the test file.
52 {
53 // "wb+" is "binary, O_RDWR | O_CREAT | O_TRUNC".
54 FILE* file{fsbridge::fopen(blkfile, "wb+")};
55 // Make the test block file about 128 MB in length.
56 for (size_t i = 0; i < node::MAX_BLOCKFILE_SIZE / ss.size(); ++i) {
57 if (fwrite(ss.data(), 1, ss.size(), file) != ss.size()) {
58 throw std::runtime_error("write to test file failed\n");
59 }
60 }
61 fclose(file);
62 }
63
64 std::multimap<uint256, FlatFilePos> blocks_with_unknown_parent;
65 FlatFilePos pos;
66 bench.run([&] {
67 // "rb" is "binary, O_RDONLY", positioned to the start of the file.
68 // The file will be closed by LoadExternalBlockFile().
69 AutoFile file{fsbridge::fopen(blkfile, "rb")};
70 testing_setup->m_node.chainman->LoadExternalBlockFile(file, &pos, &blocks_with_unknown_parent);
71 });
72 fs::remove(blkfile);
73}
74
Non-refcounted RAII wrapper for FILE*.
Definition: streams.h:392
Double ended buffer combining vector and stream-like interfaces.
Definition: streams.h:147
A Span is an object that can refer to a contiguous sequence of objects.
Definition: span.h:98
Main entry point to nanobench's benchmarking facility.
Definition: nanobench.h:627
Bench & run(char const *benchmarkName, Op &&op)
Repeatedly calls op() based on the configuration, and performs measurements.
Definition: nanobench.h:1234
Path class wrapper to block calls to the fs::path(std::string) implicit constructor and the fs::path:...
Definition: fs.h:33
BENCHMARK(LoadExternalBlockFile, benchmark::PriorityLevel::HIGH)
static void LoadExternalBlockFile(benchmark::Bench &bench)
The LoadExternalBlockFile() function is used during -reindex and -loadblock.
@ HIGH
Definition: bench.h:48
FILE * fopen(const fs::path &p, const char *mode)
Definition: fs.cpp:26
static const unsigned int MAX_BLOCKFILE_SIZE
The maximum size of a blk?????.dat file (since 0.8)
Definition: blockstorage.h:75