cip | title | author | discussions-to | status | type | created | license |
---|---|---|---|---|---|---|---|
62 |
Gingerbread Hardfork |
Paul Lange <@palango>, Gastón Ponti (@gastonponti) |
Final |
Meta |
2023-06-20 |
Apache 2.0 |
This is the Meta CIP for the technical specifications of the Celo Gingerbread Hardfork.
Enable the activation of the two parts of the Celo Gingerbread Hardfork specification which focuses on Ethereum alignment.
Add support for protocol-impacting changes that increase alignment with Ethereum by removing unused Celo-specific features and protocol differences. This hardfork is named Gingerbread by the community.
This document proposes the following blocks at which to implement these changes in the Celo networks:
- Baklava Testnet:
- Part 1: on block
18785000
- Part 2: on block
19157000
- Part 1: on block
- Alfajores Testnet
- Part 1 and Part 2: on block
19814000
- Part 1 and Part 2: on block
- Celo Mainnet
- Part 1 and Part 2: on block
21616000
- Part 1 and Part 2: on block
For more information on the opcodes and their respective EIP and CIP implementations, please see the Specification section of this document.
To enhance the EVM's capabilities and while pushing forward the Celo blockchain functionality in order to enable economic conditions for prosperity as well as reducing differences with Ethereum which will lead to increased compatibility and ease maintenance.
A second Part of the Gingerbread Hardfork was decided later to reduce even more the differences with Ethereum, and give us some future tools required for Celo's switch to become a Layer 2.
This Hardfork will be executed as a two steps release in Baklava, and just a release with one activation block for Alfajores and Mainnet.
The Gingerbread Hardfork specification meta document includes the following proposals.
CIPs to be included in the Part 1:
- CIP-52: Ultragreen Celo
- CIP-53: Remove minimum client version check
- CIP-54: Remove sending of community rewards to reserve if undercollaterized
- CIP-55: Remove Tobin Tax
- CIP-56: Remove freezable check on epoch rewards
- CIP-57: Remove full node incentives
- CIP-58: Restore opcode gas costs from Ethereum
- CIP-59: Re-add header fields with values used in Ethereum 2.0
- CIP-60: Add GASLIMIT opcode
- CIP-61: Add BASEFEE opcode
CIPs to be included in the Part 2:
- CIP-63: Remove BLS-12377, BLS-12381, CIP-20 and CIP-25 precompiles
- CIP-64: New Transaction Type: Celo Dynamic Fee v2
- CIP-65: Total Transaction Data Limit
With the above CIPs the block header contains the same data as the Ethereum chain. Therefore, the hash of the header will be changed so that it is compatible with Ethereum.
As part of Celo's switch to become a Layer 2 and the deprecation of the full node incentives (part of this Hard Fork CIP-57) in future Hard Forks:
- The Celo Legacy Transaction:
rlp(nonce, gasPrice, gas, feeCurrency, gatewayFeeRecipient, gatewayFee, to, value, data, signatureV, signatureR, signatureS)
will be changed to the original Ethereum transactionrlp(nonce, gasPrice, gas, to, value, data, signatureV, signatureR, signatureS)
, removing not only the gateway fields, but also thefeeCurrency
. - The Enveloped Transaction created in the CIP-42 (Type:
0x7c
) will be completely deprecated
As the full node incentives are removed these transactions not only consume unnecessary space, but bring unnecessary complexity to our codebase.
For the sake of maintaining the functionality of paying fees in any of our whitelisted currencies the CIP-64 was added to this Hard Fork. Even if the three transactions will work in this Gingerbread Hard Fork, we recommend to start migrating any application that uses the Celo Legacy transaction for fee payments in a different currency, or any transaction of the type 0x7c
(CIP-42) to this new CIP-64.
Ethereum Compatibility: We include CIPs to increase compatibility with ethereum transactions and opcodes.
Celo Network Maintenance: Several CIPs are included to simplify maintenance of the Celo blockchain code by removing unused features.
Adoption of the content of this CIP requires a hardfork as it introduces changes that are not backward compatible. The following clients with Celo support will implement the Celo Gingerbread hardfork specification:
- celo-blockchain
This work is licensed under the Apache License, Version 2.0.