mirror of
https://github.com/status-im/EIPs.git
synced 2025-01-24 05:39:05 +00:00
78 lines
3.3 KiB
Markdown
78 lines
3.3 KiB
Markdown
---
|
|
eip: 1052
|
|
title: EXTCODEHASH opcode
|
|
author: Nick Johnson <arachnid@notdot.net>, Paweł Bylica <pawel@ethereum.org>
|
|
discussions-to: https://ethereum-magicians.org/t/extcodehash-opcode/262
|
|
status: Final
|
|
type: Standards Track
|
|
category: Core
|
|
created: 2018-05-02
|
|
---
|
|
|
|
## Abstract
|
|
This EIP specifies a new opcode, which returns the keccak256 hash of a contract's code.
|
|
|
|
## Motivation
|
|
Many contracts need to perform checks on a contract's bytecode, but do not necessarily need the bytecode itself. For instance, a contract may want to check if another contract's bytecode is one of a set of permitted implementations, or it may perform analyses on code and whitelist any contract with matching bytecode if the analysis passes.
|
|
|
|
Contracts can presently do this using the `EXTCODECOPY` opcode, but this is expensive, especially for large contracts, in cases where only the hash is required. As a result, we propose a new opcode, `EXTCODEHASH`, which returns the keccak256 hash of a contract's bytecode.
|
|
|
|
## Specification
|
|
|
|
A new opcode, `EXTCODEHASH`, is introduced, with number 0x3F. The `EXTCODEHASH`
|
|
takes one argument from the stack, zeros the first 96 bits
|
|
and pushes to the stack the keccak256 hash of the code of the account
|
|
at the address being the remaining 160 bits.
|
|
|
|
In case the account does not exist `0` is pushed to the stack.
|
|
|
|
In case the account does not have code the keccak256 hash of empty data
|
|
(i.e. `c5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470`)
|
|
is pushed to the stack.
|
|
|
|
The gas cost of the `EXTCODEHASH` is 400.
|
|
|
|
|
|
## Rationale
|
|
|
|
As described in the motivation section, this opcode is widely useful, and saves
|
|
on wasted gas in many cases.
|
|
|
|
The gas cost is the same as the gas cost for the `BALANCE` opcode because the
|
|
execution of the `EXTCODEHASH` requires the same account lookup as in `BALANCE`.
|
|
|
|
Only the 20 last bytes of the argument are significant (the first 12 bytes are
|
|
ignored) similarly to the semantics of the `BALANCE`, `EXTCODESIZE` and
|
|
`EXTCODECOPY`.
|
|
|
|
The `EXTCODEHASH` distincts accounts without code and non-existing accounts.
|
|
This is consistent with the way accounts are represented in the state trie.
|
|
This also allows smart contracts to check whenever an account exists.
|
|
|
|
|
|
## Backwards Compatibility
|
|
|
|
There are no backwards compatibility concerns.
|
|
|
|
|
|
## Test Cases
|
|
|
|
1. The `EXTCODEHASH` of the account without code is `c5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470`
|
|
what is the keccack256 hash of empty data.
|
|
2. The `EXTCODEHASH` of non-existent account is `0`.
|
|
3. The `EXTCODEHASH` of an precompiled contract is either `c5d246...` or `0`.
|
|
4. If `EXTCODEHASH` of `A` is `X`, then `EXTCODEHASH` of `A + 2**160` is `X`.
|
|
5. The `EXTCODEHASH` of an account that selfdestructed in the current transaction.
|
|
6. The `EXTCODEHASH` of an account that selfdestructed and later the selfdestruct has been reverted.
|
|
7. The `EXTCODEHASH` of an account created in the current transaction.
|
|
8. The `EXTCODEHASH` of an account that has been newly create and later the creation has been reverted.
|
|
9. The `EXTCODEHASH` of an account that firstly does not exist and later is empty.
|
|
10. The `EXTCODEHASH` of an empty account that is going to be cleared by the state clearing rule.
|
|
|
|
|
|
## Implementation
|
|
TBD
|
|
|
|
## Copyright
|
|
Copyright and related rights waived via [CC0](https://creativecommons.org/publicdomain/zero/1.0/).
|