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

[DO NOT MERGE]feat: change kernel ordering #3193

Closed

Conversation

SWvheerden
Copy link
Collaborator

Description

This changes the kernel order to be on the excess signature (nonce then signature)

Motivation and Context

This locks the kernel into canonical ordering.

How Has This Been Tested?

Checklist:

  • I'm merging against the development branch.
  • I have squashed my commits into a single commit.

Copy link
Member

@sdbondi sdbondi left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

+1

@sdbondi
Copy link
Member

sdbondi commented Aug 19, 2021

Think you should update the canonical ordering in the consensus rules RFC (120)

@stringhandler stringhandler added W-consensus_breaking Warn - A change requiring a hard fork to be activated P-do_not_merge Process - Not ready for merging labels Aug 30, 2021
sdbondi added a commit to sdbondi/tari that referenced this pull request Sep 20, 2021
Block v1 (compatible with weatherwax at all heights):
- Kernel ordering using every kernel field
- Input MR commits to empty serialization of bitmap

Block v2 (Igor, breaking change)
- Kernel ordering (tari-project#3193)
- Input MR uses input hashes only without extaneous empty bitmap bytes
  (tari-project#3195)

Network - DHT messaging protocol:
On weatherwax: no change, fully compatible
On all other networks: protected from header malleability
sdbondi added a commit to sdbondi/tari that referenced this pull request Sep 21, 2021
Block v1 (compatible with weatherwax at all heights):
- Kernel ordering using every kernel field
- Input MR commits to empty serialization of bitmap

Block v2 (Igor, breaking change)
- Kernel ordering (tari-project#3193)
- Input MR uses input hashes only without extaneous empty bitmap bytes
  (tari-project#3195)
sdbondi added a commit to sdbondi/tari that referenced this pull request Sep 21, 2021
Block v1 (compatible with weatherwax at all heights):
- Kernel ordering using every kernel field
- Input MR commits to empty serialization of bitmap

Block v2 (Igor, breaking change)
- Kernel ordering (tari-project#3193)
- Input MR uses input hashes only without extaneous empty bitmap bytes
  (tari-project#3195)
sdbondi added a commit to sdbondi/tari that referenced this pull request Sep 21, 2021
Block v1 (compatible with weatherwax at all heights):
- Kernel ordering using every kernel field
- Input MR commits to empty serialization of bitmap

Block v2 (Igor, breaking change)
- Kernel ordering (tari-project#3193)
- Input MR uses input hashes only without extaneous empty bitmap bytes
  (tari-project#3195)
sdbondi added a commit to sdbondi/tari that referenced this pull request Sep 21, 2021
Block v1 (compatible with weatherwax at all heights):
- Kernel ordering using every kernel field
- Input MR commits to empty serialization of bitmap

Block v2 (Igor, breaking change)
- Kernel ordering (tari-project#3193)
- Input MR uses input hashes only without extaneous empty bitmap bytes
  (tari-project#3195)
aviator-app bot pushed a commit that referenced this pull request Sep 21, 2021
… compatibility (#3372)

Description
---
Block v1 (compatible with weatherwax at all heights):
- Kernel ordering using every kernel field
- Input MR commits to empty serialization of bitmap

Block v2 (Igor, breaking change)
- Kernel ordering (#3193)
- Input MR uses input hashes only without extaneous empty bitmap bytes
  (#3195)

Misc

- Add missing kernel order block validation
- Removed unnecessary transaction body sorting in wallet, it (still) is the responsibility of the GetNewBlockTemplate to assemble a final sorted block body.

Motivation and Context
---
Allow consensus breaking code to be merged without hard forking weatherwax. 
Igor will have to be reset.

To follow in subsequent PR: network breaking changes from DHT header malleability fix (#3243 ) 

How Has This Been Tested?
---
Archival sync weatherwax node from scratch, received propagated blocks
Washing machine between two weatherwax wallets
@sdbondi
Copy link
Member

sdbondi commented Sep 22, 2021

Changed included in #3372. Closing

@sdbondi sdbondi closed this Sep 22, 2021
@SWvheerden SWvheerden deleted the sw_change_ordering branch January 17, 2022 07:08
sdbondi added a commit to sdbondi/tari that referenced this pull request Feb 3, 2022
Block v1 (compatible with weatherwax at all heights):
- Kernel ordering using every kernel field
- Input MR commits to empty serialization of bitmap

Block v2 (Igor, breaking change)
- Kernel ordering (tari-project#3193)
- Input MR uses input hashes only without extaneous empty bitmap bytes
  (tari-project#3195)

Network - DHT messaging protocol:
On weatherwax: no change, fully compatible
On all other networks: protected from header malleability
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
P-do_not_merge Process - Not ready for merging W-consensus_breaking Warn - A change requiring a hard fork to be activated
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants