-
Notifications
You must be signed in to change notification settings - Fork 5.4k
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
EIP 2124: Fork identifier for chain compatibility checks #2124
Conversation
Apart these two comments I think it satisfies the EIP-1 requirements. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think this looks good. Had a brief look at ENR and the Specification here and it seems reasonably explained.
@fjl do you want to review this here before it's merged? Anyone else relevant to review this? |
Author e-mail addresses are put between < and > |
Ping @karalabe |
Sorry, was out last week. I still want to review this. |
Here is my feedback:
Technical things:
|
Here is my proposal for a better fork hash specification: To calculate the fork checksum of a fork block
In Go: func forkHash(numbers []uint64, names []string) uint32 {
var buf [8]byte
var hash uint32
for i := range numbers {
binary.BigEndian.PutUint64(buf[:], numbers[i])
hash = crc32.Update(hash, crc32.IEEETable, buf[:])
hash = crc32.Update(hash, crc32.IEEETable, []byte(names[i]))
}
return hash
} I think this is better because it adds more context into the checksum. We'd need to specify what the names are, but naming forks hasn't been a problem so far. |
We might even be able to remove the genesis hash entirely by just hashing it into the checksum. |
Note that you can still verify compatibility with past forks using the CRC32 checksum. Just calculate all intermediate checksums and match against all of them. |
Yes, it is. I didn't have it originally. @axic forced me to add it.
I'd like to take into consideration all bytes of the hash. We can use an alternative scheme, I'm not married to it, but XOR felt the simplest.
Is CRC common enough nowadays to be available for all programming languages? Re the fork names, I'm not sure that's a good idea. Different clients define forks differently. EIPXYZ vs. Byantium. Even with names, we have variations: Constantinople vs. Constaninople Fix vs. Petersburg vs. St. Petersburg, and this doesn't even take into account variations in capitalization, spacings, symbols. I think it's asking for it to include the names.
Yes, that did occur to me, just figured having the genesis separately might help cleaner separate networks from each other, independent how the forks are applied (or not). E.g. I can create a crawler for Rinkeby without having the crawler support the forks and constantly having to update it with new fork definitions. That said, due to ETH vs. ETC, it might not be useful enough. |
If you want to reduce complexity, I think the best way is removing all the "discovery protocol" stuff from this EIP. There is really no reason to bother with any particular discovery mechanism here. People It should be enough to mention that publishing a record containing the fork information improves connectivity because other nodes can verify compatibility with the issuer of the record. That's it. |
Yes, a lot of languages have it. Go, Python, Rust have it in the standard library.
It's OK to list all canonical fork names so far in this EIP if you worry about compatibility, |
Peter and I just had a long call where we tried to resolve some of the design questions The
Note that Example for mainnet:
Example for the Ropsten test network:
|
You should specify how the block numbers are serialised before hashing. I assume as 64-bit big endian? |
Yes, that's correct. |
|
||
This EIP does not attempt to solve the clean separation of 3-way-forks! If at the same future block number, the network splits into three (non-fork, fork-A and fork-B), separating the forkers from each another will need case-by-case special handling. Not handling this keeps the proposal pragmatic, simple and also avoids making it too easy to fork off mainnet. | ||
|
||
To keep the scope limited, this EIP only defines the identity scheme and validation rules. The same scheme and algorithm can be embedded into various networking protocols, allowing both the `eth/6x` handshake to be more precise (Ethereum vs. Ethereum Classic); as well as the discovery to be more useful (reject surely peers without ever connecting). |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
"only defines the identity scheme..." is confusing because ENR also has 'identity schemes' which are unrelated.
Maybe best to just delete the entire paragraph TBH.
Gotta say the whole Abstract could be removed and some of the content moved into Motivation + Rationale where it really belongs.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes, but the EIP process requires these 3 completely redundant pieces to exist, and @axic requested that I explicitly have all of them. My original EIP didn't have them. It's stupid to have them. If I've however been requested to have them, I'm not deleting them any more.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
"only defines the identity scheme..." is confusing because ENR also has 'identity schemes' which are unrelated.
Well, this EIP is not about ENR per your request, so you should not know about ENR identity schemes at all (as a matter of fact, I've no clue what they are :D).
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes, but the EIP process requires these 3 completely redundant pieces to exist, and @axic requested that I explicitly have all of them.
Don't blame it on me, I'm just following EIP-1, hehe.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't think the intention of EIP-1 is to make you repeat the same text twice with tweaked wording just so you have both sections. Maybe EIP-1 should be changed. Honestly, "simple summary" is the definition of Abstract.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@karalabe I don't understand why the fork ID is an 'identity scheme'. This sentence is the only place where 'identity' appears in the whole document. An 'identity scheme' is a way to assign identities, i.e. on a national identity card. In ENR, an identity scheme is the name of a signing function and public key crypto parameters that define how to assign a node identity.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Well, id
in forkid
means identity :)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I thought it means identifier
.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Hmm, yes, the forkid is an identifier, but doesn't the EIP define the rules (i.e. scheme) of how the ID is generated and regenerated over time? Maybe I have a different mental definition of "scheme". Anyway, I don't much care about the exact wording if you have a better alternative.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Like I said I'd just kill the entire paragraph.
|
||
Here's a full suite of tests for all possible fork IDs that Mainnet, Ropsten, Rinkeby and Görli can advertise given the Petersburg fork cap (time of writing). | ||
|
||
```go |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We should find a format for the test cases that isn't Go.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Meh. The Go code is table driven, so it's fairly trivial to copy paste. Whether it's a Go "table" or a markdown table, it makes no difference. You still need to copy paste each cell individually.
From my perspective as an author however, I don't have to screw around with converting Go tables to markdown tables, and then when something changes (like XOR to CRC), I don't have to throw all that work out and redo everything all over.
I.e. It saves time for me, it's more robust against change, and it doesn't matter to anyone else.
From my part yes. |
* EIP 2124: Zero RTT netsplit on chain mismatch * Assign number to EIP 2124 * Address review comments on EIP 2124. * Rename EIP 2124 to better reflect content * Fix cardinality * Fix email address in 2124 * Update fork identifier EIP based on review discussions. * Fixup EIP name for the fork identifier. * Remove stale mention of ENR from forkid EIP. * Add RLP encoding test cases for forkid EIP. * Add Felix too to the forkid EIP author list. * Get rid of mentioning the MTU stuffin the forkid EIP.
* EIP 2124: Zero RTT netsplit on chain mismatch * Assign number to EIP 2124 * Address review comments on EIP 2124. * Rename EIP 2124 to better reflect content * Fix cardinality * Fix email address in 2124 * Update fork identifier EIP based on review discussions. * Fixup EIP name for the fork identifier. * Remove stale mention of ENR from forkid EIP. * Add RLP encoding test cases for forkid EIP. * Add Felix too to the forkid EIP author list. * Get rid of mentioning the MTU stuffin the forkid EIP.
* EIP 2124: Zero RTT netsplit on chain mismatch * Assign number to EIP 2124 * Address review comments on EIP 2124. * Rename EIP 2124 to better reflect content * Fix cardinality * Fix email address in 2124 * Update fork identifier EIP based on review discussions. * Fixup EIP name for the fork identifier. * Remove stale mention of ENR from forkid EIP. * Add RLP encoding test cases for forkid EIP. * Add Felix too to the forkid EIP author list. * Get rid of mentioning the MTU stuffin the forkid EIP.
* EIP 2124: Zero RTT netsplit on chain mismatch * Assign number to EIP 2124 * Address review comments on EIP 2124. * Rename EIP 2124 to better reflect content * Fix cardinality * Fix email address in 2124 * Update fork identifier EIP based on review discussions. * Fixup EIP name for the fork identifier. * Remove stale mention of ENR from forkid EIP. * Add RLP encoding test cases for forkid EIP. * Add Felix too to the forkid EIP author list. * Get rid of mentioning the MTU stuffin the forkid EIP.
No description provided.