diff --git a/lite-client/lite-client.cpp b/lite-client/lite-client.cpp index 64383730b..5869559a8 100644 --- a/lite-client/lite-client.cpp +++ b/lite-client/lite-client.cpp @@ -3731,7 +3731,7 @@ void TestNode::continue_check_validator_load3(std::unique_ptr punishment_params) { +bool compute_punishment(int interval, bool severe, td::RefInt256& fine, unsigned& fine_part, Ref punishment_params, int blocks_count, bool is_masterchain) { if(punishment_params.is_null()) { - return compute_punishment_default(interval, severe, fine, fine_part); + return compute_punishment_default(interval, severe, fine, fine_part, blocks_count, is_masterchain); } block::gen::MisbehaviourPunishmentConfig::Record rec; if (!tlb::unpack_cell(punishment_params, rec)) { @@ -3822,17 +3822,18 @@ bool compute_punishment(int interval, bool severe, td::RefInt256& fine, unsigned return true; } -bool check_punishment(int interval, bool severe, td::RefInt256 fine, unsigned fine_part, Ref punishment_params) { +bool check_punishment(int interval, bool severe, td::RefInt256 fine, unsigned fine_part, Ref punishment_params, + int blocks_count, bool is_masterchain) { td::RefInt256 computed_fine; unsigned computed_fine_part; - return compute_punishment(interval, severe, computed_fine, computed_fine_part, punishment_params) && + return compute_punishment(interval, severe, computed_fine, computed_fine_part, punishment_params, blocks_count, is_masterchain) && std::llabs((long long)fine_part - (long long)computed_fine_part) <= (std::max(fine_part, computed_fine_part) >> 3) && fine * 7 <= computed_fine * 8 && computed_fine * 7 <= fine * 8; } td::Status TestNode::write_val_create_proof(TestNode::ValidatorLoadInfo& info1, TestNode::ValidatorLoadInfo& info2, - int idx, bool severe, std::string file_pfx, int cnt) { + int idx, bool severe, std::string file_pfx, int cnt, int blocks_count, bool is_masterchain) { std::string filename = PSTRING() << file_pfx << '-' << cnt << ".boc"; if (!info1.has_data()) { return td::Status::Error("first block information is incomplete"); @@ -3858,8 +3859,8 @@ td::Status TestNode::write_val_create_proof(TestNode::ValidatorLoadInfo& info1, int severity = (severe ? 2 : 1); td::RefInt256 fine = td::make_refint(101000000000); - unsigned fine_part = 0; // todo: (tolya-yanot) temporary reduction of fine // 0xffffffff / 16; // 1/16 - if (!compute_punishment(interval, severe, fine, fine_part, punishment_params)) { + unsigned fine_part = 0; + if (!compute_punishment(interval, severe, fine, fine_part, punishment_params, blocks_count, is_masterchain)) { return td::Status::Error("cannot compute adequate punishment"); } Ref cpl_descr, complaint; @@ -4173,7 +4174,8 @@ td::Status TestNode::continue_check_validator_load_proof(std::unique_ptrconfig->get_config_param(40))) { + int blocks_count = (int)(x1 + y1); + if (!check_punishment(interval, severe, suggested_fine, rec.suggested_fine_part, info2->config->get_config_param(40), blocks_count, val_idx < main_count)) { LOG(ERROR) << "proposed punishment (fine " << td::dec_string(suggested_fine) << ", fine_part=" << (double)rec.suggested_fine_part / (1LL << 32) << " is too harsh"; show_vote(root->get_hash().bits(), false); diff --git a/lite-client/lite-client.h b/lite-client/lite-client.h index 17680f448..ddb96b6ba 100644 --- a/lite-client/lite-client.h +++ b/lite-client/lite-client.h @@ -283,7 +283,7 @@ class TestNode : public td::actor::Actor { std::unique_ptr info2, int mode = 0, std::string file_pfx = ""); td::Status write_val_create_proof(ValidatorLoadInfo& info1, ValidatorLoadInfo& info2, int idx, bool severe, - std::string file_pfx, int cnt); + std::string file_pfx, int cnt, int blocks_count, bool is_masterchain); bool load_creator_stats(std::unique_ptr load_to, td::Promise> promise, bool need_proofs); td::Status check_validator_load_proof(std::string filename, std::string vset_filename = "",