-
Notifications
You must be signed in to change notification settings - Fork 433
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
RPL with all modes of operation #869
Draft
thvdveld
wants to merge
133
commits into
smoltcp-rs:main
Choose a base branch
from
thvdveld:rpl
base: main
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
Draft
Conversation
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Signed-off-by: Thibaut Vandervelden <thvdveld@vub.be> Co-authored-by: Diana Deac <diana.deac@vub.be>
Signed-off-by: Thibaut Vandervelden <thvdveld@vub.be>
Signed-off-by: Thibaut Vandervelden <thvdveld@vub.be>
Signed-off-by: Thibaut Vandervelden <thvdveld@vub.be>
Signed-off-by: Thibaut Vandervelden <thvdveld@vub.be>
Signed-off-by: Thibaut Vandervelden <thvdveld@vub.be>
Signed-off-by: Thibaut Vandervelden <thvdveld@vub.be>
Signed-off-by: Thibaut Vandervelden <thvdveld@vub.be>
Signed-off-by: Thibaut Vandervelden <thvdveld@vub.be>
Signed-off-by: Thibaut Vandervelden <thvdveld@vub.be>
Signed-off-by: Thibaut Vandervelden <thvdveld@vub.be>
Signed-off-by: Thibaut Vandervelden <thvdveld@vub.be>
Signed-off-by: Thibaut Vandervelden <thvdveld@vub.be>
Signed-off-by: Thibaut Vandervelden <thvdveld@vub.be>
Implement `StoringModeWithMulticast` aka RPL MOP3
thvdveld
changed the title
RPL Mode of Operation 0, Mode of Operation 1 and Mode of Operation 2
RPL with all modes of operation
Aug 28, 2024
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
This adds the Routing Protocol for Low-power and lossy networks (RPL) protocol, as defined in RFC6550. I tried making this smaller, but it quickly became difficult to keep track of everything, as most features are used for the different modes of operation in RPL. I will try to move changes less related to RPL, but that were required for RPL to work, into different PRs.
At the moment, the following should be working (but still in experimental phase):
The RPL option in the Hop-by-Hop header is used for detecting inconsistencies in the tree. The option contains information about the direction of the data message (where data is a term used in the standard but is ill-defined).
There are still things missing in the implementation, such as handling some options. Examples are prefix information option. There is also room for optimization. An example is the source routing header, where parts of the prefix can just be elided. This is something we don't do yet.
To test the implementation, we added integration tests. These integration tests simulate some networks. The tests then check for expected behaviours.