实验内容
针对P4 Tutorials---- source routing实验最后提出的问题。
如何使压入标签的动作在第一跳网络设备上执行,这样应该使更贴近现实中的网络场景。
实验前,我们先看一下h1 ping h2是不通的。因为和./send.py 发的带标签的包不同,直接ping的是普通的ipv4包,但是switch现在没有转发ipv4报文的逻辑。
拓扑图
Switch逻辑示意图:
我们这次实验要做是ipv4的数据包进入后在第一个switch压入指导转发的标签栈,后面的switch就所需要做的是弹出标签,从相应的端口送出数据包。
以S1为例:
- IPv4报文进到S1后改变Type类型为0x1234,压入两个标签,注意要先压入离目的端近的标签。
2. 报文出S1的Port2口并弹出一层标签,到达S2
3.报文出S2时,弹出一层标签,修改Type为0x0800
操作步骤
这里主要介绍一下相比source routing实验增加的代码。
Parser:
如果ehterType是IPV4,转到parse_ipv4
Ingress:
如果进来的是ipv4的数据包,压入两个标签
Egress:
增加一个table ipv4_final ,如果匹配目的ip,替换目的mac
Checksum computation
数据包改变做校验。
添加Switch规则
CLI 登录到S1和S2
S1添加规则:
table_add ipv4_lpm_add addlabel 10.0.2.2/32 => 1 1
table_add ipv4_lpm_add2 addlabel2 10.0.2.2/32 => 2 0
table_add ipv4_final dmac 10.0.1.1/32 => 08:00:00:00:01:11
S2添加规则:
table_add ipv4_lpm_add addlabel 10.0.1.1/32 => 1 1
table_add ipv4_lpm_add2 addlabel2 10.0.1.1/32 => 2 0
table_add ipv4_final dmac 10.0.2.2/32 => 08:00:00:00:02:22
测试
现在h1可以ping通h2
通过wireshark,我们可以在pcap的目录下看到抓包记录。
这里依次截出了从h1到h2 ping的报文转发全过程
S1 eth1 是一个IPv4包。
S1 eth2送出去时,带着一层标签。
因为自定义的type,所以wireshark不能完全识别这个包。
但是我们可以通过type 1234判断后面的16bit(80 01)是soure route的标签,换算成二进制1000 0001。
对照开始定义的srcRoute_t,第1个bit是表示bos,后面15个bit是表示端口号。
S2 eth1出来IPv4包。
实验代码https://mp.csdn.net/mp_download/creation/uploadResources/85182479