-
Notifications
You must be signed in to change notification settings - Fork 679
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
Randomized peerids #149
base: master
Are you sure you want to change the base?
Randomized peerids #149
Conversation
Right now it's hard to evaluate what's going on in the PR because most of the diff is line-ending changes. I would appreciate if all the changes could be squashed into one commit and all the line-ending diffs removed from it regardless so that I can easily read this. |
- Maps external peer ID back to internal array index with simple hashmap
bd1c866
to
ea0ab62
Compare
Removed whitespace changes, squashed down to one commit. |
On balance I think the idea of the patch seems to not be bad, but there are some improvements here we should do to make this better. incomingPeerID needs to be handled with more care. We should store the randomized ID in a separate field (probably in the 16-bit space that is currently "reserved" in ENetPeer so we don't change its ABI size), and ensure that incomingPeerID just stores the index in the peers array like most code expects, but then we can transparently map that before the user sees it, and use the value stored in that previously reserved field for the pre-mapped randomized value. The other thing that needs some thought is the map code is currently very expensive in the collision case, so it would be nice if we could find some way to chain the collision cheaply or at least more sanely bound the search. I would also like to see this integrate with the session ID so that we can gain another 2 bits of randomness for the id. We probably need to get a better random function for the peer ID and for enet in general. Using a LCG basing off the current random seed would probably be good enough here. I have some Mersenne Twister code I could rig up, but that might be overkill here. |
We also have the problem of dealing with collisions in the random ID itself, such that we need to ensure no two peers that are live have the same one. |
Those all sound like good ideas, though straining my understanding of some of the ENet fields. I'm not sure I'd be the right person to make those changes. Some thoughts:
|
No description provided.