Skip to content

Commit

Permalink
Implement evmCodeHash without mapping (no need to keccak key)
Browse files Browse the repository at this point in the history
  • Loading branch information
0xVolosnikov committed Aug 28, 2024
1 parent 5cdc5dd commit 944b6c9
Showing 1 changed file with 21 additions and 3 deletions.
24 changes: 21 additions & 3 deletions system-contracts/contracts/ContractDeployer.sol
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,7 @@ contract ContractDeployer is IContractDeployer, ISystemContract {
Deployed
}

mapping(address => bytes32) public evmCodeHash;
uint256 constant EVM_HASHES_PREFIX = 1 << 254;

uint256 public constructorReturnGas;

Expand All @@ -43,7 +43,7 @@ contract ContractDeployer is IContractDeployer, ISystemContract {
uint256 bytecodeLen = uint256(bytes32(paddedNewDeployedCode[:32]));
bytes memory trueBytecode = paddedNewDeployedCode[32:32 + bytecodeLen];

evmCodeHash[msg.sender] = keccak256(trueBytecode);
_setEvmCodeHash(msg.sender, keccak256(trueBytecode));
constructorReturnGas = constructorGasLeft;

// ToDO: use efficient call
Expand All @@ -58,6 +58,10 @@ contract ContractDeployer is IContractDeployer, ISystemContract {
_;
}

function evmCodeHash(address _address) external view returns (bytes32 _hash) {
_hash = _getEvmCodeHash(_address);
}

/// @notice Returns information about a certain account.
function getAccountInfo(address _address) external view returns (AccountInfo memory info) {
return accountInfo[_address];
Expand Down Expand Up @@ -505,6 +509,20 @@ contract ContractDeployer is IContractDeployer, ISystemContract {
}
}

require(evmCodeHash[_newAddress] != 0x0, "The code hash must be set after the constructor call");
require(_getEvmCodeHash(_newAddress) != 0x0, "The code hash must be set after the constructor call");
}

function _setEvmCodeHash(address _address, bytes32 _hash) internal {
assembly {
let slot := or(EVM_HASHES_PREFIX, _address)
sstore(slot, _hash)
}
}

function _getEvmCodeHash(address _address) internal view returns (bytes32 _hash) {
assembly {
let slot := or(EVM_HASHES_PREFIX, _address)
_hash := sload(slot)
}
}
}

0 comments on commit 944b6c9

Please sign in to comment.