Branch data Line data Source code
1 : : // Copyright (c) 2022 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 <node/chainstatemanager_args.h>
6 : :
7 : : #include <arith_uint256.h>
8 : : #include <common/args.h>
9 : : #include <common/system.h>
10 : : #include <logging.h>
11 : : #include <node/coins_view_args.h>
12 : : #include <node/database_args.h>
13 : : #include <tinyformat.h>
14 : : #include <uint256.h>
15 : : #include <util/result.h>
16 : : #include <util/strencodings.h>
17 : : #include <util/translation.h>
18 : : #include <validation.h>
19 : :
20 : : #include <algorithm>
21 : : #include <chrono>
22 : : #include <string>
23 : :
24 : : namespace node {
25 : 621 : util::Result<void> ApplyArgsManOptions(const ArgsManager& args, ChainstateManager::Options& opts)
26 : : {
27 [ + - - + ]: 1242 : if (auto value{args.GetIntArg("-checkblockindex")}) {
28 : : // Interpret bare -checkblockindex argument as 1 instead of 0.
29 [ # # # # : 0 : opts.check_block_index = args.GetArg("-checkblockindex")->empty() ? 1 : *value;
# # ]
30 : : }
31 : :
32 [ + - - + ]: 1242 : if (auto value{args.GetBoolArg("-checkpoints")}) opts.checkpoints_enabled = *value;
33 : :
34 [ + - + + ]: 1242 : if (auto value{args.GetArg("-minimumchainwork")}) {
35 [ + - + + ]: 6 : if (auto min_work{uint256::FromUserHex(*value)}) {
36 [ + - ]: 4 : opts.minimum_chain_work = UintToArith256(*min_work);
37 : : } else {
38 [ + - + - ]: 6 : return util::Error{Untranslated(strprintf("Invalid minimum work specified (%s), must be up to %d hex digits", *value, uint256::size() * 2))};
39 : : }
40 : 2 : }
41 : :
42 [ + - + + ]: 1238 : if (auto value{args.GetArg("-assumevalid")}) {
43 [ + - + + ]: 7 : if (auto block_hash{uint256::FromUserHex(*value)}) {
44 [ - + ]: 622 : opts.assumed_valid_block = *block_hash;
45 : : } else {
46 [ + - + - ]: 6 : return util::Error{Untranslated(strprintf("Invalid assumevalid block hash specified (%s), must be up to %d hex digits (or 0 to disable)", *value, uint256::size() * 2))};
47 : : }
48 : 2 : }
49 : :
50 [ + - - + ]: 1234 : if (auto value{args.GetIntArg("-maxtipage")}) opts.max_tip_age = std::chrono::seconds{*value};
51 : :
52 : 617 : ReadDatabaseArgs(args, opts.block_tree_db);
53 : 617 : ReadDatabaseArgs(args, opts.coins_db);
54 : 617 : ReadCoinsViewArgs(args, opts.coins_view);
55 : :
56 [ + - ]: 617 : int script_threads = args.GetIntArg("-par", DEFAULT_SCRIPTCHECK_THREADS);
57 [ + - ]: 617 : if (script_threads <= 0) {
58 : : // -par=0 means autodetect (number of cores - 1 script threads)
59 : : // -par=-n means "leave n cores free" (number of cores - n - 1 script threads)
60 : 617 : script_threads += GetNumCores();
61 : : }
62 : : // Subtract 1 because the main thread counts towards the par threads.
63 : 617 : opts.worker_threads_num = script_threads - 1;
64 : :
65 [ + - - + ]: 1234 : if (auto max_size = args.GetIntArg("-maxsigcachesize")) {
66 : : // 1. When supplied with a max_size of 0, both the signature cache and
67 : : // script execution cache create the minimum possible cache (2
68 : : // elements). Therefore, we can use 0 as a floor here.
69 : : // 2. Multiply first, divide after to avoid integer truncation.
70 [ # # ]: 0 : size_t clamped_size_each = std::max<int64_t>(*max_size, 0) * (1 << 20) / 2;
71 : 0 : opts.script_execution_cache_bytes = clamped_size_each;
72 : 0 : opts.signature_cache_bytes = clamped_size_each;
73 : : }
74 : :
75 : 617 : return {};
76 : : }
77 : : } // namespace node
|