Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Remove static instantiation of network_constants #3420

Merged
merged 30 commits into from
Aug 12, 2021
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
30 commits
Select commit Hold shift + click to select a range
bf53120
Passing nano::network_constants by ref in to work_pool rather than in…
clemahieu Aug 7, 2021
4a51d0c
Using object reference to network_constants rather than static instan…
clemahieu Aug 7, 2021
68f07fa
Referencing network_constants by reference within websocket_config.
clemahieu Aug 8, 2021
9fea509
Removing static instances of nano::network_constants within unit tests.
clemahieu Aug 8, 2021
238ae67
Moving work_threshold constants on to work_threshold class where they…
clemahieu Aug 8, 2021
cad65ee
Pulling nano::network_constants reference through ipc_config_tcp_sock…
clemahieu Aug 8, 2021
210f725
Pulling network_constants reference through rpc_config rather than in…
clemahieu Aug 8, 2021
c2f19a3
Passing nano::networks enum in to working_path rather than statically…
clemahieu Aug 8, 2021
7520bbe
Converting upgrade logging message that was writing to cerr to a stan…
clemahieu Aug 8, 2021
a1598c9
Removing workaround for coroutines in combination with sanitizers as …
clemahieu Aug 8, 2021
0e8b7cd
Moving threshold classes from free-functions with static network_para…
clemahieu Aug 8, 2021
442fb1e
Moving ::value function on to nano::work_thresholds where it belongs.
clemahieu Aug 8, 2021
aef5020
Moving work_v1::value function on to work_thresholds where it belongs.
clemahieu Aug 8, 2021
49aaac7
Moving threshold function on to work_thresholds class where it belongs.
clemahieu Aug 8, 2021
8e53b14
Moving multiplier normalization from being a free function in to work…
clemahieu Aug 8, 2021
3d71605
Moving work_threshold_base from a free function to a member of work_t…
clemahieu Aug 8, 2021
243a4d9
Moving work_difficulty free function on to work_thresholds class.
clemahieu Aug 8, 2021
868ec86
Moving work_validate from a free function to a member of nano::work_t…
clemahieu Aug 8, 2021
4dead4c
Moving valide_entry from a free function to a method of work_thresholds.
clemahieu Aug 8, 2021
0096d20
Passing work_thresholds in to ledger_constants and removing static re…
clemahieu Aug 9, 2021
e4e2220
Removing check for is_dev_network within using_rocksdb_in_tests as it…
clemahieu Aug 9, 2021
9d47208
Removing unnecessary check for running within unit test context and a…
clemahieu Aug 9, 2021
013104c
This removes debug checks for is_dev_network in several places that d…
clemahieu Aug 9, 2021
2a94a3b
Constifying work_threshold functions.
clemahieu Aug 9, 2021
c3ac780
Moving nano::block::difficulty on to nano::work_thresholds. This move…
clemahieu Aug 9, 2021
ebcf70e
Pulling a work_thresholds reference through opencl_work class so it d…
clemahieu Aug 10, 2021
a56a8d1
Removing empty constructor from network_constants.
clemahieu Aug 10, 2021
a8db7e7
Changing node_config from holding a copy of nano::network_params to h…
clemahieu Aug 10, 2021
7d4bc91
Rewriting how telemetry tests are run so their modifications don't al…
clemahieu Aug 10, 2021
54fb102
Moving work_thresholds in to their own object within network_params a…
clemahieu Aug 10, 2021
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
10 changes: 7 additions & 3 deletions nano/lib/config.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,7 @@ get_env_threshold_or_default ("NANO_TEST_EPOCH_2", 0xfffffff800000000), // 8x hi
get_env_threshold_or_default ("NANO_TEST_EPOCH_2_RECV", 0xfffffe0000000000) // 8x lower than epoch_1
);

