mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
Add constant optimiser for SHR/SHL instructions
This commit is contained in:
parent
fe61435c27
commit
cb352edd26
@ -6,6 +6,7 @@ Features:
|
|||||||
* Commandline interface: Error when missing or inaccessible file detected. Suppress it with the ``--ignore-missing`` flag.
|
* Commandline interface: Error when missing or inaccessible file detected. Suppress it with the ``--ignore-missing`` flag.
|
||||||
* General: Support accessing dynamic return data in post-byzantium EVMs.
|
* General: Support accessing dynamic return data in post-byzantium EVMs.
|
||||||
* Interfaces: Allow overriding external functions in interfaces with public in an implementing contract.
|
* Interfaces: Allow overriding external functions in interfaces with public in an implementing contract.
|
||||||
|
* Optimizer: Optimize ``SHL`` and ``SHR`` only involving constants (Constantinople only).
|
||||||
* Optimizer: Remove useless ``SWAP1`` instruction preceding a commutative instruction (such as ``ADD``, ``MUL``, etc).
|
* Optimizer: Remove useless ``SWAP1`` instruction preceding a commutative instruction (such as ``ADD``, ``MUL``, etc).
|
||||||
* Optimizer: Replace comparison operators (``LT``, ``GT``, etc) with opposites if preceded by ``SWAP1``, e.g. ``SWAP1 LT`` is replaced with ``GT``.
|
* Optimizer: Replace comparison operators (``LT``, ``GT``, etc) with opposites if preceded by ``SWAP1``, e.g. ``SWAP1 LT`` is replaced with ``GT``.
|
||||||
* Optimizer: Optimize across ``mload`` if ``msize()`` is not used.
|
* Optimizer: Optimize across ``mload`` if ``msize()`` is not used.
|
||||||
|
@ -89,6 +89,16 @@ std::vector<SimplificationRule<Pattern>> simplificationRuleList(
|
|||||||
u256 mask = (u256(1) << testBit) - 1;
|
u256 mask = (u256(1) << testBit) - 1;
|
||||||
return u256(boost::multiprecision::bit_test(B.d(), testBit) ? B.d() | ~mask : B.d() & mask);
|
return u256(boost::multiprecision::bit_test(B.d(), testBit) ? B.d() | ~mask : B.d() & mask);
|
||||||
}, false},
|
}, false},
|
||||||
|
{{Instruction::SHL, {A, B}}, [=]{
|
||||||
|
if (A.d() > 255)
|
||||||
|
return u256(0);
|
||||||
|
return u256(bigint(B.d()) << unsigned(A.d()));
|
||||||
|
}, false},
|
||||||
|
{{Instruction::SHR, {A, B}}, [=]{
|
||||||
|
if (A.d() > 255)
|
||||||
|
return u256(0);
|
||||||
|
return B.d() >> unsigned(A.d());
|
||||||
|
}, false},
|
||||||
|
|
||||||
// invariants involving known constants
|
// invariants involving known constants
|
||||||
{{Instruction::ADD, {X, 0}}, [=]{ return X; }, false},
|
{{Instruction::ADD, {X, 0}}, [=]{ return X; }, false},
|
||||||
|
Loading…
Reference in New Issue
Block a user