参考:P4语言编程快速开始
上一篇系列博客:P4语言编程快速开始 实践二
Demo 2
本Demo所做的修改及实现的功能:
相关修改
header_type ipv4_t {
fields {
version : 4;
ihl : 4;
diffserv : 8;
totalLen : 16;
identification : 16;
flags : 3;
fragOffset : 13;
ttl : 8;
protocol : 8;
hdrChecksum : 16;
srcAddr : 32;
dstAddr: 32;
data: 32;//data段远不止32位,这里仅取前32位以作实验
}
}
counter ingress_addr_count {
type : packets;
instance_count: 16384;
}
action set_addr_count(idx,smac,data) {
count(ingress_addr_count, idx);//调用计数器计数
modify_field(ethernet.srcAddr, smac);//修改包头源mac
modify_field(ipv4.data,data);//修改data段数据
}
python ../../cli/pd_cli.py -p simple_router -i p4_pd_rpc.simple_router -s $PWD/tests/pd_thrift:$PWD/../../testutils -m "add_entry send_frame 1 set_addr_count 1 00:aa:bb:00:00:00 0xffffffff" -c localhost:22222
验证:
但是,笔者在实验的时候,实际情况是无法ping通,猜测其原因是因为tcp字段是非法的,被执行了丢包。
图一:实验环境
图二:wireshark抓包验证