[yul-phaser] Change default metric weights so that everything has a cost

- The CodeSize::DefaultWeights gives zeros to instructions that it assumes will be optimised out. Obviously, we cannot make this assumption here since phaser is meant to find the best way for the optimiser to work.
This commit is contained in:
Kamil Śliwak 2020-02-29 22:12:38 +01:00
parent b776021870
commit bff012c76d

View File

@ -680,9 +680,11 @@ Phaser::CommandLineDescription Phaser::buildCommandLineDescription()
po::options_description metricWeightDescription("METRIC WEIGHTS", lineLength, minDescriptionLength); po::options_description metricWeightDescription("METRIC WEIGHTS", lineLength, minDescriptionLength);
metricWeightDescription.add_options() metricWeightDescription.add_options()
("expression-statement-cost", po::value<size_t>()->value_name("<COST>")->default_value(0)) // TODO: We need to figure out the best set of weights for the phaser.
("assignment-cost", po::value<size_t>()->value_name("<COST>")->default_value(0)) // This one is just a stopgap to make sure no statement or expression has zero cost.
("variable-declaration-cost", po::value<size_t>()->value_name("<COST>")->default_value(0)) ("expression-statement-cost", po::value<size_t>()->value_name("<COST>")->default_value(1))
("assignment-cost", po::value<size_t>()->value_name("<COST>")->default_value(1))
("variable-declaration-cost", po::value<size_t>()->value_name("<COST>")->default_value(1))
("function-definition-cost", po::value<size_t>()->value_name("<COST>")->default_value(1)) ("function-definition-cost", po::value<size_t>()->value_name("<COST>")->default_value(1))
("if-cost", po::value<size_t>()->value_name("<COST>")->default_value(2)) ("if-cost", po::value<size_t>()->value_name("<COST>")->default_value(2))
("switch-cost", po::value<size_t>()->value_name("<COST>")->default_value(1)) ("switch-cost", po::value<size_t>()->value_name("<COST>")->default_value(1))
@ -691,9 +693,9 @@ Phaser::CommandLineDescription Phaser::buildCommandLineDescription()
("break-cost", po::value<size_t>()->value_name("<COST>")->default_value(2)) ("break-cost", po::value<size_t>()->value_name("<COST>")->default_value(2))
("continue-cost", po::value<size_t>()->value_name("<COST>")->default_value(2)) ("continue-cost", po::value<size_t>()->value_name("<COST>")->default_value(2))
("leave-cost", po::value<size_t>()->value_name("<COST>")->default_value(2)) ("leave-cost", po::value<size_t>()->value_name("<COST>")->default_value(2))
("block-cost", po::value<size_t>()->value_name("<COST>")->default_value(0)) ("block-cost", po::value<size_t>()->value_name("<COST>")->default_value(1))
("function-call-cost", po::value<size_t>()->value_name("<COST>")->default_value(1)) ("function-call-cost", po::value<size_t>()->value_name("<COST>")->default_value(1))
("identifier-cost", po::value<size_t>()->value_name("<COST>")->default_value(0)) ("identifier-cost", po::value<size_t>()->value_name("<COST>")->default_value(1))
("literal-cost", po::value<size_t>()->value_name("<COST>")->default_value(1)) ("literal-cost", po::value<size_t>()->value_name("<COST>")->default_value(1))
; ;
keywordDescription.add(metricWeightDescription); keywordDescription.add(metricWeightDescription);