Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Network Sustainability Mechanism - ZIP 234 & 235 implementation #8948

Open
wants to merge 7 commits into
base: main
Choose a base branch
from

Conversation

mariopil
Copy link

Motivation

This PR implements ZIP-234 and ZIP-235.

Specifications & References

ZIP-234, ZIP-235

Solution

This PR is implemented above #8930 which implements the ZIP-233. It smoothes the issuance curve (ZIP-234) and introduces the split between miner fees (40%) and the amount that is burned (60%, ZIP-235). Some of the code used in the block semantical verification for block subsidy calculation has been moved into the write task, as now the block subsidy calculation relies on the current amount of money_reserve which is obtained from pool value balance at height-1- therefore the previous block must be already present at least in the non-finalized best chain.

Tests

For testing purposes, a local testnet network was set up. It contained two nodes—a zebra and a zcashd one (with the ZIP-234 & 235 implemented, too, PR zcash/zcash#6970). A transaction in a new format containing the burn_amount field was created and added to the block by zcashd. The zebra node synced with zcashd without any errors and accepted the block.

A couple of unit tests were also added.

Follow-up Work

PR Author's Checklist

  • The PR name will make sense to users.
  • The PR provides a CHANGELOG summary.
  • The solution is tested.
  • The documentation is up to date.
  • The PR has a priority label.

PR Reviewer's Checklist

  • The PR Author's checklist is complete.
  • The PR resolves the issue.

@mariopil mariopil requested review from a team as code owners October 18, 2024 13:14
@mariopil mariopil requested review from upbqdn and removed request for a team October 18, 2024 13:14
@mpguerra mpguerra requested review from conradoplg and arya2 October 21, 2024 07:40
@arya2 arya2 added the do-not-merge Tells Mergify not to merge this PR label Oct 26, 2024
@arya2 arya2 removed the do-not-merge Tells Mergify not to merge this PR label Dec 7, 2024
@mpguerra mpguerra added the no-review-reminders Turn off review reminders label Jan 13, 2025
@jackgavigan
Copy link
Contributor

jackgavigan commented Jan 16, 2025

@mariopil Does this PR need to be refreshed when the NSM ZIPs are finalized?

@mariopil
Copy link
Author

@mariopil Does this PR need to be refreshed when the NSM ZIPs are finalized?

Yes. Currently, the implementation of both 234 and 235 zips is under one feature flag, but they will be covered by separate feature flags.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
no-review-reminders Turn off review reminders
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants