This repository contains a compilation of useful resources for data plane programming, especially for the ones wanting to learn how to write P4-16 programs and test them in a virtual environment. All the exercises and examples provided are designed to work with P4-Utils, a testing and prototyping framework available here.
A big part of the materials come from the Advanced Topics in Communication Networks lecture taught at ETH Zürich. For more information, visit our website.
Attention: new update released!
New update September 2023: we have recently updated p4-learning and p4-utils to the newest version ofbmv2
andp4c
. If you are running on an older VM or versions forbmv2
andp4c
all the examples and exercises that useclone3
,resubmit
, andrecirculate
will not compile or work anymore. For more information, look at the examples and the updates in thev1model
architecture description.
As of 2021, a large update in the P4-Utils framework has been released. This entails several improvements that, unfortunately, make the new prototyping platform not backward compatible with the old exercises and examples of this repository. In response to this, P4-Learning has been updated, too: all the relevant information about the migration from the old to the new version is available here.
You will find software installation guides, lecture slides, specific development documentation, exercises, a collection of examples and much more. Specifically:
- Slides: a deck of slides that go from the story of SDN and introduction to data plane programming to advanced (research level) applications.
- Examples: a collection of examples showing how to use almost all the simple switch features.
- Exercises: a set of P4 exercises with a long description and solutions.
- Environment Installation: a guide and scripts to install the required software to start developing P4 applications on your own machine.
The documentation of P4-Learning is available in the Wiki. It contains helpful information that will help you getting started with the exercises and examples contained in this repository. Moreover, you will also find documentation about the software switches used in the network topologies and how to configure them using their control plane.
The recent update of P4-Utils introduced several improvements, affecting also P4-Learning. All the exercises and examples have already been migrated to the new version and they are now compatible with the new framework. However, should you have customized examples crafted from the old ones, please make sure that you have ported any controller to Python 3 and that the JSON network configuration file is compliant with the new specification.
Notice
Old network JSON configuration files are not compatible with the new version of P4-Utils.
You can find further information about the update changelog and how the JSON configuration file specification has changed in the Wiki. Moreover, consider that, in the new version of P4-Utils, networks can also be started using a Python script and the new NetworkAPI
.
If you already have the required software and you want to solve the exercises, run the examples or simply download the content, get a local copy of this repository on your machine:
git clone https://github.com/nsg-ethz/p4-learning.git
We will periodically add new content to this repository (especially documentation and new examples), so make sure to check it regularly or git pull
it from your machine.
Notice
In case you have not installed the dependencies, make sure to check out this section and follow the instructions.
P4-Learning depends on the following software that needs to be installed before any exercises or examples can be run. Please refer to these links to build and install it on your device.
A more detailed user guide on how to start with P4-Learning is available in the Wiki. It contains helpful information about the dependencies and the installation process. Moreover, you will find also instructions on how to use the virtual machine that we provide, so that the cumbersome installation of the various components can be skipped and you can directly start learning P4!