uint64_t nano::work_thresholds::threshold_entry (nano::work_version const version_a, nano::block_type const type_a)
uint64_t nano::work_thresholds::threshold_entry (nano::work_version const version_a, nano::block_type const type_a) const
{
uint64_t result{ std::numeric_limits<uint64_t>::max () };
if (type_a == nano::block_type::state)
Expand Down Expand Up @@ -110,12 +110,11 @@ uint64_t nano::work_thresholds::threshold (nano::block_details const & details_a

uint64_t nano::work_thresholds::threshold (nano::work_version const version_a, nano::block_details const details_a)
{
static nano::network_constants network_constants;
uint64_t result{ std::numeric_limits<uint64_t>::max () };
switch (version_a)
{
case nano::work_version::work_1:
result = network_constants.publish_thresholds.threshold (details_a);
result = threshold (details_a);
break;
default:
debug_assert (false && "Invalid version specified to ledger work_threshold");
Expand Down Expand Up @@ -199,6 +198,11 @@ bool nano::work_thresholds::validate_entry (nano::work_version const version_a,
return difficulty (version_a, root_a, work_a) < threshold_entry (version_a, nano::block_type::state);
}

bool nano::work_thresholds::validate_entry (nano::block const & block_a) const
{
return block_a.difficulty () < threshold_entry (block_a.work_version (), block_a.type ());
}

namespace nano
{
const char * network_constants::active_network_err_msg = "Invalid network. Valid values are live, test, beta and dev.";
Expand Down
4 changes: 3 additions & 1 deletion nano/lib/config.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -83,6 +83,7 @@ enum class work_version
};
enum class block_type : uint8_t;
class root;
class block;
class block_details;

class work_thresholds
Expand Down Expand Up @@ -110,7 +111,7 @@ class work_thresholds
return other_a;
}

uint64_t threshold_entry (nano::work_version const, nano::block_type const);
uint64_t threshold_entry (nano::work_version const, nano::block_type const) const;
uint64_t threshold (nano::block_details const &);
// Ledger threshold
uint64_t threshold (nano::work_version const, nano::block_details const);
Expand All @@ -120,6 +121,7 @@ class work_thresholds
double denormalized_multiplier (double const, uint64_t const);
uint64_t difficulty (nano::work_version const, nano::root const &, uint64_t const);
bool validate_entry (nano::work_version const, nano::root const &, uint64_t const);
bool validate_entry (nano::block const &) const;

/** Network work thresholds. Define these inline as constexpr when moving to cpp17. */
static const nano::work_thresholds publish_full;
Expand Down
6 changes: 0 additions & 6 deletions nano/lib/work.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -22,12 +22,6 @@ std::string nano::to_string (nano::work_version const version_a)
return result;
}

bool nano::work_validate_entry (nano::block const & block_a)
{
static nano::network_constants network_constants;
return block_a.difficulty () < network_constants.publish_thresholds.threshold_entry (block_a.work_version (), block_a.type ());
}

nano::work_pool::work_pool (nano::network_constants & network_constants, unsigned max_threads_a, std::chrono::nanoseconds pow_rate_limiter_a, std::function<boost::optional<uint64_t> (nano::work_version const, nano::root const &, uint64_t, std::atomic<int> &)> opencl_a) :
network_constants{ network_constants },
ticket (0),
Expand Down
1 change: 0 additions & 1 deletion nano/lib/work.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,6 @@ std::string to_string (nano::work_version const version_a);
class block;
class block_details;
enum class block_type : uint8_t;
bool work_validate_entry (nano::block const &);

class opencl_work;
class work_item final
Expand Down
4 changes: 2 additions & 2 deletions nano/node/blockprocessor.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -105,7 +105,7 @@ void nano::block_processor::add (std::shared_ptr<nano::block> const & block_a, u

void nano::block_processor::add (nano::unchecked_info const & info_a)
{
debug_assert (!nano::work_validate_entry (*info_a.block));
debug_assert (!node.network_params.network.publish_thresholds.validate_entry (*info_a.block));
bool quarter_full (size () > node.flags.block_processor_full_size / 4);
if (info_a.verified == nano::signature_verification::unknown && (info_a.block->type () == nano::block_type::state || info_a.block->type () == nano::block_type::open || !info_a.account.is_zero ()))
{
Expand All @@ -124,7 +124,7 @@ void nano::block_processor::add (nano::unchecked_info const & info_a)
void nano::block_processor::add_local (nano::unchecked_info const & info_a)
{
release_assert (info_a.verified == nano::signature_verification::unknown && (info_a.block->type () == nano::block_type::state || !info_a.account.is_zero ()));
debug_assert (!nano::work_validate_entry (*info_a.block));
debug_assert (!node.network_params.network.publish_thresholds.validate_entry (*info_a.block));
state_block_signature_verification.add (info_a);
}

Expand Down
2 changes: 1 addition & 1 deletion nano/node/bootstrap/bootstrap_bulk_pull.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -208,7 +208,7 @@ void nano::bulk_pull_client::received_block (boost::system::error_code const & e
{
nano::bufferstream stream (connection->receive_buffer->data (), size_a);
auto block (nano::deserialize_block (stream, type_a));
if (block != nullptr && !nano::work_validate_entry (*block))
if (block != nullptr && !connection->node->network_params.network.publish_thresholds.validate_entry (*block))
{
auto hash (block->hash ());
if (connection->node->config.logging.bulk_pull_logging ())
Expand Down
2 changes: 1 addition & 1 deletion nano/node/bootstrap/bootstrap_bulk_push.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -232,7 +232,7 @@ void nano::bulk_push_server::received_block (boost::system::error_code const & e
{
nano::bufferstream stream (receive_buffer->data (), size_a);
auto block (nano::deserialize_block (stream, type_a));
if (block != nullptr && !nano::work_validate_entry (*block))
if (block != nullptr && !connection->node->network_params.network.publish_thresholds.validate_entry (*block))
{
connection->node->process_active (std::move (block));
throttled_receive ();
Expand Down
4 changes: 2 additions & 2 deletions nano/node/bootstrap/bootstrap_server.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -426,7 +426,7 @@ void nano::bootstrap_server::receive_publish_action (boost::system::error_code c
{
if (is_realtime_connection ())
{
if (!nano::work_validate_entry (*request->block))
if (!node->network_params.network.publish_thresholds.validate_entry (*request->block))
{
add_request (std::unique_ptr<nano::message> (request.release ()));
}
Expand Down Expand Up @@ -494,7 +494,7 @@ void nano::bootstrap_server::receive_confirm_ack_action (boost::system::error_co
if (!vote_block.which ())
{
auto const & block (boost::get<std::shared_ptr<nano::block>> (vote_block));
if (nano::work_validate_entry (*block))
if (node->network_params.network.publish_thresholds.validate_entry (*block))
{
process_vote = false;
node->stats.inc_detail_only (nano::stat::type::error, nano::stat::detail::insufficient_work);
Expand Down
6 changes: 3 additions & 3 deletions nano/node/common.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -424,7 +424,7 @@ void nano::message_parser::deserialize_publish (nano::stream & stream_a, nano::m
nano::publish incoming (error, stream_a, header_a, digest_a, &block_uniquer);
if (!error && at_end (stream_a))
{
if (!nano::work_validate_entry (*incoming.block))
if (!network.publish_thresholds.validate_entry (*incoming.block))
{
visitor.publish (incoming);
}
Expand All @@ -445,7 +445,7 @@ void nano::message_parser::deserialize_confirm_req (nano::stream & stream_a, nan
nano::confirm_req incoming (error, stream_a, header_a, &block_uniquer);
if (!error && at_end (stream_a))
{
if (incoming.block == nullptr || !nano::work_validate_entry (*incoming.block))
if (incoming.block == nullptr || !network.publish_thresholds.validate_entry (*incoming.block))
{
visitor.confirm_req (incoming);
}
Expand All @@ -471,7 +471,7 @@ void nano::message_parser::deserialize_confirm_ack (nano::stream & stream_a, nan
if (!vote_block.which ())
{
auto const & block (boost::get<std::shared_ptr<nano::block>> (vote_block));
if (nano::work_validate_entry (*block))
if (network.publish_thresholds.validate_entry (*block))
{
status = parse_status::insufficient_work;
break;
Expand Down
2 changes: 1 addition & 1 deletion nano/node/json_handler.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -3123,7 +3123,7 @@ void nano::json_handler::process ()
}
if (!rpc_l->ec)
{
if (!nano::work_validate_entry (*block))
if (!rpc_l->node.network_params.network.publish_thresholds.validate_entry (*block))
{
if (!is_async)
{
Expand Down
2 changes: 1 addition & 1 deletion nano/qt/qt.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -2003,7 +2003,7 @@ nano_qt::block_entry::block_entry (nano_qt::wallet & wallet_a) :
{
show_label_ok (*status);
this->status->setText ("");
if (!nano::work_validate_entry (*block_l))
if (!this->wallet.node.network_params.network.publish_thresholds.validate_entry (*block_l))
{
this->wallet.node.process_active (std::move (block_l));
}
Expand Down
3 changes: 2 additions & 1 deletion nano/secure/ledger.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -869,7 +869,8 @@ nano::uint128_t nano::ledger::account_pending (nano::transaction const & transac

nano::process_return nano::ledger::process (nano::write_transaction const & transaction_a, nano::block & block_a, nano::signature_verification verification)
{
debug_assert (!nano::work_validate_entry (block_a) || constants.genesis == nano::dev::genesis);
static nano::network_constants network_constants;
clemahieu marked this conversation as resolved.
Show resolved Hide resolved
debug_assert (!network_constants.publish_thresholds.validate_entry (block_a) || constants.genesis == nano::dev::genesis);
ledger_processor processor (*this, transaction_a, verification);
block_a.visit (processor);
if (processor.result.code == nano::process_result::progress)
Expand Down