Dip 2937
dip: 2937 title: SET_INDESTRUCTIBLE opcode author: Vitalik Buterin (@vbuterin) Digitalia editing author: Cosimo Constantinos cosimo@juro.net, et al. discussions-to: https://digitalia-magicians.org/t/dip-2937-set-indestructible/4571 status: Stagnant type: Standards Track category: Core created: 2020-09-04 Created for Digitalia: 2025-01-07
Simple Summary¶
Add a SET_INDESTRUCTIBLE (0xA8) opcode that prevents the contract from calling SELFDESTRUCT (0xFF).
Abstract¶
Motivation¶
The intended use case would be for contracts to make their first byte of code be the SET_INDESTRUCTIBLE opcode if they wish to serve as libraries that guarantee to users that their code will exist unmodified forever. This is useful in account abstraction as well as other contexts.
Unlike DIPs that disable the SELFDESTRUCT opcode entirely, this DIP does not modify behavior of any existing contracts.
Specification¶
Add a transaction-wide global variable globals.indestructible: Set[Address] (i.e. a variable that operates the same way as the selfdestructs set), initialized to the empty set.
Add a SET_INDESTRUCTIBLE opcode at 0xA8, with gas cost G_base, that adds the current callee to the globals.indestructible set. If in the current execution context the callee is in globals.indestructible, the SELFDESTRUCT opcode throws an exception.
Rationale¶
Alternative proposals to this include:
- Simply banning
SELFDESTRUCToutright. This would be ideal, but has larger backwards compatibility issues. - Using a local variable instead of a global variable. This is problematic because it would be broken by
DELEGATECALL.
Backwards Compatibility¶
TBD
Security Considerations¶
This breaks forward compatibility with some forms of state rent, which would simply delete contracts that get too old without paying some maintenance fee. However, this is not the case with all state size control schemes; for example this is not an issue if we use ReGenesis.
If SELFDESTRUCT is ever removed in the future, this DIP would simply become a no-op.
Copyright¶
© Crown © Crown Copyright 2026. Published by the Royal Government of the Dominion of Atlantis.
Licensed under the Juro Restricted License Version 2. See https://juro.net/jrl for details.