cfe7294b568bde4d3bf0c3023a2a04ba94278fad
[cascardo/ovs.git] / tests / ofproto-dpif.at
1 AT_BANNER([ofproto-dpif])
2
3 AT_SETUP([ofproto-dpif - revalidator/wait])
4 OVS_VSWITCHD_START
5 AT_CHECK([ovs-appctl revalidator/wait])
6 OVS_VSWITCHD_STOP
7 AT_CLEANUP
8
9 AT_SETUP([ofproto-dpif - active-backup bonding])
10 # Create br0 with interfaces p1, p2 and p7, creating bond0 with p1 and p2
11 #    and br1 with interfaces p3, p4 and p8.
12 # toggle p1,p2 of bond0 up and down to test bonding in active-backup mode.
13 OVS_VSWITCHD_START(
14   [add-bond br0 bond0 p1 p2 bond_mode=active-backup --\
15    set interface p1 type=dummy options:pstream=punix:$OVS_RUNDIR/p1.sock ofport_request=1 -- \
16    set interface p2 type=dummy options:pstream=punix:$OVS_RUNDIR/p2.sock ofport_request=2 -- \
17    add-port br0 p7 -- set interface p7 ofport_request=7 type=dummy -- \
18    add-br br1 -- \
19    set bridge br1 other-config:hwaddr=aa:66:aa:66:00:00 -- \
20    set bridge br1 datapath-type=dummy other-config:datapath-id=1234 \
21                   fail-mode=secure -- \
22    add-port br1 p3 -- set interface p3 type=dummy options:stream=unix:$OVS_RUNDIR/p1.sock ofport_request=3 -- \
23    add-port br1 p4 -- set interface p4 type=dummy options:stream=unix:$OVS_RUNDIR/p2.sock ofport_request=4 -- \
24    add-port br1 p8 -- set interface p8 ofport_request=8 type=dummy --])
25 WAIT_FOR_DUMMY_PORTS([p3], [p4])
26 AT_CHECK([ovs-appctl vlog/set dpif:dbg dpif_netdev:dbg])
27
28 AT_CHECK([ovs-ofctl add-flow br0 action=normal])
29 AT_CHECK([ovs-ofctl add-flow br1 action=normal])
30 ovs-appctl netdev-dummy/set-admin-state up
31 ovs-appctl time/warp 100
32 ovs-appctl netdev-dummy/set-admin-state p2 down
33 ovs-appctl time/stop
34 ovs-appctl time/warp 100
35 AT_CHECK([ovs-appctl netdev-dummy/receive p7 'in_port(7),eth(src=50:54:00:00:00:09,dst=50:54:00:00:00:0a),eth_type(0x0800),ipv4(src=10.0.0.2,dst=10.0.0.1,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'])
36 AT_CHECK([ovs-appctl netdev-dummy/receive p7 'in_port(7),eth(src=50:54:00:00:00:0b,dst=50:54:00:00:00:0c),eth_type(0x0800),ipv4(src=10.0.0.3,dst=10.0.0.4,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'])
37 ovs-appctl time/warp 100
38 ovs-appctl netdev-dummy/set-admin-state p2 up
39 ovs-appctl netdev-dummy/set-admin-state p1 down
40 ovs-appctl time/warp 100
41 AT_CHECK([ovs-appctl netdev-dummy/receive p7 'in_port(7),eth(src=50:54:00:00:00:09,dst=50:54:00:00:00:0d),eth_type(0x0800),ipv4(src=10.0.0.5,dst=10.0.0.1,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'])
42 AT_CHECK([ovs-appctl netdev-dummy/receive p7 'in_port(7),eth(src=50:54:00:00:00:09,dst=50:54:00:00:00:0e),eth_type(0x0800),ipv4(src=10.0.0.6,dst=10.0.0.1,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'])
43 ovs-appctl time/warp 200 100
44 sleep 1
45 AT_CHECK([cat ovs-vswitchd.log | grep 'in_port=[[348]]' | FILTER_FLOW_INSTALL | STRIP_XOUT], [0], [dnl
46 recirc_id=0,ip,in_port=3,vlan_tci=0x0000/0x1fff,dl_src=50:54:00:00:00:09,dl_dst=50:54:00:00:00:0a,nw_frag=no, actions: <del>
47 recirc_id=0,ip,in_port=3,vlan_tci=0x0000/0x1fff,dl_src=50:54:00:00:00:0b,dl_dst=50:54:00:00:00:0c,nw_frag=no, actions: <del>
48 recirc_id=0,ip,in_port=4,vlan_tci=0x0000/0x1fff,dl_src=50:54:00:00:00:09,dl_dst=50:54:00:00:00:0d,nw_frag=no, actions: <del>
49 recirc_id=0,ip,in_port=4,vlan_tci=0x0000/0x1fff,dl_src=50:54:00:00:00:09,dl_dst=50:54:00:00:00:0e,nw_frag=no, actions: <del>
50 recirc_id=0,rarp,in_port=4,vlan_tci=0x0000/0x1fff,dl_src=50:54:00:00:00:09,dl_dst=ff:ff:ff:ff:ff:ff, actions: <del>
51 recirc_id=0,rarp,in_port=4,vlan_tci=0x0000/0x1fff,dl_src=50:54:00:00:00:0b,dl_dst=ff:ff:ff:ff:ff:ff, actions: <del>
52 ])
53 OVS_VSWITCHD_STOP
54 AT_CLEANUP
55
56 AT_SETUP([ofproto-dpif - balance-slb bonding])
57 # Create br0 with interfaces bond0(p1, p2, p3) and p7,
58 #    and br1 with interfaces p4, p5, p6 and p8.
59 #    p1 <-> p4, p2 <-> p5, p3 <-> p6
60 # Send some traffic, make sure the traffic are spread based on source mac.
61 OVS_VSWITCHD_START(
62   [add-bond br0 bond0 p1 p2 p3 bond_mode=balance-slb --\
63    set interface p1 type=dummy options:pstream=punix:$OVS_RUNDIR/p1.sock ofport_request=1 -- \
64    set interface p2 type=dummy options:pstream=punix:$OVS_RUNDIR/p2.sock ofport_request=2 -- \
65    set interface p3 type=dummy options:pstream=punix:$OVS_RUNDIR/p3.sock ofport_request=3 -- \
66    add-port br0 p7 -- set interface p7 ofport_request=7 type=dummy -- \
67    add-br br1 -- \
68    set bridge br1 other-config:hwaddr=aa:66:aa:66:00:00 -- \
69    set bridge br1 datapath-type=dummy other-config:datapath-id=1234 \
70                   fail-mode=secure -- \
71    add-port br1 p4 -- set interface p4 type=dummy options:stream=unix:$OVS_RUNDIR/p1.sock ofport_request=4 -- \
72    add-port br1 p5 -- set interface p5 type=dummy options:stream=unix:$OVS_RUNDIR/p2.sock ofport_request=5 -- \
73    add-port br1 p6 -- set interface p6 type=dummy options:stream=unix:$OVS_RUNDIR/p3.sock ofport_request=6 -- \
74    add-port br1 p8 -- set interface p8 ofport_request=8 type=dummy --])
75 WAIT_FOR_DUMMY_PORTS([p4], [p5], [p6])
76 AT_CHECK([ovs-ofctl add-flow br0 action=normal])
77 AT_CHECK([ovs-ofctl add-flow br1 action=normal])
78 AT_CHECK([ovs-appctl netdev-dummy/set-admin-state up], 0, [OK
79 ])
80 ovs-appctl time/stop
81 ovs-appctl time/warp 100
82 (
83 for i in `seq 0 100 |xargs printf '%02x\n'`;
84     do
85     pkt="in_port(7),eth(src=50:54:00:00:00:$i,dst=50:54:00:00:01:00),eth_type(0x0800),ipv4(src=10.0.0.2,dst=10.0.0.1,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)"
86     AT_CHECK([ovs-appctl netdev-dummy/receive p7 $pkt])
87     done
88 )
89 ovs-appctl time/warp 100
90 AT_CHECK([ovs-appctl dpif/dump-flows br1 > br1_flows.txt])
91 # Make sure there is resonable distribution to all three ports.
92 # We don't want to make this check precise, in case hash function changes.
93 AT_CHECK([test `egrep 'in_port\(4\)' br1_flows.txt |wc -l` -gt 3])
94 AT_CHECK([test `egrep 'in_port\(5\)' br1_flows.txt |wc -l` -gt 3])
95 AT_CHECK([test `egrep 'in_port\(6\)' br1_flows.txt |wc -l` -gt 3])
96 OVS_VSWITCHD_STOP
97 AT_CLEANUP
98
99 AT_SETUP([ofproto-dpif - balance-tcp bonding])
100 # Create br0 with interfaces bond0(p1, p2, p3) and p7,
101 #    and br1 with interfaces bond1(p4, p5, p6) and p8.
102 #    bond0 <-> bond1
103 # Send some traffic, make sure the traffic are spread based on L4 headers.
104 OVS_VSWITCHD_START(
105   [add-bond br0 bond0 p1 p2 p3 bond_mode=balance-tcp lacp=active \
106         other-config:lacp-time=fast other-config:bond-rebalance-interval=0 --\
107    set interface p1 type=dummy options:pstream=punix:$OVS_RUNDIR/p1.sock ofport_request=1 -- \
108    set interface p2 type=dummy options:pstream=punix:$OVS_RUNDIR/p2.sock ofport_request=2 -- \
109    set interface p3 type=dummy options:pstream=punix:$OVS_RUNDIR/p3.sock ofport_request=3 -- \
110    add-port br0 p7 -- set interface p7 ofport_request=7 type=dummy -- \
111    add-br br1 -- \
112    set bridge br1 other-config:hwaddr=aa:66:aa:66:00:00 -- \
113    set bridge br1 datapath-type=dummy other-config:datapath-id=1234 \
114                   fail-mode=secure -- \
115    add-bond br1 bond1 p4 p5 p6 bond_mode=balance-tcp lacp=active \
116         other-config:lacp-time=fast other-config:bond-rebalance-interval=0 --\
117    set interface p4 type=dummy options:stream=unix:$OVS_RUNDIR/p1.sock ofport_request=4 -- \
118    set interface p5 type=dummy options:stream=unix:$OVS_RUNDIR/p2.sock ofport_request=5 -- \
119    set interface p6 type=dummy options:stream=unix:$OVS_RUNDIR/p3.sock ofport_request=6 -- \
120    add-port br1 p8 -- set interface p8 ofport_request=8 type=dummy --])
121 AT_CHECK([ovs-appctl netdev-dummy/set-admin-state up], 0, [OK
122 ])
123 AT_CHECK([ovs-ofctl add-flow br0 action=normal])
124 AT_CHECK([ovs-ofctl add-flow br1 action=normal])
125 AT_CHECK([ovs-appctl upcall/disable-megaflows], [0], [megaflows disabled
126 ], [])
127 OVS_WAIT_WHILE([ovs-appctl bond/show | grep "may_enable: false"])
128 ovs-appctl time/stop
129 ovs-appctl time/warp 100
130 ovs-appctl lacp/show > lacp.txt
131 ovs-appctl bond/show > bond.txt
132 (
133 for i in `seq 0 255` ;
134     do
135     pkt="in_port(7),eth(src=50:54:00:00:00:05,dst=50:54:00:00:01:00),eth_type(0x0800),ipv4(src=10.0.0.2,dst=10.0.0.1,proto=6,tos=0,ttl=64,frag=no),tcp(src=8,dst=$i),tcp_flags(ack)"
136     AT_CHECK([ovs-appctl netdev-dummy/receive p7 $pkt])
137     done
138 )
139 ovs-appctl time/warp 300 100
140 AT_CHECK([ovs-appctl dpif/dump-flows br0 |grep tcp > br0_flows.txt])
141 AT_CHECK([ovs-appctl dpif/dump-flows br1 |grep tcp > br1_flows.txt])
142 # Make sure there is resonable distribution to all three ports.
143 # We don't want to make this check precise, in case hash function changes.
144 AT_CHECK([test `grep in_port.4 br1_flows.txt |wc -l` -gt 24])
145 AT_CHECK([test `grep in_port.5 br1_flows.txt |wc -l` -gt 24])
146 AT_CHECK([test `grep in_port.6 br1_flows.txt |wc -l` -gt 24])
147
148 OVS_VSWITCHD_STOP()
149 AT_CLEANUP
150
151 # Makes sure recirculation does not change the way packet is handled.
152 AT_SETUP([ofproto-dpif - balance-tcp bonding, different recirc flow ])
153 OVS_VSWITCHD_START(
154   [add-bond br0 bond0 p1 p2 bond_mode=balance-tcp lacp=active \
155        other-config:lacp-time=fast other-config:bond-rebalance-interval=0 -- \
156    set interface p1 type=dummy options:pstream=punix:$OVS_RUNDIR/p1.sock ofport_request=1 -- \
157    set interface p2 type=dummy options:pstream=punix:$OVS_RUNDIR/p2.sock ofport_request=2 -- \
158    add-br br1 -- \
159    set bridge br1 other-config:hwaddr=aa:66:aa:66:00:00 -- \
160    set bridge br1 datapath-type=dummy other-config:datapath-id=1234 \
161        fail-mode=standalone -- \
162    add-bond br1 bond1 p3 p4 bond_mode=balance-tcp lacp=active \
163        other-config:lacp-time=fast other-config:bond-rebalance-interval=0 -- \
164    set interface p3 type=dummy options:stream=unix:$OVS_RUNDIR/p1.sock ofport_request=3 -- \
165    set interface p4 type=dummy options:stream=unix:$OVS_RUNDIR/p2.sock ofport_request=4 -- \
166    add-port br1 br1- -- set interface br1- type=patch options:peer=br1+ ofport_request=100 -- \
167    add-br br-int -- \
168    set bridge br-int other-config:hwaddr=aa:77:aa:77:00:00 -- \
169    set bridge br-int datapath-type=dummy other-config:datapath-id=1235 \
170        fail-mode=secure -- \
171    add-port br-int br1+ -- set interface br1+ type=patch options:peer=br1- ofport_request=101 -- \
172    add-port br-int p5 -- set interface p5 ofport_request=5 type=dummy
173 ])
174 AT_CHECK([ovs-appctl netdev-dummy/set-admin-state up], 0, [OK
175 ])
176
177 # Waits for all ifaces enabled.
178 OVS_WAIT_UNTIL([test `ovs-appctl bond/show | grep -- "may_enable: true" |  wc -l` -ge 4])
179
180 # The dl_vlan flow should not be ever matched,
181 # since recirculation should not change the flow handling.
182 AT_DATA([flows.txt], [dnl
183 table=0 priority=1 in_port=5 actions=mod_vlan_vid:1,output(101)
184 table=0 priority=2 in_port=5 dl_vlan=1 actions=drop
185 ])
186 AT_CHECK([ovs-ofctl add-flows br-int flows.txt])
187
188 # Sends a packet to trigger recirculation.
189 # Should generate recirc_id(0x2),dp_hash(0xc1261ba2/0xff).
190 AT_CHECK([ovs-appctl netdev-dummy/receive p5 "in_port(5),eth(src=50:54:00:00:00:05,dst=50:54:00:00:01:00),eth_type(0x0800),ipv4(src=10.0.0.2,dst=10.0.0.1)"])
191
192 # Collects flow stats.
193 AT_CHECK([ovs-appctl revalidator/purge], [0])
194
195 # Checks the flow stats in br1, should only be one flow with non-zero
196 # 'n_packets' from internal table.
197 AT_CHECK([ovs-appctl bridge/dump-flows br1 | ofctl_strip | grep -- "n_packets" | grep -- "table_id" | sed -e 's/dp_hash=0x[[0-9a-f]][[0-9a-f]]*/dp_hash=0x0/' -e 's/output:[[0-9]][[0-9]]*/output/'], [0], [dnl
198 table_id=254, n_packets=1, n_bytes=64, priority=20,recirc_id=0x2,dp_hash=0x0/0xff,actions=output
199 ])
200
201 # Checks the flow stats in br-int, should be only one match.
202 AT_CHECK([ovs-ofctl dump-flows br-int | ofctl_strip | sort], [0], [dnl
203  n_packets=1, n_bytes=60, priority=1,in_port=5 actions=mod_vlan_vid:1,output:101
204  priority=2,in_port=5,dl_vlan=1 actions=drop
205 NXST_FLOW reply:
206 ])
207
208 OVS_VSWITCHD_STOP()
209 AT_CLEANUP
210
211 AT_SETUP([ofproto-dpif - resubmit])
212 OVS_VSWITCHD_START
213 ADD_OF_PORTS([br0], [1], [10], [11], [12], [13], [14], [15],
214                     [16], [17], [18], [19], [20], [21])
215 AT_DATA([flows.txt], [dnl
216 table=0 in_port=1 priority=1000 icmp actions=output(10),resubmit(2),output(19),resubmit(3),output(21)
217 table=0 in_port=2 priority=1500 icmp actions=output(11),resubmit(,1),output(16),resubmit(2,1),output(18)
218 table=0 in_port=3 priority=2000 icmp actions=output(20)
219 table=1 in_port=1 priority=1000 icmp actions=output(12),resubmit(4,1),output(13),resubmit(3),output(15)
220 table=1 in_port=2 priority=1500 icmp actions=output(17),resubmit(,2)
221 table=1 in_port=3 priority=1500 icmp actions=output(14),resubmit(,2)
222 ])
223 AT_CHECK([ovs-ofctl add-flows br0 flows.txt])
224 AT_CHECK([ovs-appctl ofproto/trace br0 'in_port=1,dl_src=50:54:00:00:00:05,dl_dst=50:54:00:00:00:07,dl_type=0x0800,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_proto=1,nw_tos=0,nw_ttl=128,icmp_type=8,icmp_code=0'], [0], [stdout])
225 AT_CHECK([tail -1 stdout], [0],
226   [Datapath actions: 10,11,12,13,14,15,16,17,18,19,20,21
227 ])
228 OVS_VSWITCHD_STOP
229 AT_CLEANUP
230
231 AT_SETUP([ofproto-dpif - goto table])
232 OVS_VSWITCHD_START
233 ADD_OF_PORTS([br0], [1], [10], [11])
234 echo "table=0 in_port=1 actions=output(10),goto_table(1)" > flows.txt
235 for i in `seq 1 63`; do echo "table=$i actions=goto_table($(($i+1)))"; done >> flows.txt
236 echo "table=64 actions=output(11)" >> flows.txt
237 AT_CHECK([ovs-ofctl -O OpenFlow12 add-flows br0 flows.txt])
238 AT_CHECK([ovs-appctl ofproto/trace br0 'in_port=1,dl_src=50:54:00:00:00:05,dl_dst=50:54:00:00:00:07,dl_type=0x0800,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_proto=1,nw_tos=0,nw_ttl=128,icmp_type=8,icmp_code=0'], [0], [stdout])
239 AT_CHECK([tail -1 stdout], [0],
240   [Datapath actions: 10,11
241 ])
242 OVS_VSWITCHD_STOP
243 AT_CLEANUP
244
245 AT_SETUP([ofproto-dpif - write actions])
246 OVS_VSWITCHD_START
247 ADD_OF_PORTS([br0], [1], [10], [11], [12], [13])
248 AT_DATA([flows.txt], [dnl
249 table=0 in_port=1,ip actions=output(10),write_actions(set_field:192.168.3.90->ip_src,output(12)),goto_table(1)
250 table=1 ip actions=write_actions(output(13)),goto_table(2)
251 table=2 ip actions=set_field:192.168.3.91->ip_src,output(11)
252 ])
253 AT_CHECK([ovs-ofctl -O OpenFlow12 add-flows br0 flows.txt])
254 AT_CHECK([ovs-appctl ofproto/trace br0 'in_port=1,dl_src=50:54:00:00:00:05,dl_dst=50:54:00:00:00:07,dl_type=0x0800,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_proto=1,nw_tos=0,nw_ttl=128,icmp_type=8,icmp_code=0'], [0], [stdout])
255 AT_CHECK([tail -2 stdout], [0],
256   [Megaflow: recirc_id=0,ip,in_port=1,nw_src=192.168.0.1,nw_frag=no
257 Datapath actions: 10,set(ipv4(src=192.168.3.91)),11,set(ipv4(src=192.168.3.90)),13
258 ])
259 OVS_VSWITCHD_STOP
260 AT_CLEANUP
261
262 AT_SETUP([ofproto-dpif - modify IPv6 Neighbor Solitication (ND)])
263 OVS_VSWITCHD_START
264 ADD_OF_PORTS([br0], [1], [10], [11], [12], [13])
265 AT_DATA([flows.txt], [dnl
266 table=0 in_port=1,icmp6,icmpv6_type=135 actions=output(10),write_actions(set_field:fe80::3->nd_target,set_field:aa:aa:aa:aa:aa:aa->nd_sll,output(12)),goto_table(1)
267 table=1 icmp6 actions=write_actions(output(13)),goto_table(2)
268 table=2 in_port=1,icmp6,icmpv6_type=135 actions=set_field:fe80::4->nd_target,set_field:cc:cc:cc:cc:cc:cc->nd_sll,output(11)
269 ])
270 AT_CHECK([ovs-ofctl -O OpenFlow12 add-flows br0 flows.txt])
271 AT_CHECK([ovs-appctl ofproto/trace br0 'in_port=1,dl_src=50:54:00:00:00:05,dl_dst=50:54:00:00:00:07,icmp6,ipv6_src=fe80::1,ipv6_dst=fe80::2,nw_tos=0,nw_ttl=128,icmpv6_type=135,nd_target=fe80::2020,nd_sll=66:55:44:33:22:11'], [0], [stdout])
272 AT_CHECK([tail -4 stdout], [0],
273   [Megaflow: recirc_id=0,icmp6,in_port=1,nw_frag=no,icmp_type=135,icmp_code=0x0/0xff,nd_target=fe80::2020,nd_sll=66:55:44:33:22:11
274 Datapath actions: 10,set(nd(target=fe80::4,sll=cc:cc:cc:cc:cc:cc)),11,set(nd(target=fe80::3,sll=aa:aa:aa:aa:aa:aa)),13
275 This flow is handled by the userspace slow path because it:
276         - Uses action(s) not supported by datapath.
277 ])
278 OVS_VSWITCHD_STOP
279 AT_CLEANUP
280
281 AT_SETUP([ofproto-dpif - clear actions])
282 OVS_VSWITCHD_START
283 ADD_OF_PORTS([br0], [1], [10], [11], [12])
284 AT_DATA([flows.txt], [dnl
285 table=0 in_port=1,ip actions=output(10),write_actions(set_field:192.168.3.90->ip_src,output(12)),goto_table(1)
286 table=1 tcp actions=set_field:91->tp_src,output(11),clear_actions
287 ])
288 AT_CHECK([ovs-ofctl -O OpenFlow12 add-flows br0 flows.txt])
289 AT_CHECK([ovs-appctl ofproto/trace br0 'in_port=1,dl_src=50:54:00:00:00:05,dl_dst=50:54:00:00:00:07,dl_type=0x0800,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_proto=6,nw_tos=0,nw_ttl=128,tp_src=8,tp_dst=9'], [0], [stdout])
290 AT_CHECK([tail -2 stdout], [0],
291   [Megaflow: recirc_id=0,tcp,in_port=1,nw_frag=no,tp_src=8
292 Datapath actions: 10,set(tcp(src=91)),11
293 ])
294 OVS_VSWITCHD_STOP
295 AT_CLEANUP
296
297 AT_SETUP([ofproto-dpif - group chaining])
298 OVS_VSWITCHD_START
299 ADD_OF_PORTS([br0], [1], [10], [11])
300 AT_CHECK([ovs-ofctl -O OpenFlow12 add-group br0 'group_id=1234,type=all,bucket=set_field:192.168.3.90->ip_src,group:123,bucket=output:11'])
301 AT_CHECK([ovs-ofctl -O OpenFlow12 add-group br0 'group_id=123,type=all,bucket=output:10'])
302 AT_CHECK([ovs-ofctl -O OpenFlow12 add-flow br0 'ip actions=group:1234'])
303 AT_CHECK([ovs-appctl ofproto/trace br0 'in_port=1,dl_src=50:54:00:00:00:05,dl_dst=50:54:00:00:00:07,dl_type=0x0800,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_proto=1,nw_tos=0,nw_ttl=128,icmp_type=8,icmp_code=0'], [0], [stdout])
304 AT_CHECK([tail -1 stdout], [0],
305   [Datapath actions: set(ipv4(src=192.168.3.90)),10,set(ipv4(src=192.168.0.1)),11
306 ])
307 OVS_VSWITCHD_STOP
308 AT_CLEANUP
309
310 AT_SETUP([ofproto-dpif - all group in action list])
311 OVS_VSWITCHD_START
312 ADD_OF_PORTS([br0], [1], [10], [11])
313 AT_CHECK([ovs-ofctl -O OpenFlow12 add-group br0 'group_id=1234,type=all,bucket=output:10,set_field:192.168.3.90->ip_src,bucket=output:11'])
314 AT_CHECK([ovs-ofctl -O OpenFlow12 add-flow br0 'ip actions=group:1234'])
315 AT_CHECK([ovs-appctl ofproto/trace br0 'in_port=1,dl_src=50:54:00:00:00:05,dl_dst=50:54:00:00:00:07,dl_type=0x0800,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_proto=1,nw_tos=0,nw_ttl=128,icmp_type=8,icmp_code=0'], [0], [stdout])
316 # Must match on the source address to be able to restore it's value for
317 # the second bucket
318 AT_CHECK([tail -2 stdout], [0],
319   [Megaflow: recirc_id=0,ip,in_port=1,nw_src=192.168.0.1,nw_frag=no
320 Datapath actions: set(ipv4(src=192.168.3.90)),10,set(ipv4(src=192.168.0.1)),11
321 ])
322 OVS_VSWITCHD_STOP
323 AT_CLEANUP
324
325 AT_SETUP([ofproto-dpif - indirect group in action list])
326 OVS_VSWITCHD_START
327 ADD_OF_PORTS([br0], [1], [10])
328 AT_CHECK([ovs-ofctl -O OpenFlow12 add-group br0 group_id=1234,type=indirect,bucket=output:10])
329 AT_CHECK([ovs-ofctl -O OpenFlow12 add-flow br0 'ip actions=group:1234'])
330 AT_CHECK([ovs-appctl ofproto/trace br0 'in_port=1,dl_src=50:54:00:00:00:05,dl_dst=50:54:00:00:00:07,dl_type=0x0800,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_proto=1,nw_tos=0,nw_ttl=128,icmp_type=8,icmp_code=0'], [0], [stdout])
331 AT_CHECK([tail -1 stdout], [0],
332   [Datapath actions: 10
333 ])
334 OVS_VSWITCHD_STOP
335 AT_CLEANUP
336
337 AT_SETUP([ofproto-dpif - group actions have no effect afterwards])
338 OVS_VSWITCHD_START
339 ADD_OF_PORTS([br0], [1], [10])
340 AT_CHECK([ovs-ofctl -O OpenFlow12 add-group br0 'group_id=1234,type=select,bucket=set_field:192.168.3.90->ip_src,output:10'])
341 AT_CHECK([ovs-ofctl -O OpenFlow12 add-flow br0 'ip actions=group:1234,output:10'])
342 AT_CHECK([ovs-appctl ofproto/trace br0 'in_port=1,dl_src=50:54:00:00:00:05,dl_dst=50:54:00:00:00:07,dl_type=0x0800,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_proto=1,nw_tos=0,nw_ttl=128,icmp_type=8,icmp_code=0'], [0], [stdout])
343 AT_CHECK([tail -1 stdout], [0],
344   [Datapath actions: set(ipv4(src=192.168.3.90,dst=192.168.0.2)),10,set(ipv4(src=192.168.0.1,dst=192.168.0.2)),10
345 ])
346 OVS_VSWITCHD_STOP
347 AT_CLEANUP
348
349 AT_SETUP([ofproto-dpif - all group in action set])
350 OVS_VSWITCHD_START
351 ADD_OF_PORTS([br0], [1], [10], [11])
352 AT_CHECK([ovs-ofctl -O OpenFlow12 add-group br0 'group_id=1234,type=all,bucket=output:10,set_field:192.168.3.90->ip_src,bucket=output:11'])
353 AT_CHECK([ovs-ofctl -O OpenFlow12 add-flow br0 'ip actions=write_actions(group:1234)'])
354 AT_CHECK([ovs-appctl ofproto/trace br0 'in_port=1,dl_src=50:54:00:00:00:05,dl_dst=50:54:00:00:00:07,dl_type=0x0800,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_proto=1,nw_tos=0,nw_ttl=128,icmp_type=8,icmp_code=0'], [0], [stdout])
355 # Must match on the source address to be able to restore it's value for
356 # the third bucket
357 AT_CHECK([tail -2 stdout], [0],
358   [Megaflow: recirc_id=0,ip,in_port=1,nw_src=192.168.0.1,nw_frag=no
359 Datapath actions: set(ipv4(src=192.168.3.90)),10,set(ipv4(src=192.168.0.1)),11
360 ])
361 OVS_VSWITCHD_STOP
362 AT_CLEANUP
363
364 AT_SETUP([ofproto-dpif - indirect group in action set])
365 OVS_VSWITCHD_START
366 ADD_OF_PORTS([br0], [1], [10])
367 AT_CHECK([ovs-ofctl -O OpenFlow12 add-group br0 group_id=1234,type=indirect,bucket=output:10])
368 AT_CHECK([ovs-ofctl -O OpenFlow12 add-flow br0 'ip actions=write_actions(group:1234)'])
369 AT_CHECK([ovs-appctl ofproto/trace br0 'in_port=1,dl_src=50:54:00:00:00:05,dl_dst=50:54:00:00:00:07,dl_type=0x0800,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_proto=1,nw_tos=0,nw_ttl=128,icmp_type=8,icmp_code=0'], [0], [stdout])
370 AT_CHECK([tail -1 stdout], [0],
371   [Datapath actions: 10
372 ])
373 OVS_VSWITCHD_STOP
374 AT_CLEANUP
375
376 AT_SETUP([ofproto-dpif - select group])
377 OVS_VSWITCHD_START
378 ADD_OF_PORTS([br0], [1], [10], [11])
379 AT_CHECK([ovs-ofctl -O OpenFlow12 add-group br0 'group_id=1234,type=select,bucket=output:10,bucket=output:11'])
380 AT_CHECK([ovs-ofctl -O OpenFlow12 add-flow br0 'ip actions=write_actions(group:1234)'])
381
382 # Try a bunch of different flows and make sure that they get distributed
383 # at least somewhat.
384 for d in 0 1 2 3 4 5 6 7 8 9 a b c d e f; do
385     AT_CHECK([ovs-appctl ofproto/trace br0 "in_port=1,dl_src=50:54:00:00:00:07,dl_dst=50:54:00:00:00:0$d,dl_type=0x0800,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_proto=1,nw_tos=0,nw_ttl=128,icmp_type=8,icmp_code=0"], [0], [stdout])
386     tail -1 stdout >> results
387 done
388 sort results | uniq -c
389 AT_CHECK([sort results | uniq], [0],
390   [Datapath actions: 10
391 Datapath actions: 11
392 ])
393 OVS_VSWITCHD_STOP
394 AT_CLEANUP
395
396 AT_SETUP([ofproto-dpif - select group with watch port])
397 OVS_VSWITCHD_START
398 ADD_OF_PORTS([br0], [1], [10], [11])
399 AT_CHECK([ovs-ofctl -O OpenFlow12 add-group br0 'group_id=1234,type=select,bucket=watch_port:10,output:10,bucket=output:11'])
400 AT_CHECK([ovs-ofctl -O OpenFlow12 add-flow br0 'ip actions=write_actions(group:1234)'])
401 AT_CHECK([ovs-appctl ofproto/trace br0 'in_port=1,dl_src=50:54:00:00:00:07,dl_dst=50:54:00:00:00:07,dl_type=0x0800,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_proto=1,nw_tos=0,nw_ttl=128,icmp_type=8,icmp_code=0'], [0], [stdout])
402 AT_CHECK([tail -1 stdout], [0],
403   [Datapath actions: 11
404 ])
405 OVS_VSWITCHD_STOP
406 AT_CLEANUP
407
408 AT_SETUP([ofproto-dpif - select group with weight])
409 OVS_VSWITCHD_START
410 ADD_OF_PORTS([br0], [1], [10], [11], [12])
411 AT_CHECK([ovs-ofctl -O OpenFlow12 add-group br0 'group_id=1234,type=select,bucket=output:10,bucket=output:11,weight=2000,bucket=output:12,weight=0'])
412 AT_CHECK([ovs-ofctl -O OpenFlow12 add-flow br0 'ip actions=write_actions(group:1234)'])
413 AT_CHECK([ovs-appctl ofproto/trace br0 'in_port=1,dl_src=50:54:00:00:00:07,dl_dst=50:54:00:00:00:07,dl_type=0x0800,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_proto=1,nw_tos=0,nw_ttl=128,icmp_type=8,icmp_code=0'], [0], [stdout])
414 AT_CHECK([tail -1 stdout], [0],
415   [Datapath actions: 11
416 ])
417 OVS_VSWITCHD_STOP
418 AT_CLEANUP
419
420 AT_SETUP([ofproto-dpif - select group with hash selection method])
421 OVS_VSWITCHD_START
422 ADD_OF_PORTS([br0], [1], [10], [11])
423 AT_CHECK([ovs-ofctl -O OpenFlow15 add-group br0 'group_id=1234,type=select,selection_method=hash,fields=eth_dst,bucket=output:10,bucket=output:11'])
424 AT_CHECK([ovs-ofctl -O OpenFlow15 add-flow br0 'ip actions=write_actions(group:1234)'])
425
426 # Try a bunch of different flows and make sure that they get distributed
427 # at least somewhat.
428 for d in 0 1 2 3 4 5 6 7 8 9 a b c d e f; do
429     AT_CHECK([ovs-appctl ofproto/trace br0 "in_port=1,dl_src=50:54:00:00:00:07,dl_dst=50:54:00:00:00:0$d,dl_type=0x0800,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_proto=1,nw_tos=0,nw_ttl=128,icmp_type=8,icmp_code=0"], [0], [stdout])
430     tail -1 stdout >> results
431 done
432 sort results | uniq -c
433 AT_CHECK([sort results | uniq], [0],
434   [Datapath actions: 10
435 Datapath actions: 11
436 ])
437
438 > results
439 # Try a bunch of different flows and make sure that they are not distributed
440 # as they only vary a field that is not hashed
441 for d in 0 1 2 3 4 5 6 7 8 9 a b c d e f; do
442     AT_CHECK([ovs-appctl ofproto/trace br0 "in_port=1,dl_src=50:54:00:00:00:$d,dl_dst=50:54:00:00:00:07,dl_type=0x0800,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_proto=1,nw_tos=0,nw_ttl=128,icmp_type=8,icmp_code=0"], [0], [stdout])
443     tail -1 stdout >> results
444 done
445 sort results | uniq -c
446 AT_CHECK([sort results | uniq], [0],
447   [Datapath actions: 10
448 ])
449
450 OVS_VSWITCHD_STOP
451 AT_CLEANUP
452
453 AT_SETUP([ofproto-dpif - fast failover group])
454 OVS_VSWITCHD_START
455 ADD_OF_PORTS([br0], [1], [10], [11])
456 AT_CHECK([ovs-ofctl -O OpenFlow12 add-group br0 'group_id=1234,type=ff,bucket=watch_port:10,output:10,bucket=watch_port:11,output:11'])
457 AT_CHECK([ovs-ofctl -O OpenFlow12 add-flow br0 'ip actions=write_actions(group:1234)'])
458 AT_CHECK([ovs-appctl ofproto/trace br0 'in_port=1,dl_src=50:54:00:00:00:05,dl_dst=50:54:00:00:00:07,dl_type=0x0800,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_proto=1,nw_tos=0,nw_ttl=128,icmp_type=8,icmp_code=0'], [0], [stdout])
459 AT_CHECK([tail -1 stdout], [0],
460   [Datapath actions: drop
461 ])
462 OVS_VSWITCHD_STOP
463 AT_CLEANUP
464
465 AT_SETUP([ofproto-dpif - group stats single bucket])
466 OVS_VSWITCHD_START
467 ADD_OF_PORTS([br0], [1], [10], [11])
468 AT_CHECK([ovs-ofctl -O OpenFlow12 add-group br0 'group_id=1234,type=select,bucket=output:10,weight=2000,bucket=output:11,weight=0'])
469 AT_CHECK([ovs-ofctl -O OpenFlow12 add-flow br0 'ip actions=write_actions(group:1234)'])
470 (
471 for i in `seq 0 2`;
472     do
473     pkt="in_port(1),eth(src=50:54:00:00:00:05,dst=50:54:00:00:01:00),eth_type(0x0800),ipv4(src=10.0.0.2,dst=10.0.0.1,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)"
474     AT_CHECK([ovs-appctl netdev-dummy/receive p1 $pkt])
475     done
476 )
477 AT_CHECK([ovs-appctl revalidator/purge], [0])
478 AT_CHECK([ovs-ofctl -O OpenFlow12 -vwarn dump-group-stats br0], [0], [stdout])
479 AT_CHECK([STRIP_XIDS stdout | sort], [0], [dnl
480  group_id=1234,ref_count=0,packet_count=3,byte_count=180,bucket0:packet_count=3,byte_count=180,bucket1:packet_count=0,byte_count=0
481 OFPST_GROUP reply (OF1.2):
482 ])
483 OVS_VSWITCHD_STOP
484 AT_CLEANUP
485
486 AT_SETUP([ofproto-dpif - group stats all buckets])
487 OVS_VSWITCHD_START
488 ADD_OF_PORTS([br0], [1], [10], [11])
489 AT_CHECK([ovs-ofctl -O OpenFlow12 add-group br0 'group_id=1234,type=all,bucket=output:10,bucket=output:11'])
490 AT_CHECK([ovs-ofctl -O OpenFlow12 add-flow br0 'ip actions=write_actions(group:1234)'])
491 (
492 for i in `seq 0 2`;
493     do
494     pkt="in_port(1),eth(src=50:54:00:00:00:05,dst=50:54:00:00:01:00),eth_type(0x0800),ipv4(src=10.0.0.2,dst=10.0.0.1,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)"
495     AT_CHECK([ovs-appctl netdev-dummy/receive p1 $pkt])
496     done
497 )
498 AT_CHECK([ovs-appctl revalidator/purge], [0])
499 AT_CHECK([ovs-ofctl -O OpenFlow12 -vwarn dump-group-stats br0], [0], [stdout])
500 AT_CHECK([STRIP_XIDS stdout | sort], [0], [dnl
501  group_id=1234,ref_count=0,packet_count=3,byte_count=180,bucket0:packet_count=3,byte_count=180,bucket1:packet_count=3,byte_count=180
502 OFPST_GROUP reply (OF1.2):
503 ])
504 OVS_VSWITCHD_STOP
505 AT_CLEANUP
506
507 AT_SETUP([ofproto-dpif - registers])
508 OVS_VSWITCHD_START
509 ADD_OF_PORTS([br0], [20], [21], [22], [33], [90])
510 AT_DATA([flows.txt], [dnl
511 in_port=90                 actions=resubmit:2,resubmit:3,resubmit:4,resubmit:91
512 in_port=91                 actions=resubmit:5,resubmit:6,resubmit:7,resubmit:92
513 in_port=92                 actions=resubmit:8,resubmit:9,resubmit:10,resubmit:11,resubmit:93
514 in_port=93                 actions=resubmit:12,resubmit:13,resubmit:14,resubmit:15
515
516 in_port=2                  actions=load:0x000db000->NXM_NX_REG0[[]]
517 in_port=3                  actions=load:0xdea->NXM_NX_REG0[[20..31]]
518 in_port=4                  actions=load:0xeef->NXM_NX_REG0[[0..11]]
519 in_port=5                  actions=move:NXM_NX_REG0[[]]->NXM_NX_REG1[[]]
520 in_port=6                  actions=load:0x22222222->NXM_NX_REG2[[]]
521 in_port=7                  actions=move:NXM_NX_REG1[[20..31]]->NXM_NX_REG2[[0..11]]
522 in_port=8                  actions=move:NXM_NX_REG1[[0..11]]->NXM_NX_REG2[[20..31]]
523 in_port=9,reg0=0xdeadbeef  actions=output:20
524 in_port=10,reg1=0xdeadbeef actions=output:21
525 in_port=11,reg2=0xeef22dea actions=output:22
526
527 dnl Sanilty check all registers
528 in_port=12 actions=load:0x10->NXM_NX_REG0[[]],load:0x11->NXM_NX_REG1[[]],load:0x12->NXM_NX_REG2[[]]
529 in_port=13 actions=load:0x13->NXM_NX_REG3[[]],load:0x14->NXM_NX_REG4[[]],load:0x15->NXM_NX_REG5[[]]
530 in_port=14 actions=load:0x16->NXM_NX_REG6[[]],load:0x17->NXM_NX_REG7[[]]
531 in_port=15,reg0=0x10,reg1=0x11,reg2=0x12,reg3=0x13,reg4=0x14,reg5=0x15,reg6=0x16,reg7=0x17 actions=output:33
532
533 ])
534 AT_CHECK([ovs-ofctl add-flows br0 flows.txt])
535 AT_CHECK([ovs-appctl ofproto/trace ovs-dummy 'in_port(90),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=1,tos=0,ttl=128,frag=no),icmp(type=8,code=0)'], [0], [stdout])
536 AT_CHECK([tail -1 stdout], [0],
537   [Datapath actions: 20,21,22,33
538 ])
539 OVS_VSWITCHD_STOP
540 AT_CLEANUP
541
542 dnl Tests that the standardized xregs are mapped onto the legacy OVS registers
543 dnl in the manner documented in ovs-ofctl(8).
544 AT_SETUP([ofproto-dpif - extended registers])
545 OVS_VSWITCHD_START
546 ADD_OF_PORTS([br0], [1], [2], [3])
547 AT_DATA([flows.txt], [dnl
548 table=0     actions=load:0xfedcba9876543210->OXM_OF_PKT_REG1[[]],resubmit(,1)
549 table=1,reg2=0xfedcba98,reg3=0x76543210   actions=2
550
551 # These low-priority rules shouldn't match.  They're here only to make really
552 # sure that the test fails if either of the above rules fails to match.
553 table=0,priority=0                        actions=3
554 table=1,priority=0                        actions=3
555 ])
556 AT_CHECK([ovs-ofctl add-flows br0 flows.txt])
557 AT_CHECK([ovs-appctl ofproto/trace ovs-dummy 'in_port(1),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=1,tos=0,ttl=128,frag=no),icmp(type=8,code=0)'], [0], [stdout])
558 AT_CHECK([tail -1 stdout], [0], [Datapath actions: 2
559 ])
560 OVS_VSWITCHD_STOP
561 AT_CLEANUP
562
563 AT_SETUP([ofproto-dpif - load and move order])
564 OVS_VSWITCHD_START
565 ADD_OF_PORTS([br0], [1], [10], [11])
566 AT_CHECK([ovs-ofctl -O OpenFlow12 add-group br0 'group_id=1234,type=all,bucket=output:10,move:NXM_NX_REG1[[]]->NXM_OF_IP_SRC[[]],bucket=output:11'])
567 AT_CHECK([ovs-ofctl -O OpenFlow12 add-flow br0 'ip actions=write_actions(load:0xffffffff->NXM_NX_REG1[[]],move:NXM_NX_REG1[[]]->NXM_NX_REG2[[]],group:1234)'])
568 AT_CHECK([ovs-appctl ofproto/trace br0 'in_port=1,dl_src=50:54:00:00:00:05,dl_dst=50:54:00:00:00:07,dl_type=0x0800,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_proto=1,nw_tos=0,nw_ttl=128,icmp_type=8,icmp_code=0'], [0], [stdout])
569 AT_CHECK([tail -2 stdout], [0],
570   [Megaflow: recirc_id=0,ip,in_port=1,nw_src=192.168.0.1,nw_frag=no
571 Datapath actions: set(ipv4(src=255.255.255.255)),10,set(ipv4(src=192.168.0.1)),11
572 ])
573 OVS_VSWITCHD_STOP
574 AT_CLEANUP
575
576 dnl Tests that 1.5 copy-field can copy into the standardized xregs.
577 AT_SETUP([ofproto-dpif - copy-field into extended registers])
578 OVS_VSWITCHD_START
579 ADD_OF_PORTS([br0], [1], [2], [3])
580 AT_DATA([flows.txt], [dnl
581 table=0     actions=move:OXM_OF_ETH_SRC[[0..47]]->OXM_OF_PKT_REG0[[0..47]],goto_table(1)
582 table=1,xreg0=0x0000505400000005   actions=2
583
584 # These low-priority rules shouldn't match.  They're here only to make really
585 # sure that the test fails if either of the above rules fails to match.
586 table=0,priority=0                        actions=3
587 table=1,priority=0                        actions=3
588 ])
589 AT_CHECK([ovs-ofctl -O OpenFlow15 add-flows br0 flows.txt])
590 AT_CHECK([ovs-appctl ofproto/trace ovs-dummy 'in_port(1),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=1,tos=0,ttl=128,frag=no),icmp(type=8,code=0)'], [0], [stdout])
591 AT_CHECK([tail -1 stdout], [0], [Datapath actions: 2
592 ])
593 OVS_VSWITCHD_STOP
594 AT_CLEANUP
595
596 dnl Tests that 1.5 set-field with mask in the metadata register.
597 AT_SETUP([ofproto-dpif - masked set-field into metadata])
598 OVS_VSWITCHD_START
599 ADD_OF_PORTS([br0], [1], [2], [3])
600 AT_DATA([flows.txt], [dnl
601 table=0     actions=set_field:0xfafafafa5a5a5a5a->metadata,goto_table(1)
602 table=1     actions=set_field:0x6b/0xff->metadata,goto_table(2)
603 table=2,metadata=0xfafafafa5a5a5a6b  actions=2
604
605 # These low-priority rules shouldn't match.  They're here only to make really
606 # sure that the test fails if either of the above rules fails to match.
607 table=0,priority=0                        actions=3
608 table=1,priority=0                        actions=3
609 table=2,priority=0                        actions=3
610 ])
611 AT_CHECK([ovs-ofctl -O OpenFlow15 add-flows br0 flows.txt])
612 AT_CHECK([ovs-appctl ofproto/trace ovs-dummy 'in_port(1),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=1,tos=0,ttl=128,frag=no),icmp(type=8,code=0)'], [0], [stdout])
613 AT_CHECK([tail -1 stdout], [0], [Datapath actions: 2
614 ])
615 OVS_VSWITCHD_STOP
616 AT_CLEANUP
617
618
619 AT_SETUP([ofproto-dpif - actset_output])
620 OVS_VSWITCHD_START
621 ADD_OF_PORTS(
622   [br0], [1], [2], [3], [4], [5], [6], [7], [8], [9], [10], [11], [12], [13])
623 AT_DATA([flows.txt], [dnl
624 table=0,actset_output=unset     actions=write_actions(output(2)),goto_table(1)
625 table=1     actions=move:ONFOXM_ET_ACTSET_OUTPUT[[0..31]]->OXM_OF_PKT_REG0[[0..31]],goto_table(2)
626
627 # Verify that actset_output got set.
628 table=2,priority=20,actset_output=2  actions=4,goto_table(3)
629 table=2,priority=10                  actions=5,goto_table(3)
630
631 # Verify that xreg0 got copied properly from actset_output.
632 table=3,priority=20,xreg0=2  actions=6,goto_table(4)
633 table=3,priority=10          actions=7,goto_table(4)
634
635 # Verify that adding a group action unsets actset_output,
636 # even if output follows group.
637 table=4 actions=write_actions(group(5),output(10)),goto_table(5)
638 table=5,priority=20,actset_output=unset  actions=8,goto_table(6)
639 table=5,priority=10                      actions=9,goto_table(6)
640
641 # Verify that adding another output action doesn't change actset_output
642 # (since there's still a group).
643 table=6 actions=write_actions(output(3)),goto_table(7)
644 table=7,priority=20,actset_output=unset  actions=10,goto_table(8)
645 table=7,priority=10                      actions=11,goto_table(8)
646
647 # Verify that clearing the action set, then writing an output action,
648 # causes actset_output to be set again.
649 table=8,actions=clear_actions,write_actions(output(3),output(2)),goto_table(9)
650 table=9,priority=20,actset_output=2 actions=12
651 table=9,priority=10                 actions=13
652 ])
653 AT_CHECK([ovs-ofctl -O OpenFlow13 add-flows br0 flows.txt])
654 AT_CHECK([ovs-appctl ofproto/trace ovs-dummy 'in_port(1),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=1,tos=0,ttl=128,frag=no),icmp(type=8,code=0)'], [0], [stdout])
655 AT_CHECK([tail -1 stdout], [0], [Datapath actions: 4,6,8,10,12,2
656 ])
657 OVS_VSWITCHD_STOP
658 AT_CLEANUP
659 AT_SETUP([ofproto-dpif - push-pop])
660 OVS_VSWITCHD_START
661 ADD_OF_PORTS([br0], [20], [21], [22], [33], [90])
662 AT_DATA([flows.txt], [dnl
663 in_port=90           actions=load:20->NXM_NX_REG0[[0..7]],load:21->NXM_NX_REG1[[0..7]],load:22->NXM_NX_REG2[[0..7]], load:33->NXM_NX_REG3[[0..7]], push:NXM_NX_REG0[[]], push:NXM_NX_REG1[[0..7]],push:NXM_NX_REG2[[0..15]], push:NXM_NX_REG3[[]], resubmit:2, resubmit:3, resubmit:4, resubmit:5
664 in_port=2            actions=pop:NXM_NX_REG0[[0..7]],output:NXM_NX_REG0[[]]
665 in_port=3            actions=pop:NXM_NX_REG1[[0..7]],output:NXM_NX_REG1[[]]
666 in_port=4            actions=pop:NXM_NX_REG2[[0..15]],output:NXM_NX_REG2[[]]
667 in_port=5            actions=pop:NXM_NX_REG3[[]],output:NXM_NX_REG3[[]]
668
669 ])
670 AT_CHECK([ovs-ofctl add-flows br0 flows.txt])
671 AT_CHECK([ovs-appctl ofproto/trace ovs-dummy 'in_port(90),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=1,tos=0,ttl=128,frag=no),icmp(type=8,code=0)'], [0], [stdout])
672 AT_CHECK([tail -1 stdout], [0],
673   [Datapath actions: 33,22,21,20
674 ])
675 OVS_VSWITCHD_STOP
676 AT_CLEANUP
677
678 AT_SETUP([ofproto-dpif - output])
679 OVS_VSWITCHD_START
680 ADD_OF_PORTS([br0], [1], [9], [10], [11], [55], [66], [77], [88])
681 AT_DATA([flows.txt], [dnl
682 in_port=1 actions=resubmit:2,resubmit:3,resubmit:4,resubmit:5,resubmit:6,resubmit:7,resubmit:8
683 in_port=2 actions=output:9
684 in_port=3 actions=load:55->NXM_NX_REG0[[]],output:NXM_NX_REG0[[]],load:66->NXM_NX_REG1[[]]
685 in_port=4 actions=output:10,output:NXM_NX_REG0[[]],output:NXM_NX_REG1[[]],output:11
686 in_port=5 actions=load:77->NXM_NX_REG0[[0..15]],load:88->NXM_NX_REG0[[16..31]]
687 in_port=6 actions=output:NXM_NX_REG0[[0..15]],output:NXM_NX_REG0[[16..31]]
688 in_port=7 actions=load:0x110000ff->NXM_NX_REG0[[]],output:NXM_NX_REG0[[]]
689 in_port=8 actions=1,9,load:9->NXM_OF_IN_PORT[[]],1,9
690 ])
691 AT_CHECK([ovs-ofctl add-flows br0 flows.txt])
692 AT_CHECK([ovs-appctl ofproto/trace ovs-dummy 'in_port(1),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=1,tos=0,ttl=128,frag=no),icmp(type=8,code=0)'], [0], [stdout])
693 AT_CHECK([tail -1 stdout], [0],
694   [Datapath actions: 9,55,10,55,66,11,77,88,9,1
695 ])
696 OVS_VSWITCHD_STOP
697 AT_CLEANUP
698
699 AT_SETUP([ofproto-dpif - dec_ttl])
700 OVS_VSWITCHD_START
701 ADD_OF_PORTS([br0], [1], [2], [3], [4])
702 AT_DATA([flows.txt], [dnl
703 table=0 in_port=1 action=dec_ttl,output:2,resubmit(1,1),output:4
704 table=1 in_port=1 action=dec_ttl,output:3
705 ])
706 AT_CHECK([ovs-ofctl add-flows br0 flows.txt])
707 AT_CHECK([ovs-appctl ofproto/trace ovs-dummy 'in_port(1),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=111,tos=0,ttl=2,frag=no)' -generate], [0], [stdout])
708 AT_CHECK([tail -4 stdout], [0],
709   [Megaflow: recirc_id=0,ip,in_port=1,nw_ttl=2,nw_frag=no
710 Datapath actions: set(ipv4(ttl=1)),2,4
711 This flow is handled by the userspace slow path because it:
712         - Sends "packet-in" messages to the OpenFlow controller.
713 ])
714 AT_CHECK([ovs-appctl ofproto/trace ovs-dummy 'in_port(1),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=111,tos=0,ttl=3,frag=no)'], [0], [stdout])
715 AT_CHECK([tail -2 stdout], [0],
716   [Megaflow: recirc_id=0,ip,in_port=1,nw_ttl=3,nw_frag=no
717 Datapath actions: set(ipv4(ttl=2)),2,set(ipv4(ttl=1)),3,4
718 ])
719 AT_CHECK([ovs-appctl ofproto/trace ovs-dummy 'in_port(1),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x86dd),ipv6(src=::1,dst=::2,label=0,proto=10,tclass=0x70,hlimit=128,frag=no)'], [0], [stdout])
720 AT_CHECK([tail -2 stdout], [0],
721   [Megaflow: recirc_id=0,ipv6,in_port=1,nw_ttl=128,nw_frag=no
722 Datapath actions: set(ipv6(hlimit=127)),2,set(ipv6(hlimit=126)),3,4
723 ])
724
725 AT_CAPTURE_FILE([ofctl_monitor.log])
726 AT_CHECK([ovs-ofctl monitor br0 65534 invalid_ttl --detach --no-chdir --pidfile 2> ofctl_monitor.log])
727 AT_CHECK([ovs-appctl ofproto/trace ovs-dummy 'in_port(1),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=111,tos=0,ttl=2,frag=no)' -generate], [0], [stdout])
728 OVS_WAIT_UNTIL([ovs-appctl -t ovs-ofctl exit])
729 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
730 NXT_PACKET_IN (xid=0x0): table_id=1 cookie=0x0 total_len=34 in_port=1 (via invalid_ttl) data_len=34 (unbuffered)
731 ip,vlan_tci=0x0000,dl_src=50:54:00:00:00:05,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_proto=111,nw_tos=0,nw_ecn=0,nw_ttl=1
732 ])
733 OVS_VSWITCHD_STOP
734 AT_CLEANUP
735
736 dnl A dec_ttl action at offset 32 in ofpacts will cause the ofpacts
737 dnl buffer to be resized just before pushing the id of the dec_ttl action.
738 dnl Thus the implementation must account for this by using the
739 dnl reallocated buffer rather than the original buffer.
740 dnl
741 dnl A number of similar rules are added to try and exercise
742 dnl xrealloc sufficiently that it returns a different base pointer
743 AT_SETUP([ofproto-dpif - dec_ttl without arguments at offset 32 in ofpacts])
744 OVS_VSWITCHD_START
745 ADD_OF_PORTS([br0], [1])
746 (for i in `seq 0 255`; do
747   printf "dl_src=10:11:11:11:11:%02x actions=output:1,output:1,output:1,dec_ttl,controller\n" $i
748  done) > flows.txt
749 AT_CHECK([ovs-ofctl add-flows br0 flows.txt])
750 OVS_VSWITCHD_STOP
751 AT_CLEANUP
752
753 dnl A dec_ttl action at offset 32 in ofpacts will cause the ofpacts
754 dnl buffer to be resized just before pushing the id of the dec_ttl action.
755 dnl Thus the implementation must account for this by using the
756 dnl reallocated buffer rather than the original buffer.
757 dnl
758 dnl A number of similar rules are added to try and exercise
759 dnl xrealloc sufficiently that it returns a different base pointer
760 AT_SETUP([ofproto-dpif - dec_ttl with arguments at offset 32 in ofpacts])
761 OVS_VSWITCHD_START
762 ADD_OF_PORTS([br0], [1])
763 (for i in `seq 0 255`; do
764   printf "dl_src=10:11:11:11:11:%02x actions=output:1,output:1,output:1,dec_ttl(1),controller\n" $i
765  done) > flows.txt
766 AT_CHECK([ovs-ofctl add-flows br0 flows.txt])
767 OVS_VSWITCHD_STOP
768 AT_CLEANUP
769
770 dnl A note action at offset 24 in ofpacts will cause the ofpacts
771 dnl buffer to be resized just before pushing the id of the dec_ttl action.
772 dnl Thus the implementation must account for this by using the
773 dnl reallocated buffer rather than the original buffer.
774 dnl
775 dnl A number of similar rules are added to try and exercise
776 dnl xrealloc sufficiently that it returns a different base pointer
777 AT_SETUP([ofproto-dpif - note at offset 24 in ofpacts])
778 OVS_VSWITCHD_START
779 ADD_OF_PORTS([br0], [1])
780 (for i in `seq 0 255`; do
781   printf "dl_src=10:11:11:11:11:%02x actions=output:1,output:1,note:ff,controller\n" $i
782  done) > flows.txt
783 AT_CHECK([ovs-ofctl add-flows br0 flows.txt])
784 OVS_VSWITCHD_STOP
785 AT_CLEANUP
786
787 AT_SETUP([ofproto-dpif - output, OFPP_NONE ingress port])
788 OVS_VSWITCHD_START
789 ADD_OF_PORTS([br0], [1], [2])
790
791 AT_CHECK([ovs-ofctl add-flow br0 action=normal])
792
793 # "in_port" defaults to OFPP_NONE if it's not specified.
794 flow="icmp,dl_src=50:54:00:00:00:05,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,icmp_type=8,icmp_code=0"
795 AT_CHECK([ovs-appctl ofproto/trace br0 "$flow"], [0], [stdout])
796 AT_CHECK([tail -1 stdout | sed 's/Datapath actions: //' | tr "," "\n" | sort -n], [0], [dnl
797 1
798 2
799 100
800 ])
801
802 OVS_VSWITCHD_STOP
803 AT_CLEANUP
804
805 AT_SETUP([ofproto-dpif - DSCP])
806 OVS_VSWITCHD_START([add-port br0 p1 -- set Interface p1 type=dummy])
807 ADD_OF_PORTS([br0], [9])
808 AT_DATA([flows.txt], [dnl
809 actions=output:LOCAL,enqueue:1:1,enqueue:1:2,enqueue:1:2,enqueue:1:1,output:1,mod_nw_tos:0,output:1,output:LOCAL
810 ])
811 AT_CHECK([ovs-ofctl add-flows br0 flows.txt])
812 AT_CHECK([ovs-vsctl -- \
813         set Port p1 qos=@newqos --\
814         --id=@newqos create QoS type=linux-htb queues=1=@q1,2=@q2 --\
815         --id=@q1 create Queue dscp=1 --\
816         --id=@q2 create Queue dscp=2], [0], [ignore])
817 AT_CHECK([ovs-appctl ofproto/trace ovs-dummy 'in_port(9),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=1.1.1.1,dst=2.2.2.2,proto=1,tos=0xff,ttl=128,frag=no),icmp(type=8,code=0)'], [0], [stdout])
818 AT_CHECK([tail -2 stdout], [0],
819   [Megaflow: recirc_id=0,skb_priority=0,ip,in_port=9,nw_tos=252,nw_frag=no
820 Datapath actions: dnl
821 100,dnl
822 set(ipv4(tos=0x4/0xfc)),set(skb_priority(0x1)),1,dnl
823 set(ipv4(tos=0x8/0xfc)),set(skb_priority(0x2)),1,dnl
824 1,dnl
825 set(ipv4(tos=0x4/0xfc)),set(skb_priority(0x1)),1,dnl
826 set(ipv4(tos=0xfc/0xfc)),set(skb_priority(0)),1,dnl
827 set(ipv4(tos=0/0xfc)),1,100
828 ])
829 OVS_VSWITCHD_STOP
830 AT_CLEANUP
831
832 AT_SETUP([ofproto-dpif - output/flood flags])
833 OVS_VSWITCHD_START
834 ADD_OF_PORTS([br0], [1], [2], [3], [4], [5], [6], [7])
835
836 AT_DATA([flows.txt], [dnl
837 in_port=local actions=local,flood
838 in_port=1 actions=flood
839 in_port=2 actions=all
840 in_port=3 actions=output:LOCAL,output:1,output:2,output:3,output:4,output:5,output:6,output:7
841 in_port=4 actions=enqueue:LOCAL:1,enqueue:1:1,enqueue:2:1,enqueue:3:2,enqueue:4:1,enqueue:5:1,enqueue:6:1,enqueue:7:1
842 ])
843 AT_CHECK([ovs-ofctl add-flows br0 flows.txt])
844 AT_CHECK([ovs-ofctl mod-port br0 5 noforward])
845 AT_CHECK([ovs-ofctl mod-port br0 6 noflood])
846
847 AT_CHECK([ovs-appctl ofproto/trace ovs-dummy 'in_port(100),eth(src=00:00:00:00:00:01,dst=00:00:00:00:00:02),eth_type(0x0900)'], [0], [stdout])
848 AT_CHECK([tail -1 stdout \
849 | sed -e 's/Datapath actions: //' | tr ',' '\n' | sort], [0], [dnl
850 1
851 2
852 3
853 4
854 7
855 ])
856
857 AT_CHECK([ovs-appctl ofproto/trace ovs-dummy 'in_port(1),eth(src=00:00:00:00:00:01,dst=00:00:00:00:00:02),eth_type(0x0900)'], [0], [stdout])
858 AT_CHECK([tail -1 stdout \
859 | sed -e 's/Datapath actions: //' | tr ',' '\n' | sort], [0], [dnl
860 100
861 2
862 3
863 4
864 7
865 ])
866
867 AT_CHECK([ovs-appctl ofproto/trace ovs-dummy 'in_port(2),eth(src=00:00:00:00:00:01,dst=00:00:00:00:00:02),eth_type(0x0900)'], [0], [stdout])
868 AT_CHECK([tail -1 stdout \
869 | sed -e 's/Datapath actions: //' | tr ',' '\n' | sort], [0], [dnl
870 1
871 100
872 3
873 4
874 6
875 7
876 ])
877
878 AT_CHECK([ovs-appctl ofproto/trace ovs-dummy 'in_port(3),eth(src=00:00:00:00:00:01,dst=00:00:00:00:00:02),eth_type(0x0900)'], [0], [stdout])
879 AT_CHECK([tail -1 stdout], [0],
880   [Datapath actions: 100,1,2,4,6,7
881 ])
882
883 AT_CHECK([ovs-appctl ofproto/trace ovs-dummy 'in_port(4),eth(src=00:00:00:00:00:01,dst=00:00:00:00:00:02),eth_type(0x0900)'], [0], [stdout])
884 AT_CHECK([tail -1 stdout], [0],
885   [Datapath actions: set(skb_priority(0x1)),100,1,2,set(skb_priority(0x2)),3,set(skb_priority(0x1)),6,7
886 ])
887 OVS_VSWITCHD_STOP
888 AT_CLEANUP
889
890 AT_SETUP([ofproto-dpif - Default Table Miss - OF1.0 (OFPTC_TABLE_MISS_CONTROLLER)])
891 OVS_VSWITCHD_START([dnl
892    add-port br0 p1 -- set Interface p1 type=dummy
893 ])
894 ON_EXIT([kill `cat ovs-ofctl.pid`])
895
896 AT_CAPTURE_FILE([ofctl_monitor.log])
897
898 AT_CHECK([ovs-ofctl monitor br0 65534 --detach --no-chdir --pidfile 2> ofctl_monitor.log])
899
900 for i in 1 2 3 ; do
901     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=6,tos=0,ttl=64,frag=no),tcp(src=8,dst=9),tcp_flags(syn)'
902 done
903 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
904 OVS_WAIT_UNTIL([ovs-appctl -t ovs-ofctl exit])
905 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
906 NXT_PACKET_IN (xid=0x0): cookie=0x0 total_len=60 in_port=1 (via no_match) data_len=60 (unbuffered)
907 tcp,vlan_tci=0x0000,dl_src=50:54:00:00:00:05,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=9,tcp_flags=syn tcp_csum:0
908 dnl
909 NXT_PACKET_IN (xid=0x0): cookie=0x0 total_len=60 in_port=1 (via no_match) data_len=60 (unbuffered)
910 tcp,vlan_tci=0x0000,dl_src=50:54:00:00:00:05,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=9,tcp_flags=syn tcp_csum:0
911 dnl
912 NXT_PACKET_IN (xid=0x0): cookie=0x0 total_len=60 in_port=1 (via no_match) data_len=60 (unbuffered)
913 tcp,vlan_tci=0x0000,dl_src=50:54:00:00:00:05,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=9,tcp_flags=syn tcp_csum:0
914 ])
915
916 AT_CHECK([ovs-appctl time/warp 5000], [0], [ignore])
917 AT_CHECK([ovs-ofctl dump-flows br0 | ofctl_strip | sort], [0], [dnl
918 NXST_FLOW reply:
919 ])
920
921 OVS_VSWITCHD_STOP
922 AT_CLEANUP
923
924 AT_SETUP([ofproto-dpif - Default Table Miss - OF1.3 (OFPTC_TABLE_MISS_DROP)])
925 OVS_VSWITCHD_START([dnl
926    add-port br0 p1 -- set Interface p1 type=dummy
927 ])
928 ON_EXIT([kill `cat ovs-ofctl.pid`])
929
930 AT_CAPTURE_FILE([ofctl_monitor.log])
931 AT_CHECK([ovs-ofctl del-flows br0])
932
933 AT_CHECK([ovs-ofctl monitor -OOpenFlow13 -P openflow10 br0 65534 --detach --no-chdir --pidfile 2> ofctl_monitor.log])
934
935 dnl Test that missed packets are droped
936 for i in 1 2 3 ; do
937     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=6,tos=0,ttl=64,frag=no),tcp(src=8,dst=9),tcp_flags(ack,syn)'
938 done
939 OVS_WAIT_UNTIL([ovs-appctl -t ovs-ofctl exit])
940
941 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
942 ])
943
944 AT_CHECK([ovs-appctl time/warp 5000], [0], [ignore])
945 AT_CHECK([ovs-ofctl -OOpenFlow13 dump-flows br0 | ofctl_strip | sort], [0], [dnl
946 OFPST_FLOW reply (OF1.3):
947 ])
948
949 OVS_VSWITCHD_STOP
950 AT_CLEANUP
951
952 AT_SETUP([ofproto-dpif - Table Miss - goto table and OFPTC_TABLE_MISS_CONTROLLER])
953 OVS_VSWITCHD_START([dnl
954    add-port br0 p1 -- set Interface p1 type=dummy
955 ])
956 ON_EXIT([kill `cat ovs-ofctl.pid`])
957
958 AT_CAPTURE_FILE([ofctl_monitor.log])
959 AT_CHECK([ovs-ofctl -OOpenFlow12 add-flow br0 'table=0 actions=goto_table(1)'])
960
961 AT_CHECK([ovs-ofctl monitor -P openflow10 br0 65534 --detach --no-chdir --pidfile 2> ofctl_monitor.log])
962
963 for i in 1 2 3 ; do
964     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=6,tos=0,ttl=64,frag=no),tcp(src=8,dst=9),tcp_flags(urg|rst)'
965 done
966 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
967 OVS_WAIT_UNTIL([ovs-appctl -t ovs-ofctl exit])
968 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
969 OFPT_PACKET_IN (xid=0x0): total_len=60 in_port=1 (via no_match) data_len=60 (unbuffered)
970 tcp,vlan_tci=0x0000,dl_src=50:54:00:00:00:05,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=9,tcp_flags=rst|urg tcp_csum:0
971 dnl
972 OFPT_PACKET_IN (xid=0x0): total_len=60 in_port=1 (via no_match) data_len=60 (unbuffered)
973 tcp,vlan_tci=0x0000,dl_src=50:54:00:00:00:05,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=9,tcp_flags=rst|urg tcp_csum:0
974 dnl
975 OFPT_PACKET_IN (xid=0x0): total_len=60 in_port=1 (via no_match) data_len=60 (unbuffered)
976 tcp,vlan_tci=0x0000,dl_src=50:54:00:00:00:05,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=9,tcp_flags=rst|urg tcp_csum:0
977 ])
978
979 AT_CHECK([ovs-appctl revalidator/purge], [0])
980 AT_CHECK([ovs-ofctl -OOpenFlow12 dump-flows br0 | ofctl_strip | sort], [0], [dnl
981  n_packets=3, n_bytes=180, actions=goto_table:1
982 OFPST_FLOW reply (OF1.2):
983 ])
984
985 OVS_VSWITCHD_STOP
986 AT_CLEANUP
987
988 AT_SETUP([ofproto-dpif - Table Miss - resubmit and OFPTC_TABLE_MISS_CONTROLLER])
989 OVS_VSWITCHD_START([dnl
990    add-port br0 p1 -- set Interface p1 type=dummy
991 ])
992 ON_EXIT([kill `cat ovs-ofctl.pid`])
993
994 AT_CAPTURE_FILE([ofctl_monitor.log])
995 AT_CHECK([ovs-ofctl -OOpenFlow12 add-flow br0 'table=0 actions=resubmit(1,1)'])
996
997 AT_CHECK([ovs-ofctl monitor -P openflow10 br0 65534 --detach --no-chdir --pidfile 2> ofctl_monitor.log])
998
999 for i in 1 2 3 ; do
1000     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=6,tos=0,ttl=64,frag=no),tcp(src=8,dst=9),tcp_flags(0x010)'
1001 done
1002
1003 OVS_WAIT_UNTIL([ovs-appctl -t ovs-ofctl exit])
1004 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
1005 ])
1006
1007 AT_CHECK([ovs-appctl revalidator/purge], [0])
1008 AT_CHECK([ovs-ofctl -OOpenFlow12 dump-flows br0 | ofctl_strip | sort], [0], [dnl
1009  n_packets=3, n_bytes=180, actions=resubmit(1,1)
1010 OFPST_FLOW reply (OF1.2):
1011 ])
1012
1013 OVS_VSWITCHD_STOP
1014 AT_CLEANUP
1015
1016 AT_SETUP([ofproto-dpif - Table Miss - OFPTC_TABLE_MISS_CONTINUE])
1017 OVS_VSWITCHD_START([dnl
1018    add-port br0 p1 -- set Interface p1 type=dummy
1019 ])
1020 ON_EXIT([kill `cat ovs-ofctl.pid`])
1021
1022 AT_CAPTURE_FILE([ofctl_monitor.log])
1023 AT_CHECK([ovs-ofctl add-flow br0 'table=1 dl_src=10:11:11:11:11:11 actions=controller'])
1024 AT_CHECK([ovs-ofctl -OOpenFlow11 mod-table br0 all continue])
1025
1026 dnl Miss table 0, Hit table 1
1027 AT_CHECK([ovs-ofctl monitor br0 65534 --detach --no-chdir --pidfile 2> ofctl_monitor.log])
1028
1029 for i in 1 2 3 ; do
1030     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=10:11:11:11:11:11,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=6,tos=0,ttl=64,frag=no),tcp(src=8,dst=9),tcp_flags(0x010)'
1031 done
1032 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
1033 OVS_WAIT_UNTIL([ovs-appctl -t ovs-ofctl exit])
1034
1035 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
1036 NXT_PACKET_IN (xid=0x0): table_id=1 cookie=0x0 total_len=60 in_port=1 (via action) data_len=60 (unbuffered)
1037 tcp,vlan_tci=0x0000,dl_src=10:11:11:11:11:11,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=9,tcp_flags=ack tcp_csum:0
1038 dnl
1039 NXT_PACKET_IN (xid=0x0): table_id=1 cookie=0x0 total_len=60 in_port=1 (via action) data_len=60 (unbuffered)
1040 tcp,vlan_tci=0x0000,dl_src=10:11:11:11:11:11,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=9,tcp_flags=ack tcp_csum:0
1041 dnl
1042 NXT_PACKET_IN (xid=0x0): table_id=1 cookie=0x0 total_len=60 in_port=1 (via action) data_len=60 (unbuffered)
1043 tcp,vlan_tci=0x0000,dl_src=10:11:11:11:11:11,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=9,tcp_flags=ack tcp_csum:0
1044 ])
1045
1046 dnl Hit table 0, Miss all other tables, sent to controller
1047 AT_CHECK([ovs-ofctl monitor br0 65534 -P nxm --detach --no-chdir --pidfile 2> ofctl_monitor.log])
1048
1049 for i in 1 2 3 ; do
1050     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=6,tos=0,ttl=64,frag=no),tcp(src=8,dst=9),tcp_flags(0x010)'
1051 done
1052 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
1053 OVS_WAIT_UNTIL([ovs-appctl -t ovs-ofctl exit])
1054
1055 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
1056 NXT_PACKET_IN (xid=0x0): table_id=253 cookie=0x0 total_len=60 in_port=1 (via no_match) data_len=60 (unbuffered)
1057 tcp,vlan_tci=0x0000,dl_src=50:54:00:00:00:05,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=9,tcp_flags=ack tcp_csum:0
1058 dnl
1059 NXT_PACKET_IN (xid=0x0): table_id=253 cookie=0x0 total_len=60 in_port=1 (via no_match) data_len=60 (unbuffered)
1060 tcp,vlan_tci=0x0000,dl_src=50:54:00:00:00:05,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=9,tcp_flags=ack tcp_csum:0
1061 dnl
1062 NXT_PACKET_IN (xid=0x0): table_id=253 cookie=0x0 total_len=60 in_port=1 (via no_match) data_len=60 (unbuffered)
1063 tcp,vlan_tci=0x0000,dl_src=50:54:00:00:00:05,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=9,tcp_flags=ack tcp_csum:0
1064 ])
1065
1066 AT_CHECK([ovs-appctl revalidator/purge], [0])
1067 AT_CHECK([ovs-ofctl -OOpenFlow12 dump-flows br0 | ofctl_strip | sort], [0], [dnl
1068  table=1, n_packets=3, n_bytes=180, dl_src=10:11:11:11:11:11 actions=CONTROLLER:65535
1069 OFPST_FLOW reply (OF1.2):
1070 ])
1071
1072 OVS_VSWITCHD_STOP
1073 AT_CLEANUP
1074
1075 AT_SETUP([ofproto-dpif - Table Miss - goto table and OFPTC_TABLE_MISS_CONTINUE])
1076 OVS_VSWITCHD_START([dnl
1077    add-port br0 p1 -- set Interface p1 type=dummy
1078 ])
1079 ON_EXIT([kill `cat ovs-ofctl.pid`])
1080
1081 AT_CAPTURE_FILE([ofctl_monitor.log])
1082 AT_DATA([flows.txt], [dnl
1083 table=0 actions=goto_table(1)
1084 table=2 dl_src=10:11:11:11:11:11 actions=controller
1085 ])
1086 AT_CHECK([ovs-ofctl -OOpenFlow12 add-flows br0 flows.txt])
1087 AT_CHECK([ovs-ofctl -OOpenFlow11 mod-table br0 all continue])
1088
1089 dnl Hit table 0, Miss table 1, Hit table 2
1090 AT_CHECK([ovs-ofctl monitor br0 65534 --detach --no-chdir --pidfile 2> ofctl_monitor.log])
1091
1092 for i in 1 2 3 ; do
1093     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=10:11:11:11:11:11,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=6,tos=0,ttl=64,frag=no),tcp(src=8,dst=9),tcp_flags(0x010)'
1094 done
1095 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
1096 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
1097
1098 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
1099 NXT_PACKET_IN (xid=0x0): table_id=2 cookie=0x0 total_len=60 in_port=1 (via action) data_len=60 (unbuffered)
1100 tcp,vlan_tci=0x0000,dl_src=10:11:11:11:11:11,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=9,tcp_flags=ack tcp_csum:0
1101 dnl
1102 NXT_PACKET_IN (xid=0x0): table_id=2 cookie=0x0 total_len=60 in_port=1 (via action) data_len=60 (unbuffered)
1103 tcp,vlan_tci=0x0000,dl_src=10:11:11:11:11:11,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=9,tcp_flags=ack tcp_csum:0
1104 dnl
1105 NXT_PACKET_IN (xid=0x0): table_id=2 cookie=0x0 total_len=60 in_port=1 (via action) data_len=60 (unbuffered)
1106 tcp,vlan_tci=0x0000,dl_src=10:11:11:11:11:11,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=9,tcp_flags=ack tcp_csum:0
1107 ])
1108
1109 dnl Hit table 1, Miss all other tables, sent to controller
1110 AT_CHECK([ovs-ofctl monitor br0 65534 -P nxm --detach --no-chdir --pidfile 2> ofctl_monitor.log])
1111
1112 for i in 1 2 3 ; do
1113     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=6,tos=0,ttl=64,frag=no),tcp(src=8,dst=9),tcp_flags(0x010)'
1114 done
1115 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
1116 OVS_WAIT_UNTIL([ovs-appctl -t ovs-ofctl exit])
1117
1118 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
1119 NXT_PACKET_IN (xid=0x0): table_id=253 cookie=0x0 total_len=60 in_port=1 (via no_match) data_len=60 (unbuffered)
1120 tcp,vlan_tci=0x0000,dl_src=50:54:00:00:00:05,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=9,tcp_flags=ack tcp_csum:0
1121 dnl
1122 NXT_PACKET_IN (xid=0x0): table_id=253 cookie=0x0 total_len=60 in_port=1 (via no_match) data_len=60 (unbuffered)
1123 tcp,vlan_tci=0x0000,dl_src=50:54:00:00:00:05,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=9,tcp_flags=ack tcp_csum:0
1124 dnl
1125 NXT_PACKET_IN (xid=0x0): table_id=253 cookie=0x0 total_len=60 in_port=1 (via no_match) data_len=60 (unbuffered)
1126 tcp,vlan_tci=0x0000,dl_src=50:54:00:00:00:05,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=9,tcp_flags=ack tcp_csum:0
1127 ])
1128
1129 AT_CHECK([ovs-appctl revalidator/purge], [0])
1130 AT_CHECK([ovs-ofctl -OOpenFlow12 dump-flows br0 | ofctl_strip | sort], [0], [dnl
1131  n_packets=6, n_bytes=360, actions=goto_table:1
1132  table=2, n_packets=3, n_bytes=180, dl_src=10:11:11:11:11:11 actions=CONTROLLER:65535
1133 OFPST_FLOW reply (OF1.2):
1134 ])
1135
1136 OVS_VSWITCHD_STOP
1137 AT_CLEANUP
1138
1139 AT_SETUP([ofproto-dpif - Table Miss - resubmit and OFPTC_TABLE_MISS_CONTINUE])
1140 OVS_VSWITCHD_START([dnl
1141    add-port br0 p1 -- set Interface p1 type=dummy
1142 ])
1143 ON_EXIT([kill `cat ovs-ofctl.pid`])
1144
1145 AT_CAPTURE_FILE([ofctl_monitor.log])
1146 AT_DATA([flows.txt], [dnl
1147 table=0 actions=resubmit(1,1)
1148 table=2 dl_src=10:11:11:11:11:11 actions=controller
1149 ])
1150 AT_CHECK([ovs-ofctl -OOpenFlow12 add-flows br0 flows.txt])
1151 AT_CHECK([ovs-ofctl -OOpenFlow11 mod-table br0 all continue])
1152
1153 dnl Hit table 0, Miss table 1, Dropped
1154 AT_CHECK([ovs-ofctl monitor br0 65534 --detach --no-chdir --pidfile 2> ofctl_monitor.log])
1155
1156 for i in 1 2 3 ; do
1157     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=10:11:11:11:11:11,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=6,tos=0,ttl=64,frag=no),tcp(src=8,dst=9),tcp_flags(0x010)'
1158 done
1159 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
1160
1161 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
1162 ])
1163
1164 dnl Hit table 1, Dropped
1165 AT_CHECK([ovs-ofctl monitor br0 65534 -P nxm --detach --no-chdir --pidfile 2> ofctl_monitor.log])
1166
1167 for i in 1 2 3 ; do
1168     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=6,tos=0,ttl=64,frag=no),tcp(src=8,dst=9),tcp_flags(0x010)'
1169 done
1170 OVS_WAIT_UNTIL([ovs-appctl -t ovs-ofctl exit])
1171
1172 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
1173 ])
1174
1175 AT_CHECK([ovs-appctl revalidator/purge], [0])
1176 AT_CHECK([ovs-ofctl -OOpenFlow12 dump-flows br0 | ofctl_strip | sort], [0], [dnl
1177  n_packets=6, n_bytes=360, actions=resubmit(1,1)
1178  table=2, dl_src=10:11:11:11:11:11 actions=CONTROLLER:65535
1179 OFPST_FLOW reply (OF1.2):
1180 ])
1181
1182 OVS_VSWITCHD_STOP
1183 AT_CLEANUP
1184
1185 AT_SETUP([ofproto-dpif - Table Miss - OFPTC_TABLE_MISS_DROP])
1186 OVS_VSWITCHD_START([dnl
1187    add-port br0 p1 -- set Interface p1 type=dummy
1188 ])
1189 ON_EXIT([kill `cat ovs-ofctl.pid`])
1190
1191 AT_CAPTURE_FILE([ofctl_monitor.log])
1192 AT_CHECK([ovs-ofctl -OOpenFlow11 mod-table br0 all drop])
1193
1194 AT_CHECK([ovs-ofctl monitor -P openflow10 br0 65534 --detach --no-chdir --pidfile 2> ofctl_monitor.log])
1195
1196 dnl Test that missed packets are droped
1197 for i in 1 2 3 ; do
1198     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=6,tos=0,ttl=64,frag=no),tcp(src=8,dst=9),tcp_flags(0x010)'
1199 done
1200 OVS_WAIT_UNTIL([ovs-appctl -t ovs-ofctl exit])
1201
1202 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
1203 ])
1204
1205 AT_CHECK([ovs-appctl time/warp 5000], [0], [ignore])
1206 AT_CHECK([ovs-ofctl dump-flows br0 | ofctl_strip | sort], [0], [dnl
1207 NXST_FLOW reply:
1208 ])
1209
1210 OVS_VSWITCHD_STOP
1211 AT_CLEANUP
1212
1213 AT_SETUP([ofproto-dpif - Table Miss - goto table and OFPTC_TABLE_MISS_DROP])
1214 OVS_VSWITCHD_START([dnl
1215    add-port br0 p1 -- set Interface p1 type=dummy
1216 ])
1217 ON_EXIT([kill `cat ovs-ofctl.pid`])
1218
1219 AT_CAPTURE_FILE([ofctl_monitor.log])
1220 AT_CHECK([ovs-ofctl del-flows br0])
1221 AT_CHECK([ovs-ofctl -OOpenFlow12 add-flow br0 'table=0 actions=goto_table(1)'])
1222 AT_CHECK([ovs-ofctl -OOpenFlow11 mod-table br0 all drop])
1223
1224 AT_CHECK([ovs-ofctl monitor -P openflow10 br0 65534 --detach --no-chdir --pidfile 2> ofctl_monitor.log])
1225
1226 dnl Test that missed packets are droped
1227 for i in 1 2 3 ; do
1228     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=6,tos=0,ttl=64,frag=no),tcp(src=8,dst=9),tcp_flags(0x010)'
1229 done
1230 OVS_WAIT_UNTIL([ovs-appctl -t ovs-ofctl exit])
1231
1232 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
1233 ])
1234
1235 AT_CHECK([ovs-appctl revalidator/purge], [0])
1236 AT_CHECK([ovs-ofctl -OOpenFlow12 dump-flows br0 | ofctl_strip | sort], [0], [dnl
1237  n_packets=3, n_bytes=180, actions=goto_table:1
1238 OFPST_FLOW reply (OF1.2):
1239 ])
1240
1241 OVS_VSWITCHD_STOP
1242 AT_CLEANUP
1243
1244 AT_SETUP([ofproto-dpif - Table Miss - resubmit and OFPTC_TABLE_MISS_DROP])
1245 OVS_VSWITCHD_START([dnl
1246    add-port br0 p1 -- set Interface p1 type=dummy
1247 ])
1248 ON_EXIT([kill `cat ovs-ofctl.pid`])
1249
1250 AT_CAPTURE_FILE([ofctl_monitor.log])
1251 AT_CHECK([ovs-ofctl del-flows br0])
1252 AT_CHECK([ovs-ofctl -OOpenFlow12 add-flow br0 'table=0 actions=resubmit(1,1)'])
1253 AT_CHECK([ovs-ofctl -OOpenFlow11 mod-table br0 all drop])
1254
1255 AT_CHECK([ovs-ofctl monitor -P openflow10 br0 65534 --detach --no-chdir --pidfile 2> ofctl_monitor.log])
1256
1257 dnl Test that missed packets are droped
1258 for i in 1 2 3 ; do
1259     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=6,tos=0,ttl=64,frag=no),tcp(src=8,dst=9),tcp_flags(0x010)'
1260 done
1261 OVS_WAIT_UNTIL([ovs-appctl -t ovs-ofctl exit])
1262
1263 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
1264 ])
1265
1266 AT_CHECK([ovs-appctl revalidator/purge], [0])
1267 AT_CHECK([ovs-ofctl -OOpenFlow12 dump-flows br0 | ofctl_strip | sort], [0], [dnl
1268  n_packets=3, n_bytes=180, actions=resubmit(1,1)
1269 OFPST_FLOW reply (OF1.2):
1270 ])
1271
1272 OVS_VSWITCHD_STOP
1273 AT_CLEANUP
1274
1275 AT_SETUP([ofproto-dpif - controller])
1276 OVS_VSWITCHD_START([dnl
1277    add-port br0 p1 -- set Interface p1 type=dummy
1278 ])
1279 ON_EXIT([kill `cat ovs-ofctl.pid`])
1280
1281 AT_CAPTURE_FILE([ofctl_monitor.log])
1282 AT_DATA([flows.txt], [dnl
1283 cookie=0x0 dl_src=10:11:11:11:11:11 actions=controller
1284 cookie=0x1 dl_src=20:22:22:22:22:22 actions=controller,resubmit(80,1)
1285 cookie=0x2 dl_src=30:33:33:33:33:33 actions=mod_vlan_vid:15,controller
1286
1287 cookie=0x3 table=1 in_port=80 actions=load:1->NXM_NX_REG0[[]],mod_vlan_vid:80,controller,resubmit(81,2)
1288 cookie=0x4 table=2 in_port=81 actions=load:2->NXM_NX_REG1[[]],mod_dl_src:80:81:81:81:81:81,controller,resubmit(82,3)
1289 cookie=0x5 table=3 in_port=82 actions=load:3->NXM_NX_REG2[[]],mod_dl_dst:82:82:82:82:82:82,controller,resubmit(83,4)
1290 cookie=0x6 table=4 in_port=83 actions=load:4->NXM_NX_REG3[[]],mod_nw_src:83.83.83.83,controller,resubmit(84,5)
1291 cookie=0x7 table=5 in_port=84 actions=load:5->NXM_NX_REG4[[]],load:6->NXM_NX_TUN_ID[[]],mod_nw_dst:84.84.84.84,controller,resubmit(85,6)
1292 cookie=0x8 table=6 in_port=85 actions=mod_tp_src:85,controller,resubmit(86,7)
1293 cookie=0x9 table=7 in_port=86 actions=mod_tp_dst:86,controller,controller
1294 cookie=0xa dl_src=40:44:44:44:44:41 actions=mod_vlan_vid:99,mod_vlan_pcp:1,controller
1295 cookie=0xd dl_src=80:88:88:88:88:88 arp actions=load:2->OXM_OF_ARP_OP[[]],controller,load:0xc0a88001->OXM_OF_ARP_SPA[[]],controller,load:0x404444444441->OXM_OF_ARP_THA[[]],load:0x01010101->OXM_OF_ARP_SPA[[]],load:0x02020202->OXM_OF_ARP_TPA[[]],controller
1296 ])
1297 AT_CHECK([ovs-ofctl add-flows br0 flows.txt])
1298
1299 dnl Flow miss.
1300 AT_CHECK([ovs-ofctl monitor -P openflow10 br0 65534 --detach --no-chdir --pidfile 2> ofctl_monitor.log])
1301
1302 for i in 1 2 3 ; do
1303     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=6,tos=0,ttl=64,frag=no),tcp(src=8,dst=9),tcp_flags(0x010)'
1304 done
1305 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
1306 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
1307
1308 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
1309 OFPT_PACKET_IN (xid=0x0): total_len=60 in_port=1 (via no_match) data_len=60 (unbuffered)
1310 tcp,vlan_tci=0x0000,dl_src=50:54:00:00:00:05,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=9,tcp_flags=ack tcp_csum:0
1311 dnl
1312 OFPT_PACKET_IN (xid=0x0): total_len=60 in_port=1 (via no_match) data_len=60 (unbuffered)
1313 tcp,vlan_tci=0x0000,dl_src=50:54:00:00:00:05,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=9,tcp_flags=ack tcp_csum:0
1314 dnl
1315 OFPT_PACKET_IN (xid=0x0): total_len=60 in_port=1 (via no_match) data_len=60 (unbuffered)
1316 tcp,vlan_tci=0x0000,dl_src=50:54:00:00:00:05,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=9,tcp_flags=ack tcp_csum:0
1317 ])
1318
1319 dnl Singleton controller action.
1320 AT_CHECK([ovs-ofctl monitor -P openflow10 br0 65534 --detach --no-chdir --pidfile 2> ofctl_monitor.log])
1321
1322 for i in 1 2 3 ; do
1323     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=10:11:11:11:11:11,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=6,tos=0,ttl=64,frag=no),tcp(src=8,dst=10),tcp_flags(0x002)'
1324 done
1325 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
1326 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
1327
1328 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
1329 OFPT_PACKET_IN (xid=0x0): total_len=60 in_port=1 (via action) data_len=60 (unbuffered)
1330 tcp,vlan_tci=0x0000,dl_src=10:11:11:11:11:11,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=10,tcp_flags=syn tcp_csum:0
1331 dnl
1332 OFPT_PACKET_IN (xid=0x0): total_len=60 in_port=1 (via action) data_len=60 (unbuffered)
1333 tcp,vlan_tci=0x0000,dl_src=10:11:11:11:11:11,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=10,tcp_flags=syn tcp_csum:0
1334 dnl
1335 OFPT_PACKET_IN (xid=0x0): total_len=60 in_port=1 (via action) data_len=60 (unbuffered)
1336 tcp,vlan_tci=0x0000,dl_src=10:11:11:11:11:11,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=10,tcp_flags=syn tcp_csum:0
1337 ])
1338
1339 dnl Modified controller action.
1340 AT_CHECK([ovs-ofctl monitor -P openflow10 br0 65534 --detach --no-chdir --pidfile 2> ofctl_monitor.log])
1341
1342 for i in 1 2 3 ; do
1343     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=30:33:33:33:33:33,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=6,tos=0,ttl=64,frag=no),tcp(src=8,dst=10),tcp_flags(0x001)'
1344 done
1345 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
1346 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
1347
1348 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
1349 OFPT_PACKET_IN (xid=0x0): total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
1350 tcp,dl_vlan=15,dl_vlan_pcp=0,dl_src=30:33:33:33:33:33,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=10,tcp_flags=fin tcp_csum:0
1351 dnl
1352 OFPT_PACKET_IN (xid=0x0): total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
1353 tcp,dl_vlan=15,dl_vlan_pcp=0,dl_src=30:33:33:33:33:33,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=10,tcp_flags=fin tcp_csum:0
1354 dnl
1355 OFPT_PACKET_IN (xid=0x0): total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
1356 tcp,dl_vlan=15,dl_vlan_pcp=0,dl_src=30:33:33:33:33:33,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=10,tcp_flags=fin tcp_csum:0
1357 ])
1358
1359 dnl Modified VLAN controller action.
1360 AT_CHECK([ovs-ofctl monitor br0 65534 -P nxm --detach --pidfile 2> ofctl_monitor.log])
1361
1362 for i in 1 2 3; do
1363     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=40:44:44:44:44:41,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=16,tos=0,ttl=64,frag=no)'
1364 done
1365 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
1366 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
1367
1368 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
1369 NXT_PACKET_IN (xid=0x0): cookie=0xa total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
1370 ip,dl_vlan=99,dl_vlan_pcp=1,dl_src=40:44:44:44:44:41,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_proto=16,nw_tos=0,nw_ecn=0,nw_ttl=64
1371 dnl
1372 NXT_PACKET_IN (xid=0x0): cookie=0xa total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
1373 ip,dl_vlan=99,dl_vlan_pcp=1,dl_src=40:44:44:44:44:41,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_proto=16,nw_tos=0,nw_ecn=0,nw_ttl=64
1374 dnl
1375 NXT_PACKET_IN (xid=0x0): cookie=0xa total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
1376 ip,dl_vlan=99,dl_vlan_pcp=1,dl_src=40:44:44:44:44:41,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_proto=16,nw_tos=0,nw_ecn=0,nw_ttl=64
1377 ])
1378
1379 dnl Checksum TCP.
1380 AT_CHECK([ovs-ofctl monitor br0 65534 -P nxm --detach --no-chdir --pidfile 2> ofctl_monitor.log])
1381
1382 for i in 1 ; do
1383     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=20:22:22:22:22:22,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=6,tos=0,ttl=64,frag=no),tcp(src=8,dst=11),tcp_flags(0x001)'
1384 done
1385 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 18])
1386 ovs-appctl -t ovs-ofctl exit
1387
1388 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
1389 NXT_PACKET_IN (xid=0x0): cookie=0x1 total_len=60 in_port=1 (via action) data_len=60 (unbuffered)
1390 tcp,vlan_tci=0x0000,dl_src=20:22:22:22:22:22,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=11,tcp_flags=fin tcp_csum:0
1391 dnl
1392 NXT_PACKET_IN (xid=0x0): table_id=1 cookie=0x3 total_len=64 reg0=0x1,in_port=1 (via action) data_len=64 (unbuffered)
1393 tcp,dl_vlan=80,dl_vlan_pcp=0,dl_src=20:22:22:22:22:22,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=11,tcp_flags=fin tcp_csum:0
1394 dnl
1395 NXT_PACKET_IN (xid=0x0): table_id=2 cookie=0x4 total_len=64 reg0=0x1,reg1=0x2,in_port=1 (via action) data_len=64 (unbuffered)
1396 tcp,dl_vlan=80,dl_vlan_pcp=0,dl_src=80:81:81:81:81:81,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=11,tcp_flags=fin tcp_csum:0
1397 dnl
1398 NXT_PACKET_IN (xid=0x0): table_id=3 cookie=0x5 total_len=64 reg0=0x1,reg1=0x2,reg2=0x3,in_port=1 (via action) data_len=64 (unbuffered)
1399 tcp,dl_vlan=80,dl_vlan_pcp=0,dl_src=80:81:81:81:81:81,dl_dst=82:82:82:82:82:82,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=11,tcp_flags=fin tcp_csum:0
1400 dnl
1401 NXT_PACKET_IN (xid=0x0): table_id=4 cookie=0x6 total_len=64 reg0=0x1,reg1=0x2,reg2=0x3,reg3=0x4,in_port=1 (via action) data_len=64 (unbuffered)
1402 tcp,dl_vlan=80,dl_vlan_pcp=0,dl_src=80:81:81:81:81:81,dl_dst=82:82:82:82:82:82,nw_src=83.83.83.83,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=11,tcp_flags=fin tcp_csum:1a03
1403 dnl
1404 NXT_PACKET_IN (xid=0x0): table_id=5 cookie=0x7 total_len=64 reg0=0x1,reg1=0x2,reg2=0x3,reg3=0x4,reg4=0x5,tun_id=0x6,in_port=1 (via action) data_len=64 (unbuffered)
1405 tcp,dl_vlan=80,dl_vlan_pcp=0,dl_src=80:81:81:81:81:81,dl_dst=82:82:82:82:82:82,nw_src=83.83.83.83,nw_dst=84.84.84.84,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=11,tcp_flags=fin tcp_csum:3205
1406 dnl
1407 NXT_PACKET_IN (xid=0x0): table_id=6 cookie=0x8 total_len=64 reg0=0x1,reg1=0x2,reg2=0x3,reg3=0x4,reg4=0x5,tun_id=0x6,in_port=1 (via action) data_len=64 (unbuffered)
1408 tcp,dl_vlan=80,dl_vlan_pcp=0,dl_src=80:81:81:81:81:81,dl_dst=82:82:82:82:82:82,nw_src=83.83.83.83,nw_dst=84.84.84.84,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=85,tp_dst=11,tcp_flags=fin tcp_csum:31b8
1409 dnl
1410 NXT_PACKET_IN (xid=0x0): table_id=7 cookie=0x9 total_len=64 reg0=0x1,reg1=0x2,reg2=0x3,reg3=0x4,reg4=0x5,tun_id=0x6,in_port=1 (via action) data_len=64 (unbuffered)
1411 tcp,dl_vlan=80,dl_vlan_pcp=0,dl_src=80:81:81:81:81:81,dl_dst=82:82:82:82:82:82,nw_src=83.83.83.83,nw_dst=84.84.84.84,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=85,tp_dst=86,tcp_flags=fin tcp_csum:316d
1412 dnl
1413 NXT_PACKET_IN (xid=0x0): table_id=7 cookie=0x9 total_len=64 reg0=0x1,reg1=0x2,reg2=0x3,reg3=0x4,reg4=0x5,tun_id=0x6,in_port=1 (via action) data_len=64 (unbuffered)
1414 tcp,dl_vlan=80,dl_vlan_pcp=0,dl_src=80:81:81:81:81:81,dl_dst=82:82:82:82:82:82,nw_src=83.83.83.83,nw_dst=84.84.84.84,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=85,tp_dst=86,tcp_flags=fin tcp_csum:316d
1415 ])
1416
1417 dnl Checksum UDP.
1418 AT_CHECK([ovs-ofctl monitor br0 65534 --detach --no-chdir --pidfile 2> ofctl_monitor.log])
1419
1420 for i in 1 ; do
1421     ovs-appctl netdev-dummy/receive p1 '50 54 00 00 00 07 20 22 22 22 22 22 08 00 45 00 00 1C 00 00 00 00 00 11 00 00 C0 A8 00 01 C0 A8 00 02 00 08 00 0B 00 00 12 34 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00'
1422 done
1423 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 18])
1424 ovs-appctl -t ovs-ofctl exit
1425
1426 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
1427 NXT_PACKET_IN (xid=0x0): cookie=0x1 total_len=60 in_port=1 (via action) data_len=60 (unbuffered)
1428 udp,vlan_tci=0x0000,dl_src=20:22:22:22:22:22,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=0,tp_src=8,tp_dst=11 udp_csum:1234
1429 dnl
1430 NXT_PACKET_IN (xid=0x0): table_id=1 cookie=0x3 total_len=64 reg0=0x1,in_port=1 (via action) data_len=64 (unbuffered)
1431 udp,dl_vlan=80,dl_vlan_pcp=0,dl_src=20:22:22:22:22:22,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=0,tp_src=8,tp_dst=11 udp_csum:1234
1432 dnl
1433 NXT_PACKET_IN (xid=0x0): table_id=2 cookie=0x4 total_len=64 reg0=0x1,reg1=0x2,in_port=1 (via action) data_len=64 (unbuffered)
1434 udp,dl_vlan=80,dl_vlan_pcp=0,dl_src=80:81:81:81:81:81,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=0,tp_src=8,tp_dst=11 udp_csum:1234
1435 dnl
1436 NXT_PACKET_IN (xid=0x0): table_id=3 cookie=0x5 total_len=64 reg0=0x1,reg1=0x2,reg2=0x3,in_port=1 (via action) data_len=64 (unbuffered)
1437 udp,dl_vlan=80,dl_vlan_pcp=0,dl_src=80:81:81:81:81:81,dl_dst=82:82:82:82:82:82,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=0,tp_src=8,tp_dst=11 udp_csum:1234
1438 dnl
1439 NXT_PACKET_IN (xid=0x0): table_id=4 cookie=0x6 total_len=64 reg0=0x1,reg1=0x2,reg2=0x3,reg3=0x4,in_port=1 (via action) data_len=64 (unbuffered)
1440 udp,dl_vlan=80,dl_vlan_pcp=0,dl_src=80:81:81:81:81:81,dl_dst=82:82:82:82:82:82,nw_src=83.83.83.83,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=0,tp_src=8,tp_dst=11 udp_csum:2c37
1441 dnl
1442 NXT_PACKET_IN (xid=0x0): table_id=5 cookie=0x7 total_len=64 reg0=0x1,reg1=0x2,reg2=0x3,reg3=0x4,reg4=0x5,tun_id=0x6,in_port=1 (via action) data_len=64 (unbuffered)
1443 udp,dl_vlan=80,dl_vlan_pcp=0,dl_src=80:81:81:81:81:81,dl_dst=82:82:82:82:82:82,nw_src=83.83.83.83,nw_dst=84.84.84.84,nw_tos=0,nw_ecn=0,nw_ttl=0,tp_src=8,tp_dst=11 udp_csum:4439
1444 dnl
1445 NXT_PACKET_IN (xid=0x0): table_id=6 cookie=0x8 total_len=64 reg0=0x1,reg1=0x2,reg2=0x3,reg3=0x4,reg4=0x5,tun_id=0x6,in_port=1 (via action) data_len=64 (unbuffered)
1446 udp,dl_vlan=80,dl_vlan_pcp=0,dl_src=80:81:81:81:81:81,dl_dst=82:82:82:82:82:82,nw_src=83.83.83.83,nw_dst=84.84.84.84,nw_tos=0,nw_ecn=0,nw_ttl=0,tp_src=85,tp_dst=11 udp_csum:43ec
1447 dnl
1448 NXT_PACKET_IN (xid=0x0): table_id=7 cookie=0x9 total_len=64 reg0=0x1,reg1=0x2,reg2=0x3,reg3=0x4,reg4=0x5,tun_id=0x6,in_port=1 (via action) data_len=64 (unbuffered)
1449 udp,dl_vlan=80,dl_vlan_pcp=0,dl_src=80:81:81:81:81:81,dl_dst=82:82:82:82:82:82,nw_src=83.83.83.83,nw_dst=84.84.84.84,nw_tos=0,nw_ecn=0,nw_ttl=0,tp_src=85,tp_dst=86 udp_csum:43a1
1450 dnl
1451 NXT_PACKET_IN (xid=0x0): table_id=7 cookie=0x9 total_len=64 reg0=0x1,reg1=0x2,reg2=0x3,reg3=0x4,reg4=0x5,tun_id=0x6,in_port=1 (via action) data_len=64 (unbuffered)
1452 udp,dl_vlan=80,dl_vlan_pcp=0,dl_src=80:81:81:81:81:81,dl_dst=82:82:82:82:82:82,nw_src=83.83.83.83,nw_dst=84.84.84.84,nw_tos=0,nw_ecn=0,nw_ttl=0,tp_src=85,tp_dst=86 udp_csum:43a1
1453 ])
1454
1455 dnl Modified ARP controller action.
1456 AT_CHECK([ovs-ofctl monitor br0 65534 -P nxm --detach --pidfile 2> ofctl_monitor.log])
1457
1458 for i in 1 2 3; do
1459     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=80:88:88:88:88:88,dst=ff:ff:ff:ff:ff:ff),eth_type(0x0806),arp(sip=192.168.0.1,tip=192.168.0.2,op=1,sha=50:54:00:00:00:05,tha=00:00:00:00:00:00)'
1460 done
1461
1462 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 18])
1463 OVS_WAIT_UNTIL([ovs-appctl -t ovs-ofctl exit])
1464 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
1465 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=60 in_port=1 (via action) data_len=60 (unbuffered)
1466 arp,vlan_tci=0x0000,dl_src=80:88:88:88:88:88,dl_dst=ff:ff:ff:ff:ff:ff,arp_spa=192.168.0.1,arp_tpa=192.168.0.2,arp_op=2,arp_sha=50:54:00:00:00:05,arp_tha=00:00:00:00:00:00
1467 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=60 in_port=1 (via action) data_len=60 (unbuffered)
1468 arp,vlan_tci=0x0000,dl_src=80:88:88:88:88:88,dl_dst=ff:ff:ff:ff:ff:ff,arp_spa=192.168.128.1,arp_tpa=192.168.0.2,arp_op=2,arp_sha=50:54:00:00:00:05,arp_tha=00:00:00:00:00:00
1469 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=60 in_port=1 (via action) data_len=60 (unbuffered)
1470 arp,vlan_tci=0x0000,dl_src=80:88:88:88:88:88,dl_dst=ff:ff:ff:ff:ff:ff,arp_spa=1.1.1.1,arp_tpa=2.2.2.2,arp_op=2,arp_sha=50:54:00:00:00:05,arp_tha=40:44:44:44:44:41
1471 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=60 in_port=1 (via action) data_len=60 (unbuffered)
1472 arp,vlan_tci=0x0000,dl_src=80:88:88:88:88:88,dl_dst=ff:ff:ff:ff:ff:ff,arp_spa=192.168.0.1,arp_tpa=192.168.0.2,arp_op=2,arp_sha=50:54:00:00:00:05,arp_tha=00:00:00:00:00:00
1473 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=60 in_port=1 (via action) data_len=60 (unbuffered)
1474 arp,vlan_tci=0x0000,dl_src=80:88:88:88:88:88,dl_dst=ff:ff:ff:ff:ff:ff,arp_spa=192.168.128.1,arp_tpa=192.168.0.2,arp_op=2,arp_sha=50:54:00:00:00:05,arp_tha=00:00:00:00:00:00
1475 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=60 in_port=1 (via action) data_len=60 (unbuffered)
1476 arp,vlan_tci=0x0000,dl_src=80:88:88:88:88:88,dl_dst=ff:ff:ff:ff:ff:ff,arp_spa=1.1.1.1,arp_tpa=2.2.2.2,arp_op=2,arp_sha=50:54:00:00:00:05,arp_tha=40:44:44:44:44:41
1477 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=60 in_port=1 (via action) data_len=60 (unbuffered)
1478 arp,vlan_tci=0x0000,dl_src=80:88:88:88:88:88,dl_dst=ff:ff:ff:ff:ff:ff,arp_spa=192.168.0.1,arp_tpa=192.168.0.2,arp_op=2,arp_sha=50:54:00:00:00:05,arp_tha=00:00:00:00:00:00
1479 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=60 in_port=1 (via action) data_len=60 (unbuffered)
1480 arp,vlan_tci=0x0000,dl_src=80:88:88:88:88:88,dl_dst=ff:ff:ff:ff:ff:ff,arp_spa=192.168.128.1,arp_tpa=192.168.0.2,arp_op=2,arp_sha=50:54:00:00:00:05,arp_tha=00:00:00:00:00:00
1481 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=60 in_port=1 (via action) data_len=60 (unbuffered)
1482 arp,vlan_tci=0x0000,dl_src=80:88:88:88:88:88,dl_dst=ff:ff:ff:ff:ff:ff,arp_spa=1.1.1.1,arp_tpa=2.2.2.2,arp_op=2,arp_sha=50:54:00:00:00:05,arp_tha=40:44:44:44:44:41
1483 ])
1484
1485 AT_CHECK([ovs-appctl time/warp 5000], [0], [ignore])
1486
1487 dnl Checksum SCTP.
1488 AT_CHECK([ovs-ofctl monitor br0 65534 --detach --no-chdir --pidfile 2> ofctl_monitor.log])
1489
1490 for i in 1 ; do
1491     ovs-appctl netdev-dummy/receive p1 '50 54 00 00 00 07 20 22 22 22 22 22 08 00 45 00 00 24 00 00 00 00 00 84 00 00 C0 A8 00 01 C0 A8 00 02 04 58 08 af 00 00 00 00 d9 d7 91 57 01 00 00 34 cf 28 ec 4e 00 01 40 00 00 0a ff ff b7 53 24 19 00 05 00 08 7f 00 00 01 00 05 00 08 c0 a8 02 07 00 0c 00 06 00 05 00 00 80 00 00 04 c0 00 00 04'
1492 done
1493
1494 AT_CHECK([ovs-appctl time/warp 1000], [0], [ignore])
1495 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 18])
1496 OVS_WAIT_UNTIL([ovs-appctl -t ovs-ofctl exit])
1497 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
1498 NXT_PACKET_IN (xid=0x0): cookie=0x1 total_len=98 in_port=1 (via action) data_len=98 (unbuffered)
1499 sctp,vlan_tci=0x0000,dl_src=20:22:22:22:22:22,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=0,tp_src=1112,tp_dst=2223 sctp_csum:d9d79157
1500 dnl
1501 NXT_PACKET_IN (xid=0x0): table_id=1 cookie=0x3 total_len=102 reg0=0x1,in_port=1 (via action) data_len=102 (unbuffered)
1502 sctp,dl_vlan=80,dl_vlan_pcp=0,dl_src=20:22:22:22:22:22,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=0,tp_src=1112,tp_dst=2223 sctp_csum:d9d79157
1503 dnl
1504 NXT_PACKET_IN (xid=0x0): table_id=2 cookie=0x4 total_len=102 reg0=0x1,reg1=0x2,in_port=1 (via action) data_len=102 (unbuffered)
1505 sctp,dl_vlan=80,dl_vlan_pcp=0,dl_src=80:81:81:81:81:81,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=0,tp_src=1112,tp_dst=2223 sctp_csum:d9d79157
1506 dnl
1507 NXT_PACKET_IN (xid=0x0): table_id=3 cookie=0x5 total_len=102 reg0=0x1,reg1=0x2,reg2=0x3,in_port=1 (via action) data_len=102 (unbuffered)
1508 sctp,dl_vlan=80,dl_vlan_pcp=0,dl_src=80:81:81:81:81:81,dl_dst=82:82:82:82:82:82,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=0,tp_src=1112,tp_dst=2223 sctp_csum:d9d79157
1509 dnl
1510 NXT_PACKET_IN (xid=0x0): table_id=4 cookie=0x6 total_len=102 reg0=0x1,reg1=0x2,reg2=0x3,reg3=0x4,in_port=1 (via action) data_len=102 (unbuffered)
1511 sctp,dl_vlan=80,dl_vlan_pcp=0,dl_src=80:81:81:81:81:81,dl_dst=82:82:82:82:82:82,nw_src=83.83.83.83,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=0,tp_src=1112,tp_dst=2223 sctp_csum:d9d79157
1512 dnl
1513 NXT_PACKET_IN (xid=0x0): table_id=5 cookie=0x7 total_len=102 reg0=0x1,reg1=0x2,reg2=0x3,reg3=0x4,reg4=0x5,tun_id=0x6,in_port=1 (via action) data_len=102 (unbuffered)
1514 sctp,dl_vlan=80,dl_vlan_pcp=0,dl_src=80:81:81:81:81:81,dl_dst=82:82:82:82:82:82,nw_src=83.83.83.83,nw_dst=84.84.84.84,nw_tos=0,nw_ecn=0,nw_ttl=0,tp_src=1112,tp_dst=2223 sctp_csum:d9d79157
1515 dnl
1516 NXT_PACKET_IN (xid=0x0): table_id=6 cookie=0x8 total_len=102 reg0=0x1,reg1=0x2,reg2=0x3,reg3=0x4,reg4=0x5,tun_id=0x6,in_port=1 (via action) data_len=102 (unbuffered)
1517 sctp,dl_vlan=80,dl_vlan_pcp=0,dl_src=80:81:81:81:81:81,dl_dst=82:82:82:82:82:82,nw_src=83.83.83.83,nw_dst=84.84.84.84,nw_tos=0,nw_ecn=0,nw_ttl=0,tp_src=85,tp_dst=2223 sctp_csum:dd778f5f
1518 dnl
1519 NXT_PACKET_IN (xid=0x0): table_id=7 cookie=0x9 total_len=102 reg0=0x1,reg1=0x2,reg2=0x3,reg3=0x4,reg4=0x5,tun_id=0x6,in_port=1 (via action) data_len=102 (unbuffered)
1520 sctp,dl_vlan=80,dl_vlan_pcp=0,dl_src=80:81:81:81:81:81,dl_dst=82:82:82:82:82:82,nw_src=83.83.83.83,nw_dst=84.84.84.84,nw_tos=0,nw_ecn=0,nw_ttl=0,tp_src=85,tp_dst=86 sctp_csum:62051f56
1521 dnl
1522 NXT_PACKET_IN (xid=0x0): table_id=7 cookie=0x9 total_len=102 reg0=0x1,reg1=0x2,reg2=0x3,reg3=0x4,reg4=0x5,tun_id=0x6,in_port=1 (via action) data_len=102 (unbuffered)
1523 sctp,dl_vlan=80,dl_vlan_pcp=0,dl_src=80:81:81:81:81:81,dl_dst=82:82:82:82:82:82,nw_src=83.83.83.83,nw_dst=84.84.84.84,nw_tos=0,nw_ecn=0,nw_ttl=0,tp_src=85,tp_dst=86 sctp_csum:62051f56
1524 ])
1525
1526 AT_CHECK([ovs-ofctl dump-flows br0 | ofctl_strip | sort], [0], [dnl
1527  cookie=0x1, n_packets=3, n_bytes=218, dl_src=20:22:22:22:22:22 actions=CONTROLLER:65535,resubmit(80,1)
1528  cookie=0x2, n_packets=3, n_bytes=180, dl_src=30:33:33:33:33:33 actions=mod_vlan_vid:15,CONTROLLER:65535
1529  cookie=0x3, table=1, n_packets=3, n_bytes=218, in_port=80 actions=load:0x1->NXM_NX_REG0[[]],mod_vlan_vid:80,CONTROLLER:65535,resubmit(81,2)
1530  cookie=0x4, table=2, n_packets=3, n_bytes=218, in_port=81 actions=load:0x2->NXM_NX_REG1[[]],mod_dl_src:80:81:81:81:81:81,CONTROLLER:65535,resubmit(82,3)
1531  cookie=0x5, table=3, n_packets=3, n_bytes=218, in_port=82 actions=load:0x3->NXM_NX_REG2[[]],mod_dl_dst:82:82:82:82:82:82,CONTROLLER:65535,resubmit(83,4)
1532  cookie=0x6, table=4, n_packets=3, n_bytes=218, in_port=83 actions=load:0x4->NXM_NX_REG3[[]],mod_nw_src:83.83.83.83,CONTROLLER:65535,resubmit(84,5)
1533  cookie=0x7, table=5, n_packets=3, n_bytes=218, in_port=84 actions=load:0x5->NXM_NX_REG4[[]],load:0x6->NXM_NX_TUN_ID[[]],mod_nw_dst:84.84.84.84,CONTROLLER:65535,resubmit(85,6)
1534  cookie=0x8, table=6, n_packets=3, n_bytes=218, in_port=85 actions=mod_tp_src:85,CONTROLLER:65535,resubmit(86,7)
1535  cookie=0x9, table=7, n_packets=3, n_bytes=218, in_port=86 actions=mod_tp_dst:86,CONTROLLER:65535,CONTROLLER:65535
1536  cookie=0xa, n_packets=3, n_bytes=180, dl_src=40:44:44:44:44:41 actions=mod_vlan_vid:99,mod_vlan_pcp:1,CONTROLLER:65535
1537  cookie=0xd, n_packets=3, n_bytes=180, arp,dl_src=80:88:88:88:88:88 actions=load:0x2->NXM_OF_ARP_OP[[]],CONTROLLER:65535,load:0xc0a88001->NXM_OF_ARP_SPA[[]],CONTROLLER:65535,load:0x404444444441->NXM_NX_ARP_THA[[]],load:0x1010101->NXM_OF_ARP_SPA[[]],load:0x2020202->NXM_OF_ARP_TPA[[]],CONTROLLER:65535
1538  n_packets=3, n_bytes=180, dl_src=10:11:11:11:11:11 actions=CONTROLLER:65535
1539 NXST_FLOW reply:
1540 ])
1541
1542 OVS_VSWITCHD_STOP
1543 AT_CLEANUP
1544
1545 AT_SETUP([ofproto-dpif - MPLS handling])
1546 OVS_VSWITCHD_START([dnl
1547    add-port br0 p1 -- set Interface p1 type=dummy
1548 ])
1549 ON_EXIT([kill `cat ovs-ofctl.pid`])
1550
1551 AT_CAPTURE_FILE([ofctl_monitor.log])
1552 AT_DATA([flows.txt], [dnl
1553 cookie=0xa dl_src=40:44:44:44:44:42 actions=push_mpls:0x8847,load:10->OXM_OF_MPLS_LABEL[[]],load:3->OXM_OF_MPLS_TC[[]],controller
1554 cookie=0xa dl_src=41:44:44:44:44:42 actions=push_mpls:0x8847,load:10->OXM_OF_MPLS_LABEL[[]],load:3->OXM_OF_MPLS_TC[[]],pop_mpls:0x0800,controller
1555 cookie=0xa dl_src=40:44:44:44:44:43 actions=push_mpls:0x8847,load:10->OXM_OF_MPLS_LABEL[[]],load:3->OXM_OF_MPLS_TC[[]],controller
1556 cookie=0xa dl_src=40:44:44:44:44:44 actions=push_mpls:0x8847,load:10->OXM_OF_MPLS_LABEL[[]],load:3->OXM_OF_MPLS_TC[[]],controller
1557 cookie=0xa dl_src=40:44:44:44:44:45 actions=push_mpls:0x8847,load:10->OXM_OF_MPLS_LABEL[[]],load:3->OXM_OF_MPLS_TC[[]],dec_mpls_ttl,controller
1558 cookie=0xa dl_src=40:44:44:44:44:46 actions=push_mpls:0x8847,load:10->OXM_OF_MPLS_LABEL[[]],load:3->OXM_OF_MPLS_TC[[]],set_mpls_ttl(10),controller
1559 cookie=0xa dl_src=40:44:44:44:44:47 actions=push_mpls:0x8847,load:10->OXM_OF_MPLS_LABEL[[]],load:3->OXM_OF_MPLS_TC[[]],dec_mpls_ttl,set_mpls_ttl(10),controller
1560 cookie=0xa dl_src=40:44:44:44:44:48 actions=push_mpls:0x8847,load:10->OXM_OF_MPLS_LABEL[[]],load:3->OXM_OF_MPLS_TC[[]],set_mpls_ttl(10),dec_mpls_ttl,controller
1561 cookie=0xa mpls,dl_src=40:44:44:44:44:49 actions=push_mpls:0x8848,load:10->OXM_OF_MPLS_LABEL[[]],CONTROLLER:65535
1562 cookie=0xb dl_src=50:55:55:55:55:55 dl_type=0x8847 actions=load:1000->OXM_OF_MPLS_LABEL[[]],controller
1563 cookie=0xd dl_src=60:66:66:66:66:66 actions=pop_mpls:0x0800,controller
1564 cookie=0xc dl_src=70:77:77:77:77:77 actions=push_mpls:0x8848,load:1000->OXM_OF_MPLS_LABEL[[]],load:7->OXM_OF_MPLS_TC[[]],controller
1565
1566 cookie=0xd dl_src=60:66:66:66:00:01 actions=pop_mpls:0x0800,dec_ttl,controller
1567 cookie=0xd dl_src=60:66:66:66:00:02 actions=pop_mpls:0x0800,load:0xa000001->OXM_OF_IPV4_DST[[]],controller
1568 cookie=0xd dl_src=60:66:66:66:00:03 actions=pop_mpls:0x0800,move:OXM_OF_IPV4_DST[[]]->OXM_OF_IPV4_SRC[[]],controller
1569 cookie=0xd dl_src=60:66:66:66:00:04 actions=pop_mpls:0x0800,push:OXM_OF_IPV4_DST[[]],pop:OXM_OF_IPV4_SRC[[]],controller
1570 cookie=0xd dl_src=60:66:66:66:00:05 actions=pop_mpls:0x0800,multipath(eth_src,50,modulo_n,256,0,OXM_OF_IPV4_SRC[[0..7]]),controller
1571 cookie=0xd dl_src=60:66:66:66:00:06 actions=pop_mpls:0x0800,bundle_load(eth_src,50,hrw,ofport,OXM_OF_IPV4_SRC[[0..15]],slaves:1,2),controller
1572 cookie=0xd dl_src=60:66:66:66:00:07 actions=pop_mpls:0x0800,learn(table=1,hard_timeout=60,eth_type=0x800,nw_proto=6,OXM_OF_IPV4_SRC[[]]=OXM_OF_IPV4_DST[[]]),controller
1573
1574 cookie=0xd dl_src=60:66:66:66:00:08 actions=pop_mpls:0x0806,resubmit(1,1)
1575 cookie=0xd table=1 arp actions=controller
1576
1577 cookie=0xdeadbeef table=2 dl_src=60:66:66:66:00:09 actions=pop_mpls:0x0800,mod_nw_tos:48
1578 cookie=0xd dl_src=60:66:66:66:00:09 actions=resubmit(,2),controller
1579 cookie=0xd dl_src=60:66:66:66:00:0a actions=pop_mpls:0x0800,mod_nw_dst:10.0.0.1,controller
1580 cookie=0xd dl_src=60:66:66:66:00:0b actions=pop_mpls:0x0800,mod_nw_src:10.0.0.1,controller
1581
1582 cookie=0xd dl_src=60:66:66:66:01:00 actions=pop_mpls:0x8848,controller
1583 cookie=0xd dl_src=60:66:66:66:01:01 actions=pop_mpls:0x8847,dec_mpls_ttl,controller
1584 cookie=0xd dl_src=60:66:66:66:01:02 actions=pop_mpls:0x8848,load:3->OXM_OF_MPLS_TC[[]],controller
1585
1586 cookie=0xd dl_src=60:66:66:66:02:00 actions=pop_mpls:0x8847,pop_mpls:0x0800,controller
1587 cookie=0xe dl_src=60:66:66:66:02:01 actions=pop_mpls:0x8848,pop_mpls:0x0800,dec_ttl,controller
1588 cookie=0xe dl_src=60:66:66:66:02:10 actions=pop_mpls:0x8847,dec_mpls_ttl,pop_mpls:0x0800,dec_ttl,controller
1589
1590 cookie=0xe dl_src=60:66:66:66:03:00 actions=pop_mpls:0x8848,pop_mpls:0x8848,controller
1591 cookie=0xe dl_src=60:66:66:66:03:01 actions=pop_mpls:0x8847,pop_mpls:0x8847,dec_mpls_ttl,controller
1592 cookie=0xe dl_src=60:66:66:66:03:10 actions=pop_mpls:0x8848,dec_mpls_ttl,pop_mpls:0x8848,dec_mpls_ttl,controller
1593
1594 cookie=0xf dl_src=60:66:66:66:04:00 actions=pop_mpls:0x0800,push_mpls:0x8847,controller
1595 cookie=0xf dl_src=60:66:66:66:04:01 actions=pop_mpls:0x0800,push_mpls:0x8848,dec_mpls_ttl,controller
1596 cookie=0xf dl_src=60:66:66:66:04:10 actions=pop_mpls:0x0800,dec_ttl,push_mpls:0x8848,dec_mpls_ttl,controller
1597
1598 cookie=0x5 dl_src=60:66:66:66:05:00 actions=push_mpls:0x8848,pop_mpls:0x8847,controller
1599 cookie=0x5 dl_src=60:66:66:66:05:01 actions=push_mpls:0x8847,pop_mpls:0x8848,dec_mpls_ttl,controller
1600 cookie=0x5 dl_src=60:66:66:66:05:10 actions=push_mpls:0x8848,dec_mpls_ttl,pop_mpls:0x8847,dec_mpls_ttl,controller
1601 ])
1602 AT_CHECK([ovs-ofctl add-flows br0 flows.txt])
1603
1604 dnl Modified MPLS controller action.
1605 AT_CHECK([ovs-ofctl monitor br0 65534 -P nxm --detach --pidfile 2> ofctl_monitor.log])
1606
1607 for i in 1 2 3; do
1608     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=40:44:44:44:44:42,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=17,tos=0,ttl=64,frag=no),udp(src=7777,dst=80)'
1609 done
1610 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
1611 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
1612
1613 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
1614 NXT_PACKET_IN (xid=0x0): cookie=0xa total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
1615 mpls,vlan_tci=0x0000,dl_src=40:44:44:44:44:42,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=3,mpls_ttl=64,mpls_bos=1
1616 dnl
1617 NXT_PACKET_IN (xid=0x0): cookie=0xa total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
1618 mpls,vlan_tci=0x0000,dl_src=40:44:44:44:44:42,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=3,mpls_ttl=64,mpls_bos=1
1619 dnl
1620 NXT_PACKET_IN (xid=0x0): cookie=0xa total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
1621 mpls,vlan_tci=0x0000,dl_src=40:44:44:44:44:42,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=3,mpls_ttl=64,mpls_bos=1
1622 ])
1623
1624 dnl Modified MPLS controller action.
1625 AT_CHECK([ovs-ofctl monitor br0 65534 -P nxm --detach --pidfile 2> ofctl_monitor.log])
1626
1627 for i in 1 2 3; do
1628     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=41:44:44:44:44:42,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=16,tos=0,ttl=64,frag=no)'
1629 done
1630 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
1631 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
1632
1633 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
1634 NXT_PACKET_IN (xid=0x0): cookie=0xa total_len=60 in_port=1 (via action) data_len=60 (unbuffered)
1635 ip,vlan_tci=0x0000,dl_src=41:44:44:44:44:42,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_proto=16,nw_tos=0,nw_ecn=0,nw_ttl=64
1636 dnl
1637 NXT_PACKET_IN (xid=0x0): cookie=0xa total_len=60 in_port=1 (via action) data_len=60 (unbuffered)
1638 ip,vlan_tci=0x0000,dl_src=41:44:44:44:44:42,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_proto=16,nw_tos=0,nw_ecn=0,nw_ttl=64
1639 dnl
1640 NXT_PACKET_IN (xid=0x0): cookie=0xa total_len=60 in_port=1 (via action) data_len=60 (unbuffered)
1641 ip,vlan_tci=0x0000,dl_src=41:44:44:44:44:42,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_proto=16,nw_tos=0,nw_ecn=0,nw_ttl=64
1642 ])
1643
1644 dnl Modified MPLS controller action.
1645 AT_CHECK([ovs-ofctl monitor br0 65534 -P nxm --detach --pidfile 2> ofctl_monitor.log])
1646
1647 dnl in_port(1),eth(src=00:01:02:03:04:05,dst=10:11:12:13:14:15),eth_type(0x8847),mpls(label=100,tc=3,ttl=64,bos=1)
1648
1649 for i in 1 2 3; do
1650     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=40:44:44:44:44:43,dst=50:54:00:00:00:07),eth_type(0x8847),mpls(label=11,tc=3,ttl=64,bos=1)'
1651 done
1652 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
1653 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
1654
1655 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
1656 NXT_PACKET_IN (xid=0x0): cookie=0xa total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
1657 mpls,vlan_tci=0x0000,dl_src=40:44:44:44:44:43,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=3,mpls_ttl=64,mpls_bos=0,mpls_lse1=46912
1658 dnl
1659 NXT_PACKET_IN (xid=0x0): cookie=0xa total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
1660 mpls,vlan_tci=0x0000,dl_src=40:44:44:44:44:43,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=3,mpls_ttl=64,mpls_bos=0,mpls_lse1=46912
1661 dnl
1662 NXT_PACKET_IN (xid=0x0): cookie=0xa total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
1663 mpls,vlan_tci=0x0000,dl_src=40:44:44:44:44:43,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=3,mpls_ttl=64,mpls_bos=0,mpls_lse1=46912
1664 ])
1665
1666 dnl Modified MPLS controller action.
1667 AT_CHECK([ovs-ofctl monitor br0 65534 -P nxm --detach --pidfile 2> ofctl_monitor.log])
1668
1669 for i in 1 2 3; do
1670     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=40:44:44:44:44:44,dst=50:54:00:00:00:07),eth_type(0x8100),vlan(vid=99,pcp=7),encap(eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=16,tos=0,ttl=64,frag=no))'
1671 done
1672 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
1673 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
1674
1675 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
1676 NXT_PACKET_IN (xid=0x0): cookie=0xa total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
1677 mpls,dl_vlan=99,dl_vlan_pcp=7,dl_src=40:44:44:44:44:44,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=3,mpls_ttl=64,mpls_bos=1
1678 dnl
1679 NXT_PACKET_IN (xid=0x0): cookie=0xa total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
1680 mpls,dl_vlan=99,dl_vlan_pcp=7,dl_src=40:44:44:44:44:44,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=3,mpls_ttl=64,mpls_bos=1
1681 dnl
1682 NXT_PACKET_IN (xid=0x0): cookie=0xa total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
1683 mpls,dl_vlan=99,dl_vlan_pcp=7,dl_src=40:44:44:44:44:44,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=3,mpls_ttl=64,mpls_bos=1
1684 ])
1685
1686 dnl Modified MPLS controller action.
1687 AT_CHECK([ovs-ofctl monitor br0 65534 -P nxm --detach --pidfile 2> ofctl_monitor.log])
1688
1689 for i in 1 2 3; do
1690     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=40:44:44:44:44:45,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=16,tos=0,ttl=64,frag=no)'
1691 done
1692 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
1693 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
1694
1695 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
1696 NXT_PACKET_IN (xid=0x0): cookie=0xa total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
1697 mpls,vlan_tci=0x0000,dl_src=40:44:44:44:44:45,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=3,mpls_ttl=63,mpls_bos=1
1698 dnl
1699 NXT_PACKET_IN (xid=0x0): cookie=0xa total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
1700 mpls,vlan_tci=0x0000,dl_src=40:44:44:44:44:45,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=3,mpls_ttl=63,mpls_bos=1
1701 dnl
1702 NXT_PACKET_IN (xid=0x0): cookie=0xa total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
1703 mpls,vlan_tci=0x0000,dl_src=40:44:44:44:44:45,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=3,mpls_ttl=63,mpls_bos=1
1704 ])
1705
1706 dnl Modified MPLS controller action.
1707 AT_CHECK([ovs-ofctl monitor br0 65534 -P nxm --detach --pidfile 2> ofctl_monitor.log])
1708
1709 for i in 1 2 3; do
1710     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=40:44:44:44:44:46,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=16,tos=0,ttl=64,frag=no)'
1711 done
1712 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
1713 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
1714
1715 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
1716 NXT_PACKET_IN (xid=0x0): cookie=0xa total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
1717 mpls,vlan_tci=0x0000,dl_src=40:44:44:44:44:46,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=3,mpls_ttl=10,mpls_bos=1
1718 dnl
1719 NXT_PACKET_IN (xid=0x0): cookie=0xa total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
1720 mpls,vlan_tci=0x0000,dl_src=40:44:44:44:44:46,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=3,mpls_ttl=10,mpls_bos=1
1721 dnl
1722 NXT_PACKET_IN (xid=0x0): cookie=0xa total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
1723 mpls,vlan_tci=0x0000,dl_src=40:44:44:44:44:46,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=3,mpls_ttl=10,mpls_bos=1
1724 ])
1725
1726 dnl Modified MPLS controller action.
1727 AT_CHECK([ovs-ofctl monitor br0 65534 -P nxm --detach --pidfile 2> ofctl_monitor.log])
1728
1729 for i in 1 2 3; do
1730     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=40:44:44:44:44:47,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=16,tos=0,ttl=64,frag=no)'
1731 done
1732 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
1733 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
1734
1735 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
1736 NXT_PACKET_IN (xid=0x0): cookie=0xa total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
1737 mpls,vlan_tci=0x0000,dl_src=40:44:44:44:44:47,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=3,mpls_ttl=10,mpls_bos=1
1738 dnl
1739 NXT_PACKET_IN (xid=0x0): cookie=0xa total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
1740 mpls,vlan_tci=0x0000,dl_src=40:44:44:44:44:47,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=3,mpls_ttl=10,mpls_bos=1
1741 dnl
1742 NXT_PACKET_IN (xid=0x0): cookie=0xa total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
1743 mpls,vlan_tci=0x0000,dl_src=40:44:44:44:44:47,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=3,mpls_ttl=10,mpls_bos=1
1744 ])
1745
1746 AT_CHECK([ovs-appctl time/warp 5000], [0], [ignore])
1747
1748 dnl Modified MPLS controller action.
1749 AT_CHECK([ovs-ofctl monitor br0 65534 -P nxm --detach --pidfile 2> ofctl_monitor.log])
1750
1751 for i in 1 2 3; do
1752     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=40:44:44:44:44:49,dst=50:54:00:00:00:07),eth_type(0x8847),mpls(label=10,tc=3,ttl=64,bos=1)'
1753 done
1754 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
1755 ovs-appctl -t ovs-ofctl exit
1756
1757 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
1758 NXT_PACKET_IN (xid=0x0): cookie=0xa total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
1759 mplsm,vlan_tci=0x0000,dl_src=40:44:44:44:44:49,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=3,mpls_ttl=64,mpls_bos=0,mpls_lse1=42816
1760 dnl
1761 NXT_PACKET_IN (xid=0x0): cookie=0xa total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
1762 mplsm,vlan_tci=0x0000,dl_src=40:44:44:44:44:49,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=3,mpls_ttl=64,mpls_bos=0,mpls_lse1=42816
1763 dnl
1764 NXT_PACKET_IN (xid=0x0): cookie=0xa total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
1765 mplsm,vlan_tci=0x0000,dl_src=40:44:44:44:44:49,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=3,mpls_ttl=64,mpls_bos=0,mpls_lse1=42816
1766 ])
1767
1768 AT_CHECK([ovs-appctl time/warp 5000], [0], [ignore])
1769
1770 dnl Modified MPLS controller action.
1771 AT_CHECK([ovs-ofctl monitor br0 65534 -P nxm --detach --pidfile 2> ofctl_monitor.log])
1772
1773 for i in 1 2 3; do
1774     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=40:44:44:44:44:48,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=16,tos=0,ttl=64,frag=no)'
1775 done
1776 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
1777 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
1778
1779 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
1780 NXT_PACKET_IN (xid=0x0): cookie=0xa total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
1781 mpls,vlan_tci=0x0000,dl_src=40:44:44:44:44:48,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=3,mpls_ttl=9,mpls_bos=1
1782 dnl
1783 NXT_PACKET_IN (xid=0x0): cookie=0xa total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
1784 mpls,vlan_tci=0x0000,dl_src=40:44:44:44:44:48,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=3,mpls_ttl=9,mpls_bos=1
1785 dnl
1786 NXT_PACKET_IN (xid=0x0): cookie=0xa total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
1787 mpls,vlan_tci=0x0000,dl_src=40:44:44:44:44:48,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=3,mpls_ttl=9,mpls_bos=1
1788 ])
1789
1790 dnl Modified MPLS actions.
1791 AT_CHECK([ovs-ofctl monitor br0 65534 -P nxm --detach --pidfile 2> ofctl_monitor.log])
1792
1793 for i in 1 2 3; do
1794     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:55:55:55:55:55,dst=50:54:00:00:00:07),eth_type(0x8847),mpls(label=100,tc=7,ttl=64,bos=1)'
1795 done
1796 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
1797 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
1798
1799 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
1800 NXT_PACKET_IN (xid=0x0): cookie=0xb total_len=60 in_port=1 (via action) data_len=60 (unbuffered)
1801 mpls,vlan_tci=0x0000,dl_src=50:55:55:55:55:55,dl_dst=50:54:00:00:00:07,mpls_label=1000,mpls_tc=7,mpls_ttl=64,mpls_bos=1
1802 dnl
1803 NXT_PACKET_IN (xid=0x0): cookie=0xb total_len=60 in_port=1 (via action) data_len=60 (unbuffered)
1804 mpls,vlan_tci=0x0000,dl_src=50:55:55:55:55:55,dl_dst=50:54:00:00:00:07,mpls_label=1000,mpls_tc=7,mpls_ttl=64,mpls_bos=1
1805 dnl
1806 NXT_PACKET_IN (xid=0x0): cookie=0xb total_len=60 in_port=1 (via action) data_len=60 (unbuffered)
1807 mpls,vlan_tci=0x0000,dl_src=50:55:55:55:55:55,dl_dst=50:54:00:00:00:07,mpls_label=1000,mpls_tc=7,mpls_ttl=64,mpls_bos=1
1808 ])
1809
1810 dnl Modified MPLS ipv6 controller action.
1811 AT_CHECK([ovs-ofctl monitor br0 65534 -P nxm --detach --pidfile 2> ofctl_monitor.log])
1812
1813 for i in 1 2 3; do
1814     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=70:77:77:77:77:77,dst=50:54:00:00:00:07),eth_type(0x86dd),ipv6(src=::1,dst=::2,label=0,proto=10,tclass=0x70,hlimit=128,frag=no)'
1815 done
1816 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
1817 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
1818
1819 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
1820 NXT_PACKET_IN (xid=0x0): cookie=0xc total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
1821 mplsm,vlan_tci=0x0000,dl_src=70:77:77:77:77:77,dl_dst=50:54:00:00:00:07,mpls_label=1000,mpls_tc=7,mpls_ttl=128,mpls_bos=1
1822 dnl
1823 NXT_PACKET_IN (xid=0x0): cookie=0xc total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
1824 mplsm,vlan_tci=0x0000,dl_src=70:77:77:77:77:77,dl_dst=50:54:00:00:00:07,mpls_label=1000,mpls_tc=7,mpls_ttl=128,mpls_bos=1
1825 dnl
1826 NXT_PACKET_IN (xid=0x0): cookie=0xc total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
1827 mplsm,vlan_tci=0x0000,dl_src=70:77:77:77:77:77,dl_dst=50:54:00:00:00:07,mpls_label=1000,mpls_tc=7,mpls_ttl=128,mpls_bos=1
1828 ])
1829
1830
1831 dnl Modified MPLS pop action.
1832 dnl The input is a frame with two MPLS headers which tcpdump -vve shows as:
1833 dnl 60:66:66:66:66:66 > 50:54:00:00:00:07, ethertype MPLS multicast (0x8847), length 66: MPLS (label 20, exp 0, ttl 32)
1834 dnl             (tos 0x0, ttl 64, id 0, offset 0, flags [none], proto TCP (6), length 44)
1835
1836 AT_CHECK([ovs-ofctl monitor br0 65534 -P nxm --detach --pidfile 2> ofctl_monitor.log])
1837
1838 for i in 1 2 3; do
1839     ovs-appctl netdev-dummy/receive p1 '50 54 00 00 00 07 60 66 66 66 66 66 88 47 00 01 41 20 45 00 00 2c 00 00 00 00 40 06 3b 78 c0 a8 00 01 c0 a8 00 02 00 50 00 00 00 00 00 2a 00 00 00 2a 50 00 27 10 77 44 00 00 48 4f 47 45'
1840 done
1841 #for i in 2 3; do
1842 #    ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=60:66:66:66:66:66,dst=50:54:00:00:00:07),eth_type(0x8847),mpls(label=10,tc=3,ttl=100,bos=1)'
1843 #done
1844 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
1845 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
1846
1847 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
1848 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=58 in_port=1 (via action) data_len=58 (unbuffered)
1849 tcp,vlan_tci=0x0000,dl_src=60:66:66:66:66:66,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=80,tp_dst=0,tcp_flags=0 tcp_csum:7744
1850 dnl
1851 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=58 in_port=1 (via action) data_len=58 (unbuffered)
1852 tcp,vlan_tci=0x0000,dl_src=60:66:66:66:66:66,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=80,tp_dst=0,tcp_flags=0 tcp_csum:7744
1853 dnl
1854 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=58 in_port=1 (via action) data_len=58 (unbuffered)
1855 tcp,vlan_tci=0x0000,dl_src=60:66:66:66:66:66,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=80,tp_dst=0,tcp_flags=0 tcp_csum:7744
1856 ])
1857
1858 AT_CHECK([ovs-appctl time/warp 5000], [0], [ignore])
1859
1860 dnl Modified MPLS pop action.
1861 dnl The input is a frame with a single MPLS label stack entry which tcpdump -vve shows as:
1862 dnl 60:66:66:66:00:01 > 50:54:00:00:00:07, ethertype MPLS multicast (0x8848), length 62: MPLS (label 20, exp 0, [S], ttl 32)
1863 dnl             (tos 0x0, ttl 255, id 0, offset 0, flags [none], proto TCP (6), length 44)
1864 dnl         192.168.0.1.80 > 192.168.0.2.0: Flags [none], cksum 0x77ec (correct), seq 42:46, win 10000, length 4
1865 AT_CHECK([ovs-ofctl monitor br0 65534 -P nxm --detach --pidfile 2> ofctl_monitor.log])
1866
1867 for i in 1 2 3; do
1868     ovs-appctl netdev-dummy/receive p1 '50 54 00 00 00 07 60 66 66 66 00 01 88 48 00 01 41 20 45 00 00 2c 00 00 00 00 ff 06 3a 78 c0 a8 00 01 c0 a8 00 02 00 50 00 00 00 00 00 2a 00 00 00 2a 50 00 27 10 77 44 00 00 48 4f 47 45'
1869 done
1870 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
1871 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
1872
1873 AT_CHECK([STRIP_METADATA ofctl_monitor.log], [0], [dnl
1874 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=58 in_port=1 (via action) data_len=58 (unbuffered)
1875 tcp,vlan_tci=0x0000,dl_src=60:66:66:66:00:01,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=254,tp_src=80,tp_dst=0,tcp_flags=0 tcp_csum:7744
1876 dnl
1877 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=58 in_port=1 (via action) data_len=58 (unbuffered)
1878 tcp,vlan_tci=0x0000,dl_src=60:66:66:66:00:01,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=254,tp_src=80,tp_dst=0,tcp_flags=0 tcp_csum:7744
1879 dnl
1880 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=58 in_port=1 (via action) data_len=58 (unbuffered)
1881 tcp,vlan_tci=0x0000,dl_src=60:66:66:66:00:01,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=254,tp_src=80,tp_dst=0,tcp_flags=0 tcp_csum:7744
1882 ])
1883
1884 AT_CHECK([ovs-appctl time/warp 5000], [0], [ignore])
1885
1886 dnl Modified MPLS pop action.
1887 dnl The input is a frame with a single MPLS label stack entry which tcpdump -vve shows as:
1888 dnl 60:66:66:66:00:02 > 50:54:00:00:00:07, ethertype MPLS unicast (0x8847), length 62: MPLS (label 20, exp 0, [S], ttl 32)
1889 dnl             (tos 0x0, ttl 255, id 0, offset 0, flags [none], proto TCP (6), length 44)
1890 dnl         192.168.0.1.80 > 192.168.0.2.0: Flags [none], cksum 0x77ec (correct), seq 42:46, win 10000, length 4
1891 AT_CHECK([ovs-ofctl monitor br0 65534 -P nxm --detach --pidfile 2> ofctl_monitor.log])
1892
1893 for i in 1 2 3; do
1894     ovs-appctl netdev-dummy/receive p1 '50 54 00 00 00 07 60 66 66 66 00 02 88 47 00 01 41 20 45 00 00 2c 00 00 00 00 ff 06 3a 78 c0 a8 00 01 c0 a8 00 02 00 50 00 00 00 00 00 2a 00 00 00 2a 50 00 27 10 77 44 00 00 48 4f 47 45'
1895 done
1896 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
1897 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
1898
1899 AT_CHECK([STRIP_METADATA ofctl_monitor.log], [0], [dnl
1900 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=58 in_port=1 (via action) data_len=58 (unbuffered)
1901 tcp,vlan_tci=0x0000,dl_src=60:66:66:66:00:02,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=10.0.0.1,nw_tos=0,nw_ecn=0,nw_ttl=255,tp_src=80,tp_dst=0,tcp_flags=0 tcp_csum:2dee
1902 dnl
1903 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=58 in_port=1 (via action) data_len=58 (unbuffered)
1904 tcp,vlan_tci=0x0000,dl_src=60:66:66:66:00:02,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=10.0.0.1,nw_tos=0,nw_ecn=0,nw_ttl=255,tp_src=80,tp_dst=0,tcp_flags=0 tcp_csum:2dee
1905 dnl
1906 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=58 in_port=1 (via action) data_len=58 (unbuffered)
1907 tcp,vlan_tci=0x0000,dl_src=60:66:66:66:00:02,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=10.0.0.1,nw_tos=0,nw_ecn=0,nw_ttl=255,tp_src=80,tp_dst=0,tcp_flags=0 tcp_csum:2dee
1908 ])
1909
1910 AT_CHECK([ovs-appctl time/warp 5000], [0], [ignore])
1911
1912 dnl Modified MPLS pop action.
1913 dnl The input is a frame with a single MPLS label stack entry which tcpdump -vve shows as:
1914 dnl 60:66:66:66:00:03 > 50:54:00:00:00:07, ethertype MPLS multicast (0x8848), length 62: MPLS (label 20, exp 0, [S], ttl 32)
1915 dnl             (tos 0x0, ttl 255, id 0, offset 0, flags [none], proto TCP (6), length 44)
1916 dnl         192.168.0.1.80 > 192.168.0.2.0: Flags [none], cksum 0x77ec (correct), seq 42:46, win 10000, length 4
1917 AT_CHECK([ovs-ofctl monitor br0 65534 -P nxm --detach --pidfile 2> ofctl_monitor.log])
1918
1919 for i in 1 2 3; do
1920     ovs-appctl netdev-dummy/receive p1 '50 54 00 00 00 07 60 66 66 66 00 03 88 48 00 01 41 20 45 00 00 2c 00 00 00 00 ff 06 3a 78 c0 a8 00 01 c0 a8 00 02 00 50 00 00 00 00 00 2a 00 00 00 2a 50 00 27 10 77 44 00 00 48 4f 47 45'
1921 done
1922 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
1923 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
1924
1925 AT_CHECK([STRIP_METADATA ofctl_monitor.log], [0], [dnl
1926 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=58 in_port=1 (via action) data_len=58 (unbuffered)
1927 tcp,vlan_tci=0x0000,dl_src=60:66:66:66:00:03,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.2,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=255,tp_src=80,tp_dst=0,tcp_flags=0 tcp_csum:7743
1928 dnl
1929 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=58 in_port=1 (via action) data_len=58 (unbuffered)
1930 tcp,vlan_tci=0x0000,dl_src=60:66:66:66:00:03,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.2,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=255,tp_src=80,tp_dst=0,tcp_flags=0 tcp_csum:7743
1931 dnl
1932 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=58 in_port=1 (via action) data_len=58 (unbuffered)
1933 tcp,vlan_tci=0x0000,dl_src=60:66:66:66:00:03,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.2,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=255,tp_src=80,tp_dst=0,tcp_flags=0 tcp_csum:7743
1934 ])
1935
1936 AT_CHECK([ovs-appctl time/warp 5000], [0], [ignore])
1937
1938 dnl Modified MPLS pop action.
1939 dnl The input is a frame with a single MPLS label stack entry which tcpdump -vve shows as:
1940 dnl 60:66:66:66:00:04 > 50:54:00:00:00:07, ethertype MPLS unicast (0x8847), length 62: MPLS (label 20, exp 0, [S], ttl 32)
1941 dnl             (tos 0x0, ttl 255, id 0, offset 0, flags [none], proto TCP (6), length 44)
1942 dnl         192.168.0.1.80 > 192.168.0.2.0: Flags [none], cksum 0x77ec (correct), seq 42:46, win 10000, length 4
1943 AT_CHECK([ovs-ofctl monitor br0 65534 -P nxm --detach --pidfile 2> ofctl_monitor.log])
1944
1945 for i in 1 2 3; do
1946     ovs-appctl netdev-dummy/receive p1 '50 54 00 00 00 07 60 66 66 66 00 04 88 47 00 01 41 20 45 00 00 2c 00 00 00 00 ff 06 3a 78 c0 a8 00 01 c0 a8 00 02 00 50 00 00 00 00 00 2a 00 00 00 2a 50 00 27 10 77 44 00 00 48 4f 47 45'
1947 done
1948 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
1949 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
1950
1951 AT_CHECK([STRIP_METADATA ofctl_monitor.log], [0], [dnl
1952 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=58 in_port=1 (via action) data_len=58 (unbuffered)
1953 tcp,vlan_tci=0x0000,dl_src=60:66:66:66:00:04,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.2,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=255,tp_src=80,tp_dst=0,tcp_flags=0 tcp_csum:7743
1954 dnl
1955 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=58 in_port=1 (via action) data_len=58 (unbuffered)
1956 tcp,vlan_tci=0x0000,dl_src=60:66:66:66:00:04,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.2,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=255,tp_src=80,tp_dst=0,tcp_flags=0 tcp_csum:7743
1957 dnl
1958 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=58 in_port=1 (via action) data_len=58 (unbuffered)
1959 tcp,vlan_tci=0x0000,dl_src=60:66:66:66:00:04,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.2,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=255,tp_src=80,tp_dst=0,tcp_flags=0 tcp_csum:7743
1960 ])
1961
1962 AT_CHECK([ovs-appctl time/warp 5000], [0], [ignore])
1963
1964 dnl Modified MPLS pop action.
1965 dnl The input is a frame with a single MPLS label stack entry which tcpdump -vve shows as:
1966 dnl 60:66:66:66:00:05 > 50:54:00:00:00:07, ethertype MPLS unicast (0x8847), length 62: MPLS (label 20, exp 0, [S], ttl 32)
1967 dnl             (tos 0x0, ttl 255, id 0, offset 0, flags [none], proto TCP (6), length 44)
1968 dnl         192.168.0.1.80 > 192.168.0.2.0: Flags [none], cksum 0x77ec (correct), seq 42:46, win 10000, length 4
1969 AT_CHECK([ovs-ofctl monitor br0 65534 -P nxm --detach --pidfile 2> ofctl_monitor.log])
1970
1971 for i in 1 2 3; do
1972     ovs-appctl netdev-dummy/receive p1 '50 54 00 00 00 07 60 66 66 66 00 05 88 48 00 01 41 20 45 00 00 2c 00 00 00 00 ff 06 3a 78 c0 a8 00 01 c0 a8 00 02 00 50 00 00 00 00 00 2a 00 00 00 2a 50 00 27 10 77 44 00 00 48 4f 47 45'
1973 done
1974 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
1975 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
1976
1977 AT_CHECK([STRIP_METADATA ofctl_monitor.log], [0], [dnl
1978 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=58 in_port=1 (via action) data_len=58 (unbuffered)
1979 tcp,vlan_tci=0x0000,dl_src=60:66:66:66:00:05,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.106,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=255,tp_src=80,tp_dst=0,tcp_flags=0 tcp_csum:76db
1980 dnl
1981 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=58 in_port=1 (via action) data_len=58 (unbuffered)
1982 tcp,vlan_tci=0x0000,dl_src=60:66:66:66:00:05,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.106,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=255,tp_src=80,tp_dst=0,tcp_flags=0 tcp_csum:76db
1983 dnl
1984 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=58 in_port=1 (via action) data_len=58 (unbuffered)
1985 tcp,vlan_tci=0x0000,dl_src=60:66:66:66:00:05,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.106,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=255,tp_src=80,tp_dst=0,tcp_flags=0 tcp_csum:76db
1986 ])
1987
1988 AT_CHECK([ovs-appctl time/warp 5000], [0], [ignore])
1989
1990 dnl Modified MPLS pop action.
1991 dnl The input is a frame with a single MPLS label stack entry which tcpdump -vve shows as:
1992 dnl 60:66:66:66:00:06 > 50:54:00:00:00:07, ethertype MPLS multicast (0x8848), length 62: MPLS (label 20, exp 0, [S], ttl 32)
1993 dnl             (tos 0x0, ttl 255, id 0, offset 0, flags [none], proto TCP (6), length 44)
1994 dnl         192.168.0.1.80 > 192.168.0.2.0: Flags [none], cksum 0x77ec (correct), seq 42:46, win 10000, length 4
1995 AT_CHECK([ovs-ofctl monitor br0 65534 -P nxm --detach --pidfile 2> ofctl_monitor.log])
1996
1997 for i in 1 2 3; do
1998     ovs-appctl netdev-dummy/receive p1 '50 54 00 00 00 07 60 66 66 66 00 06 88 47 00 01 41 20 45 00 00 2c 00 00 00 00 ff 06 3a 78 c0 a8 00 01 c0 a8 00 02 00 50 00 00 00 00 00 2a 00 00 00 2a 50 00 27 10 77 44 00 00 48 4f 47 45'
1999 done
2000 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
2001 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
2002
2003 AT_CHECK([STRIP_METADATA ofctl_monitor.log], [0], [dnl
2004 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=58 in_port=1 (via action) data_len=58 (unbuffered)
2005 tcp,vlan_tci=0x0000,dl_src=60:66:66:66:00:06,dl_dst=50:54:00:00:00:07,nw_src=192.168.255.255,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=255,tp_src=80,tp_dst=0,tcp_flags=0 tcp_csum:7745
2006 dnl
2007 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=58 in_port=1 (via action) data_len=58 (unbuffered)
2008 tcp,vlan_tci=0x0000,dl_src=60:66:66:66:00:06,dl_dst=50:54:00:00:00:07,nw_src=192.168.255.255,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=255,tp_src=80,tp_dst=0,tcp_flags=0 tcp_csum:7745
2009 dnl
2010 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=58 in_port=1 (via action) data_len=58 (unbuffered)
2011 tcp,vlan_tci=0x0000,dl_src=60:66:66:66:00:06,dl_dst=50:54:00:00:00:07,nw_src=192.168.255.255,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=255,tp_src=80,tp_dst=0,tcp_flags=0 tcp_csum:7745
2012 ])
2013
2014 AT_CHECK([ovs-appctl time/warp 5000], [0], [ignore])
2015
2016 dnl Modified MPLS pop action.
2017 dnl The input is a frame with a single MPLS label stack entry which tcpdump -vve shows as:
2018 dnl 60:66:66:66:00:07 > 50:54:00:00:00:07, ethertype MPLS multicast (0x8848), length 62: MPLS (label 20, exp 0, [S], ttl 32)
2019 dnl             (tos 0x0, ttl 255, id 0, offset 0, flags [none], proto TCP (6), length 44)
2020 dnl         192.168.0.1.80 > 192.168.0.2.0: Flags [none], cksum 0x77ec (correct), seq 42:46, win 10000, length 4
2021 AT_CHECK([ovs-ofctl monitor br0 65534 -P nxm --detach --pidfile 2> ofctl_monitor.log])
2022
2023 for i in 1 2 3; do
2024     ovs-appctl netdev-dummy/receive p1 '50 54 00 00 00 07 60 66 66 66 00 07 88 48 00 01 41 20 45 00 00 2c 00 00 00 00 ff 06 3a 78 c0 a8 00 01 c0 a8 00 02 00 50 00 00 00 00 00 2a 00 00 00 2a 50 00 27 10 77 44 00 00 48 4f 47 45'
2025 done
2026 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
2027 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
2028
2029 AT_CHECK([STRIP_METADATA ofctl_monitor.log], [0], [dnl
2030 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=58 in_port=1 (via action) data_len=58 (unbuffered)
2031 tcp,vlan_tci=0x0000,dl_src=60:66:66:66:00:07,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=255,tp_src=80,tp_dst=0,tcp_flags=0 tcp_csum:7744
2032 dnl
2033 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=58 in_port=1 (via action) data_len=58 (unbuffered)
2034 tcp,vlan_tci=0x0000,dl_src=60:66:66:66:00:07,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=255,tp_src=80,tp_dst=0,tcp_flags=0 tcp_csum:7744
2035 dnl
2036 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=58 in_port=1 (via action) data_len=58 (unbuffered)
2037 tcp,vlan_tci=0x0000,dl_src=60:66:66:66:00:07,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=255,tp_src=80,tp_dst=0,tcp_flags=0 tcp_csum:7744
2038 ])
2039
2040 AT_CHECK([ovs-appctl time/warp 5000], [0], [ignore])
2041
2042 dnl Modified MPLS pop action.
2043 dnl The input is an ARP frame with a single MPLS label stack entry which tcpdump -vve shows as:
2044 dnl 60:66:66:66:00:08 > ff:ff:ff:ff:ff:ff, ethertype MPLS unicast (0x8847), length 46: MPLS (label 20, exp 0, [S], ttl 32)
2045 AT_CHECK([ovs-ofctl monitor br0 65534 -P nxm --detach --pidfile 2> ofctl_monitor.log])
2046
2047 for i in 1 2 3; do
2048     ovs-appctl netdev-dummy/receive p1 'ff ff ff ff ff ff 60 66 66 66 00 08 88 47 00 01 41 20 00 01 08 00 06 04 00 02 60 66 66 66 00 08 c0 a8 00 01 ff ff ff ff ff ff ff ff ff ff'
2049 done
2050 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
2051 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
2052
2053 AT_CHECK([STRIP_METADATA ofctl_monitor.log], [0], [dnl
2054 NXT_PACKET_IN (xid=0x0): table_id=1 cookie=0xd total_len=56 in_port=1 (via action) data_len=56 (unbuffered)
2055 arp,vlan_tci=0x0000,dl_src=60:66:66:66:00:08,dl_dst=ff:ff:ff:ff:ff:ff,arp_spa=192.168.0.1,arp_tpa=255.255.255.255,arp_op=2,arp_sha=60:66:66:66:00:08,arp_tha=ff:ff:ff:ff:ff:ff
2056 dnl
2057 NXT_PACKET_IN (xid=0x0): table_id=1 cookie=0xd total_len=56 in_port=1 (via action) data_len=56 (unbuffered)
2058 arp,vlan_tci=0x0000,dl_src=60:66:66:66:00:08,dl_dst=ff:ff:ff:ff:ff:ff,arp_spa=192.168.0.1,arp_tpa=255.255.255.255,arp_op=2,arp_sha=60:66:66:66:00:08,arp_tha=ff:ff:ff:ff:ff:ff
2059 dnl
2060 NXT_PACKET_IN (xid=0x0): table_id=1 cookie=0xd total_len=56 in_port=1 (via action) data_len=56 (unbuffered)
2061 arp,vlan_tci=0x0000,dl_src=60:66:66:66:00:08,dl_dst=ff:ff:ff:ff:ff:ff,arp_spa=192.168.0.1,arp_tpa=255.255.255.255,arp_op=2,arp_sha=60:66:66:66:00:08,arp_tha=ff:ff:ff:ff:ff:ff
2062 ])
2063
2064 AT_CHECK([ovs-appctl time/warp 5000], [0], [ignore])
2065
2066 dnl Modified MPLS pop action.
2067 dnl The input is a frame with a single MPLS label stack entry which tcpdump -vve shows as:
2068 dnl 60:66:66:66:00:09 > 50:54:00:00:00:07, ethertype MPLS multicast (0x8848), length 62: MPLS (label 20, exp 0, [S], ttl 32)
2069 dnl             (tos 0x0, ttl 255, id 0, offset 0, flags [none], proto TCP (6), length 44)
2070 dnl         192.168.0.1.80 > 192.168.0.2.0: Flags [none], cksum 0x77ec (correct), seq 42:46, win 10000, length 4
2071 AT_CHECK([ovs-ofctl monitor br0 65534 -P nxm --detach --pidfile 2> ofctl_monitor.log])
2072
2073 for i in 1 2 3; do
2074     ovs-appctl netdev-dummy/receive p1 '50 54 00 00 00 07 60 66 66 66 00 09 88 48 00 01 41 20 45 00 00 2c 00 00 00 00 ff 06 3a 78 c0 a8 00 01 c0 a8 00 02 00 50 00 00 00 00 00 2a 00 00 00 2a 50 00 27 10 77 44 00 00 48 4f 47 45'
2075 done
2076 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
2077 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
2078
2079 AT_CHECK([STRIP_METADATA ofctl_monitor.log], [0], [dnl
2080 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=58 in_port=1 (via action) data_len=58 (unbuffered)
2081 tcp,vlan_tci=0x0000,dl_src=60:66:66:66:00:09,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=48,nw_ecn=0,nw_ttl=255,tp_src=80,tp_dst=0,tcp_flags=0 tcp_csum:7744
2082 dnl
2083 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=58 in_port=1 (via action) data_len=58 (unbuffered)
2084 tcp,vlan_tci=0x0000,dl_src=60:66:66:66:00:09,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=48,nw_ecn=0,nw_ttl=255,tp_src=80,tp_dst=0,tcp_flags=0 tcp_csum:7744
2085 dnl
2086 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=58 in_port=1 (via action) data_len=58 (unbuffered)
2087 tcp,vlan_tci=0x0000,dl_src=60:66:66:66:00:09,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=48,nw_ecn=0,nw_ttl=255,tp_src=80,tp_dst=0,tcp_flags=0 tcp_csum:7744
2088 ])
2089
2090 AT_CHECK([ovs-appctl time/warp 5000], [0], [ignore])
2091
2092 dnl Modified MPLS pop action.
2093 dnl The input is a frame with a single MPLS label stack entry which tcpdump -vve shows as:
2094 dnl 60:66:66:66:00:0a > 50:54:00:00:00:07, ethertype MPLS multicast (0x8848), length 62: MPLS (label 20, exp 0, [S], ttl 32)
2095 dnl             (tos 0x0, ttl 255, id 0, offset 0, flags [none], proto TCP (6), length 44)
2096 dnl         192.168.0.1.80 > 192.168.0.2.0: Flags [none], cksum 0x77ec (correct), seq 42:46, win 10000, length 4
2097 AT_CHECK([ovs-ofctl monitor br0 65534 -P nxm --detach --pidfile 2> ofctl_monitor.log])
2098
2099 for i in 1 2 3; do
2100     ovs-appctl netdev-dummy/receive p1 '50 54 00 00 00 07 60 66 66 66 00 0a 88 48 00 01 41 20 45 00 00 2c 00 00 00 00 ff 06 3a 78 c0 a8 00 01 c0 a8 00 02 00 50 00 00 00 00 00 2a 00 00 00 2a 50 00 27 10 77 44 00 00 48 4f 47 45'
2101 done
2102 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
2103 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
2104
2105 AT_CHECK([STRIP_METADATA ofctl_monitor.log], [0], [dnl
2106 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=58 in_port=1 (via action) data_len=58 (unbuffered)
2107 tcp,vlan_tci=0x0000,dl_src=60:66:66:66:00:0a,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=10.0.0.1,nw_tos=0,nw_ecn=0,nw_ttl=255,tp_src=80,tp_dst=0,tcp_flags=0 tcp_csum:2dee
2108 dnl
2109 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=58 in_port=1 (via action) data_len=58 (unbuffered)
2110 tcp,vlan_tci=0x0000,dl_src=60:66:66:66:00:0a,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=10.0.0.1,nw_tos=0,nw_ecn=0,nw_ttl=255,tp_src=80,tp_dst=0,tcp_flags=0 tcp_csum:2dee
2111 dnl
2112 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=58 in_port=1 (via action) data_len=58 (unbuffered)
2113 tcp,vlan_tci=0x0000,dl_src=60:66:66:66:00:0a,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=10.0.0.1,nw_tos=0,nw_ecn=0,nw_ttl=255,tp_src=80,tp_dst=0,tcp_flags=0 tcp_csum:2dee
2114 ])
2115
2116 AT_CHECK([ovs-appctl time/warp 5000], [0], [ignore])
2117
2118 dnl Modified MPLS pop action.
2119 dnl The input is a frame with a single MPLS label stack entry which tcpdump -vve shows as:
2120 dnl 60:66:66:66:00:0b > 50:54:00:00:00:07, ethertype MPLS multicast (0x8848), length 62: MPLS (label 20, exp 0, [S], ttl 32)
2121 dnl             (tos 0x0, ttl 255, id 0, offset 0, flags [none], proto TCP (6), length 44)
2122 dnl         192.168.0.1.80 > 192.168.0.2.0: Flags [none], cksum 0x77ec (correct), seq 42:46, win 10000, length 4
2123 AT_CHECK([ovs-ofctl monitor br0 65534 -P nxm --detach --pidfile 2> ofctl_monitor.log])
2124
2125 for i in 1 2 3; do
2126     ovs-appctl netdev-dummy/receive p1 '50 54 00 00 00 07 60 66 66 66 00 0b 88 48 00 01 41 20 45 00 00 2c 00 00 00 00 ff 06 3a 78 c0 a8 00 01 c0 a8 00 02 00 50 00 00 00 00 00 2a 00 00 00 2a 50 00 27 10 77 44 00 00 48 4f 47 45'
2127 done
2128 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
2129 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
2130
2131 AT_CHECK([STRIP_METADATA ofctl_monitor.log], [0], [dnl
2132 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=58 in_port=1 (via action) data_len=58 (unbuffered)
2133 tcp,vlan_tci=0x0000,dl_src=60:66:66:66:00:0b,dl_dst=50:54:00:00:00:07,nw_src=10.0.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=255,tp_src=80,tp_dst=0,tcp_flags=0 tcp_csum:2ded
2134 dnl
2135 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=58 in_port=1 (via action) data_len=58 (unbuffered)
2136 tcp,vlan_tci=0x0000,dl_src=60:66:66:66:00:0b,dl_dst=50:54:00:00:00:07,nw_src=10.0.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=255,tp_src=80,tp_dst=0,tcp_flags=0 tcp_csum:2ded
2137 dnl
2138 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=58 in_port=1 (via action) data_len=58 (unbuffered)
2139 tcp,vlan_tci=0x0000,dl_src=60:66:66:66:00:0b,dl_dst=50:54:00:00:00:07,nw_src=10.0.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=255,tp_src=80,tp_dst=0,tcp_flags=0 tcp_csum:2ded
2140 ])
2141
2142 AT_CHECK([ovs-appctl time/warp 5000], [0], [ignore])
2143
2144 dnl Modified MPLS pop action.
2145 dnl The input is a frame with two MPLS label stack entries which tcpdump -vve shows as:
2146 dnl 60:66:66:66:01:00 > 50:54:00:00:00:07, ethertype MPLS multicast (0x8848), length 66: MPLS (label 20, exp 0, ttl 32)
2147 dnl             (label 20, exp 0, [S], ttl 31)
2148 dnl             (tos 0x0, ttl 254, id 0, offset 0, flags [none], proto TCP (6), length 44)
2149 dnl        192.168.0.1.80 > 192.168.0.2.0: Flags [none], cksum 0x7744 (correct), seq 42:46, win 10000, length 4
2150 AT_CHECK([ovs-ofctl monitor br0 65534 -P nxm --detach --pidfile 2> ofctl_monitor.log])
2151
2152 for i in 1 2 3; do
2153     ovs-appctl netdev-dummy/receive p1 '50 54 00 00 00 07 60 66 66 66 01 00 88 48 00 01 40 20 00 01 41 1f 45 00 00 2c 00 00 00 00 ff 06 3b 78 c0 a8 00 01 c0 a8 00 02 00 50 00 00 00 00 00 2a 00 00 00 2a 50 00 27 10 77 44 00 00 48 4f 47 45'
2154 done
2155 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
2156 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
2157
2158 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
2159 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=62 in_port=1 (via action) data_len=62 (unbuffered)
2160 mplsm,vlan_tci=0x0000,dl_src=60:66:66:66:01:00,dl_dst=50:54:00:00:00:07,mpls_label=20,mpls_tc=0,mpls_ttl=31,mpls_bos=1
2161 dnl
2162 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=62 in_port=1 (via action) data_len=62 (unbuffered)
2163 mplsm,vlan_tci=0x0000,dl_src=60:66:66:66:01:00,dl_dst=50:54:00:00:00:07,mpls_label=20,mpls_tc=0,mpls_ttl=31,mpls_bos=1
2164 dnl
2165 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=62 in_port=1 (via action) data_len=62 (unbuffered)
2166 mplsm,vlan_tci=0x0000,dl_src=60:66:66:66:01:00,dl_dst=50:54:00:00:00:07,mpls_label=20,mpls_tc=0,mpls_ttl=31,mpls_bos=1
2167 ])
2168
2169 AT_CHECK([ovs-appctl time/warp 5000], [0], [ignore])
2170
2171 dnl Modified MPLS pop action.
2172 dnl The input is a frame with two MPLS label stack entries which tcpdump -vve shows as:
2173 dnl 60:66:66:66:01:01 > 50:54:00:00:00:07, ethertype MPLS unicast (0x8847), length 66: MPLS (label 20, exp 0, ttl 32)
2174 dnl             (label 20, exp 0, [S], ttl 31)
2175 dnl             (tos 0x0, ttl 254, id 0, offset 0, flags [none], proto TCP (6), length 44)
2176 dnl        192.168.0.1.80 > 192.168.0.2.0: Flags [none], cksum 0x7744 (correct), seq 42:46, win 10000, length 4
2177 AT_CHECK([ovs-ofctl monitor br0 65534 -P nxm --detach --pidfile 2> ofctl_monitor.log])
2178
2179 for i in 1 2 3; do
2180     ovs-appctl netdev-dummy/receive p1 '50 54 00 00 00 07 60 66 66 66 01 01 88 47 00 01 40 20 00 01 41 1f 45 00 00 2c 00 00 00 00 ff 06 3b 78 c0 a8 00 01 c0 a8 00 02 00 50 00 00 00 00 00 2a 00 00 00 2a 50 00 27 10 77 44 00 00 48 4f 47 45'
2181 done
2182 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
2183 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
2184
2185 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
2186 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=62 in_port=1 (via action) data_len=62 (unbuffered)
2187 mpls,vlan_tci=0x0000,dl_src=60:66:66:66:01:01,dl_dst=50:54:00:00:00:07,mpls_label=20,mpls_tc=0,mpls_ttl=30,mpls_bos=1
2188 dnl
2189 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=62 in_port=1 (via action) data_len=62 (unbuffered)
2190 mpls,vlan_tci=0x0000,dl_src=60:66:66:66:01:01,dl_dst=50:54:00:00:00:07,mpls_label=20,mpls_tc=0,mpls_ttl=30,mpls_bos=1
2191 dnl
2192 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=62 in_port=1 (via action) data_len=62 (unbuffered)
2193 mpls,vlan_tci=0x0000,dl_src=60:66:66:66:01:01,dl_dst=50:54:00:00:00:07,mpls_label=20,mpls_tc=0,mpls_ttl=30,mpls_bos=1
2194 ])
2195
2196 AT_CHECK([ovs-appctl time/warp 5000], [0], [ignore])
2197
2198 dnl Modified MPLS pop action.
2199 dnl The input is a frame with two MPLS label stack entries which tcpdump -vve shows as:
2200 dnl 60:66:66:66:01:02 > 50:54:00:00:00:07, ethertype MPLS multicast (0x8848), length 66: MPLS (label 20, exp 0, ttl 32)
2201 dnl             (label 20, exp 0, [S], ttl 31)
2202 dnl             (tos 0x0, ttl 254, id 0, offset 0, flags [none], proto TCP (6), length 44)
2203 dnl        192.168.0.1.80 > 192.168.0.2.0: Flags [none], cksum 0x7744 (correct), seq 42:46, win 10000, length 4
2204 AT_CHECK([ovs-ofctl monitor br0 65534 -P nxm --detach --pidfile 2> ofctl_monitor.log])
2205
2206 for i in 1 2 3; do
2207     ovs-appctl netdev-dummy/receive p1 '50 54 00 00 00 07 60 66 66 66 01 02 88 48 00 01 40 20 00 01 41 1f 45 00 00 2c 00 00 00 00 ff 06 3b 78 c0 a8 00 01 c0 a8 00 02 00 50 00 00 00 00 00 2a 00 00 00 2a 50 00 27 10 77 44 00 00 48 4f 47 45'
2208 done
2209 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
2210 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
2211
2212 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
2213 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=62 in_port=1 (via action) data_len=62 (unbuffered)
2214 mplsm,vlan_tci=0x0000,dl_src=60:66:66:66:01:02,dl_dst=50:54:00:00:00:07,mpls_label=20,mpls_tc=3,mpls_ttl=31,mpls_bos=1
2215 dnl
2216 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=62 in_port=1 (via action) data_len=62 (unbuffered)
2217 mplsm,vlan_tci=0x0000,dl_src=60:66:66:66:01:02,dl_dst=50:54:00:00:00:07,mpls_label=20,mpls_tc=3,mpls_ttl=31,mpls_bos=1
2218 dnl
2219 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=62 in_port=1 (via action) data_len=62 (unbuffered)
2220 mplsm,vlan_tci=0x0000,dl_src=60:66:66:66:01:02,dl_dst=50:54:00:00:00:07,mpls_label=20,mpls_tc=3,mpls_ttl=31,mpls_bos=1
2221 ])
2222
2223 AT_CHECK([ovs-appctl time/warp 5000], [0], [ignore])
2224
2225 dnl Modified MPLS pop action.
2226 dnl The input is a frame with two MPLS label stack entries which tcpdump -vve shows as:
2227 dnl 60:66:66:66:02:00 > 50:54:00:00:02:00, ethertype MPLS unicast (0x8847), length 66: MPLS (label 20, exp 0, ttl 32)
2228 dnl             (label 20, exp 0, [S], ttl 31)
2229 dnl             (tos 0x0, ttl 254, id 0, offset 0, flags [none], proto TCP (6), length 44)
2230 dnl        192.168.0.1.80 > 192.168.0.2.0: Flags [none], cksum 0x7744 (correct), seq 42:46, win 10000, length 4
2231 AT_CHECK([ovs-ofctl monitor br0 65534 -P nxm --detach --pidfile 2> ofctl_monitor.log])
2232
2233 for i in 1 2 3; do
2234     ovs-appctl netdev-dummy/receive p1 '50 54 00 00 00 07 60 66 66 66 02 00 88 47 00 01 40 20 00 01 41 1f 45 00 00 2c 00 00 00 00 ff 06 3b 78 c0 a8 00 01 c0 a8 00 02 00 50 00 00 00 00 00 2a 00 00 00 2a 50 00 27 10 77 44 00 00 48 4f 47 45'
2235 done
2236 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
2237 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
2238
2239 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
2240 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=58 in_port=1 (via action) data_len=58 (unbuffered)
2241 tcp,vlan_tci=0x0000,dl_src=60:66:66:66:02:00,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=255,tp_src=80,tp_dst=0,tcp_flags=0 tcp_csum:7744
2242 dnl
2243 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=58 in_port=1 (via action) data_len=58 (unbuffered)
2244 tcp,vlan_tci=0x0000,dl_src=60:66:66:66:02:00,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=255,tp_src=80,tp_dst=0,tcp_flags=0 tcp_csum:7744
2245 dnl
2246 NXT_PACKET_IN (xid=0x0): cookie=0xd total_len=58 in_port=1 (via action) data_len=58 (unbuffered)
2247 tcp,vlan_tci=0x0000,dl_src=60:66:66:66:02:00,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=255,tp_src=80,tp_dst=0,tcp_flags=0 tcp_csum:7744
2248 ])
2249
2250 AT_CHECK([ovs-appctl time/warp 5000], [0], [ignore])
2251
2252 dnl Modified MPLS pop action.
2253 dnl The input is a frame with two MPLS label stack entries which tcpdump -vve shows as:
2254 dnl 60:66:66:66:02:01 > 50:54:00:00:02:01, ethertype MPLS multicast (0x8848), length 66: MPLS (label 20, exp 0, ttl 32)
2255 dnl             (label 20, exp 0, [S], ttl 31)
2256 dnl             (tos 0x0, ttl 254, id 0, offset 0, flags [none], proto TCP (6), length 44)
2257 dnl        192.168.0.1.80 > 192.168.0.2.0: Flags [none], cksum 0x7744 (correct), seq 42:46, win 10000, length 4
2258 AT_CHECK([ovs-ofctl monitor br0 65534 -P nxm --detach --pidfile 2> ofctl_monitor.log])
2259
2260 for i in 1 2 3; do
2261     ovs-appctl netdev-dummy/receive p1 '50 54 00 00 00 07 60 66 66 66 02 01 88 48 00 01 40 20 00 01 41 1f 45 00 00 2c 00 00 00 00 ff 06 3b 78 c0 a8 00 01 c0 a8 00 02 00 50 00 00 00 00 00 2a 00 00 00 2a 50 00 27 10 77 44 00 00 48 4f 47 45'
2262 done
2263
2264 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
2265 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
2266
2267 AT_CHECK([STRIP_METADATA ofctl_monitor.log], [0], [dnl
2268 NXT_PACKET_IN (xid=0x0): cookie=0xe total_len=58 in_port=1 (via action) data_len=58 (unbuffered)
2269 tcp,vlan_tci=0x0000,dl_src=60:66:66:66:02:01,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=254,tp_src=80,tp_dst=0,tcp_flags=0 tcp_csum:7744
2270 dnl
2271 NXT_PACKET_IN (xid=0x0): cookie=0xe total_len=58 in_port=1 (via action) data_len=58 (unbuffered)
2272 tcp,vlan_tci=0x0000,dl_src=60:66:66:66:02:01,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=254,tp_src=80,tp_dst=0,tcp_flags=0 tcp_csum:7744
2273 dnl
2274 NXT_PACKET_IN (xid=0x0): cookie=0xe total_len=58 in_port=1 (via action) data_len=58 (unbuffered)
2275 tcp,vlan_tci=0x0000,dl_src=60:66:66:66:02:01,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=254,tp_src=80,tp_dst=0,tcp_flags=0 tcp_csum:7744
2276 ])
2277
2278 AT_CHECK([ovs-appctl time/warp 5000], [0], [ignore])
2279
2280 dnl Modified MPLS pop action.
2281 dnl The input is a frame with two MPLS label stack entries which tcpdump -vve shows as:
2282 dnl 60:66:66:66:02:10 > 50:54:00:00:00:07, ethertype MPLS unicast (0x8847), length 66: MPLS (label 20, exp 0, ttl 32)
2283 dnl             (label 20, exp 0, [S], ttl 31)
2284 dnl             (tos 0x0, ttl 254, id 0, offset 0, flags [none], proto TCP (6), length 44)
2285 dnl        192.168.0.1.80 > 192.168.0.2.0: Flags [none], cksum 0x7744 (correct), seq 42:46, win 10000, length 4
2286 AT_CHECK([ovs-ofctl monitor br0 65534 -P nxm --detach --pidfile 2> ofctl_monitor.log])
2287
2288 for i in 1 2 3; do
2289     ovs-appctl netdev-dummy/receive p1 '50 54 00 00 00 07 60 66 66 66 02 10 88 47 00 01 40 20 00 01 41 1f 45 00 00 2c 00 00 00 00 ff 06 3b 78 c0 a8 00 01 c0 a8 00 02 00 50 00 00 00 00 00 2a 00 00 00 2a 50 00 27 10 77 44 00 00 48 4f 47 45'
2290 done
2291 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
2292 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
2293
2294 AT_CHECK([STRIP_METADATA ofctl_monitor.log], [0], [dnl
2295 NXT_PACKET_IN (xid=0x0): cookie=0xe total_len=58 in_port=1 (via action) data_len=58 (unbuffered)
2296 tcp,vlan_tci=0x0000,dl_src=60:66:66:66:02:10,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=254,tp_src=80,tp_dst=0,tcp_flags=0 tcp_csum:7744
2297 dnl
2298 NXT_PACKET_IN (xid=0x0): cookie=0xe total_len=58 in_port=1 (via action) data_len=58 (unbuffered)
2299 tcp,vlan_tci=0x0000,dl_src=60:66:66:66:02:10,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=254,tp_src=80,tp_dst=0,tcp_flags=0 tcp_csum:7744
2300 dnl
2301 NXT_PACKET_IN (xid=0x0): cookie=0xe total_len=58 in_port=1 (via action) data_len=58 (unbuffered)
2302 tcp,vlan_tci=0x0000,dl_src=60:66:66:66:02:10,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=254,tp_src=80,tp_dst=0,tcp_flags=0 tcp_csum:7744
2303 ])
2304
2305 AT_CHECK([ovs-appctl time/warp 5000], [0], [ignore])
2306
2307 dnl Modified MPLS pop action.
2308 dnl The input is a frame with three MPLS label stack entries which tcpdump -vve shows as:
2309 dnl 60:66:66:66:03:00 > 50:54:00:00:00:07, ethertype MPLS unicast (0x8847), length 66: MPLS (label 20, exp 0, ttl 32)
2310 dnl             (label 20, exp 0, ttl 31)
2311 dnl             (label 20, exp 0, [S], ttl 30)
2312 dnl             (tos 0x0, ttl 254, id 0, offset 0, flags [none], proto TCP (6), length 44)
2313 dnl        192.168.0.1.80 > 192.168.0.2.0: Flags [none], cksum 0x7744 (correct), seq 42:46, win 10000, length 4
2314 AT_CHECK([ovs-ofctl monitor br0 65534 -P nxm --detach --pidfile 2> ofctl_monitor.log])
2315
2316 for i in 1 2 3; do
2317     ovs-appctl netdev-dummy/receive p1 '50 54 00 00 00 07 60 66 66 66 03 00 88 47 00 01 40 20 00 01 40 1f 00 01 41 1e 45 00 00 2c 00 00 00 00 ff 06 3b 78 c0 a8 00 01 c0 a8 00 02 00 50 00 00 00 00 00 2a 00 00 00 2a 50 00 27 10 77 44 00 00 48 4f 47 45'
2318 done
2319 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
2320 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
2321
2322 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
2323 NXT_PACKET_IN (xid=0x0): cookie=0xe total_len=62 in_port=1 (via action) data_len=62 (unbuffered)
2324 mplsm,vlan_tci=0x0000,dl_src=60:66:66:66:03:00,dl_dst=50:54:00:00:00:07,mpls_label=20,mpls_tc=0,mpls_ttl=30,mpls_bos=1
2325 dnl
2326 NXT_PACKET_IN (xid=0x0): cookie=0xe total_len=62 in_port=1 (via action) data_len=62 (unbuffered)
2327 mplsm,vlan_tci=0x0000,dl_src=60:66:66:66:03:00,dl_dst=50:54:00:00:00:07,mpls_label=20,mpls_tc=0,mpls_ttl=30,mpls_bos=1
2328 dnl
2329 NXT_PACKET_IN (xid=0x0): cookie=0xe total_len=62 in_port=1 (via action) data_len=62 (unbuffered)
2330 mplsm,vlan_tci=0x0000,dl_src=60:66:66:66:03:00,dl_dst=50:54:00:00:00:07,mpls_label=20,mpls_tc=0,mpls_ttl=30,mpls_bos=1
2331 ])
2332
2333 AT_CHECK([ovs-appctl time/warp 5000], [0], [ignore])
2334
2335 dnl Modified MPLS pop action.
2336 dnl The input is a frame with three MPLS label stack entries which tcpdump -vve shows as:
2337 dnl 60:66:66:66:03:01 > 50:54:00:00:00:00, ethertype MPLS multicast (0x8848), length 66: MPLS (label 20, exp 0, ttl 32)
2338 dnl             (label 20, exp 0, ttl 31)
2339 dnl             (label 20, exp 0, [S], ttl 30)
2340 dnl             (tos 0x0, ttl 254, id 0, offset 0, flags [none], proto TCP (6), length 44)
2341 dnl        192.168.0.1.80 > 192.168.0.2.0: Flags [none], cksum 0x7744 (correct), seq 42:46, win 10000, length 4
2342 AT_CHECK([ovs-ofctl monitor br0 65534 -P nxm --detach --pidfile 2> ofctl_monitor.log])
2343
2344 for i in 1 2 3; do
2345     ovs-appctl netdev-dummy/receive p1 '50 54 00 00 00 07 60 66 66 66 03 01 88 48 00 01 40 20 00 01 40 1f 00 01 41 1e 45 00 00 2c 00 00 00 00 ff 06 3b 78 c0 a8 00 01 c0 a8 00 02 00 50 00 00 00 00 00 2a 00 00 00 2a 50 00 27 10 77 44 00 00 48 4f 47 45'
2346 done
2347 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
2348 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
2349
2350 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
2351 NXT_PACKET_IN (xid=0x0): cookie=0xe total_len=62 in_port=1 (via action) data_len=62 (unbuffered)
2352 mpls,vlan_tci=0x0000,dl_src=60:66:66:66:03:01,dl_dst=50:54:00:00:00:07,mpls_label=20,mpls_tc=0,mpls_ttl=29,mpls_bos=1
2353 dnl
2354 NXT_PACKET_IN (xid=0x0): cookie=0xe total_len=62 in_port=1 (via action) data_len=62 (unbuffered)
2355 mpls,vlan_tci=0x0000,dl_src=60:66:66:66:03:01,dl_dst=50:54:00:00:00:07,mpls_label=20,mpls_tc=0,mpls_ttl=29,mpls_bos=1
2356 dnl
2357 NXT_PACKET_IN (xid=0x0): cookie=0xe total_len=62 in_port=1 (via action) data_len=62 (unbuffered)
2358 mpls,vlan_tci=0x0000,dl_src=60:66:66:66:03:01,dl_dst=50:54:00:00:00:07,mpls_label=20,mpls_tc=0,mpls_ttl=29,mpls_bos=1
2359 ])
2360
2361 AT_CHECK([ovs-appctl time/warp 5000], [0], [ignore])
2362
2363 dnl Modified MPLS pop action.
2364 dnl The input is a frame with three MPLS label stack entries which tcpdump -vve shows as:
2365 dnl 60:66:66:66:03:10 > 50:54:00:00:00:00, ethertype MPLS unicast (0x8847), length 66: MPLS (label 20, exp 0, ttl 32)
2366 dnl             (label 20, exp 0, ttl 31)
2367 dnl             (label 20, exp 0, [S], ttl 30)
2368 dnl             (tos 0x0, ttl 254, id 0, offset 0, flags [none], proto TCP (6), length 44)
2369 dnl        192.168.0.1.80 > 192.168.0.2.0: Flags [none], cksum 0x7744 (correct), seq 42:46, win 10000, length 4
2370 AT_CHECK([ovs-ofctl monitor br0 65534 -P nxm --detach --pidfile 2> ofctl_monitor.log])
2371
2372 for i in 1 2 3; do
2373     ovs-appctl netdev-dummy/receive p1 '50 54 00 00 00 07 60 66 66 66 03 10 88 47 00 01 40 20 00 01 40 1f 00 01 41 1e 45 00 00 2c 00 00 00 00 ff 06 3b 78 c0 a8 00 01 c0 a8 00 02 00 50 00 00 00 00 00 2a 00 00 00 2a 50 00 27 10 77 44 00 00 48 4f 47 45'
2374 done
2375 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
2376 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
2377
2378 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
2379 NXT_PACKET_IN (xid=0x0): cookie=0xe total_len=62 in_port=1 (via action) data_len=62 (unbuffered)
2380 mplsm,vlan_tci=0x0000,dl_src=60:66:66:66:03:10,dl_dst=50:54:00:00:00:07,mpls_label=20,mpls_tc=0,mpls_ttl=29,mpls_bos=1
2381 dnl
2382 NXT_PACKET_IN (xid=0x0): cookie=0xe total_len=62 in_port=1 (via action) data_len=62 (unbuffered)
2383 mplsm,vlan_tci=0x0000,dl_src=60:66:66:66:03:10,dl_dst=50:54:00:00:00:07,mpls_label=20,mpls_tc=0,mpls_ttl=29,mpls_bos=1
2384 dnl
2385 NXT_PACKET_IN (xid=0x0): cookie=0xe total_len=62 in_port=1 (via action) data_len=62 (unbuffered)
2386 mplsm,vlan_tci=0x0000,dl_src=60:66:66:66:03:10,dl_dst=50:54:00:00:00:07,mpls_label=20,mpls_tc=0,mpls_ttl=29,mpls_bos=1
2387 ])
2388
2389 AT_CHECK([ovs-appctl time/warp 5000], [0], [ignore])
2390
2391 dnl Modified MPLS pop action.
2392 dnl The input is a frame with a single MPLS label stack entry which tcpdump -vve shows as:
2393 dnl 60:66:66:66:04:00 > 50:54:00:00:00:07, ethertype MPLS multicast (0x8848), length 62: MPLS (label 20, exp 0, [S], ttl 32)
2394 dnl             (tos 0x0, ttl 255, id 0, offset 0, flags [none], proto TCP (6), length 44)
2395 dnl         192.168.0.1.80 > 192.168.0.2.0: Flags [none], cksum 0x77ec (correct), seq 42:46, win 10000, length 4
2396 AT_CHECK([ovs-ofctl monitor br0 65534 -P nxm --detach --pidfile 2> ofctl_monitor.log])
2397
2398 for i in 1 2 3; do
2399     ovs-appctl netdev-dummy/receive p1 '50 54 00 00 00 07 60 66 66 66 04 00 88 48 00 01 41 20 45 00 00 2c 00 00 00 00 ff 06 3a 78 c0 a8 00 01 c0 a8 00 02 00 50 00 00 00 00 00 2a 00 00 00 2a 50 00 27 10 77 44 00 00 48 4f 47 45'
2400 done
2401 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
2402 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
2403
2404 AT_CHECK([STRIP_METADATA ofctl_monitor.log], [0], [dnl
2405 NXT_PACKET_IN (xid=0x0): cookie=0xf total_len=62 in_port=1 (via action) data_len=62 (unbuffered)
2406 mpls,vlan_tci=0x0000,dl_src=60:66:66:66:04:00,dl_dst=50:54:00:00:00:07,mpls_label=0,mpls_tc=0,mpls_ttl=255,mpls_bos=1
2407 dnl
2408 NXT_PACKET_IN (xid=0x0): cookie=0xf total_len=62 in_port=1 (via action) data_len=62 (unbuffered)
2409 mpls,vlan_tci=0x0000,dl_src=60:66:66:66:04:00,dl_dst=50:54:00:00:00:07,mpls_label=0,mpls_tc=0,mpls_ttl=255,mpls_bos=1
2410 dnl
2411 NXT_PACKET_IN (xid=0x0): cookie=0xf total_len=62 in_port=1 (via action) data_len=62 (unbuffered)
2412 mpls,vlan_tci=0x0000,dl_src=60:66:66:66:04:00,dl_dst=50:54:00:00:00:07,mpls_label=0,mpls_tc=0,mpls_ttl=255,mpls_bos=1
2413 ])
2414
2415 AT_CHECK([ovs-appctl time/warp 5000], [0], [ignore])
2416
2417 dnl Modified MPLS pop action.
2418 dnl The input is a frame with a single MPLS label stack entry which tcpdump -vve shows as:
2419 dnl 60:66:66:66:04:01 > 50:54:00:00:00:07, ethertype MPLS unicast (0x8847), length 62: MPLS (label 20, exp 0, [S], ttl 32)
2420 dnl             (tos 0x0, ttl 255, id 0, offset 0, flags [none], proto TCP (6), length 44)
2421 dnl         192.168.0.1.80 > 192.168.0.2.0: Flags [none], cksum 0x77ec (correct), seq 42:46, win 10000, length 4
2422 AT_CHECK([ovs-ofctl monitor br0 65534 -P nxm --detach --pidfile 2> ofctl_monitor.log])
2423
2424 for i in 1 2 3; do
2425     ovs-appctl netdev-dummy/receive p1 '50 54 00 00 00 07 60 66 66 66 04 01 88 47 00 01 41 20 45 00 00 2c 00 00 00 00 ff 06 3a 78 c0 a8 00 01 c0 a8 00 02 00 50 00 00 00 00 00 2a 00 00 00 2a 50 00 27 10 77 44 00 00 48 4f 47 45'
2426 done
2427 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
2428 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
2429
2430 AT_CHECK([STRIP_METADATA ofctl_monitor.log], [0], [dnl
2431 NXT_PACKET_IN (xid=0x0): cookie=0xf total_len=62 in_port=1 (via action) data_len=62 (unbuffered)
2432 mplsm,vlan_tci=0x0000,dl_src=60:66:66:66:04:01,dl_dst=50:54:00:00:00:07,mpls_label=0,mpls_tc=0,mpls_ttl=254,mpls_bos=1
2433 dnl
2434 NXT_PACKET_IN (xid=0x0): cookie=0xf total_len=62 in_port=1 (via action) data_len=62 (unbuffered)
2435 mplsm,vlan_tci=0x0000,dl_src=60:66:66:66:04:01,dl_dst=50:54:00:00:00:07,mpls_label=0,mpls_tc=0,mpls_ttl=254,mpls_bos=1
2436 dnl
2437 NXT_PACKET_IN (xid=0x0): cookie=0xf total_len=62 in_port=1 (via action) data_len=62 (unbuffered)
2438 mplsm,vlan_tci=0x0000,dl_src=60:66:66:66:04:01,dl_dst=50:54:00:00:00:07,mpls_label=0,mpls_tc=0,mpls_ttl=254,mpls_bos=1
2439 ])
2440
2441 AT_CHECK([ovs-appctl time/warp 5000], [0], [ignore])
2442
2443 dnl Modified MPLS pop action.
2444 dnl The input is a frame with a single MPLS label stack entry which tcpdump -vve shows as:
2445 dnl 60:66:66:66:04:10 > 50:54:00:00:00:07, ethertype MPLS multicast (0x8848), length 62: MPLS (label 20, exp 0, [S], ttl 32)
2446 dnl             (tos 0x0, ttl 255, id 0, offset 0, flags [none], proto TCP (6), length 44)
2447 dnl         192.168.0.1.80 > 192.168.0.2.0: Flags [none], cksum 0x77ec (correct), seq 42:46, win 10000, length 4
2448 AT_CHECK([ovs-ofctl monitor br0 65534 -P nxm --detach --pidfile 2> ofctl_monitor.log])
2449
2450 for i in 1 2 3; do
2451     ovs-appctl netdev-dummy/receive p1 '50 54 00 00 00 07 60 66 66 66 04 10 88 48 00 01 41 20 45 00 00 2c 00 00 00 00 ff 06 3a 78 c0 a8 00 01 c0 a8 00 02 00 50 00 00 00 00 00 2a 00 00 00 2a 50 00 27 10 77 44 00 00 48 4f 47 45'
2452 done
2453 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
2454 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
2455
2456 AT_CHECK([STRIP_METADATA  ofctl_monitor.log], [0], [dnl
2457 NXT_PACKET_IN (xid=0x0): cookie=0xf total_len=62 in_port=1 (via action) data_len=62 (unbuffered)
2458 mplsm,vlan_tci=0x0000,dl_src=60:66:66:66:04:10,dl_dst=50:54:00:00:00:07,mpls_label=0,mpls_tc=0,mpls_ttl=253,mpls_bos=1
2459 dnl
2460 NXT_PACKET_IN (xid=0x0): cookie=0xf total_len=62 in_port=1 (via action) data_len=62 (unbuffered)
2461 mplsm,vlan_tci=0x0000,dl_src=60:66:66:66:04:10,dl_dst=50:54:00:00:00:07,mpls_label=0,mpls_tc=0,mpls_ttl=253,mpls_bos=1
2462 dnl
2463 NXT_PACKET_IN (xid=0x0): cookie=0xf total_len=62 in_port=1 (via action) data_len=62 (unbuffered)
2464 mplsm,vlan_tci=0x0000,dl_src=60:66:66:66:04:10,dl_dst=50:54:00:00:00:07,mpls_label=0,mpls_tc=0,mpls_ttl=253,mpls_bos=1
2465 ])
2466
2467 AT_CHECK([ovs-appctl time/warp 5000], [0], [ignore])
2468
2469 dnl Modified MPLS pop action.
2470 dnl The input is a frame with a single MPLS label stack entry which tcpdump -vve shows as:
2471 dnl 60:66:66:66:05:00 > 50:54:00:00:00:07, ethertype MPLS unicast (0x8847), length 62: MPLS (label 20, exp 0, [S], ttl 32)
2472 dnl             (tos 0x0, ttl 255, id 0, offset 0, flags [none], proto TCP (6), length 44)
2473 dnl         192.168.0.1.80 > 192.168.0.2.0: Flags [none], cksum 0x77ec (correct), seq 42:46, win 10000, length 4
2474 AT_CHECK([ovs-ofctl monitor br0 65534 -P nxm --detach --pidfile 2> ofctl_monitor.log])
2475
2476 for i in 1 2 3; do
2477     ovs-appctl netdev-dummy/receive p1 '50 54 00 00 00 07 60 66 66 66 05 00 88 47 00 01 41 20 45 00 00 2c 00 00 00 00 ff 06 3a 78 c0 a8 00 01 c0 a8 00 02 00 50 00 00 00 00 00 2a 00 00 00 2a 50 00 27 10 77 44 00 00 48 4f 47 45'
2478 done
2479
2480 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
2481 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
2482
2483 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
2484 NXT_PACKET_IN (xid=0x0): cookie=0x5 total_len=62 in_port=1 (via action) data_len=62 (unbuffered)
2485 mpls,vlan_tci=0x0000,dl_src=60:66:66:66:05:00,dl_dst=50:54:00:00:00:07,mpls_label=20,mpls_tc=0,mpls_ttl=32,mpls_bos=1
2486 dnl
2487 NXT_PACKET_IN (xid=0x0): cookie=0x5 total_len=62 in_port=1 (via action) data_len=62 (unbuffered)
2488 mpls,vlan_tci=0x0000,dl_src=60:66:66:66:05:00,dl_dst=50:54:00:00:00:07,mpls_label=20,mpls_tc=0,mpls_ttl=32,mpls_bos=1
2489 dnl
2490 NXT_PACKET_IN (xid=0x0): cookie=0x5 total_len=62 in_port=1 (via action) data_len=62 (unbuffered)
2491 mpls,vlan_tci=0x0000,dl_src=60:66:66:66:05:00,dl_dst=50:54:00:00:00:07,mpls_label=20,mpls_tc=0,mpls_ttl=32,mpls_bos=1
2492 ])
2493
2494 AT_CHECK([ovs-appctl time/warp 5000], [0], [ignore])
2495
2496 dnl Modified MPLS pop action.
2497 dnl The input is a frame with a single MPLS label stack entry which tcpdump -vve shows as:
2498 dnl 60:66:66:66:05:01 > 50:54:00:00:00:07, ethertype MPLS multicast (0x8848), length 62: MPLS (label 20, exp 0, [S], ttl 32)
2499 dnl             (tos 0x0, ttl 255, id 0, offset 0, flags [none], proto TCP (6), length 44)
2500 dnl         192.168.0.1.80 > 192.168.0.2.0: Flags [none], cksum 0x77ec (correct), seq 42:46, win 10000, length 4
2501 AT_CHECK([ovs-ofctl monitor br0 65534 -P nxm --detach --pidfile 2> ofctl_monitor.log])
2502
2503 for i in 1 2 3; do
2504     ovs-appctl netdev-dummy/receive p1 '50 54 00 00 00 07 60 66 66 66 05 01 88 48 00 01 41 20 45 00 00 2c 00 00 00 00 ff 06 3a 78 c0 a8 00 01 c0 a8 00 02 00 50 00 00 00 00 00 2a 00 00 00 2a 50 00 27 10 77 44 00 00 48 4f 47 45'
2505 done
2506 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
2507 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
2508
2509 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
2510 NXT_PACKET_IN (xid=0x0): cookie=0x5 total_len=62 in_port=1 (via action) data_len=62 (unbuffered)
2511 mplsm,vlan_tci=0x0000,dl_src=60:66:66:66:05:01,dl_dst=50:54:00:00:00:07,mpls_label=20,mpls_tc=0,mpls_ttl=31,mpls_bos=1
2512 dnl
2513 NXT_PACKET_IN (xid=0x0): cookie=0x5 total_len=62 in_port=1 (via action) data_len=62 (unbuffered)
2514 mplsm,vlan_tci=0x0000,dl_src=60:66:66:66:05:01,dl_dst=50:54:00:00:00:07,mpls_label=20,mpls_tc=0,mpls_ttl=31,mpls_bos=1
2515 dnl
2516 NXT_PACKET_IN (xid=0x0): cookie=0x5 total_len=62 in_port=1 (via action) data_len=62 (unbuffered)
2517 mplsm,vlan_tci=0x0000,dl_src=60:66:66:66:05:01,dl_dst=50:54:00:00:00:07,mpls_label=20,mpls_tc=0,mpls_ttl=31,mpls_bos=1
2518 ])
2519
2520 AT_CHECK([ovs-appctl time/warp 5000], [0], [ignore])
2521
2522 dnl Modified MPLS pop action.
2523 dnl The input is a frame with a single MPLS label stack entry which tcpdump -vve shows as:
2524 dnl 60:66:66:66:05:10 > 50:54:00:00:00:07, ethertype MPLS unicast (0x8847), length 62: MPLS (label 20, exp 0, [S], ttl 32)
2525 dnl             (tos 0x0, ttl 255, id 0, offset 0, flags [none], proto TCP (6), length 44)
2526 dnl         192.168.0.1.80 > 192.168.0.2.0: Flags [none], cksum 0x77ec (correct), seq 42:46, win 10000, length 4
2527 AT_CHECK([ovs-ofctl monitor br0 65534 -P nxm --detach --pidfile 2> ofctl_monitor.log])
2528
2529 for i in 1 2 3; do
2530     ovs-appctl netdev-dummy/receive p1 '50 54 00 00 00 07 60 66 66 66 05 10 88 47 00 01 41 20 45 00 00 2c 00 00 00 00 ff 06 3a 78 c0 a8 00 01 c0 a8 00 02 00 50 00 00 00 00 00 2a 00 00 00 2a 50 00 27 10 77 44 00 00 48 4f 47 45'
2531 done
2532
2533 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
2534 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
2535
2536 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
2537 NXT_PACKET_IN (xid=0x0): cookie=0x5 total_len=62 in_port=1 (via action) data_len=62 (unbuffered)
2538 mpls,vlan_tci=0x0000,dl_src=60:66:66:66:05:10,dl_dst=50:54:00:00:00:07,mpls_label=20,mpls_tc=0,mpls_ttl=31,mpls_bos=1
2539 dnl
2540 NXT_PACKET_IN (xid=0x0): cookie=0x5 total_len=62 in_port=1 (via action) data_len=62 (unbuffered)
2541 mpls,vlan_tci=0x0000,dl_src=60:66:66:66:05:10,dl_dst=50:54:00:00:00:07,mpls_label=20,mpls_tc=0,mpls_ttl=31,mpls_bos=1
2542 dnl
2543 NXT_PACKET_IN (xid=0x0): cookie=0x5 total_len=62 in_port=1 (via action) data_len=62 (unbuffered)
2544 mpls,vlan_tci=0x0000,dl_src=60:66:66:66:05:10,dl_dst=50:54:00:00:00:07,mpls_label=20,mpls_tc=0,mpls_ttl=31,mpls_bos=1
2545 ])
2546
2547 AT_CHECK([ovs-appctl revalidator/purge], [0])
2548 AT_CHECK([ovs-ofctl dump-flows br0 | ofctl_strip | sort], [0], [dnl
2549  cookie=0x5, n_packets=3, n_bytes=186, dl_src=60:66:66:66:05:00 actions=push_mpls:0x8848,pop_mpls:0x8847,CONTROLLER:65535
2550  cookie=0x5, n_packets=3, n_bytes=186, dl_src=60:66:66:66:05:01 actions=push_mpls:0x8847,pop_mpls:0x8848,dec_mpls_ttl,CONTROLLER:65535
2551  cookie=0x5, n_packets=3, n_bytes=186, dl_src=60:66:66:66:05:10 actions=push_mpls:0x8848,dec_mpls_ttl,pop_mpls:0x8847,dec_mpls_ttl,CONTROLLER:65535
2552  cookie=0xa, n_packets=3, n_bytes=180, dl_src=40:44:44:44:44:42 actions=push_mpls:0x8847,load:0xa->OXM_OF_MPLS_LABEL[[]],load:0x3->OXM_OF_MPLS_TC[[]],CONTROLLER:65535
2553  cookie=0xa, n_packets=3, n_bytes=180, dl_src=40:44:44:44:44:43 actions=push_mpls:0x8847,load:0xa->OXM_OF_MPLS_LABEL[[]],load:0x3->OXM_OF_MPLS_TC[[]],CONTROLLER:65535
2554  cookie=0xa, n_packets=3, n_bytes=180, dl_src=40:44:44:44:44:44 actions=push_mpls:0x8847,load:0xa->OXM_OF_MPLS_LABEL[[]],load:0x3->OXM_OF_MPLS_TC[[]],CONTROLLER:65535
2555  cookie=0xa, n_packets=3, n_bytes=180, dl_src=40:44:44:44:44:45 actions=push_mpls:0x8847,load:0xa->OXM_OF_MPLS_LABEL[[]],load:0x3->OXM_OF_MPLS_TC[[]],dec_mpls_ttl,CONTROLLER:65535
2556  cookie=0xa, n_packets=3, n_bytes=180, dl_src=40:44:44:44:44:46 actions=push_mpls:0x8847,load:0xa->OXM_OF_MPLS_LABEL[[]],load:0x3->OXM_OF_MPLS_TC[[]],set_mpls_ttl(10),CONTROLLER:65535
2557  cookie=0xa, n_packets=3, n_bytes=180, dl_src=40:44:44:44:44:47 actions=push_mpls:0x8847,load:0xa->OXM_OF_MPLS_LABEL[[]],load:0x3->OXM_OF_MPLS_TC[[]],dec_mpls_ttl,set_mpls_ttl(10),CONTROLLER:65535
2558  cookie=0xa, n_packets=3, n_bytes=180, dl_src=40:44:44:44:44:48 actions=push_mpls:0x8847,load:0xa->OXM_OF_MPLS_LABEL[[]],load:0x3->OXM_OF_MPLS_TC[[]],set_mpls_ttl(10),dec_mpls_ttl,CONTROLLER:65535
2559  cookie=0xa, n_packets=3, n_bytes=180, dl_src=41:44:44:44:44:42 actions=push_mpls:0x8847,load:0xa->OXM_OF_MPLS_LABEL[[]],load:0x3->OXM_OF_MPLS_TC[[]],pop_mpls:0x0800,CONTROLLER:65535
2560  cookie=0xa, n_packets=3, n_bytes=180, mpls,dl_src=40:44:44:44:44:49 actions=push_mpls:0x8848,load:0xa->OXM_OF_MPLS_LABEL[[]],CONTROLLER:65535
2561  cookie=0xb, n_packets=3, n_bytes=180, mpls,dl_src=50:55:55:55:55:55 actions=load:0x3e8->OXM_OF_MPLS_LABEL[[]],CONTROLLER:65535
2562  cookie=0xc, n_packets=3, n_bytes=180, dl_src=70:77:77:77:77:77 actions=push_mpls:0x8848,load:0x3e8->OXM_OF_MPLS_LABEL[[]],load:0x7->OXM_OF_MPLS_TC[[]],CONTROLLER:65535
2563  cookie=0xd, n_packets=3, n_bytes=180, dl_src=60:66:66:66:00:08 actions=pop_mpls:0x0806,resubmit(1,1)
2564  cookie=0xd, n_packets=3, n_bytes=186, dl_src=60:66:66:66:00:01 actions=pop_mpls:0x0800,dec_ttl,CONTROLLER:65535
2565  cookie=0xd, n_packets=3, n_bytes=186, dl_src=60:66:66:66:00:02 actions=pop_mpls:0x0800,load:0xa000001->NXM_OF_IP_DST[[]],CONTROLLER:65535
2566  cookie=0xd, n_packets=3, n_bytes=186, dl_src=60:66:66:66:00:03 actions=pop_mpls:0x0800,move:NXM_OF_IP_DST[[]]->NXM_OF_IP_SRC[[]],CONTROLLER:65535
2567  cookie=0xd, n_packets=3, n_bytes=186, dl_src=60:66:66:66:00:04 actions=pop_mpls:0x0800,push:NXM_OF_IP_DST[[]],pop:NXM_OF_IP_SRC[[]],CONTROLLER:65535
2568  cookie=0xd, n_packets=3, n_bytes=186, dl_src=60:66:66:66:00:05 actions=pop_mpls:0x0800,multipath(eth_src,50,modulo_n,256,0,NXM_OF_IP_SRC[[0..7]]),CONTROLLER:65535
2569  cookie=0xd, n_packets=3, n_bytes=186, dl_src=60:66:66:66:00:06 actions=pop_mpls:0x0800,bundle_load(eth_src,50,hrw,ofport,NXM_OF_IP_SRC[[0..15]],slaves:1,2),CONTROLLER:65535
2570  cookie=0xd, n_packets=3, n_bytes=186, dl_src=60:66:66:66:00:07 actions=pop_mpls:0x0800,learn(table=1,hard_timeout=60,eth_type=0x800,nw_proto=6,NXM_OF_IP_SRC[[]]=NXM_OF_IP_DST[[]]),CONTROLLER:65535
2571  cookie=0xd, n_packets=3, n_bytes=186, dl_src=60:66:66:66:00:09 actions=resubmit(,2),CONTROLLER:65535
2572  cookie=0xd, n_packets=3, n_bytes=186, dl_src=60:66:66:66:00:0a actions=pop_mpls:0x0800,mod_nw_dst:10.0.0.1,CONTROLLER:65535
2573  cookie=0xd, n_packets=3, n_bytes=186, dl_src=60:66:66:66:00:0b actions=pop_mpls:0x0800,mod_nw_src:10.0.0.1,CONTROLLER:65535
2574  cookie=0xd, n_packets=3, n_bytes=186, dl_src=60:66:66:66:66:66 actions=pop_mpls:0x0800,CONTROLLER:65535
2575  cookie=0xd, n_packets=3, n_bytes=198, dl_src=60:66:66:66:01:00 actions=pop_mpls:0x8848,CONTROLLER:65535
2576  cookie=0xd, n_packets=3, n_bytes=198, dl_src=60:66:66:66:01:01 actions=pop_mpls:0x8847,dec_mpls_ttl,CONTROLLER:65535
2577  cookie=0xd, n_packets=3, n_bytes=198, dl_src=60:66:66:66:01:02 actions=pop_mpls:0x8848,load:0x3->OXM_OF_MPLS_TC[[]],CONTROLLER:65535
2578  cookie=0xd, n_packets=3, n_bytes=198, dl_src=60:66:66:66:02:00 actions=pop_mpls:0x8847,pop_mpls:0x0800,CONTROLLER:65535
2579  cookie=0xd, table=1, n_packets=3, n_bytes=168, arp actions=CONTROLLER:65535
2580  cookie=0xdeadbeef, table=2, n_packets=3, n_bytes=186, dl_src=60:66:66:66:00:09 actions=pop_mpls:0x0800,mod_nw_tos:48
2581  cookie=0xe, n_packets=3, n_bytes=198, dl_src=60:66:66:66:02:01 actions=pop_mpls:0x8848,pop_mpls:0x0800,dec_ttl,CONTROLLER:65535
2582  cookie=0xe, n_packets=3, n_bytes=198, dl_src=60:66:66:66:02:10 actions=pop_mpls:0x8847,dec_mpls_ttl,pop_mpls:0x0800,dec_ttl,CONTROLLER:65535
2583  cookie=0xe, n_packets=3, n_bytes=210, dl_src=60:66:66:66:03:00 actions=pop_mpls:0x8848,pop_mpls:0x8848,CONTROLLER:65535
2584  cookie=0xe, n_packets=3, n_bytes=210, dl_src=60:66:66:66:03:01 actions=pop_mpls:0x8847,pop_mpls:0x8847,dec_mpls_ttl,CONTROLLER:65535
2585  cookie=0xe, n_packets=3, n_bytes=210, dl_src=60:66:66:66:03:10 actions=pop_mpls:0x8848,dec_mpls_ttl,pop_mpls:0x8848,dec_mpls_ttl,CONTROLLER:65535
2586  cookie=0xf, n_packets=3, n_bytes=186, dl_src=60:66:66:66:04:00 actions=pop_mpls:0x0800,push_mpls:0x8847,CONTROLLER:65535
2587  cookie=0xf, n_packets=3, n_bytes=186, dl_src=60:66:66:66:04:01 actions=pop_mpls:0x0800,push_mpls:0x8848,dec_mpls_ttl,CONTROLLER:65535
2588  cookie=0xf, n_packets=3, n_bytes=186, dl_src=60:66:66:66:04:10 actions=pop_mpls:0x0800,dec_ttl,push_mpls:0x8848,dec_mpls_ttl,CONTROLLER:65535
2589 NXST_FLOW reply:
2590 ])
2591
2592 OVS_VSWITCHD_STOP
2593 AT_CLEANUP
2594
2595 AT_SETUP([ofproto-dpif - MPLS handling with goto_table])
2596 OVS_VSWITCHD_START([dnl
2597    add-port br0 p1 -- set Interface p1 type=dummy
2598 ])
2599 ON_EXIT([kill `cat ovs-ofctl.pid`])
2600
2601 AT_CAPTURE_FILE([ofctl_monitor.log])
2602 AT_DATA([flows.txt], [dnl
2603 table=0 mplsm actions=pop_mpls:0x800,goto_table(1)
2604 table=1 ip,ip_dscp=8 actions=controller
2605 ])
2606 AT_CHECK([ovs-ofctl -O OpenFlow12 add-flows br0 flows.txt])
2607
2608
2609 dnl Modified MPLS pop action.
2610 dnl The input is a frame with a single MPLS label stack entry which tcpdump -vve shows as:
2611 dnl 60:66:66:66:00:08 > 50:54:00:00:00:01, ethertype MPLS multicast (0x8848), length 62: MPLS (label 20, exp 0, [S], ttl 32)
2612 dnl             (tos 0x20, ttl 255, id 0, offset 0, flags [none], proto TCP (6), length 44)
2613 dnl         192.168.0.1.80 > 192.168.0.2.0: Flags [none], cksum 0x77ec (correct), seq 42:46, win 10000, length 4
2614 AT_CHECK([ovs-ofctl -O OpenFlow12 monitor br0 65534 -P nxm --detach --pidfile 2> ofctl_monitor.log])
2615
2616 for i in 1 2 3; do
2617     ovs-appctl netdev-dummy/receive p1 '50 54 00 00 00 01 60 66 66 66 00 08 88 48 00 01 41 20 45 20 00 2c 00 00 00 00 ff 06 3a 78 c0 a8 00 01 c0 a8 00 02 00 50 00 00 00 00 00 2a 00 00 00 2a 50 00 27 10 77 44 00 00 48 4f 47 45'
2618 done
2619 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
2620 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
2621
2622 AT_CHECK([STRIP_METADATA ofctl_monitor.log], [0], [dnl
2623 OFPT_PACKET_IN (OF1.2) (xid=0x0): table_id=1 total_len=58 in_port=1 (via action) data_len=58 (unbuffered)
2624 tcp,vlan_tci=0x0000,dl_src=60:66:66:66:00:08,dl_dst=50:54:00:00:00:01,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=32,nw_ecn=0,nw_ttl=255,tp_src=80,tp_dst=0,tcp_flags=0 tcp_csum:7744
2625 dnl
2626 OFPT_PACKET_IN (OF1.2) (xid=0x0): table_id=1 total_len=58 in_port=1 (via action) data_len=58 (unbuffered)
2627 tcp,vlan_tci=0x0000,dl_src=60:66:66:66:00:08,dl_dst=50:54:00:00:00:01,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=32,nw_ecn=0,nw_ttl=255,tp_src=80,tp_dst=0,tcp_flags=0 tcp_csum:7744
2628 dnl
2629 OFPT_PACKET_IN (OF1.2) (xid=0x0): table_id=1 total_len=58 in_port=1 (via action) data_len=58 (unbuffered)
2630 tcp,vlan_tci=0x0000,dl_src=60:66:66:66:00:08,dl_dst=50:54:00:00:00:01,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=32,nw_ecn=0,nw_ttl=255,tp_src=80,tp_dst=0,tcp_flags=0 tcp_csum:7744
2631 ])
2632
2633 AT_CHECK([ovs-appctl revalidator/purge], [0])
2634 AT_CHECK([ovs-ofctl -O OpenFlow12 dump-flows br0 | ofctl_strip | sort], [0], [dnl
2635  n_packets=3, n_bytes=186, mplsm actions=pop_mpls:0x0800,goto_table:1
2636  table=1, n_packets=3, n_bytes=174, ip,nw_tos=32 actions=CONTROLLER:65535
2637 OFPST_FLOW reply (OF1.2):
2638 ])
2639
2640 OVS_VSWITCHD_STOP
2641 AT_CLEANUP
2642
2643 AT_SETUP([ofproto-dpif - MPLS handling with write_actions])
2644 OVS_VSWITCHD_START([dnl
2645    add-port br0 p1 -- set Interface p1 type=dummy
2646 ])
2647 ON_EXIT([kill `cat ovs-ofctl.pid`])
2648
2649 dnl N.B: The first (and only) action that accesses L3 data after the
2650 dnl pop_mpls action is present in write_actions. This exercises recirculation
2651 dnl triggered in write_actions due to a previous action not in write actions.
2652 AT_CAPTURE_FILE([ofctl_monitor.log])
2653 AT_DATA([flows.txt], [dnl
2654 mplsm actions=pop_mpls:0x800,write_actions(dec_ttl,controller)
2655 ])
2656 AT_CHECK([ovs-ofctl -O OpenFlow12 add-flows br0 flows.txt])
2657
2658 dnl Modified MPLS pop action.
2659 dnl The input is a frame with a single MPLS label stack entry which tcpdump -vve shows as:
2660 dnl 60:66:66:66:00:08 > 50:54:00:00:00:01, ethertype MPLS multicast (0x8848), length 62: MPLS (label 20, exp 0, [S], ttl 32)
2661 dnl             (tos 0x20, ttl 255, id 0, offset 0, flags [none], proto TCP (6), length 44)
2662 dnl         192.168.0.1.80 > 192.168.0.2.0: Flags [none], cksum 0x77ec (correct), seq 42:46, win 10000, length 4
2663 AT_CHECK([ovs-ofctl -O OpenFlow12 monitor br0 65534 -P nxm --detach --pidfile 2> ofctl_monitor.log])
2664
2665 for i in 1 2 3; do
2666     ovs-appctl netdev-dummy/receive p1 '50 54 00 00 00 01 60 66 66 66 00 08 88 48 00 01 41 20 45 20 00 2c 00 00 00 00 ff 06 3a 78 c0 a8 00 01 c0 a8 00 02 00 50 00 00 00 00 00 2a 00 00 00 2a 50 00 27 10 77 44 00 00 48 4f 47 45'
2667 done
2668 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
2669 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
2670
2671 AT_CHECK([STRIP_METADATA ofctl_monitor.log], [0], [dnl
2672 OFPT_PACKET_IN (OF1.2) (xid=0x0): total_len=58 in_port=1 (via action) data_len=58 (unbuffered)
2673 tcp,vlan_tci=0x0000,dl_src=60:66:66:66:00:08,dl_dst=50:54:00:00:00:01,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=32,nw_ecn=0,nw_ttl=254,tp_src=80,tp_dst=0,tcp_flags=0 tcp_csum:7744
2674 dnl
2675 OFPT_PACKET_IN (OF1.2) (xid=0x0): total_len=58 in_port=1 (via action) data_len=58 (unbuffered)
2676 tcp,vlan_tci=0x0000,dl_src=60:66:66:66:00:08,dl_dst=50:54:00:00:00:01,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=32,nw_ecn=0,nw_ttl=254,tp_src=80,tp_dst=0,tcp_flags=0 tcp_csum:7744
2677 dnl
2678 OFPT_PACKET_IN (OF1.2) (xid=0x0): total_len=58 in_port=1 (via action) data_len=58 (unbuffered)
2679 tcp,vlan_tci=0x0000,dl_src=60:66:66:66:00:08,dl_dst=50:54:00:00:00:01,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=32,nw_ecn=0,nw_ttl=254,tp_src=80,tp_dst=0,tcp_flags=0 tcp_csum:7744
2680 ])
2681
2682 AT_CHECK([ovs-appctl revalidator/purge], [0])
2683 AT_CHECK([ovs-ofctl -O OpenFlow12 dump-flows br0 | ofctl_strip | sort], [0], [dnl
2684  n_packets=3, n_bytes=186, mplsm actions=pop_mpls:0x0800,write_actions(dec_ttl,CONTROLLER:65535)
2685 OFPST_FLOW reply (OF1.2):
2686 ])
2687
2688 OVS_VSWITCHD_STOP
2689 AT_CLEANUP
2690
2691 AT_SETUP([ofproto-dpif - table-miss flow (OpenFlow 1.0)])
2692 OVS_VSWITCHD_START([dnl
2693    add-port br0 p1 -- set Interface p1 type=dummy
2694 ])
2695 ON_EXIT([kill `cat ovs-ofctl.pid`])
2696
2697 AT_CAPTURE_FILE([ofctl_monitor.log])
2698 # A table-miss flow has priority 0 and no match
2699 AT_CHECK([ovs-ofctl --protocols=OpenFlow10 add-flow br0 'priority=0 actions=output:CONTROLLER'])
2700
2701 dnl Singleton controller action.
2702 AT_CHECK([ovs-ofctl monitor -P openflow10 --protocols=OpenFlow10 br0 65534 --detach --no-chdir --pidfile 2> ofctl_monitor.log])
2703
2704 for i in 1 2 3 ; do
2705     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=10:11:11:11:11:11,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=6,tos=0,ttl=64,frag=no),tcp(src=8,dst=10),tcp_flags(0x002)'
2706 done
2707 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
2708 ovs-appctl -t ovs-ofctl exit
2709
2710 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
2711 OFPT_PACKET_IN (xid=0x0): total_len=60 in_port=1 (via action) data_len=60 (unbuffered)
2712 tcp,vlan_tci=0x0000,dl_src=10:11:11:11:11:11,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=10,tcp_flags=syn tcp_csum:0
2713 dnl
2714 OFPT_PACKET_IN (xid=0x0): total_len=60 in_port=1 (via action) data_len=60 (unbuffered)
2715 tcp,vlan_tci=0x0000,dl_src=10:11:11:11:11:11,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=10,tcp_flags=syn tcp_csum:0
2716 dnl
2717 OFPT_PACKET_IN (xid=0x0): total_len=60 in_port=1 (via action) data_len=60 (unbuffered)
2718 tcp,vlan_tci=0x0000,dl_src=10:11:11:11:11:11,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=10,tcp_flags=syn tcp_csum:0
2719 ])
2720
2721 AT_CHECK([ovs-appctl revalidator/purge], [0])
2722 AT_CHECK([ovs-ofctl --protocols=OpenFlow10 dump-flows br0 | ofctl_strip | sort], [0], [dnl
2723  n_packets=3, n_bytes=180, priority=0 actions=CONTROLLER:65535
2724 NXST_FLOW reply:
2725 ])
2726
2727 OVS_VSWITCHD_STOP
2728 AT_CLEANUP
2729
2730
2731 AT_SETUP([ofproto-dpif - table-miss flow (OpenFlow 1.3)])
2732 OVS_VSWITCHD_START([dnl
2733    add-port br0 p1 -- set Interface p1 type=dummy
2734 ])
2735 ON_EXIT([kill `cat ovs-ofctl.pid`])
2736
2737 AT_CAPTURE_FILE([ofctl_monitor.log])
2738 # A table-miss flow has priority 0 and no match
2739 AT_CHECK([ovs-ofctl --protocols=OpenFlow13 add-flow br0 'priority=0 actions=output:CONTROLLER'])
2740
2741 dnl Singleton controller action.
2742 AT_CHECK([ovs-ofctl monitor -P openflow10 --protocols=OpenFlow13 br0 65534 --detach --no-chdir --pidfile 2> ofctl_monitor.log])
2743
2744 for i in 1 2 3 ; do
2745     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=10:11:11:11:11:11,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=6,tos=0,ttl=64,frag=no),tcp(src=8,dst=10),tcp_flags(0x002)'
2746 done
2747 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
2748 ovs-appctl -t ovs-ofctl exit
2749
2750 AT_CHECK([ovs-appctl time/warp 5000], [0], [ignore])
2751
2752 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
2753 OFPT_PACKET_IN (OF1.3) (xid=0x0): cookie=0x0 total_len=60 in_port=1 (via no_match) data_len=60 (unbuffered)
2754 tcp,vlan_tci=0x0000,dl_src=10:11:11:11:11:11,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=10,tcp_flags=syn tcp_csum:0
2755 dnl
2756 OFPT_PACKET_IN (OF1.3) (xid=0x0): cookie=0x0 total_len=60 in_port=1 (via no_match) data_len=60 (unbuffered)
2757 tcp,vlan_tci=0x0000,dl_src=10:11:11:11:11:11,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=10,tcp_flags=syn tcp_csum:0
2758 dnl
2759 OFPT_PACKET_IN (OF1.3) (xid=0x0): cookie=0x0 total_len=60 in_port=1 (via no_match) data_len=60 (unbuffered)
2760 tcp,vlan_tci=0x0000,dl_src=10:11:11:11:11:11,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=10,tcp_flags=syn tcp_csum:0
2761 ])
2762
2763 AT_CHECK([ovs-appctl revalidator/purge], [0])
2764 AT_CHECK([ovs-ofctl --protocols=OpenFlow13 dump-flows br0 | ofctl_strip | sort], [0], [dnl
2765  n_packets=3, n_bytes=180, priority=0 actions=CONTROLLER:65535
2766 OFPST_FLOW reply (OF1.3):
2767 ])
2768
2769 OVS_VSWITCHD_STOP
2770 AT_CLEANUP
2771
2772 AT_SETUP([ofproto-dpif - table-miss flow with async config (OpenFlow 1.3)])
2773 OVS_VSWITCHD_START([dnl
2774    add-port br0 p1 -- set Interface p1 type=dummy
2775 ])
2776 ON_EXIT([kill `cat ovs-ofctl.pid`])
2777
2778 ovs-appctl time/stop
2779
2780 AT_CAPTURE_FILE([ofctl_monitor.log])
2781 # A table-miss flow has priority 0 and no match
2782 AT_CHECK([ovs-ofctl --protocols=OpenFlow13 add-flow br0 'priority=0 actions=output:CONTROLLER'])
2783
2784 dnl Singleton controller action.
2785 AT_CHECK([ovs-ofctl monitor -P openflow10 --protocols=OpenFlow13 br0 65534 --detach --no-chdir --pidfile 2> ofctl_monitor.log])
2786
2787 # Become slave (OF 1.3), which should disable everything except port status.
2788 ovs-appctl -t ovs-ofctl ofctl/send 041800180000000200000003000000000000000000000001
2789
2790 # Ensure that ovs-vswitchd gets a chance to reply before sending another command.
2791 ovs-appctl time/warp 500 100
2792
2793 # Use OF 1.3 OFPT_SET_ASYNC to enable OFPR_NO_MATCH for slave only.
2794 ovs-appctl -t ovs-ofctl ofctl/send 041c002000000002000000000000000100000000000000000000000000000000
2795
2796 ovs-appctl time/warp 500 100
2797 for i in 1 2 3 ; do
2798     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=10:11:11:11:11:11,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=6,tos=0,ttl=64,frag=no),tcp(src=8,dst=10),tcp_flags(0x002)'
2799 done
2800 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
2801 ovs-appctl -t ovs-ofctl exit
2802
2803 AT_CHECK([ovs-appctl revalidator/purge], [0])
2804 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
2805 send: OFPT_ROLE_REQUEST (OF1.3) (xid=0x2): role=slave generation_id=1
2806 OFPT_ROLE_REPLY (OF1.3) (xid=0x2): role=slave generation_id=1
2807 dnl
2808 send: OFPT_SET_ASYNC (OF1.3) (xid=0x2):
2809  master:
2810        PACKET_IN: (off)
2811      PORT_STATUS: (off)
2812     FLOW_REMOVED: (off)
2813
2814  slave:
2815        PACKET_IN: no_match
2816      PORT_STATUS: (off)
2817     FLOW_REMOVED: (off)
2818 dnl
2819 OFPT_PACKET_IN (OF1.3) (xid=0x0): cookie=0x0 total_len=60 in_port=1 (via no_match) data_len=60 (unbuffered)
2820 tcp,vlan_tci=0x0000,dl_src=10:11:11:11:11:11,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=10,tcp_flags=syn tcp_csum:0
2821 dnl
2822 OFPT_PACKET_IN (OF1.3) (xid=0x0): cookie=0x0 total_len=60 in_port=1 (via no_match) data_len=60 (unbuffered)
2823 tcp,vlan_tci=0x0000,dl_src=10:11:11:11:11:11,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=10,tcp_flags=syn tcp_csum:0
2824 dnl
2825 OFPT_PACKET_IN (OF1.3) (xid=0x0): cookie=0x0 total_len=60 in_port=1 (via no_match) data_len=60 (unbuffered)
2826 tcp,vlan_tci=0x0000,dl_src=10:11:11:11:11:11,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=10,tcp_flags=syn tcp_csum:0
2827 ])
2828
2829 AT_CHECK([ovs-appctl time/warp 5000], [0], [ignore])
2830
2831 AT_CHECK([ovs-ofctl --protocols=OpenFlow13 dump-flows br0 | ofctl_strip | sort], [0], [dnl
2832  n_packets=3, n_bytes=180, priority=0 actions=CONTROLLER:65535
2833 OFPST_FLOW reply (OF1.3):
2834 ])
2835
2836 OVS_VSWITCHD_STOP
2837 AT_CLEANUP
2838
2839
2840 AT_SETUP([ofproto-dpif - table-miss flow (OpenFlow 1.4)])
2841 OVS_VSWITCHD_START([dnl
2842    add-port br0 p1 -- set Interface p1 type=dummy
2843 ])
2844 ON_EXIT([kill `cat ovs-ofctl.pid`])
2845
2846 AT_CAPTURE_FILE([ofctl_monitor.log])
2847 # A table-miss flow has priority 0 and no match
2848 AT_CHECK([ovs-ofctl --protocols=OpenFlow14 add-flow br0 'priority=0 actions=output:CONTROLLER'])
2849
2850 dnl Singleton controller action.
2851 AT_CHECK([ovs-ofctl monitor -P openflow10 --protocols=OpenFlow14 br0 65534 --detach --no-chdir --pidfile 2> ofctl_monitor.log])
2852
2853 for i in 1 2 3 ; do
2854     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=10:11:11:11:11:11,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=6,tos=0,ttl=64,frag=no),tcp(src=8,dst=10),tcp_flags(0x002)'
2855 done
2856 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
2857 ovs-appctl -t ovs-ofctl exit
2858
2859 AT_CHECK([ovs-appctl revalidator/purge], [0])
2860 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
2861 OFPT_PACKET_IN (OF1.4) (xid=0x0): cookie=0x0 total_len=60 in_port=1 (via no_match) data_len=60 (unbuffered)
2862 tcp,vlan_tci=0x0000,dl_src=10:11:11:11:11:11,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=10,tcp_flags=syn tcp_csum:0
2863 dnl
2864 OFPT_PACKET_IN (OF1.4) (xid=0x0): cookie=0x0 total_len=60 in_port=1 (via no_match) data_len=60 (unbuffered)
2865 tcp,vlan_tci=0x0000,dl_src=10:11:11:11:11:11,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=10,tcp_flags=syn tcp_csum:0
2866 dnl
2867 OFPT_PACKET_IN (OF1.4) (xid=0x0): cookie=0x0 total_len=60 in_port=1 (via no_match) data_len=60 (unbuffered)
2868 tcp,vlan_tci=0x0000,dl_src=10:11:11:11:11:11,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=10,tcp_flags=syn tcp_csum:0
2869 ])
2870
2871 AT_CHECK([ovs-appctl time/warp 5000], [0], [ignore])
2872
2873 AT_CHECK([ovs-ofctl --protocols=OpenFlow14 dump-flows br0 | ofctl_strip | sort], [0], [dnl
2874  n_packets=3, n_bytes=180, priority=0 actions=CONTROLLER:65535
2875 OFPST_FLOW reply (OF1.4):
2876 ])
2877
2878 OVS_VSWITCHD_STOP
2879 AT_CLEANUP
2880
2881
2882 AT_SETUP([ofproto-dpif - packet-in reasons (Openflow 1.3)])
2883 OVS_VSWITCHD_START([dnl
2884    add-port br0 p1 -- set Interface p1 type=dummy
2885 ])
2886 ON_EXIT([kill `cat ovs-ofctl.pid`])
2887
2888 AT_CAPTURE_FILE([ofctl_monitor.log])
2889 AT_DATA([flows.txt], [dnl
2890 table=0 in_port=1 actions=write_actions(output(CONTROLLER)),goto_table(1)
2891 table=1 actions=output(CONTROLLER),goto_table(2)
2892 table=2 actions=group:1234
2893 ])
2894 AT_CHECK([ovs-ofctl --protocols=OpenFlow13 add-group br0 'group_id=1234,type=all,bucket=output:10,bucket=output:CONTROLLER'])
2895 AT_CHECK([ovs-ofctl --protocols=OpenFlow13 add-flows br0 flows.txt])
2896
2897 dnl Singleton controller action.
2898 AT_CHECK([ovs-ofctl monitor -P openflow10 --protocols=OpenFlow13 br0 65534 --detach --no-chdir --pidfile 2> ofctl_monitor.log])
2899
2900 for i in 1 2 3 ; do
2901     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=10:11:11:11:11:11,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=6,tos=0,ttl=64,frag=no),tcp(src=8,dst=10),tcp_flags(0x002)'
2902 done
2903 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
2904 ovs-appctl -t ovs-ofctl exit
2905
2906 AT_CHECK([ovs-appctl time/warp 5000], [0], [ignore])
2907
2908 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
2909 OFPT_PACKET_IN (OF1.3) (xid=0x0): table_id=1 cookie=0x0 total_len=60 in_port=1 (via action) data_len=60 (unbuffered)
2910 tcp,vlan_tci=0x0000,dl_src=10:11:11:11:11:11,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=10,tcp_flags=syn tcp_csum:0
2911 dnl
2912 OFPT_PACKET_IN (OF1.3) (xid=0x0): table_id=2 cookie=0x0 total_len=60 in_port=1 (via action) data_len=60 (unbuffered)
2913 tcp,vlan_tci=0x0000,dl_src=10:11:11:11:11:11,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=10,tcp_flags=syn tcp_csum:0
2914 dnl
2915 OFPT_PACKET_IN (OF1.3) (xid=0x0): cookie=0x0 total_len=60 in_port=1 (via action) data_len=60 (unbuffered)
2916 tcp,vlan_tci=0x0000,dl_src=10:11:11:11:11:11,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=10,tcp_flags=syn tcp_csum:0
2917 dnl
2918 OFPT_PACKET_IN (OF1.3) (xid=0x0): table_id=1 cookie=0x0 total_len=60 in_port=1 (via action) data_len=60 (unbuffered)
2919 tcp,vlan_tci=0x0000,dl_src=10:11:11:11:11:11,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=10,tcp_flags=syn tcp_csum:0
2920 dnl
2921 OFPT_PACKET_IN (OF1.3) (xid=0x0): table_id=2 cookie=0x0 total_len=60 in_port=1 (via action) data_len=60 (unbuffered)
2922 tcp,vlan_tci=0x0000,dl_src=10:11:11:11:11:11,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=10,tcp_flags=syn tcp_csum:0
2923 dnl
2924 OFPT_PACKET_IN (OF1.3) (xid=0x0): cookie=0x0 total_len=60 in_port=1 (via action) data_len=60 (unbuffered)
2925 tcp,vlan_tci=0x0000,dl_src=10:11:11:11:11:11,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=10,tcp_flags=syn tcp_csum:0
2926 dnl
2927 OFPT_PACKET_IN (OF1.3) (xid=0x0): table_id=1 cookie=0x0 total_len=60 in_port=1 (via action) data_len=60 (unbuffered)
2928 tcp,vlan_tci=0x0000,dl_src=10:11:11:11:11:11,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=10,tcp_flags=syn tcp_csum:0
2929 dnl
2930 OFPT_PACKET_IN (OF1.3) (xid=0x0): table_id=2 cookie=0x0 total_len=60 in_port=1 (via action) data_len=60 (unbuffered)
2931 tcp,vlan_tci=0x0000,dl_src=10:11:11:11:11:11,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=10,tcp_flags=syn tcp_csum:0
2932 dnl
2933 OFPT_PACKET_IN (OF1.3) (xid=0x0): cookie=0x0 total_len=60 in_port=1 (via action) data_len=60 (unbuffered)
2934 tcp,vlan_tci=0x0000,dl_src=10:11:11:11:11:11,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=10,tcp_flags=syn tcp_csum:0
2935 ])
2936
2937 AT_CHECK([ovs-appctl time/warp 5000], [0], [ignore])
2938
2939 AT_CHECK([ovs-ofctl --protocols=OpenFlow13 dump-flows br0 | ofctl_strip | sort], [0], [dnl
2940  n_packets=3, n_bytes=180, in_port=1 actions=write_actions(CONTROLLER:65535),goto_table:1
2941  table=1, n_packets=3, n_bytes=180, actions=CONTROLLER:65535,goto_table:2
2942  table=2, n_packets=3, n_bytes=180, actions=group:1234
2943 OFPST_FLOW reply (OF1.3):
2944 ])
2945
2946 OVS_VSWITCHD_STOP
2947 AT_CLEANUP
2948
2949
2950 AT_SETUP([ofproto-dpif - packet-in reasons (Openflow 1.4)])
2951 OVS_VSWITCHD_START([dnl
2952    add-port br0 p1 -- set Interface p1 type=dummy
2953 ])
2954 ON_EXIT([kill `cat ovs-ofctl.pid`])
2955
2956 AT_CAPTURE_FILE([ofctl_monitor.log])
2957 AT_DATA([flows.txt], [dnl
2958 table=0 in_port=1 actions=write_actions(output(CONTROLLER)),goto_table(1)
2959 table=1 actions=output(CONTROLLER),goto_table(2)
2960 table=2 actions=group:1234
2961 ])
2962 AT_CHECK([ovs-ofctl --protocols=OpenFlow14 add-group br0 'group_id=1234,type=all,bucket=output:10,bucket=output:CONTROLLER'])
2963 AT_CHECK([ovs-ofctl --protocols=OpenFlow14 add-flows br0 flows.txt])
2964
2965 dnl Singleton controller action.
2966 AT_CHECK([ovs-ofctl monitor -P openflow10 --protocols=OpenFlow14 br0 65534 --detach --no-chdir --pidfile 2> ofctl_monitor.log])
2967
2968 for i in 1 2 3 ; do
2969     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=10:11:11:11:11:11,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=6,tos=0,ttl=64,frag=no),tcp(src=8,dst=10),tcp_flags(0x002)'
2970 done
2971 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
2972 ovs-appctl -t ovs-ofctl exit
2973
2974 AT_CHECK([ovs-appctl time/warp 5000], [0], [ignore])
2975
2976 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
2977 OFPT_PACKET_IN (OF1.4) (xid=0x0): table_id=1 cookie=0x0 total_len=60 in_port=1 (via action) data_len=60 (unbuffered)
2978 tcp,vlan_tci=0x0000,dl_src=10:11:11:11:11:11,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=10,tcp_flags=syn tcp_csum:0
2979 dnl
2980 OFPT_PACKET_IN (OF1.4) (xid=0x0): table_id=2 cookie=0x0 total_len=60 in_port=1 (via group) data_len=60 (unbuffered)
2981 tcp,vlan_tci=0x0000,dl_src=10:11:11:11:11:11,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=10,tcp_flags=syn tcp_csum:0
2982 dnl
2983 OFPT_PACKET_IN (OF1.4) (xid=0x0): cookie=0x0 total_len=60 in_port=1 (via action_set) data_len=60 (unbuffered)
2984 tcp,vlan_tci=0x0000,dl_src=10:11:11:11:11:11,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=10,tcp_flags=syn tcp_csum:0
2985 dnl
2986 OFPT_PACKET_IN (OF1.4) (xid=0x0): table_id=1 cookie=0x0 total_len=60 in_port=1 (via action) data_len=60 (unbuffered)
2987 tcp,vlan_tci=0x0000,dl_src=10:11:11:11:11:11,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=10,tcp_flags=syn tcp_csum:0
2988 dnl
2989 OFPT_PACKET_IN (OF1.4) (xid=0x0): table_id=2 cookie=0x0 total_len=60 in_port=1 (via group) data_len=60 (unbuffered)
2990 tcp,vlan_tci=0x0000,dl_src=10:11:11:11:11:11,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=10,tcp_flags=syn tcp_csum:0
2991 dnl
2992 OFPT_PACKET_IN (OF1.4) (xid=0x0): cookie=0x0 total_len=60 in_port=1 (via action_set) data_len=60 (unbuffered)
2993 tcp,vlan_tci=0x0000,dl_src=10:11:11:11:11:11,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=10,tcp_flags=syn tcp_csum:0
2994 dnl
2995 OFPT_PACKET_IN (OF1.4) (xid=0x0): table_id=1 cookie=0x0 total_len=60 in_port=1 (via action) data_len=60 (unbuffered)
2996 tcp,vlan_tci=0x0000,dl_src=10:11:11:11:11:11,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=10,tcp_flags=syn tcp_csum:0
2997 dnl
2998 OFPT_PACKET_IN (OF1.4) (xid=0x0): table_id=2 cookie=0x0 total_len=60 in_port=1 (via group) data_len=60 (unbuffered)
2999 tcp,vlan_tci=0x0000,dl_src=10:11:11:11:11:11,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=10,tcp_flags=syn tcp_csum:0
3000 dnl
3001 OFPT_PACKET_IN (OF1.4) (xid=0x0): cookie=0x0 total_len=60 in_port=1 (via action_set) data_len=60 (unbuffered)
3002 tcp,vlan_tci=0x0000,dl_src=10:11:11:11:11:11,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,tp_src=8,tp_dst=10,tcp_flags=syn tcp_csum:0
3003 ])
3004
3005 AT_CHECK([ovs-appctl time/warp 5000], [0], [ignore])
3006
3007 AT_CHECK([ovs-ofctl --protocols=OpenFlow14 dump-flows br0 | ofctl_strip | sort], [0], [dnl
3008  n_packets=3, n_bytes=180, in_port=1 actions=write_actions(CONTROLLER:65535),goto_table:1
3009  table=1, n_packets=3, n_bytes=180, actions=CONTROLLER:65535,goto_table:2
3010  table=2, n_packets=3, n_bytes=180, actions=group:1234
3011 OFPST_FLOW reply (OF1.4):
3012 ])
3013
3014 OVS_VSWITCHD_STOP
3015 AT_CLEANUP
3016
3017
3018 AT_SETUP([ofproto-dpif - ARP modification slow-path])
3019 OVS_VSWITCHD_START
3020 ADD_OF_PORTS([br0], [1], [2])
3021
3022 ovs-vsctl -- set Interface p2 type=dummy options:pcap=p2.pcap
3023 ovs-ofctl add-flow br0 'in_port=1,arp actions=load:2->OXM_OF_ARP_OP[[]],2,load:0xc0a88001->OXM_OF_ARP_SPA[[]],2,load:0x404444444441->OXM_OF_ARP_THA[[]],2'
3024
3025 # Input some packets that should follow the arp modification slow-path.
3026 for i in 1 2 3; do
3027     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=80:88:88:88:88:88,dst=ff:ff:ff:ff:ff:ff),eth_type(0x0806),arp(sip=192.168.0.1,tip=192.168.0.2,op=1,sha=50:54:00:00:00:05,tha=00:00:00:00:00:00)'
3028 done
3029 AT_CHECK([ovs-appctl time/warp 5000], [0], [ignore])
3030
3031 # Check the packets that were output.
3032 AT_CHECK([ovs-ofctl parse-pcap p2.pcap], [0], [dnl
3033 arp,in_port=ANY,vlan_tci=0x0000,dl_src=80:88:88:88:88:88,dl_dst=ff:ff:ff:ff:ff:ff,arp_spa=192.168.0.1,arp_tpa=192.168.0.2,arp_op=2,arp_sha=50:54:00:00:00:05,arp_tha=00:00:00:00:00:00
3034 arp,in_port=ANY,vlan_tci=0x0000,dl_src=80:88:88:88:88:88,dl_dst=ff:ff:ff:ff:ff:ff,arp_spa=192.168.128.1,arp_tpa=192.168.0.2,arp_op=2,arp_sha=50:54:00:00:00:05,arp_tha=00:00:00:00:00:00
3035 arp,in_port=ANY,vlan_tci=0x0000,dl_src=80:88:88:88:88:88,dl_dst=ff:ff:ff:ff:ff:ff,arp_spa=192.168.128.1,arp_tpa=192.168.0.2,arp_op=2,arp_sha=50:54:00:00:00:05,arp_tha=40:44:44:44:44:41
3036 arp,in_port=ANY,vlan_tci=0x0000,dl_src=80:88:88:88:88:88,dl_dst=ff:ff:ff:ff:ff:ff,arp_spa=192.168.0.1,arp_tpa=192.168.0.2,arp_op=2,arp_sha=50:54:00:00:00:05,arp_tha=00:00:00:00:00:00
3037 arp,in_port=ANY,vlan_tci=0x0000,dl_src=80:88:88:88:88:88,dl_dst=ff:ff:ff:ff:ff:ff,arp_spa=192.168.128.1,arp_tpa=192.168.0.2,arp_op=2,arp_sha=50:54:00:00:00:05,arp_tha=00:00:00:00:00:00
3038 arp,in_port=ANY,vlan_tci=0x0000,dl_src=80:88:88:88:88:88,dl_dst=ff:ff:ff:ff:ff:ff,arp_spa=192.168.128.1,arp_tpa=192.168.0.2,arp_op=2,arp_sha=50:54:00:00:00:05,arp_tha=40:44:44:44:44:41
3039 arp,in_port=ANY,vlan_tci=0x0000,dl_src=80:88:88:88:88:88,dl_dst=ff:ff:ff:ff:ff:ff,arp_spa=192.168.0.1,arp_tpa=192.168.0.2,arp_op=2,arp_sha=50:54:00:00:00:05,arp_tha=00:00:00:00:00:00
3040 arp,in_port=ANY,vlan_tci=0x0000,dl_src=80:88:88:88:88:88,dl_dst=ff:ff:ff:ff:ff:ff,arp_spa=192.168.128.1,arp_tpa=192.168.0.2,arp_op=2,arp_sha=50:54:00:00:00:05,arp_tha=00:00:00:00:00:00
3041 arp,in_port=ANY,vlan_tci=0x0000,dl_src=80:88:88:88:88:88,dl_dst=ff:ff:ff:ff:ff:ff,arp_spa=192.168.128.1,arp_tpa=192.168.0.2,arp_op=2,arp_sha=50:54:00:00:00:05,arp_tha=40:44:44:44:44:41
3042 ])
3043
3044 OVS_VSWITCHD_STOP
3045 AT_CLEANUP
3046
3047 AT_SETUP([ofproto-dpif - VLAN handling])
3048 OVS_VSWITCHD_START(
3049   [set Bridge br0 fail-mode=standalone -- \
3050    add-port br0 p1                                  trunks=10,12 -- \
3051    add-port br0 p2                           tag=10              -- \
3052    add-port br0 p3                           tag=12              \
3053                    other-config:priority-tags=true               -- \
3054    add-port br0 p4                           tag=12              -- \
3055    add-port br0 p5 vlan_mode=native-tagged   tag=10              -- \
3056    add-port br0 p6 vlan_mode=native-tagged   tag=10 trunks=10,12 -- \
3057    add-port br0 p7 vlan_mode=native-untagged tag=12              -- \
3058    add-port br0 p8 vlan_mode=native-untagged tag=12 trunks=10,12 \
3059                    other-config:priority-tags=true               -- \
3060    set Interface p1 type=dummy -- \
3061    set Interface p2 type=dummy -- \
3062    set Interface p3 type=dummy -- \
3063    set Interface p4 type=dummy -- \
3064    set Interface p5 type=dummy -- \
3065    set Interface p6 type=dummy -- \
3066    set Interface p7 type=dummy -- \
3067    set Interface p8 type=dummy --])
3068
3069 dnl Each of these specifies an in_port by number, a VLAN VID (or "none"),
3070 dnl a VLAN PCP (used if the VID isn't "none") and the expected set of datapath
3071 dnl actions.
3072 for tuple in \
3073         "100 none 0 drop" \
3074         "100 0    0 drop" \
3075         "100 0    1 drop" \
3076         "100 10   0 1,5,6,7,8,pop_vlan,2" \
3077         "100 10   1 1,5,6,7,8,pop_vlan,2" \
3078         "100 11   0 5,7" \
3079         "100 11   1 5,7" \
3080         "100 12   0 1,5,6,pop_vlan,3,4,7,8" \
3081         "100 12   1 1,5,6,pop_vlan,4,7,push_vlan(vid=0,pcp=1),3,8" \
3082         "1  none 0 drop" \
3083         "1  0    0 drop" \
3084         "1  0    1 drop" \
3085         "1  10   0 5,6,7,8,100,pop_vlan,2" \
3086         "1  10   1 5,6,7,8,100,pop_vlan,2" \
3087         "1  11   0 drop" \
3088         "1  11   1 drop" \
3089         "1  12   0 5,6,100,pop_vlan,3,4,7,8" \
3090         "1  12   1 5,6,100,pop_vlan,4,7,push_vlan(vid=0,pcp=1),3,8" \
3091         "2  none 0 push_vlan(vid=10,pcp=0),1,5,6,7,8,100" \
3092         "2  0    0 pop_vlan,push_vlan(vid=10,pcp=0),1,5,6,7,8,100" \
3093         "2  0    1 pop_vlan,push_vlan(vid=10,pcp=1),1,5,6,7,8,100" \
3094         "2  10   0 drop" \
3095         "2  10   1 drop" \
3096         "2  11   0 drop" \
3097         "2  11   1 drop" \
3098         "2  12   0 drop" \
3099         "2  12   1 drop" \
3100         "3  none 0 4,7,8,push_vlan(vid=12,pcp=0),1,5,6,100" \
3101         "3  0    0 pop_vlan,4,7,8,push_vlan(vid=12,pcp=0),1,5,6,100" \
3102         "3  0    1 8,pop_vlan,4,7,push_vlan(vid=12,pcp=1),1,5,6,100" \
3103         "3  10   0 drop" \
3104         "3  10   1 drop" \
3105         "3  11   0 drop" \
3106         "3  11   1 drop" \
3107         "3  12   0 drop" \
3108         "3  12   1 drop" \
3109         "4  none 0 3,7,8,push_vlan(vid=12,pcp=0),1,5,6,100" \
3110         "4  0    0 pop_vlan,3,7,8,push_vlan(vid=12,pcp=0),1,5,6,100" \
3111         "4  0    1 3,8,pop_vlan,7,push_vlan(vid=12,pcp=1),1,5,6,100" \
3112         "4  10   0 drop" \
3113         "4  10   1 drop" \
3114         "4  11   0 drop" \
3115         "4  11   1 drop" \
3116         "4  12   0 drop" \
3117         "4  12   1 drop" \
3118         "5  none 0 2,push_vlan(vid=10,pcp=0),1,6,7,8,100" \
3119         "5  0    0 pop_vlan,2,push_vlan(vid=10,pcp=0),1,6,7,8,100" \
3120         "5  0    1 pop_vlan,2,push_vlan(vid=10,pcp=1),1,6,7,8,100" \
3121         "5  10   0 1,6,7,8,100,pop_vlan,2" \
3122         "5  10   1 1,6,7,8,100,pop_vlan,2" \
3123         "5  11   0 7,100" \
3124         "5  11   1 7,100" \
3125         "5  12   0 1,6,100,pop_vlan,3,4,7,8" \
3126         "5  12   1 1,6,100,pop_vlan,4,7,push_vlan(vid=0,pcp=1),3,8" \
3127         "6  none 0 2,push_vlan(vid=10,pcp=0),1,5,7,8,100" \
3128         "6  0    0 pop_vlan,2,push_vlan(vid=10,pcp=0),1,5,7,8,100" \
3129         "6  0    1 pop_vlan,2,push_vlan(vid=10,pcp=1),1,5,7,8,100" \
3130         "6  10   0 1,5,7,8,100,pop_vlan,2" \
3131         "6  10   1 1,5,7,8,100,pop_vlan,2" \
3132         "6  11   0 drop" \
3133         "6  11   1 drop" \
3134         "6  12   0 1,5,100,pop_vlan,3,4,7,8" \
3135         "6  12   1 1,5,100,pop_vlan,4,7,push_vlan(vid=0,pcp=1),3,8" \
3136         "7  none 0 3,4,8,push_vlan(vid=12,pcp=0),1,5,6,100" \
3137         "7  0    0 pop_vlan,3,4,8,push_vlan(vid=12,pcp=0),1,5,6,100" \
3138         "7  0    1 3,8,pop_vlan,4,push_vlan(vid=12,pcp=1),1,5,6,100" \
3139         "7  10   0 1,5,6,8,100,pop_vlan,2" \
3140         "7  10   1 1,5,6,8,100,pop_vlan,2" \
3141         "7  11   0 5,100" \
3142         "7  11   1 5,100" \
3143         "7  12   0 1,5,6,100,pop_vlan,3,4,8" \
3144         "7  12   1 1,5,6,100,pop_vlan,4,push_vlan(vid=0,pcp=1),3,8" \
3145         "8  none 0 3,4,7,push_vlan(vid=12,pcp=0),1,5,6,100" \
3146         "8  0    0 pop_vlan,3,4,7,push_vlan(vid=12,pcp=0),1,5,6,100" \
3147         "8  0    1 3,pop_vlan,4,7,push_vlan(vid=12,pcp=1),1,5,6,100" \
3148         "8  10   0 1,5,6,7,100,pop_vlan,2" \
3149         "8  10   1 1,5,6,7,100,pop_vlan,2" \
3150         "8  11   0 drop" \
3151         "8  11   1 drop" \
3152         "8  12   0 1,5,6,100,pop_vlan,3,4,7" \
3153         "8  12   1 1,5,6,100,pop_vlan,4,7,push_vlan(vid=0,pcp=1),3"
3154 do
3155   set $tuple
3156   in_port=$1
3157   vlan=$2
3158   pcp=$3
3159   expected=$4
3160
3161   if test $vlan = none; then
3162     flow="in_port($in_port),eth(src=50:54:00:00:00:01,dst=ff:ff:ff:ff:ff:ff),eth_type(0xabcd)"
3163   else
3164     flow="in_port($in_port),eth(src=50:54:00:00:00:01,dst=ff:ff:ff:ff:ff:ff),eth_type(0x8100),vlan(vid=$vlan,pcp=$pcp),encap(eth_type(0xabcd))"
3165   fi
3166
3167   echo "----------------------------------------------------------------------"
3168   echo "in_port=$in_port vlan=$vlan pcp=$pcp"
3169
3170   AT_CHECK([ovs-appctl ofproto/trace ovs-dummy "$flow"], [0], [stdout])
3171   actual=`tail -1 stdout | sed 's/Datapath actions: //'`
3172
3173   AT_CHECK([ovs-dpctl normalize-actions "$flow" "$expected"], [0], [stdout])
3174   mv stdout expout
3175   AT_CHECK([ovs-dpctl normalize-actions "$flow" "$actual"], [0], [expout])
3176 done
3177
3178 OVS_VSWITCHD_STOP
3179 AT_CLEANUP
3180
3181 AT_SETUP([ofproto-dpif - MPLS handling])
3182 OVS_VSWITCHD_START([dnl
3183    add-port br0 p1 -- set Interface p1 type=dummy
3184 ])
3185 ON_EXIT([kill `cat ovs-ofctl.pid`])
3186
3187 AT_CAPTURE_FILE([ofctl_monitor.log])
3188 AT_DATA([flows.txt], [dnl
3189 dl_src=40:44:44:44:00:00 actions=push_mpls:0x8847,controller
3190 dl_src=40:44:44:44:00:01,mpls actions=push_mpls:0x8847,controller
3191 dl_src=40:44:44:44:00:02,mpls actions=push_mpls:0x8848,controller
3192 ])
3193 AT_CHECK([ovs-ofctl --protocols=OpenFlow12 add-flows br0 flows.txt])
3194
3195 dnl In this test, we push an MPLS tag to an ethernet packet.
3196 AT_CHECK([ovs-ofctl --protocols=OpenFlow12 monitor br0 65534 -m -P nxm --detach --pidfile 2> ofctl_monitor.log])
3197
3198 for i in 1 2 3; do
3199     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=40:44:44:44:00:00,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=6,tos=0,ttl=64,frag=no)'
3200 done
3201 OVS_WAIT_UNTIL([test `grep OFPT_PACKET_IN ofctl_monitor.log | wc -l` -ge 3])
3202 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
3203
3204 AT_CHECK([cat ofctl_monitor.log | ofctl_strip], [0], [dnl
3205 OFPT_PACKET_IN (OF1.2): total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
3206 mpls,vlan_tci=0x0000,dl_src=40:44:44:44:00:00,dl_dst=50:54:00:00:00:07,mpls_label=0,mpls_tc=0,mpls_ttl=64,mpls_bos=1
3207 00000000  50 54 00 00 00 07 40 44-44 44 00 00 88 47 00 00
3208 00000010  01 40 45 00 00 28 00 00-00 00 40 06 f9 7c c0 a8
3209 00000020  00 01 c0 a8 00 02 00 00-00 00 00 00 00 00 00 00
3210 00000030  00 00 50 00 00 00 00 00-00 00 00 00 00 00 00 00
3211 dnl
3212 OFPT_PACKET_IN (OF1.2): total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
3213 mpls,vlan_tci=0x0000,dl_src=40:44:44:44:00:00,dl_dst=50:54:00:00:00:07,mpls_label=0,mpls_tc=0,mpls_ttl=64,mpls_bos=1
3214 00000000  50 54 00 00 00 07 40 44-44 44 00 00 88 47 00 00
3215 00000010  01 40 45 00 00 28 00 00-00 00 40 06 f9 7c c0 a8
3216 00000020  00 01 c0 a8 00 02 00 00-00 00 00 00 00 00 00 00
3217 00000030  00 00 50 00 00 00 00 00-00 00 00 00 00 00 00 00
3218 dnl
3219 OFPT_PACKET_IN (OF1.2): total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
3220 mpls,vlan_tci=0x0000,dl_src=40:44:44:44:00:00,dl_dst=50:54:00:00:00:07,mpls_label=0,mpls_tc=0,mpls_ttl=64,mpls_bos=1
3221 00000000  50 54 00 00 00 07 40 44-44 44 00 00 88 47 00 00
3222 00000010  01 40 45 00 00 28 00 00-00 00 40 06 f9 7c c0 a8
3223 00000020  00 01 c0 a8 00 02 00 00-00 00 00 00 00 00 00 00
3224 00000030  00 00 50 00 00 00 00 00-00 00 00 00 00 00 00 00
3225 ])
3226
3227 dnl In this test, we push an MPLS tag to an MPLS packet. The LSE should be
3228 dnl copied exactly, except for the BOS bit.
3229 AT_CHECK([ovs-ofctl --protocols=OpenFlow12 monitor br0 65534 -m -P nxm --detach --pidfile 2> ofctl_monitor.log])
3230
3231 for i in 1 2 3; do
3232     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=40:44:44:44:00:01,dst=50:54:00:00:00:07),eth_type(0x8847),mpls(label=10,tc=0,ttl=64,bos=1)'
3233 done
3234 OVS_WAIT_UNTIL([test `grep OFPT_PACKET_IN ofctl_monitor.log | wc -l` -ge 3])
3235 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
3236
3237 AT_CHECK([cat ofctl_monitor.log | ofctl_strip], [0], [dnl
3238 OFPT_PACKET_IN (OF1.2): total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
3239 mpls,vlan_tci=0x0000,dl_src=40:44:44:44:00:01,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=0,mpls_ttl=64,mpls_bos=0,mpls_lse1=41280
3240 00000000  50 54 00 00 00 07 40 44-44 44 00 01 88 47 00 00
3241 00000010  a0 40 00 00 a1 40 00 00-00 00 00 00 00 00 00 00
3242 00000020  00 00 00 00 00 00 00 00-00 00 00 00 00 00 00 00
3243 00000030  00 00 00 00 00 00 00 00-00 00 00 00 00 00 00 00
3244 dnl
3245 OFPT_PACKET_IN (OF1.2): total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
3246 mpls,vlan_tci=0x0000,dl_src=40:44:44:44:00:01,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=0,mpls_ttl=64,mpls_bos=0,mpls_lse1=41280
3247 00000000  50 54 00 00 00 07 40 44-44 44 00 01 88 47 00 00
3248 00000010  a0 40 00 00 a1 40 00 00-00 00 00 00 00 00 00 00
3249 00000020  00 00 00 00 00 00 00 00-00 00 00 00 00 00 00 00
3250 00000030  00 00 00 00 00 00 00 00-00 00 00 00 00 00 00 00
3251 dnl
3252 OFPT_PACKET_IN (OF1.2): total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
3253 mpls,vlan_tci=0x0000,dl_src=40:44:44:44:00:01,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=0,mpls_ttl=64,mpls_bos=0,mpls_lse1=41280
3254 00000000  50 54 00 00 00 07 40 44-44 44 00 01 88 47 00 00
3255 00000010  a0 40 00 00 a1 40 00 00-00 00 00 00 00 00 00 00
3256 00000020  00 00 00 00 00 00 00 00-00 00 00 00 00 00 00 00
3257 00000030  00 00 00 00 00 00 00 00-00 00 00 00 00 00 00 00
3258 ])
3259
3260 dnl In this test, we push an MPLS tag to an MPLS packet. The LSE should be
3261 dnl copied exactly, except for the BOS bit. The ethertype should be updated
3262 dnl to the MPLS ethertype of the MPLS push action which differs to that
3263 dnl of the input packet.
3264 AT_CHECK([ovs-ofctl --protocols=OpenFlow12 monitor br0 65534 -m -P nxm --detach --pidfile 2> ofctl_monitor.log])
3265
3266 for i in 1 2 3; do
3267     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=40:44:44:44:00:02,dst=50:54:00:00:00:07),eth_type(0x8847),mpls(label=10,tc=0,ttl=64,bos=1)'
3268 done
3269 OVS_WAIT_UNTIL([test `grep OFPT_PACKET_IN ofctl_monitor.log | wc -l` -ge 3])
3270 OVS_WAIT_UNTIL([ovs-appctl -t ovs-ofctl exit])
3271
3272 AT_CHECK([cat ofctl_monitor.log | ofctl_strip], [0], [dnl
3273 OFPT_PACKET_IN (OF1.2): total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
3274 mplsm,vlan_tci=0x0000,dl_src=40:44:44:44:00:02,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=0,mpls_ttl=64,mpls_bos=0,mpls_lse1=41280
3275 00000000  50 54 00 00 00 07 40 44-44 44 00 02 88 48 00 00
3276 00000010  a0 40 00 00 a1 40 00 00-00 00 00 00 00 00 00 00
3277 00000020  00 00 00 00 00 00 00 00-00 00 00 00 00 00 00 00
3278 00000030  00 00 00 00 00 00 00 00-00 00 00 00 00 00 00 00
3279 dnl
3280 OFPT_PACKET_IN (OF1.2): total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
3281 mplsm,vlan_tci=0x0000,dl_src=40:44:44:44:00:02,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=0,mpls_ttl=64,mpls_bos=0,mpls_lse1=41280
3282 00000000  50 54 00 00 00 07 40 44-44 44 00 02 88 48 00 00
3283 00000010  a0 40 00 00 a1 40 00 00-00 00 00 00 00 00 00 00
3284 00000020  00 00 00 00 00 00 00 00-00 00 00 00 00 00 00 00
3285 00000030  00 00 00 00 00 00 00 00-00 00 00 00 00 00 00 00
3286 dnl
3287 OFPT_PACKET_IN (OF1.2): total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
3288 mplsm,vlan_tci=0x0000,dl_src=40:44:44:44:00:02,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=0,mpls_ttl=64,mpls_bos=0,mpls_lse1=41280
3289 00000000  50 54 00 00 00 07 40 44-44 44 00 02 88 48 00 00
3290 00000010  a0 40 00 00 a1 40 00 00-00 00 00 00 00 00 00 00
3291 00000020  00 00 00 00 00 00 00 00-00 00 00 00 00 00 00 00
3292 00000030  00 00 00 00 00 00 00 00-00 00 00 00 00 00 00 00
3293 ])
3294
3295 OVS_VSWITCHD_STOP
3296 AT_CLEANUP
3297
3298 AT_SETUP([ofproto-dpif - VLAN+MPLS handling])
3299 OVS_VSWITCHD_START([dnl
3300    add-port br0 p1 -- set Interface p1 type=dummy
3301 ])
3302 ON_EXIT([kill `cat ovs-ofctl.pid`])
3303
3304 AT_CAPTURE_FILE([ofctl_monitor.log])
3305 AT_DATA([flows.txt], [dnl
3306 cookie=0xa dl_src=40:44:44:44:54:50 actions=push_mpls:0x8847,load:10->OXM_OF_MPLS_LABEL[[]],push_vlan:0x8100,set_vlan_vid:99,set_vlan_pcp:1,controller
3307 cookie=0xa dl_src=40:44:44:44:54:51 actions=push_mpls:0x8847,load:10->OXM_OF_MPLS_LABEL[[]],push_vlan:0x8100,set_vlan_vid:99,set_vlan_pcp:1,controller
3308 cookie=0xa dl_src=40:44:44:44:54:52 actions=push_mpls:0x8847,load:10->OXM_OF_MPLS_LABEL[[]],push_vlan:0x8100,load:99->OXM_OF_VLAN_VID[[]],set_vlan_pcp:1,controller
3309 cookie=0xa dl_src=40:44:44:44:54:53 actions=push_mpls:0x8847,load:10->OXM_OF_MPLS_LABEL[[]],push_vlan:0x8100,load:99->OXM_OF_VLAN_VID[[]],set_vlan_pcp:1,controller
3310 cookie=0xa dl_src=40:44:44:44:54:54 actions=push_vlan:0x8100,set_vlan_vid:99,set_vlan_pcp:1,push_mpls:0x8847,load:10->OXM_OF_MPLS_LABEL[[]],controller
3311 cookie=0xa dl_src=40:44:44:44:54:55 actions=push_vlan:0x8100,set_vlan_vid:99,set_vlan_pcp:1,push_mpls:0x8847,load:10->OXM_OF_MPLS_LABEL[[]],controller
3312 cookie=0xa dl_src=40:44:44:44:54:56 actions=push_vlan:0x8100,load:99->OXM_OF_VLAN_VID[[]],set_vlan_pcp:1,push_mpls:0x8847,load:10->OXM_OF_MPLS_LABEL[[]],controller
3313 cookie=0xa dl_src=40:44:44:44:54:57 actions=push_vlan:0x8100,load:99->OXM_OF_VLAN_VID[[]],set_vlan_pcp:1,push_mpls:0x8847,load:10->OXM_OF_MPLS_LABEL[[]],controller
3314 cookie=0xa dl_src=40:44:44:44:54:58,vlan_tci=0x1000/0x1000 actions=load:99->OXM_OF_VLAN_VID[[]],set_vlan_pcp:1,push_mpls:0x8847,load:10->OXM_OF_MPLS_LABEL[[]],controller
3315 cookie=0xa dl_src=40:44:44:44:54:59,vlan_tci=0x1000/0x1000 actions=push_mpls:0x8847,load:10->OXM_OF_MPLS_LABEL[[]],set_vlan_pcp:1,load:99->OXM_OF_VLAN_VID[[]],controller
3316 ])
3317 AT_CHECK([ovs-ofctl --protocols=OpenFlow12 add-flows br0 flows.txt])
3318
3319 dnl Modified MPLS controller action.
3320 dnl In this test, we push the MPLS tag before pushing a VLAN tag, so we see
3321 dnl both of these in the final flow
3322 AT_CHECK([ovs-ofctl --protocols=OpenFlow12 monitor br0 65534 -m -P nxm --detach --pidfile 2> ofctl_monitor.log])
3323
3324 for i in 1 2 3; do
3325     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=40:44:44:44:54:50,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=6,tos=0,ttl=64,frag=no)'
3326 done
3327 OVS_WAIT_UNTIL([test `grep OFPT_PACKET_IN ofctl_monitor.log | wc -l` -ge 3])
3328 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
3329
3330 AT_CHECK([cat ofctl_monitor.log | ofctl_strip], [0], [dnl
3331 OFPT_PACKET_IN (OF1.2): total_len=68 in_port=1 (via action) data_len=68 (unbuffered)
3332 mpls,dl_vlan=99,dl_vlan_pcp=1,dl_src=40:44:44:44:54:50,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=0,mpls_ttl=64,mpls_bos=1
3333 00000000  50 54 00 00 00 07 40 44-44 44 54 50 81 00 20 63
3334 00000010  88 47 00 00 a1 40 45 00-00 28 00 00 00 00 40 06
3335 00000020  f9 7c c0 a8 00 01 c0 a8-00 02 00 00 00 00 00 00
3336 00000030  00 00 00 00 00 00 50 00-00 00 00 00 00 00 00 00
3337 00000040  00 00 00 00
3338 dnl
3339 OFPT_PACKET_IN (OF1.2): total_len=68 in_port=1 (via action) data_len=68 (unbuffered)
3340 mpls,dl_vlan=99,dl_vlan_pcp=1,dl_src=40:44:44:44:54:50,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=0,mpls_ttl=64,mpls_bos=1
3341 00000000  50 54 00 00 00 07 40 44-44 44 54 50 81 00 20 63
3342 00000010  88 47 00 00 a1 40 45 00-00 28 00 00 00 00 40 06
3343 00000020  f9 7c c0 a8 00 01 c0 a8-00 02 00 00 00 00 00 00
3344 00000030  00 00 00 00 00 00 50 00-00 00 00 00 00 00 00 00
3345 00000040  00 00 00 00
3346 dnl
3347 OFPT_PACKET_IN (OF1.2): total_len=68 in_port=1 (via action) data_len=68 (unbuffered)
3348 mpls,dl_vlan=99,dl_vlan_pcp=1,dl_src=40:44:44:44:54:50,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=0,mpls_ttl=64,mpls_bos=1
3349 00000000  50 54 00 00 00 07 40 44-44 44 54 50 81 00 20 63
3350 00000010  88 47 00 00 a1 40 45 00-00 28 00 00 00 00 40 06
3351 00000020  f9 7c c0 a8 00 01 c0 a8-00 02 00 00 00 00 00 00
3352 00000030  00 00 00 00 00 00 50 00-00 00 00 00 00 00 00 00
3353 00000040  00 00 00 00
3354 ])
3355
3356 dnl Modified MPLS controller action.
3357 dnl In this test, the input packet in vlan-tagged, which should be stripped
3358 dnl before we push the MPLS and VLAN tags.
3359 AT_CHECK([ovs-ofctl --protocols=OpenFlow12 monitor br0 65534 -m -P nxm --detach --pidfile 2> ofctl_monitor.log])
3360
3361 for i in 1 2 3; do
3362     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=40:44:44:44:54:51,dst=50:54:00:00:00:07),eth_type(0x8100),vlan(vid=88,pcp=7),encap(eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=6,tos=0,ttl=64,frag=no))'
3363 done
3364 OVS_WAIT_UNTIL([test `grep OFPT_PACKET_IN ofctl_monitor.log | wc -l` -ge 3])
3365 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
3366
3367 AT_CHECK([cat ofctl_monitor.log | ofctl_strip], [0], [dnl
3368 OFPT_PACKET_IN (OF1.2): total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
3369 mpls,dl_vlan=99,dl_vlan_pcp=1,dl_src=40:44:44:44:54:51,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=0,mpls_ttl=64,mpls_bos=1
3370 00000000  50 54 00 00 00 07 40 44-44 44 54 51 81 00 20 63
3371 00000010  88 47 00 00 a1 40 45 00-00 28 00 00 00 00 40 06
3372 00000020  f9 7c c0 a8 00 01 c0 a8-00 02 00 00 00 00 00 00
3373 00000030  00 00 00 00 00 00 50 00-00 00 00 00 00 00 00 00
3374 dnl
3375 OFPT_PACKET_IN (OF1.2): total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
3376 mpls,dl_vlan=99,dl_vlan_pcp=1,dl_src=40:44:44:44:54:51,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=0,mpls_ttl=64,mpls_bos=1
3377 00000000  50 54 00 00 00 07 40 44-44 44 54 51 81 00 20 63
3378 00000010  88 47 00 00 a1 40 45 00-00 28 00 00 00 00 40 06
3379 00000020  f9 7c c0 a8 00 01 c0 a8-00 02 00 00 00 00 00 00
3380 00000030  00 00 00 00 00 00 50 00-00 00 00 00 00 00 00 00
3381 dnl
3382 OFPT_PACKET_IN (OF1.2): total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
3383 mpls,dl_vlan=99,dl_vlan_pcp=1,dl_src=40:44:44:44:54:51,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=0,mpls_ttl=64,mpls_bos=1
3384 00000000  50 54 00 00 00 07 40 44-44 44 54 51 81 00 20 63
3385 00000010  88 47 00 00 a1 40 45 00-00 28 00 00 00 00 40 06
3386 00000020  f9 7c c0 a8 00 01 c0 a8-00 02 00 00 00 00 00 00
3387 00000030  00 00 00 00 00 00 50 00-00 00 00 00 00 00 00 00
3388 ])
3389
3390 dnl Modified MPLS controller action.
3391 dnl In this test, we push the MPLS tag before pushing a VLAN tag, so we see
3392 dnl both of these in the final flow
3393 AT_CHECK([ovs-ofctl --protocols=OpenFlow12 monitor br0 65534 -m -P nxm --detach --pidfile 2> ofctl_monitor.log])
3394
3395 for i in 1 2 3; do
3396     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=40:44:44:44:54:52,dst=52:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=6,tos=0,ttl=64,frag=no)'
3397 done
3398 OVS_WAIT_UNTIL([test `grep OFPT_PACKET_IN ofctl_monitor.log | wc -l` -ge 3])
3399 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
3400
3401 AT_CHECK([cat ofctl_monitor.log | ofctl_strip], [0], [dnl
3402 OFPT_PACKET_IN (OF1.2): total_len=68 in_port=1 (via action) data_len=68 (unbuffered)
3403 mpls,dl_vlan=99,dl_vlan_pcp=1,dl_src=40:44:44:44:54:52,dl_dst=52:54:00:00:00:07,mpls_label=10,mpls_tc=0,mpls_ttl=64,mpls_bos=1
3404 00000000  52 54 00 00 00 07 40 44-44 44 54 52 81 00 20 63
3405 00000010  88 47 00 00 a1 40 45 00-00 28 00 00 00 00 40 06
3406 00000020  f9 7c c0 a8 00 01 c0 a8-00 02 00 00 00 00 00 00
3407 00000030  00 00 00 00 00 00 50 00-00 00 00 00 00 00 00 00
3408 00000040  00 00 00 00
3409 dnl
3410 OFPT_PACKET_IN (OF1.2): total_len=68 in_port=1 (via action) data_len=68 (unbuffered)
3411 mpls,dl_vlan=99,dl_vlan_pcp=1,dl_src=40:44:44:44:54:52,dl_dst=52:54:00:00:00:07,mpls_label=10,mpls_tc=0,mpls_ttl=64,mpls_bos=1
3412 00000000  52 54 00 00 00 07 40 44-44 44 54 52 81 00 20 63
3413 00000010  88 47 00 00 a1 40 45 00-00 28 00 00 00 00 40 06
3414 00000020  f9 7c c0 a8 00 01 c0 a8-00 02 00 00 00 00 00 00
3415 00000030  00 00 00 00 00 00 50 00-00 00 00 00 00 00 00 00
3416 00000040  00 00 00 00
3417 dnl
3418 OFPT_PACKET_IN (OF1.2): total_len=68 in_port=1 (via action) data_len=68 (unbuffered)
3419 mpls,dl_vlan=99,dl_vlan_pcp=1,dl_src=40:44:44:44:54:52,dl_dst=52:54:00:00:00:07,mpls_label=10,mpls_tc=0,mpls_ttl=64,mpls_bos=1
3420 00000000  52 54 00 00 00 07 40 44-44 44 54 52 81 00 20 63
3421 00000010  88 47 00 00 a1 40 45 00-00 28 00 00 00 00 40 06
3422 00000020  f9 7c c0 a8 00 01 c0 a8-00 02 00 00 00 00 00 00
3423 00000030  00 00 00 00 00 00 50 00-00 00 00 00 00 00 00 00
3424 00000040  00 00 00 00
3425 ])
3426
3427 dnl Modified MPLS controller action.
3428 dnl In this test, the input packet in vlan-tagged, which should be stripped
3429 dnl before we push the MPLS and VLAN tags.
3430 AT_CHECK([ovs-ofctl --protocols=OpenFlow12 monitor br0 65534 -m -P nxm --detach --pidfile 2> ofctl_monitor.log])
3431
3432 for i in 1 2 3; do
3433     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=40:44:44:44:54:53,dst=50:54:00:00:00:07),eth_type(0x8100),vlan(vid=88,pcp=7),encap(eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=6,tos=0,ttl=64,frag=no))'
3434 done
3435 OVS_WAIT_UNTIL([test `grep OFPT_PACKET_IN ofctl_monitor.log | wc -l` -ge 3])
3436 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
3437
3438 AT_CHECK([cat ofctl_monitor.log | ofctl_strip], [0], [dnl
3439 OFPT_PACKET_IN (OF1.2): total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
3440 mpls,dl_vlan=99,dl_vlan_pcp=1,dl_src=40:44:44:44:54:53,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=0,mpls_ttl=64,mpls_bos=1
3441 00000000  50 54 00 00 00 07 40 44-44 44 54 53 81 00 20 63
3442 00000010  88 47 00 00 a1 40 45 00-00 28 00 00 00 00 40 06
3443 00000020  f9 7c c0 a8 00 01 c0 a8-00 02 00 00 00 00 00 00
3444 00000030  00 00 00 00 00 00 50 00-00 00 00 00 00 00 00 00
3445 dnl
3446 OFPT_PACKET_IN (OF1.2): total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
3447 mpls,dl_vlan=99,dl_vlan_pcp=1,dl_src=40:44:44:44:54:53,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=0,mpls_ttl=64,mpls_bos=1
3448 00000000  50 54 00 00 00 07 40 44-44 44 54 53 81 00 20 63
3449 00000010  88 47 00 00 a1 40 45 00-00 28 00 00 00 00 40 06
3450 00000020  f9 7c c0 a8 00 01 c0 a8-00 02 00 00 00 00 00 00
3451 00000030  00 00 00 00 00 00 50 00-00 00 00 00 00 00 00 00
3452 dnl
3453 OFPT_PACKET_IN (OF1.2): total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
3454 mpls,dl_vlan=99,dl_vlan_pcp=1,dl_src=40:44:44:44:54:53,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=0,mpls_ttl=64,mpls_bos=1
3455 00000000  50 54 00 00 00 07 40 44-44 44 54 53 81 00 20 63
3456 00000010  88 47 00 00 a1 40 45 00-00 28 00 00 00 00 40 06
3457 00000020  f9 7c c0 a8 00 01 c0 a8-00 02 00 00 00 00 00 00
3458 00000030  00 00 00 00 00 00 50 00-00 00 00 00 00 00 00 00
3459 ])
3460
3461 dnl Modified MPLS controller action.
3462 dnl In this test, we push the VLAN tag before pushing a MPLS tag, but these
3463 dnl actions are reordered, so we see both of these in the final flow.
3464 AT_CHECK([ovs-ofctl --protocols=OpenFlow12 monitor br0 65534 -m -P nxm --detach --pidfile 2> ofctl_monitor.log])
3465
3466 for i in 1 2 3; do
3467     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=40:44:44:44:54:54,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=6,tos=0,ttl=64,frag=no)'
3468 done
3469 OVS_WAIT_UNTIL([test `grep OFPT_PACKET_IN ofctl_monitor.log | wc -l` -ge 3])
3470 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
3471
3472 AT_CHECK([cat ofctl_monitor.log | ofctl_strip], [0], [dnl
3473 OFPT_PACKET_IN (OF1.2): total_len=68 in_port=1 (via action) data_len=68 (unbuffered)
3474 mpls,dl_vlan=99,dl_vlan_pcp=1,dl_src=40:44:44:44:54:54,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=0,mpls_ttl=64,mpls_bos=1
3475 00000000  50 54 00 00 00 07 40 44-44 44 54 54 81 00 20 63
3476 00000010  88 47 00 00 a1 40 45 00-00 28 00 00 00 00 40 06
3477 00000020  f9 7c c0 a8 00 01 c0 a8-00 02 00 00 00 00 00 00
3478 00000030  00 00 00 00 00 00 50 00-00 00 00 00 00 00 00 00
3479 00000040  00 00 00 00
3480 dnl
3481 OFPT_PACKET_IN (OF1.2): total_len=68 in_port=1 (via action) data_len=68 (unbuffered)
3482 mpls,dl_vlan=99,dl_vlan_pcp=1,dl_src=40:44:44:44:54:54,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=0,mpls_ttl=64,mpls_bos=1
3483 00000000  50 54 00 00 00 07 40 44-44 44 54 54 81 00 20 63
3484 00000010  88 47 00 00 a1 40 45 00-00 28 00 00 00 00 40 06
3485 00000020  f9 7c c0 a8 00 01 c0 a8-00 02 00 00 00 00 00 00
3486 00000030  00 00 00 00 00 00 50 00-00 00 00 00 00 00 00 00
3487 00000040  00 00 00 00
3488 dnl
3489 OFPT_PACKET_IN (OF1.2): total_len=68 in_port=1 (via action) data_len=68 (unbuffered)
3490 mpls,dl_vlan=99,dl_vlan_pcp=1,dl_src=40:44:44:44:54:54,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=0,mpls_ttl=64,mpls_bos=1
3491 00000000  50 54 00 00 00 07 40 44-44 44 54 54 81 00 20 63
3492 00000010  88 47 00 00 a1 40 45 00-00 28 00 00 00 00 40 06
3493 00000020  f9 7c c0 a8 00 01 c0 a8-00 02 00 00 00 00 00 00
3494 00000030  00 00 00 00 00 00 50 00-00 00 00 00 00 00 00 00
3495 00000040  00 00 00 00
3496 ])
3497
3498 dnl Modified MPLS controller action.
3499 dnl In this test, the input packet in vlan-tagged, which should be stripped
3500 dnl before we push the MPLS and VLAN tags.
3501 AT_CHECK([ovs-ofctl --protocols=OpenFlow12 monitor br0 65534 -m -P nxm --detach --pidfile 2> ofctl_monitor.log])
3502
3503 for i in 1 2 3; do
3504     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=40:44:44:44:54:55,dst=50:54:00:00:00:07),eth_type(0x8100),vlan(vid=88,pcp=7),encap(eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=6,tos=0,ttl=64,frag=no))'
3505 done
3506 OVS_WAIT_UNTIL([test `grep OFPT_PACKET_IN ofctl_monitor.log | wc -l` -ge 3])
3507 OVS_APP_EXIT_AND_WAIT([ovs-ofctl])
3508
3509 AT_CHECK([cat ofctl_monitor.log | ofctl_strip], [0], [dnl
3510 OFPT_PACKET_IN (OF1.2): total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
3511 mpls,dl_vlan=99,dl_vlan_pcp=1,dl_src=40:44:44:44:54:55,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=0,mpls_ttl=64,mpls_bos=1
3512 00000000  50 54 00 00 00 07 40 44-44 44 54 55 81 00 20 63
3513 00000010  88 47 00 00 a1 40 45 00-00 28 00 00 00 00 40 06
3514 00000020  f9 7c c0 a8 00 01 c0 a8-00 02 00 00 00 00 00 00
3515 00000030  00 00 00 00 00 00 50 00-00 00 00 00 00 00 00 00
3516 dnl
3517 OFPT_PACKET_IN (OF1.2): total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
3518 mpls,dl_vlan=99,dl_vlan_pcp=1,dl_src=40:44:44:44:54:55,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=0,mpls_ttl=64,mpls_bos=1
3519 00000000  50 54 00 00 00 07 40 44-44 44 54 55 81 00 20 63
3520 00000010  88 47 00 00 a1 40 45 00-00 28 00 00 00 00 40 06
3521 00000020  f9 7c c0 a8 00 01 c0 a8-00 02 00 00 00 00 00 00
3522 00000030  00 00 00 00 00 00 50 00-00 00 00 00 00 00 00 00
3523 dnl
3524 OFPT_PACKET_IN (OF1.2): total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
3525 mpls,dl_vlan=99,dl_vlan_pcp=1,dl_src=40:44:44:44:54:55,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=0,mpls_ttl=64,mpls_bos=1
3526 00000000  50 54 00 00 00 07 40 44-44 44 54 55 81 00 20 63
3527 00000010  88 47 00 00 a1 40 45 00-00 28 00 00 00 00 40 06
3528 00000020  f9 7c c0 a8 00 01 c0 a8-00 02 00 00 00 00 00 00
3529 00000030  00 00 00 00 00 00 50 00-00 00 00 00 00 00 00 00
3530 ])
3531
3532 dnl Modified MPLS controller action.
3533 dnl In this test, we push the VLAN tag before pushing a MPLS tag, but these
3534 dnl actions are reordered, so we see both of these in the final flow.
3535 AT_CHECK([ovs-ofctl --protocols=OpenFlow12 monitor br0 65534 -m -P nxm --detach --pidfile 2> ofctl_monitor.log])
3536
3537 for i in 1 2 3; do
3538     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=40:44:44:44:54:56,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=6,tos=0,ttl=64,frag=no)'
3539 done
3540 OVS_WAIT_UNTIL([test `grep OFPT_PACKET_IN ofctl_monitor.log | wc -l` -ge 3])
3541 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
3542
3543 AT_CHECK([cat ofctl_monitor.log | ofctl_strip], [0], [dnl
3544 OFPT_PACKET_IN (OF1.2): total_len=68 in_port=1 (via action) data_len=68 (unbuffered)
3545 mpls,dl_vlan=99,dl_vlan_pcp=1,dl_src=40:44:44:44:54:56,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=0,mpls_ttl=64,mpls_bos=1
3546 00000000  50 54 00 00 00 07 40 44-44 44 54 56 81 00 20 63
3547 00000010  88 47 00 00 a1 40 45 00-00 28 00 00 00 00 40 06
3548 00000020  f9 7c c0 a8 00 01 c0 a8-00 02 00 00 00 00 00 00
3549 00000030  00 00 00 00 00 00 50 00-00 00 00 00 00 00 00 00
3550 00000040  00 00 00 00
3551 dnl
3552 OFPT_PACKET_IN (OF1.2): total_len=68 in_port=1 (via action) data_len=68 (unbuffered)
3553 mpls,dl_vlan=99,dl_vlan_pcp=1,dl_src=40:44:44:44:54:56,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=0,mpls_ttl=64,mpls_bos=1
3554 00000000  50 54 00 00 00 07 40 44-44 44 54 56 81 00 20 63
3555 00000010  88 47 00 00 a1 40 45 00-00 28 00 00 00 00 40 06
3556 00000020  f9 7c c0 a8 00 01 c0 a8-00 02 00 00 00 00 00 00
3557 00000030  00 00 00 00 00 00 50 00-00 00 00 00 00 00 00 00
3558 00000040  00 00 00 00
3559 dnl
3560 OFPT_PACKET_IN (OF1.2): total_len=68 in_port=1 (via action) data_len=68 (unbuffered)
3561 mpls,dl_vlan=99,dl_vlan_pcp=1,dl_src=40:44:44:44:54:56,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=0,mpls_ttl=64,mpls_bos=1
3562 00000000  50 54 00 00 00 07 40 44-44 44 54 56 81 00 20 63
3563 00000010  88 47 00 00 a1 40 45 00-00 28 00 00 00 00 40 06
3564 00000020  f9 7c c0 a8 00 01 c0 a8-00 02 00 00 00 00 00 00
3565 00000030  00 00 00 00 00 00 50 00-00 00 00 00 00 00 00 00
3566 00000040  00 00 00 00
3567 ])
3568
3569 dnl Modified MPLS controller action.
3570 dnl In this test, the input packet in vlan-tagged, which should be stripped
3571 dnl before we push the MPLS and VLAN tags.
3572 AT_CHECK([ovs-ofctl --protocols=OpenFlow12 monitor br0 -m 65534 -P nxm --detach --pidfile 2> ofctl_monitor.log])
3573
3574 for i in 1 2 3; do
3575     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=40:44:44:44:54:57,dst=50:54:00:00:00:07),eth_type(0x8100),vlan(vid=88,pcp=7),encap(eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=6,tos=0,ttl=64,frag=no))'
3576 done
3577 OVS_WAIT_UNTIL([test `grep OFPT_PACKET_IN ofctl_monitor.log | wc -l` -ge 3])
3578 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
3579
3580 AT_CHECK([cat ofctl_monitor.log | ofctl_strip], [0], [dnl
3581 OFPT_PACKET_IN (OF1.2): total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
3582 mpls,dl_vlan=99,dl_vlan_pcp=1,dl_src=40:44:44:44:54:57,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=0,mpls_ttl=64,mpls_bos=1
3583 00000000  50 54 00 00 00 07 40 44-44 44 54 57 81 00 20 63
3584 00000010  88 47 00 00 a1 40 45 00-00 28 00 00 00 00 40 06
3585 00000020  f9 7c c0 a8 00 01 c0 a8-00 02 00 00 00 00 00 00
3586 00000030  00 00 00 00 00 00 50 00-00 00 00 00 00 00 00 00
3587 dnl
3588 OFPT_PACKET_IN (OF1.2): total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
3589 mpls,dl_vlan=99,dl_vlan_pcp=1,dl_src=40:44:44:44:54:57,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=0,mpls_ttl=64,mpls_bos=1
3590 00000000  50 54 00 00 00 07 40 44-44 44 54 57 81 00 20 63
3591 00000010  88 47 00 00 a1 40 45 00-00 28 00 00 00 00 40 06
3592 00000020  f9 7c c0 a8 00 01 c0 a8-00 02 00 00 00 00 00 00
3593 00000030  00 00 00 00 00 00 50 00-00 00 00 00 00 00 00 00
3594 dnl
3595 OFPT_PACKET_IN (OF1.2): total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
3596 mpls,dl_vlan=99,dl_vlan_pcp=1,dl_src=40:44:44:44:54:57,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=0,mpls_ttl=64,mpls_bos=1
3597 00000000  50 54 00 00 00 07 40 44-44 44 54 57 81 00 20 63
3598 00000010  88 47 00 00 a1 40 45 00-00 28 00 00 00 00 40 06
3599 00000020  f9 7c c0 a8 00 01 c0 a8-00 02 00 00 00 00 00 00
3600 00000030  00 00 00 00 00 00 50 00-00 00 00 00 00 00 00 00
3601 ])
3602
3603 dnl Modified MPLS controller action.
3604 dnl In this test, the input packet in vlan-tagged, which should be stripped
3605 dnl before we push the MPLS and VLAN tags.
3606 AT_CHECK([ovs-ofctl --protocols=OpenFlow12 monitor br0 65534 -m -P nxm --detach --pidfile 2> ofctl_monitor.log])
3607
3608 for i in 1 2 3; do
3609     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=40:44:44:44:54:58,dst=50:54:00:00:00:07),eth_type(0x8100),vlan(vid=88,pcp=7),encap(eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=6,tos=0,ttl=64,frag=no))'
3610 done
3611 OVS_WAIT_UNTIL([test `grep OFPT_PACKET_IN ofctl_monitor.log | wc -l` -ge 3])
3612 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
3613
3614 AT_CHECK([cat ofctl_monitor.log | ofctl_strip], [0], [dnl
3615 OFPT_PACKET_IN (OF1.2): total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
3616 mpls,dl_vlan=99,dl_vlan_pcp=1,dl_src=40:44:44:44:54:58,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=0,mpls_ttl=64,mpls_bos=1
3617 00000000  50 54 00 00 00 07 40 44-44 44 54 58 81 00 20 63
3618 00000010  88 47 00 00 a1 40 45 00-00 28 00 00 00 00 40 06
3619 00000020  f9 7c c0 a8 00 01 c0 a8-00 02 00 00 00 00 00 00
3620 00000030  00 00 00 00 00 00 50 00-00 00 00 00 00 00 00 00
3621 dnl
3622 OFPT_PACKET_IN (OF1.2): total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
3623 mpls,dl_vlan=99,dl_vlan_pcp=1,dl_src=40:44:44:44:54:58,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=0,mpls_ttl=64,mpls_bos=1
3624 00000000  50 54 00 00 00 07 40 44-44 44 54 58 81 00 20 63
3625 00000010  88 47 00 00 a1 40 45 00-00 28 00 00 00 00 40 06
3626 00000020  f9 7c c0 a8 00 01 c0 a8-00 02 00 00 00 00 00 00
3627 00000030  00 00 00 00 00 00 50 00-00 00 00 00 00 00 00 00
3628 dnl
3629 OFPT_PACKET_IN (OF1.2): total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
3630 mpls,dl_vlan=99,dl_vlan_pcp=1,dl_src=40:44:44:44:54:58,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=0,mpls_ttl=64,mpls_bos=1
3631 00000000  50 54 00 00 00 07 40 44-44 44 54 58 81 00 20 63
3632 00000010  88 47 00 00 a1 40 45 00-00 28 00 00 00 00 40 06
3633 00000020  f9 7c c0 a8 00 01 c0 a8-00 02 00 00 00 00 00 00
3634 00000030  00 00 00 00 00 00 50 00-00 00 00 00 00 00 00 00
3635 ])
3636
3637 dnl Modified MPLS controller action.
3638 dnl In this test, the input packet in vlan-tagged, which should be modified
3639 dnl before we push MPLS and VLAN tags.
3640 AT_CHECK([ovs-ofctl --protocols=OpenFlow12 monitor br0 65534 -m -P nxm --detach --pidfile 2> ofctl_monitor.log])
3641
3642 for i in 1 2 3; do
3643     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=40:44:44:44:54:59,dst=50:54:00:00:00:07),eth_type(0x8100),vlan(vid=88,pcp=7),encap(eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=6,tos=0,ttl=64,frag=no))'
3644 done
3645 OVS_WAIT_UNTIL([test `grep OFPT_PACKET_IN ofctl_monitor.log | wc -l` -ge 3])
3646 ovs-appctl -t ovs-ofctl exit
3647
3648 AT_CHECK([cat ofctl_monitor.log | ofctl_strip], [0], [dnl
3649 OFPT_PACKET_IN (OF1.2): total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
3650 mpls,dl_vlan=99,dl_vlan_pcp=1,dl_src=40:44:44:44:54:59,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=0,mpls_ttl=64,mpls_bos=1
3651 00000000  50 54 00 00 00 07 40 44-44 44 54 59 81 00 20 63
3652 00000010  88 47 00 00 a1 40 45 00-00 28 00 00 00 00 40 06
3653 00000020  f9 7c c0 a8 00 01 c0 a8-00 02 00 00 00 00 00 00
3654 00000030  00 00 00 00 00 00 50 00-00 00 00 00 00 00 00 00
3655 dnl
3656 OFPT_PACKET_IN (OF1.2): total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
3657 mpls,dl_vlan=99,dl_vlan_pcp=1,dl_src=40:44:44:44:54:59,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=0,mpls_ttl=64,mpls_bos=1
3658 00000000  50 54 00 00 00 07 40 44-44 44 54 59 81 00 20 63
3659 00000010  88 47 00 00 a1 40 45 00-00 28 00 00 00 00 40 06
3660 00000020  f9 7c c0 a8 00 01 c0 a8-00 02 00 00 00 00 00 00
3661 00000030  00 00 00 00 00 00 50 00-00 00 00 00 00 00 00 00
3662 dnl
3663 OFPT_PACKET_IN (OF1.2): total_len=64 in_port=1 (via action) data_len=64 (unbuffered)
3664 mpls,dl_vlan=99,dl_vlan_pcp=1,dl_src=40:44:44:44:54:59,dl_dst=50:54:00:00:00:07,mpls_label=10,mpls_tc=0,mpls_ttl=64,mpls_bos=1
3665 00000000  50 54 00 00 00 07 40 44-44 44 54 59 81 00 20 63
3666 00000010  88 47 00 00 a1 40 45 00-00 28 00 00 00 00 40 06
3667 00000020  f9 7c c0 a8 00 01 c0 a8-00 02 00 00 00 00 00 00
3668 00000030  00 00 00 00 00 00 50 00-00 00 00 00 00 00 00 00
3669 ])
3670
3671 AT_CHECK([ovs-appctl revalidator/purge], [0])
3672 AT_CHECK([ovs-ofctl --protocols=OpenFlow12 dump-flows br0 | ofctl_strip | sort], [0], [dnl
3673  cookie=0xa, n_packets=3, n_bytes=180, dl_src=40:44:44:44:54:50 actions=push_mpls:0x8847,load:0xa->OXM_OF_MPLS_LABEL[[]],push_vlan:0x8100,set_field:4195->vlan_vid,set_field:1->vlan_pcp,CONTROLLER:65535
3674  cookie=0xa, n_packets=3, n_bytes=180, dl_src=40:44:44:44:54:51 actions=push_mpls:0x8847,load:0xa->OXM_OF_MPLS_LABEL[[]],push_vlan:0x8100,set_field:4195->vlan_vid,set_field:1->vlan_pcp,CONTROLLER:65535
3675  cookie=0xa, n_packets=3, n_bytes=180, dl_src=40:44:44:44:54:52 actions=push_mpls:0x8847,load:0xa->OXM_OF_MPLS_LABEL[[]],push_vlan:0x8100,load:0x63->OXM_OF_VLAN_VID[[]],set_field:1->vlan_pcp,CONTROLLER:65535
3676  cookie=0xa, n_packets=3, n_bytes=180, dl_src=40:44:44:44:54:53 actions=push_mpls:0x8847,load:0xa->OXM_OF_MPLS_LABEL[[]],push_vlan:0x8100,load:0x63->OXM_OF_VLAN_VID[[]],set_field:1->vlan_pcp,CONTROLLER:65535
3677  cookie=0xa, n_packets=3, n_bytes=180, dl_src=40:44:44:44:54:54 actions=push_vlan:0x8100,set_field:4195->vlan_vid,set_field:1->vlan_pcp,push_mpls:0x8847,load:0xa->OXM_OF_MPLS_LABEL[[]],CONTROLLER:65535
3678  cookie=0xa, n_packets=3, n_bytes=180, dl_src=40:44:44:44:54:55 actions=push_vlan:0x8100,set_field:4195->vlan_vid,set_field:1->vlan_pcp,push_mpls:0x8847,load:0xa->OXM_OF_MPLS_LABEL[[]],CONTROLLER:65535
3679  cookie=0xa, n_packets=3, n_bytes=180, dl_src=40:44:44:44:54:56 actions=push_vlan:0x8100,load:0x63->OXM_OF_VLAN_VID[[]],set_field:1->vlan_pcp,push_mpls:0x8847,load:0xa->OXM_OF_MPLS_LABEL[[]],CONTROLLER:65535
3680  cookie=0xa, n_packets=3, n_bytes=180, dl_src=40:44:44:44:54:57 actions=push_vlan:0x8100,load:0x63->OXM_OF_VLAN_VID[[]],set_field:1->vlan_pcp,push_mpls:0x8847,load:0xa->OXM_OF_MPLS_LABEL[[]],CONTROLLER:65535
3681  cookie=0xa, n_packets=3, n_bytes=180, vlan_tci=0x1000/0x1000,dl_src=40:44:44:44:54:58 actions=load:0x63->OXM_OF_VLAN_VID[[]],set_field:1->vlan_pcp,push_mpls:0x8847,load:0xa->OXM_OF_MPLS_LABEL[[]],CONTROLLER:65535
3682  cookie=0xa, n_packets=3, n_bytes=180, vlan_tci=0x1000/0x1000,dl_src=40:44:44:44:54:59 actions=push_mpls:0x8847,load:0xa->OXM_OF_MPLS_LABEL[[]],set_field:1->vlan_pcp,load:0x63->OXM_OF_VLAN_VID[[]],CONTROLLER:65535
3683 OFPST_FLOW reply (OF1.2):
3684 ])
3685
3686 OVS_VSWITCHD_STOP
3687 AT_CLEANUP
3688
3689 AT_SETUP([ofproto-dpif - fragment handling - trace])
3690 OVS_VSWITCHD_START
3691 ADD_OF_PORTS([br0], [1], [2], [3], [4], [5], [6], [90])
3692 AT_DATA([flows.txt], [dnl
3693 priority=75 tcp ip_frag=no    tp_dst=80 actions=move:OXM_OF_TCP_DST[[]]->OXM_OF_TCP_SRC[[]],output:1
3694 priority=75 tcp ip_frag=first tp_dst=80 actions=move:OXM_OF_TCP_DST[[]]->OXM_OF_TCP_SRC[[]],output:2
3695 priority=50 tcp ip_frag=no              actions=move:OXM_OF_TCP_DST[[]]->OXM_OF_TCP_SRC[[]],output:4
3696 priority=50 tcp ip_frag=first           actions=move:OXM_OF_TCP_DST[[]]->OXM_OF_TCP_SRC[[]],output:5
3697 priority=50 tcp ip_frag=later           actions=output:6
3698 ])
3699 AT_CHECK([ovs-ofctl replace-flows br0 flows.txt])
3700
3701 base_flow="in_port(90),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=6,tos=0,ttl=128"
3702 no_flow="$base_flow,frag=no),tcp(src=12345,dst=80)"
3703 first_flow="$base_flow,frag=first),tcp(src=12345,dst=80)"
3704 later_flow="$base_flow,frag=later)"
3705
3706     # mode    no  first  later
3707 for tuple in \
3708     'normal    1     5      6' \
3709     'drop      1  drop   drop' \
3710     'nx-match  1     2      6'
3711 do
3712   set $tuple
3713   mode=$1
3714   no=$2
3715   first=$3
3716   later=$4
3717
3718   AT_CHECK([ovs-ofctl set-frags br0 $mode])
3719   for type in no first later; do
3720     eval flow=\$${type}_flow exp_output=\$$type
3721     printf "\n%s\n" "----$mode $type-----"
3722     AT_CHECK([ovs-appctl ofproto/trace ovs-dummy "$flow"], [0], [stdout])
3723     : > expout
3724     if test $mode = drop && test $type != no; then
3725         echo 'Packets dropped because they are IP fragments and the fragment handling mode is "drop".' >> expout
3726         echo "Datapath actions: $exp_output" >> expout
3727     elif test $type = later; then
3728         echo "Datapath actions: $exp_output" >> expout
3729     else
3730         echo "Datapath actions: set(tcp(src=80,dst=80)),$exp_output" >> expout
3731     fi
3732     AT_CHECK([grep 'IP fragments' stdout; tail -1 stdout], [0], [expout])
3733   done
3734 done
3735 OVS_VSWITCHD_STOP
3736 AT_CLEANUP
3737
3738 AT_SETUP([ofproto-dpif - fragment handling - upcall])
3739 OVS_VSWITCHD_START
3740 ADD_OF_PORTS([br0], [1], [2], [3], [4], [5], [6], [90])
3741 AT_DATA([flows.txt], [dnl
3742 priority=75 tcp ip_frag=no    tp_dst=80 actions=set_field:81->tcp_dst,output:1
3743 priority=75 tcp ip_frag=first tp_dst=80 actions=set_field:81->tcp_dst,output:2
3744 priority=50 tcp ip_frag=no              actions=set_field:81->tcp_dst,output:4
3745 priority=50 tcp ip_frag=first           actions=set_field:81->tcp_dst,output:5
3746 priority=50 tcp ip_frag=later           actions=output:6
3747 ])
3748 AT_CHECK([ovs-ofctl replace-flows br0 flows.txt])
3749
3750 base_flow="in_port(90),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=6,tos=0,ttl=128"
3751 no_flow="$base_flow,frag=no),tcp(src=12345,dst=80)"
3752 first_flow="$base_flow,frag=first),tcp(src=12345,dst=80)"
3753 later_flow="$base_flow,frag=later)"
3754
3755 AT_CHECK([ovs-appctl vlog/set dpif:dbg dpif_netdev:dbg])
3756
3757 mode=normal
3758
3759 AT_CHECK([ovs-ofctl set-frags br0 $mode])
3760 for type in no first later; do
3761   eval flow=\$${type}_flow
3762   printf "\n%s\n" "----$mode $type-----"
3763
3764   AT_CHECK([ovs-appctl netdev-dummy/receive p90 "$flow"], [0], [stdout])
3765 done
3766
3767 AT_CHECK([ovs-appctl dpctl/dump-flows], [0], [dnl
3768 flow-dump from non-dpdk interfaces:
3769 recirc_id(0),in_port(90),eth_type(0x0800),ipv4(proto=6,frag=no),tcp(dst=80), packets:0, bytes:0, used:never, actions:set(tcp(dst=81)),1
3770 recirc_id(0),in_port(90),eth_type(0x0800),ipv4(proto=6,frag=first),tcp(dst=80), packets:0, bytes:0, used:never, actions:set(tcp(dst=81)),5
3771 recirc_id(0),in_port(90),eth_type(0x0800),ipv4(proto=6,frag=later), packets:0, bytes:0, used:never, actions:6
3772 ])
3773
3774 mode=drop
3775
3776 AT_CHECK([ovs-appctl revalidator/purge], [0])
3777 AT_CHECK([ovs-ofctl set-frags br0 $mode])
3778 for type in no first later; do
3779   eval flow=\$${type}_flow
3780   printf "\n%s\n" "----$mode $type-----"
3781
3782   AT_CHECK([ovs-appctl netdev-dummy/receive p90 "$flow"], [0], [stdout])
3783 done
3784
3785 AT_CHECK([ovs-appctl dpctl/dump-flows], [0], [dnl
3786 flow-dump from non-dpdk interfaces:
3787 recirc_id(0),in_port(90),eth_type(0x0800),ipv4(proto=6,frag=no),tcp(dst=80), packets:0, bytes:0, used:never, actions:set(tcp(dst=81)),1
3788 recirc_id(0),in_port(90),eth_type(0x0800),ipv4(frag=first), packets:0, bytes:0, used:never, actions:drop
3789 recirc_id(0),in_port(90),eth_type(0x0800),ipv4(frag=later), packets:0, bytes:0, used:never, actions:drop
3790 ])
3791
3792 mode=nx-match
3793
3794 AT_CHECK([ovs-appctl revalidator/purge], [0])
3795 AT_CHECK([ovs-ofctl set-frags br0 $mode])
3796 for type in no first later; do
3797   eval flow=\$${type}_flow
3798   printf "\n%s\n" "----$mode $type-----"
3799
3800   AT_CHECK([ovs-appctl netdev-dummy/receive p90 "$flow"], [0], [stdout])
3801 done
3802
3803 AT_CHECK([ovs-appctl dpctl/dump-flows], [0], [dnl
3804 flow-dump from non-dpdk interfaces:
3805 recirc_id(0),in_port(90),eth_type(0x0800),ipv4(proto=6,frag=no),tcp(dst=80), packets:0, bytes:0, used:never, actions:set(tcp(dst=81)),1
3806 recirc_id(0),in_port(90),eth_type(0x0800),ipv4(proto=6,frag=first),tcp(dst=80), packets:0, bytes:0, used:never, actions:set(tcp(dst=81)),2
3807 recirc_id(0),in_port(90),eth_type(0x0800),ipv4(proto=6,frag=later), packets:0, bytes:0, used:never, actions:6
3808 ])
3809
3810 OVS_VSWITCHD_STOP
3811 AT_CLEANUP
3812
3813 AT_SETUP([ofproto-dpif - fragment handling - actions])
3814 OVS_VSWITCHD_START
3815 ADD_OF_PORTS([br0], [1], [2], [3], [4], [5], [6], [90])
3816
3817 AT_CHECK([ovs-ofctl add-flow br0 "tcp,ip_frag=later actions=move:OXM_OF_TCP_DST[[0..7]]->OXM_OF_TCP_SRC[[0..7]],output:1"], [1], [], [stderr])
3818 AT_CHECK([tail -2 stderr | sed 's/^.*|WARN|//'], [0], [dnl
3819 source field tcp_dst lacks correct prerequisites
3820 ovs-ofctl: actions are invalid with specified match (OFPBAC_MATCH_INCONSISTENT)
3821 ])
3822
3823 AT_CHECK([ovs-ofctl -O OpenFlow15 add-flow br0 "tcp,ip_frag=later actions=move:OXM_OF_PKT_REG0[[0..7]]->OXM_OF_TCP_SRC[[0..7]],output:1"], [1], [], [stderr])
3824 AT_CHECK([tail -2 stderr | sed 's/^.*|WARN|//'], [0], [dnl
3825 destination field tcp_src lacks correct prerequisites
3826 ovs-ofctl: actions are invalid with specified match (OFPBAC_MATCH_INCONSISTENT)
3827 ])
3828
3829 AT_CHECK([ovs-ofctl add-flow br0 "udp,ip_frag=later actions=set_field:8888->udp_src,output:1"], [1], [], [stderr])
3830 AT_CHECK([tail -2 stderr | sed 's/^.*|WARN|//'], [0], [dnl
3831 set_field udp_src lacks correct prerequisities
3832 ovs-ofctl: actions are invalid with specified match (OFPBAC_MATCH_INCONSISTENT)
3833 ])
3834
3835 AT_CHECK([ovs-ofctl add-flow br0 "udp,ip_frag=later actions=load:8888->NXM_OF_UDP_DST[[]],output:1"], [1], [], [stderr])
3836 AT_CHECK([tail -2 stderr | sed 's/^.*|WARN|//'], [0], [dnl
3837 set_field udp_dst lacks correct prerequisities
3838 ovs-ofctl: actions are invalid with specified match (OFPBAC_MATCH_INCONSISTENT)
3839 ])
3840
3841 AT_CHECK([ovs-ofctl add-flow br0 "sctp,ip_frag=later actions=set_field:8888->sctp_src,output:1"], [1], [], [stderr])
3842 AT_CHECK([tail -2 stderr | sed 's/^.*|WARN|//'], [0], [dnl
3843 set_field sctp_src lacks correct prerequisities
3844 ovs-ofctl: actions are invalid with specified match (OFPBAC_MATCH_INCONSISTENT)
3845 ])
3846
3847 AT_CHECK([ovs-ofctl add-flow br0 "sctp,ip_frag=later actions=set_field:8888->sctp_dst,output:1"], [1], [], [stderr])
3848 AT_CHECK([tail -2 stderr | sed 's/^.*|WARN|//'], [0], [dnl
3849 set_field sctp_dst lacks correct prerequisities
3850 ovs-ofctl: actions are invalid with specified match (OFPBAC_MATCH_INCONSISTENT)
3851 ])
3852
3853 AT_CHECK([ovs-ofctl add-flow br0 "tcp,ip_frag=later actions=learn(table=1,hard_timeout=60,eth_type=0x800,nw_proto=6,NXM_OF_IP_SRC[[]]=NXM_OF_IP_DST[[]],NXM_OF_TCP_SRC[[]]=NXM_OF_TCP_DST[[]],output:NXM_NX_REG0[[0..15]]),output:1"], [1], [], [stderr])
3854 AT_CHECK([tail -2 stderr | sed 's/^.*|WARN|//'], [0], [dnl
3855 source field tcp_dst lacks correct prerequisites
3856 ovs-ofctl: actions are invalid with specified match (OFPBAC_MATCH_INCONSISTENT)
3857 ])
3858
3859 AT_DATA([flows.txt], [dnl
3860 priority=75 tcp actions=load:42->OXM_OF_TCP_SRC[[0..7]],output:1
3861 ])
3862 AT_CHECK([ovs-ofctl -O OpenFlow12 replace-flows br0 flows.txt])
3863
3864 AT_CHECK([ovs-appctl vlog/set dpif:dbg dpif_netdev:dbg])
3865
3866 mode=normal
3867
3868 AT_CHECK([ovs-ofctl set-frags br0 $mode])
3869 for frag in 4000 6000 6008 4010; do
3870   printf "\n%s\n" "----$mode $frag-----"
3871
3872   AT_CHECK([ovs-appctl netdev-dummy/receive p90 "0021853763af 0026b98cb0f9 0800 4500 003c 2e24 $frag 40 06 465d ac11370d ac11370b 828b 0016 751e267b 00000000 a002 16d0 1736 0000 02 04 05 b4 04 02 08 0a 2d 25 08 5f 00 00 00 00 01 03 03 07"])
3873 done
3874
3875 AT_CHECK([ovs-appctl dpctl/dump-flows | sed 's/used:[[0-9]].[[0-9]]*s/used:0.001s/'], [0], [dnl
3876 flow-dump from non-dpdk interfaces:
3877 recirc_id(0),in_port(90),eth_type(0x0800),ipv4(proto=6,frag=no),tcp(src=33419), packets:0, bytes:0, used:never, actions:set(tcp(src=33322)),1
3878 recirc_id(0),in_port(90),eth_type(0x0800),ipv4(proto=6,frag=first),tcp(src=33419), packets:0, bytes:0, used:never, actions:set(tcp(src=33322)),1
3879 recirc_id(0),in_port(90),eth_type(0x0800),ipv4(proto=6,frag=later), packets:1, bytes:74, used:0.001s, actions:1
3880 ])
3881
3882 AT_CHECK([ovs-appctl revalidator/purge], [0])
3883 AT_CHECK([ovs-ofctl set-frags br0 $mode])
3884 for frag in 4000 6000 6008 4010; do
3885   printf "\n%s\n" "----$mode $frag truncated transport header -----"
3886
3887   AT_CHECK([ovs-appctl netdev-dummy/receive p90 "0021853763af 0026b98cb0f9 0800 4500 0018 2e24 $frag 40 06 465d ac11370d ac11370b 828b 0016"])
3888 done
3889
3890 AT_CHECK([ovs-appctl dpctl/dump-flows | sed 's/used:[[0-9]].[[0-9]]*s/used:0.001s/'], [0], [dnl
3891 flow-dump from non-dpdk interfaces:
3892 recirc_id(0),in_port(90),eth_type(0x0800),ipv4(proto=6,frag=no),tcp(src=0), packets:0, bytes:0, used:never, actions:set(tcp(src=42)),1
3893 recirc_id(0),in_port(90),eth_type(0x0800),ipv4(proto=6,frag=first),tcp(src=0), packets:0, bytes:0, used:never, actions:set(tcp(src=42)),1
3894 recirc_id(0),in_port(90),eth_type(0x0800),ipv4(proto=6,frag=later), packets:1, bytes:60, used:0.001s, actions:1
3895 ])
3896
3897 AT_CHECK([ovs-appctl revalidator/purge], [0])
3898 AT_CHECK([ovs-ofctl set-frags br0 $mode])
3899 for frag in 4000 6000 6001 4002; do
3900   printf "\n%s\n" "----$mode $frag missing transport header-----"
3901
3902   AT_CHECK([ovs-appctl netdev-dummy/receive p90 "0021853763af 0026b98cb0f9 0800 4500 0014 2e24 $frag 40 06 465d ac11370d ac11370b"])
3903 done
3904
3905 AT_CHECK([ovs-appctl dpctl/dump-flows | sed 's/used:[[0-9]].[[0-9]]*s/used:0.001s/'], [0], [dnl
3906 flow-dump from non-dpdk interfaces:
3907 recirc_id(0),in_port(90),eth_type(0x0800),ipv4(proto=6,frag=no),tcp(src=0), packets:0, bytes:0, used:never, actions:set(tcp(src=42)),1
3908 recirc_id(0),in_port(90),eth_type(0x0800),ipv4(proto=6,frag=first),tcp(src=0), packets:0, bytes:0, used:never, actions:set(tcp(src=42)),1
3909 recirc_id(0),in_port(90),eth_type(0x0800),ipv4(proto=6,frag=later), packets:1, bytes:60, used:0.001s, actions:1
3910 ])
3911
3912 OVS_VSWITCHD_STOP
3913 AT_CLEANUP
3914
3915 AT_SETUP([ofproto-dpif - exit])
3916 OVS_VSWITCHD_START
3917 ADD_OF_PORTS([br0], [1], [2], [3], [10], [11], [12], [13], [14])
3918 AT_DATA([flows.txt], [dnl
3919 in_port=1 actions=output:10,exit,output:11
3920 in_port=2 actions=output:12,resubmit:1,output:12
3921 in_port=3 actions=output:13,resubmit:2,output:14
3922 ])
3923 AT_CHECK([ovs-ofctl add-flows br0 flows.txt])
3924 AT_CHECK([ovs-appctl ofproto/trace ovs-dummy 'in_port(1),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=1,tos=0,ttl=128,frag=no),icmp(type=8,code=0)'], [0], [stdout])
3925 AT_CHECK([tail -1 stdout], [0],
3926   [Datapath actions: 10
3927 ])
3928 AT_CHECK([ovs-appctl ofproto/trace ovs-dummy 'in_port(2),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=1,tos=0,ttl=128,frag=no),icmp(type=8,code=0)'], [0], [stdout])
3929 AT_CHECK([tail -1 stdout], [0],
3930   [Datapath actions: 12,10
3931 ])
3932 AT_CHECK([ovs-appctl ofproto/trace ovs-dummy 'in_port(3),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=1,tos=0,ttl=128,frag=no),icmp(type=8,code=0)'], [0], [stdout])
3933 AT_CHECK([tail -1 stdout], [0],
3934   [Datapath actions: 13,12,10
3935 ])
3936 OVS_VSWITCHD_STOP
3937 AT_CLEANUP
3938
3939
3940 AT_SETUP([ofproto-dpif - mirroring, select_all])
3941 OVS_VSWITCHD_START
3942 ADD_OF_PORTS([br0], 1, 2, 3)
3943 ovs-vsctl \
3944         set Bridge br0 mirrors=@m --\
3945         --id=@p3 get Port p3 --\
3946         --id=@m create Mirror name=mymirror select_all=true output_port=@p3
3947
3948 AT_DATA([flows.txt], [dnl
3949 in_port=1 actions=output:2
3950 in_port=2 actions=output:1
3951 ])
3952 AT_CHECK([ovs-ofctl add-flows br0 flows.txt])
3953
3954 flow="in_port(1),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=1,tos=0,ttl=128,frag=no),icmp(type=8,code=0)"
3955 AT_CHECK([ovs-appctl ofproto/trace ovs-dummy "$flow"], [0], [stdout])
3956 AT_CHECK_UNQUOTED([tail -1 stdout], [0],
3957   [Datapath actions: 2,3
3958 ])
3959
3960 flow="in_port(2),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=1,tos=0,ttl=128,frag=no),icmp(type=8,code=0)"
3961 AT_CHECK([ovs-appctl ofproto/trace ovs-dummy "$flow"], [0], [stdout])
3962 AT_CHECK_UNQUOTED([tail -1 stdout], [0],
3963   [Datapath actions: 1,3
3964 ])
3965
3966 OVS_VSWITCHD_STOP
3967 AT_CLEANUP
3968
3969
3970 AT_SETUP([ofproto-dpif - mirroring, select_src])
3971 OVS_VSWITCHD_START
3972 ADD_OF_PORTS([br0], 1, 2, 3)
3973 ovs-vsctl \
3974         set Bridge br0 mirrors=@m --\
3975         --id=@p1 get Port p1 -- --id=@p3 get Port p3 --\
3976         --id=@m create Mirror name=mymirror select_src_port=@p1 output_port=@p3
3977
3978 AT_DATA([flows.txt], [dnl
3979 in_port=1 actions=output:2
3980 in_port=2 actions=output:1
3981 ])
3982 AT_CHECK([ovs-ofctl add-flows br0 flows.txt])
3983
3984 flow="in_port(1),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=1,tos=0,ttl=128,frag=no),icmp(type=8,code=0)"
3985 AT_CHECK([ovs-appctl ofproto/trace ovs-dummy "$flow"], [0], [stdout])
3986 AT_CHECK_UNQUOTED([tail -1 stdout], [0],
3987   [Datapath actions: 2,3
3988 ])
3989
3990 flow="in_port(2),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=1,tos=0,ttl=128,frag=no),icmp(type=8,code=0)"
3991 AT_CHECK([ovs-appctl ofproto/trace ovs-dummy "$flow"], [0], [stdout])
3992 AT_CHECK_UNQUOTED([tail -1 stdout], [0],
3993   [Datapath actions: 1
3994 ])
3995 OVS_VSWITCHD_STOP
3996 AT_CLEANUP
3997
3998 AT_SETUP([ofproto-dpif - mirroring, OFPP_NONE ingress port])
3999 OVS_VSWITCHD_START
4000 ADD_OF_PORTS([br0], 1, 2)
4001 ovs-vsctl \
4002         set Bridge br0 mirrors=@m --\
4003         --id=@p2 get Port p2 --\
4004         --id=@m create Mirror name=mymirror select_all=true output_port=@p2
4005
4006 AT_CHECK([ovs-ofctl add-flow br0 action=output:1])
4007
4008 # "in_port" defaults to OFPP_NONE if it's not specified.
4009 flow="icmp,dl_src=50:54:00:00:00:05,dl_dst=50:54:00:00:00:07,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_ttl=128,icmp_type=8,icmp_code=0"
4010 AT_CHECK([ovs-appctl ofproto/trace br0 "$flow"], [0], [stdout])
4011 AT_CHECK_UNQUOTED([tail -1 stdout], [0],
4012   [Datapath actions: 1,2
4013 ])
4014
4015 OVS_VSWITCHD_STOP
4016 AT_CLEANUP
4017
4018
4019 AT_SETUP([ofproto-dpif - mirroring, select_dst])
4020 OVS_VSWITCHD_START
4021 ADD_OF_PORTS([br0], 1, 2, 3)
4022 ovs-vsctl \
4023         set Bridge br0 mirrors=@m --\
4024         --id=@p2 get Port p2 -- --id=@p3 get Port p3 --\
4025         --id=@m create Mirror name=mymirror select_dst_port=@p2 output_port=@p3
4026
4027 AT_DATA([flows.txt], [dnl
4028 in_port=1 actions=output:2
4029 in_port=2 actions=output:1
4030 ])
4031 AT_CHECK([ovs-ofctl add-flows br0 flows.txt])
4032
4033 flow="in_port(1),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=1,tos=0,ttl=128,frag=no),icmp(type=8,code=0)"
4034 AT_CHECK([ovs-appctl ofproto/trace ovs-dummy "$flow"], [0], [stdout])
4035 AT_CHECK_UNQUOTED([tail -1 stdout], [0],
4036   [Datapath actions: 2,3
4037 ])
4038
4039 flow="in_port(2),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=1,tos=0,ttl=128,frag=no),icmp(type=8,code=0)"
4040 AT_CHECK([ovs-appctl ofproto/trace ovs-dummy "$flow"], [0], [stdout])
4041 AT_CHECK_UNQUOTED([tail -1 stdout], [0],
4042   [Datapath actions: 1
4043 ])
4044
4045 OVS_VSWITCHD_STOP
4046 AT_CLEANUP
4047
4048
4049 AT_SETUP([ofproto-dpif - mirroring, select_vlan])
4050 OVS_VSWITCHD_START
4051 ADD_OF_PORTS([br0], 1, 2, 3)
4052 ovs-vsctl \
4053         set Bridge br0 mirrors=@m --\
4054         --id=@p2 get Port p2 -- --id=@p3 get Port p3 --\
4055         --id=@m create Mirror name=mymirror select_all=true select_vlan=11 output_port=@p3
4056
4057 AT_DATA([flows.txt], [dnl
4058 in_port=1, actions=output:2
4059 ])
4060 AT_CHECK([ovs-ofctl add-flows br0 flows.txt])
4061
4062 flow="in_port(1),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=1,tos=0,ttl=128,frag=no),icmp(type=8,code=0)"
4063 AT_CHECK([ovs-appctl ofproto/trace ovs-dummy "$flow"], [0], [stdout])
4064 AT_CHECK_UNQUOTED([tail -1 stdout], [0],
4065   [Datapath actions: 2
4066 ])
4067
4068 flow="in_port(1),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x8100),vlan(vid=10,pcp=0),encap(eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=1,tos=0,ttl=128,frag=no),icmp(type=8,code=0))"
4069 AT_CHECK([ovs-appctl ofproto/trace ovs-dummy "$flow"], [0], [stdout])
4070 AT_CHECK_UNQUOTED([tail -1 stdout], [0],
4071   [Datapath actions: 2
4072 ])
4073
4074 flow="in_port(1),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x8100),vlan(vid=11,pcp=0),encap(eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=1,tos=0,ttl=128,frag=no),icmp(type=8,code=0))"
4075 AT_CHECK([ovs-appctl ofproto/trace ovs-dummy "$flow"], [0], [stdout])
4076 AT_CHECK_UNQUOTED([tail -1 stdout], [0],
4077   [Datapath actions: 2,3
4078 ])
4079
4080 OVS_VSWITCHD_STOP
4081 AT_CLEANUP
4082
4083
4084 AT_SETUP([ofproto-dpif - mirroring, output_port])
4085 OVS_VSWITCHD_START
4086 ADD_OF_PORTS([br0], 1, 2, 3)
4087 ovs-vsctl \
4088         set Bridge br0 mirrors=@m --\
4089         --id=@p3 get Port p3 --\
4090         --id=@m create Mirror name=mymirror select_all=true output_port=@p3
4091
4092 AT_DATA([flows.txt], [dnl
4093 in_port=1 actions=mod_vlan_vid:17,output:2
4094 in_port=2 actions=output:1
4095 ])
4096 AT_CHECK([ovs-ofctl add-flows br0 flows.txt])
4097
4098 flow="in_port(1),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=1,tos=0,ttl=128,frag=no),icmp(type=8,code=0)"
4099 AT_CHECK([ovs-appctl ofproto/trace ovs-dummy "$flow"], [0], [stdout])
4100 AT_CHECK_UNQUOTED([tail -1 stdout], [0],
4101   [Datapath actions: push_vlan(vid=17,pcp=0),2,pop_vlan,3
4102 ])
4103
4104 flow="in_port(2),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=1,tos=0,ttl=128,frag=no),icmp(type=8,code=0)"
4105 AT_CHECK([ovs-appctl ofproto/trace ovs-dummy "$flow"], [0], [stdout])
4106 AT_CHECK_UNQUOTED([tail -1 stdout], [0],
4107   [Datapath actions: 1,3
4108 ])
4109
4110 OVS_VSWITCHD_STOP
4111 AT_CLEANUP
4112
4113 AT_SETUP([ofproto-dpif - mirroring, output_vlan])
4114 OVS_VSWITCHD_START
4115 ADD_OF_PORTS([br0], 1, 2)
4116 ovs-vsctl \
4117         set Bridge br0 mirrors=@m --\
4118         --id=@m create Mirror name=mymirror select_all=true output_vlan=12
4119
4120 AT_DATA([flows.txt], [dnl
4121 in_port=1 actions=output:2
4122 in_port=2 actions=mod_vlan_vid:17,output:1
4123 ])
4124 AT_CHECK([ovs-ofctl add-flows br0 flows.txt])
4125
4126 flow="in_port(1),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=1,tos=0,ttl=128,frag=no),icmp(type=8,code=0)"
4127 AT_CHECK([ovs-appctl ofproto/trace ovs-dummy "$flow"], [0], [stdout])
4128 actual=`tail -1 stdout | sed 's/Datapath actions: //'`
4129
4130 expected="2,push_vlan(vid=12,pcp=0),1,2,100"
4131 AT_CHECK([ovs-dpctl normalize-actions "$flow" "$expected"], [0], [stdout])
4132 mv stdout expout
4133 AT_CHECK([ovs-dpctl normalize-actions "$flow" "$actual"], [0], [expout])
4134
4135 flow="in_port(2),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=1,tos=0,ttl=128,frag=no),icmp(type=8,code=0)"
4136 AT_CHECK([ovs-appctl ofproto/trace ovs-dummy "$flow"], [0], [stdout])
4137 actual=`tail -1 stdout | sed 's/Datapath actions: //'`
4138
4139 expected="push_vlan(vid=17,pcp=0),1,pop_vlan,push_vlan(vid=12,pcp=0),1,2,100"
4140 AT_CHECK([ovs-dpctl normalize-actions "$flow" "$expected"], [0], [stdout])
4141 mv stdout expout
4142 AT_CHECK([ovs-dpctl normalize-actions "$flow" "$actual"], [0], [expout])
4143
4144 OVS_VSWITCHD_STOP
4145 AT_CLEANUP
4146
4147 # Two testcases below are for the ofproto/trace command
4148 # The first one tests all correct syntax:
4149 # ofproto/trace [dp_name] odp_flow [-generate|packet]
4150 # ofproto/trace br_name br_flow [-generate|packet]
4151 AT_SETUP([ofproto-dpif - ofproto/trace command 1])
4152 OVS_VSWITCHD_START([set bridge br0 fail-mode=standalone])
4153 ADD_OF_PORTS([br0], 1, 2, 3)
4154
4155 AT_DATA([flows.txt], [dnl
4156 in_port=1 actions=output:2
4157 in_port=2 actions=output:1
4158 ])
4159 AT_CHECK([ovs-ofctl add-flows br0 flows.txt])
4160
4161 odp_flow="in_port(p1)"
4162 br_flow="in_port=1"
4163 # Test command: ofproto/trace odp_flow with in_port as a name.
4164 AT_CHECK([ovs-appctl ofproto/trace "$odp_flow"], [0], [stdout])
4165 AT_CHECK([tail -1 stdout], [0], [dnl
4166 Datapath actions: 2
4167 ])
4168
4169 odp_flow="in_port(1)"
4170 # Test command: ofproto/trace odp_flow
4171 AT_CHECK([ovs-appctl ofproto/trace "$odp_flow"], [0], [stdout])
4172 AT_CHECK([tail -1 stdout], [0], [dnl
4173 Datapath actions: 2
4174 ])
4175
4176 # Test command: ofproto/trace dp_name odp_flow
4177 AT_CHECK([ovs-appctl ofproto/trace ovs-dummy "$odp_flow"], [0], [stdout])
4178 AT_CHECK([tail -1 stdout], [0], [dnl
4179 Datapath actions: 2
4180 ])
4181 # Test commmand: ofproto/trace br_name br_flow
4182 AT_CHECK([ovs-appctl ofproto/trace br0 "$br_flow"], [0], [stdout])
4183 AT_CHECK([tail -1 stdout], [0], [dnl
4184 Datapath actions: 2
4185 ])
4186
4187 # Delete the inserted flows
4188 AT_CHECK([ovs-ofctl del-flows br0 "in_port=1"], [0], [stdout])
4189 AT_CHECK([ovs-ofctl del-flows br0 "in_port=2"], [0], [stdout])
4190
4191 # This section below tests the [-generate] option
4192 odp_flow="in_port(3),eth(src=50:54:00:00:00:05,dst=ff:ff:ff:ff:ff:ff)"
4193 br_flow="arp,in_port=3,vlan_tci=0x0000,dl_src=50:54:00:00:00:05,dl_dst=ff:ff:ff:ff:ff:ff"
4194
4195 # Test command: ofproto/trace odp_flow
4196 AT_CHECK([ovs-appctl ofproto/trace "$odp_flow"], [0], [stdout])
4197 # Check for no MAC learning entry
4198 AT_CHECK_UNQUOTED([ovs-appctl fdb/show br0 | sed 's/[[0-9]]\{1,\}$/?/'], [0], [dnl
4199  port  VLAN  MAC                Age
4200 ])
4201
4202 # Test command: ofproto/trace br_name br_flow
4203 AT_CHECK([ovs-appctl ofproto/trace br0 "$br_flow"], [0], [stdout])
4204 # Check for no MAC learning entry
4205 AT_CHECK_UNQUOTED([ovs-appctl fdb/show br0 | sed 's/[[0-9]]\{1,\}$/?/'], [0], [dnl
4206  port  VLAN  MAC                Age
4207 ])
4208
4209 # Test command: ofproto/trace odp_flow -generate
4210 AT_CHECK([ovs-appctl ofproto/trace "$odp_flow" -generate], [0], [stdout])
4211 # Check for the MAC learning entry
4212 AT_CHECK_UNQUOTED([ovs-appctl fdb/show br0 | sed 's/[[0-9]]\{1,\}$/?/'], [0], [dnl
4213  port  VLAN  MAC                Age
4214     3     0  50:54:00:00:00:05    ?
4215 ])
4216
4217 # Test command: ofproto/trace dp_name odp_flow -generate
4218 AT_CHECK([ovs-appctl ofproto/trace ovs-dummy \
4219   "in_port(1),eth(src=50:54:00:00:00:06,dst=50:54:00:00:00:05)" \
4220   -generate], [0], [stdout])
4221 # Check for both MAC learning entries
4222 AT_CHECK_UNQUOTED([ovs-appctl fdb/show br0 | sed 's/[[0-9]]\{1,\}$/?/'], [0], [dnl
4223  port  VLAN  MAC                Age
4224     3     0  50:54:00:00:00:05    ?
4225     1     0  50:54:00:00:00:06    ?
4226 ])
4227
4228 # Test command: ofproto/trace br_name br_flow -generate
4229 AT_CHECK([ovs-appctl ofproto/trace br0 \
4230   "in_port=2,dl_src=50:54:00:00:00:07,dl_dst=50:54:00:00:00:06" \
4231   -generate], [0], [stdout])
4232 # Check for both MAC learning entries.
4233 AT_CHECK_UNQUOTED([ovs-appctl fdb/show br0 | sed 's/[[0-9]]\{1,\}$/?/'], [0], [dnl
4234  port  VLAN  MAC                Age
4235     3     0  50:54:00:00:00:05    ?
4236     1     0  50:54:00:00:00:06    ?
4237     2     0  50:54:00:00:00:07    ?
4238 ])
4239
4240 # This section beflow tests the [packet] option
4241 # The ovs-tcpundump of packets between port1 and port2
4242 pkt1to2="50540000000250540000000108064500001C000100004001F98CC0A80001C0A800020800F7FF00000000"
4243 pkt2to1="50540000000150540000000208064500001C000100004001F98CC0A80002C0A800010800F7FF00000000"
4244
4245 # Construct the MAC learning table
4246 AT_CHECK([ovs-appctl ofproto/trace ovs-dummy \
4247   "in_port(1),eth(src=50:54:00:00:00:01,dst=ff:ff:ff:ff:ff:ff)" \
4248   -generate], [0], [stdout])
4249
4250 # Construct the MAC learning table
4251 AT_CHECK([ovs-appctl ofproto/trace ovs-dummy \
4252   "in_port(2),eth(src=50:54:00:00:00:02,dst=ff:ff:ff:ff:ff:ff)" \
4253   -generate], [0], [stdout])
4254
4255 # Test command: ofproto/trace odp_flow packet
4256 AT_CHECK([ovs-appctl ofproto/trace \
4257   "in_port(1),skb_priority(1),skb_mark(2)" "$pkt1to2"], [0], [stdout])
4258 AT_CHECK([tail -1 stdout], [0], [dnl
4259 Datapath actions: 2
4260 ])
4261 AT_CHECK([head -n 2 stdout], [0], [dnl
4262 Bridge: br0
4263 Flow: pkt_mark=0x2,skb_priority=0x1,arp,in_port=1,vlan_tci=0x0000,dl_src=50:54:00:00:00:01,dl_dst=50:54:00:00:00:02,arp_spa=0.0.0.0,arp_tpa=0.0.0.0,arp_op=0,arp_sha=00:00:00:00:00:00,arp_tha=00:00:00:00:00:00
4264 ])
4265
4266 # Test command: ofproto/trace dp_name odp_flow packet
4267 AT_CHECK([ovs-appctl ofproto/trace ovs-dummy \
4268   "in_port(1),skb_priority(1),skb_mark(2)" "$pkt1to2"], [0], [stdout])
4269 AT_CHECK([tail -1 stdout], [0], [dnl
4270 Datapath actions: 2
4271 ])
4272 AT_CHECK([head -n 2 stdout], [0], [dnl
4273 Bridge: br0
4274 Flow: pkt_mark=0x2,skb_priority=0x1,arp,in_port=1,vlan_tci=0x0000,dl_src=50:54:00:00:00:01,dl_dst=50:54:00:00:00:02,arp_spa=0.0.0.0,arp_tpa=0.0.0.0,arp_op=0,arp_sha=00:00:00:00:00:00,arp_tha=00:00:00:00:00:00
4275 ])
4276
4277 # Test command: ofproto/trace br_name br_flow packet
4278 AT_CHECK([ovs-appctl ofproto/trace br0 \
4279   "in_port=2,skb_priority=2,pkt_mark=1" "$pkt2to1"], [0], [stdout],[stderr])
4280 AT_CHECK([tail -1 stdout], [0], [dnl
4281 Datapath actions: 1
4282 ])
4283 AT_CHECK([head -n 2 stdout], [0], [dnl
4284 Bridge: br0
4285 Flow: pkt_mark=0x1,skb_priority=0x2,arp,in_port=2,vlan_tci=0x0000,dl_src=50:54:00:00:00:02,dl_dst=50:54:00:00:00:01,arp_spa=0.0.0.0,arp_tpa=0.0.0.0,arp_op=0,arp_sha=00:00:00:00:00:00,arp_tha=00:00:00:00:00:00
4286 ])
4287
4288 OVS_VSWITCHD_STOP
4289 AT_CLEANUP
4290
4291 # The second test tests the corner cases
4292 AT_SETUP([ofproto-dpif - ofproto/trace command 2])
4293 OVS_VSWITCHD_START
4294 ADD_OF_PORTS([br0], 1, 2)
4295
4296 # Define flows
4297 odp_flow="in_port(1),eth(src=50:54:00:00:00:01,dst=50:54:00:00:00:02)"
4298 br_flow="in_port=1,dl_src=50:54:00:00:00:01,dl_dst=50:54:00:00:00:02"
4299 # Define options
4300 generate="-generate"
4301 pkt="50540000000250540000000108064500001C000100004001F98CC0A80001C0A800020800F7FF00000000"
4302
4303 # Test incorrect command: ofproto/trace wrong_name odp_flow [-generate|packet]
4304 m4_foreach(
4305 [option],
4306 [[],
4307 ["$generate"],
4308 ["$pkt"]],
4309 [AT_CHECK([ovs-appctl ofproto/trace wrong_name "$odp_flow" option],
4310   [2], [], [stderr])
4311 AT_CHECK([tail -2 stderr], [0], [dnl
4312 Cannot find the datapath
4313 ovs-appctl: ovs-vswitchd: server returned an error
4314 ])])
4315
4316 # Test incorrect command: ofproto/trace empty_string odp_flow [-generate|packet]
4317 m4_foreach(
4318 [option],
4319 [[],
4320 ["$generate"],
4321 ["$pkt"]],
4322 [AT_CHECK([ovs-appctl ofproto/trace "" "$odp_flow" option],
4323   [2], [], [stderr])
4324 AT_CHECK([tail -2 stderr], [0], [dnl
4325 Cannot find the datapath
4326 ovs-appctl: ovs-vswitchd: server returned an error
4327 ])])
4328
4329 # Test incorrect command: ofproto/trace nonexist_dp_name odp_flow [-generate|packet]
4330 m4_foreach(
4331 [option],
4332 [[],
4333 ["$generate"],
4334 ["$pkt"]],
4335 [AT_CHECK([ovs-appctl ofproto/trace ovs-system "$odp_flow" option],
4336   [2], [], [stderr])
4337 AT_CHECK([tail -2 stderr], [0], [dnl
4338 Cannot find the datapath
4339 ovs-appctl: ovs-vswitchd: server returned an error
4340 ])])
4341
4342 # Test incorrect command: ofproto/trace br_name odp_flow [-generate|packet]
4343 m4_foreach(
4344 [option],
4345 [[],
4346 ["$generate"],
4347 ["$pkt"]],
4348 [AT_CHECK([ovs-appctl ofproto/trace br0 "$odp_flow" option],
4349   [2], [], [stderr])
4350 AT_CHECK([tail -2 stderr], [0], [dnl
4351 Cannot find the datapath
4352 ovs-appctl: ovs-vswitchd: server returned an error
4353 ])])
4354
4355 # Test incorrect command: ofproto/trace dp_name br_flow [-generate|packet]
4356 m4_foreach(
4357 [option],
4358 [[],
4359 ["$generate"],
4360 ["$pkt"]],
4361 [AT_CHECK([ovs-appctl ofproto/trace ovs-dummy "$br_flow" option],
4362   [2], [], [stderr])
4363 AT_CHECK([tail -2 stderr], [0], [dnl
4364 Unknown bridge name
4365 ovs-appctl: ovs-vswitchd: server returned an error
4366 ])])
4367
4368 # Test incorrect command: ofproto/trace br_flow [-generate|packet]
4369 m4_foreach(
4370 [option],
4371 [[],
4372 ["$generate"],
4373 ["$pkt"]],
4374 [AT_CHECK([ovs-appctl ofproto/trace "$br_flow" option],
4375   [2], [], [stderr])
4376 AT_CHECK([tail -2 stderr], [0], [dnl
4377 Must specify bridge name
4378 ovs-appctl: ovs-vswitchd: server returned an error
4379 ])])
4380
4381 # Test incorrect command: ofproto/trace dp_name odp_flow garbage_option
4382 AT_CHECK([ovs-appctl ofproto/trace \
4383   ovs-dummy "$odp_flow" garbage_option],
4384   [2], [stdout],[stderr])
4385 AT_CHECK([tail -2 stderr], [0], [dnl
4386 Trailing garbage in packet data
4387 ovs-appctl: ovs-vswitchd: server returned an error
4388 ])
4389
4390 # Test incorrect command: ofproto/trace with 4 arguments
4391 AT_CHECK([ovs-appctl ofproto/trace \
4392   arg1, arg2, arg3, arg4], [2], [stdout],[stderr])
4393 AT_CHECK([tail -2 stderr], [0], [dnl
4394 "ofproto/trace" command takes at most 3 arguments
4395 ovs-appctl: ovs-vswitchd: server returned an error
4396 ])
4397
4398 # Test incorrect command: ofproto/trace with 0 argument
4399 AT_CHECK([ovs-appctl ofproto/trace ], [2], [stdout],[stderr])
4400 AT_CHECK([tail -2 stderr], [0], [dnl
4401 "ofproto/trace" command requires at least 1 arguments
4402 ovs-appctl: ovs-vswitchd: server returned an error
4403 ])
4404
4405 OVS_VSWITCHD_STOP
4406 AT_CLEANUP
4407
4408 # The third test checks that the output of "ovs-dpctl -m" is valid to trace.
4409 AT_SETUP([ofproto-dpif - ofproto/trace from dpctl output])
4410 OVS_VSWITCHD_START([dnl
4411     set Open_vSwitch . other_config:max-idle=10000 \
4412     -- add-port br0 p1 -- set Interface p1 type=dummy])
4413
4414 AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'])
4415 ovs-appctl revalidator/wait
4416 AT_CHECK([ovs-appctl dpif/dump-flows -m br0 | sed 's/, packets.*$//' > dp_flows1.txt])
4417
4418 odp_flow=`cat dp_flows1.txt`
4419 AT_CHECK([ovs-appctl ofproto/trace "$odp_flow" | sed 's/\([[Ff]]low:\).*/\1 <cleared>/'], [0], [dnl
4420 Bridge: br0
4421 Flow: <cleared>
4422 No match, packets dropped because OFPPC_NO_PACKET_IN is set on in_port.
4423
4424 Rule: table=254 cookie=0 priority=0,reg0=0x2
4425 OpenFlow actions=drop
4426
4427 Final flow: <cleared>
4428 Megaflow: <cleared>
4429 Datapath actions: drop
4430 ])
4431
4432 dnl Now, try again without megaflows:
4433 ovs-appctl upcall/disable-megaflows
4434
4435 AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'])
4436 ovs-appctl revalidator/wait
4437 AT_CHECK([ovs-appctl dpif/dump-flows -m br0 | sed 's/, packets.*$//' > dp_flows2.txt])
4438
4439 odp_flow=`cat dp_flows2.txt`
4440 AT_CHECK([ovs-appctl ofproto/trace "$odp_flow" | sed 's/\([[Ff]]low:\).*/\1 <cleared>/'], [0], [dnl
4441 Bridge: br0
4442 Flow: <cleared>
4443 No match, packets dropped because OFPPC_NO_PACKET_IN is set on in_port.
4444
4445 Rule: table=254 cookie=0 priority=0,reg0=0x2
4446 OpenFlow actions=drop
4447
4448 Final flow: <cleared>
4449 Megaflow: <cleared>
4450 Datapath actions: drop
4451 ])
4452
4453 OVS_VSWITCHD_STOP
4454 AT_CLEANUP
4455
4456 AT_SETUP([ofproto-dpif - ofproto/trace-packet-out])
4457 OVS_VSWITCHD_START
4458 ADD_OF_PORTS([br0], 1, 2, 3)
4459
4460 AT_DATA([flows.txt], [dnl
4461 in_port=1 actions=output:2
4462 in_port=2 actions=output:1
4463 ])
4464 AT_CHECK([ovs-ofctl add-flows br0 flows.txt])
4465
4466 AT_CHECK([ovs-appctl ofproto/trace-packet-out br0 in_port=1 'mod_vlan_vid:123,resubmit(,0)'], [0], [stdout])
4467 AT_CHECK([tail -1 stdout], [0], [dnl
4468 Datapath actions: push_vlan(vid=123,pcp=0),2
4469 ])
4470
4471 OVS_VSWITCHD_STOP
4472 AT_CLEANUP
4473
4474
4475 m4_define([OFPROTO_TRACE],
4476   [flow="$2"
4477    AT_CHECK([ovs-appctl ofproto/trace $1 "$flow" $3], [0], [stdout])
4478    actual=`tail -1 stdout | sed 's/Datapath actions: //'`
4479    expected="$4"
4480    AT_CHECK([ovs-dpctl normalize-actions "$flow" "$expected" $5],
4481      [0], [stdout])
4482    mv stdout expout
4483    AT_CHECK([ovs-dpctl normalize-actions "$flow" "$actual" $5],
4484      [0], [expout])])
4485
4486 AT_SETUP([ofproto-dpif - MAC learning])
4487 OVS_VSWITCHD_START([set bridge br0 fail-mode=standalone])
4488 ADD_OF_PORTS([br0], 1, 2, 3)
4489
4490 arp='eth_type(0x0806),arp(sip=192.168.0.1,tip=192.168.0.2,op=1,sha=50:54:00:00:00:05,tha=00:00:00:00:00:00)'
4491
4492 # Trace an ARP packet arriving on p3, to create a MAC learning entry.
4493 OFPROTO_TRACE(
4494   [ovs-dummy],
4495   [in_port(3),eth(src=50:54:00:00:00:05,dst=ff:ff:ff:ff:ff:ff),$arp],
4496   [-generate],
4497   [1,2,100])
4498
4499 # Check for the MAC learning entry.
4500 AT_CHECK_UNQUOTED([ovs-appctl fdb/show br0 | sed 's/[[0-9]]\{1,\}$/?/'], [0], [dnl
4501  port  VLAN  MAC                Age
4502     3     0  50:54:00:00:00:05    ?
4503 ])
4504
4505 # Trace a packet arrival destined for the learned MAC.
4506 # (This will also learn a MAC.)
4507 OFPROTO_TRACE(
4508   [ovs-dummy],
4509   [in_port(1),eth(src=50:54:00:00:00:06,dst=50:54:00:00:00:05),$arp],
4510   [-generate],
4511   [3])
4512
4513 # Check for both MAC learning entries.
4514 AT_CHECK_UNQUOTED([ovs-appctl fdb/show br0 | sed 's/[[0-9]]\{1,\}$/?/'], [0], [dnl
4515  port  VLAN  MAC                Age
4516     3     0  50:54:00:00:00:05    ?
4517     1     0  50:54:00:00:00:06    ?
4518 ])
4519
4520 # Trace a packet arrival that updates the first learned MAC entry.
4521 OFPROTO_TRACE(
4522   [ovs-dummy],
4523   [in_port(2),eth(src=50:54:00:00:00:05,dst=ff:ff:ff:ff:ff:ff),$arp],
4524   [-generate],
4525   [1,3,100])
4526
4527 # Check that the MAC learning entry was updated.
4528 AT_CHECK_UNQUOTED([ovs-appctl fdb/show br0 | sed 's/[[0-9]]\{1,\}$/?/'], [0], [dnl
4529  port  VLAN  MAC                Age
4530     1     0  50:54:00:00:00:06    ?
4531     2     0  50:54:00:00:00:05    ?
4532 ])
4533
4534 # Add another bridge.
4535 AT_CHECK(
4536   [ovs-vsctl \
4537      -- add-br br1 \
4538      -- set bridge br1 datapath-type=dummy])
4539 ADD_OF_PORTS([br1], 4, 5)
4540
4541 # Trace some packet arrivals in br1 to create MAC learning entries there too.
4542 OFPROTO_TRACE(
4543   [ovs-dummy],
4544   [in_port(4),eth(src=50:54:00:00:00:06,dst=ff:ff:ff:ff:ff:ff),$arp],
4545   [-generate],
4546   [5,101])
4547 OFPROTO_TRACE(
4548   [ovs-dummy],
4549   [in_port(5),eth(src=50:54:00:00:00:07,dst=ff:ff:ff:ff:ff:ff),$arp],
4550   [-generate],
4551   [4,101])
4552
4553 # Check that the MAC learning entries were added.
4554 AT_CHECK_UNQUOTED([ovs-appctl fdb/show br1 | sed 's/[[0-9]]\{1,\}$/?/'], [0], [dnl
4555  port  VLAN  MAC                Age
4556     4     0  50:54:00:00:00:06    ?
4557     5     0  50:54:00:00:00:07    ?
4558 ])
4559
4560 # Delete port p1 and see that its MAC learning entry disappeared, and
4561 # that the MAC learning entry for the same MAC was also deleted from br1.
4562 AT_CHECK([ovs-vsctl del-port p1])
4563 AT_CHECK_UNQUOTED([ovs-appctl fdb/show br0 | sed 's/[[0-9]]\{1,\}$/?/'], [0], [dnl
4564  port  VLAN  MAC                Age
4565     2     0  50:54:00:00:00:05    ?
4566 ])
4567 AT_CHECK_UNQUOTED([ovs-appctl fdb/show br1 | sed 's/[[0-9]]\{1,\}$/?/'], [0], [dnl
4568  port  VLAN  MAC                Age
4569     5     0  50:54:00:00:00:07    ?
4570 ])
4571
4572 OVS_VSWITCHD_STOP
4573 AT_CLEANUP
4574
4575 AT_SETUP([ofproto-dpif - MAC table overflow])
4576 OVS_VSWITCHD_START(
4577   [set bridge br0 fail-mode=standalone other-config:mac-table-size=10])
4578 ADD_OF_PORTS([br0], 1, 2, 3)
4579
4580 arp='eth_type(0x0806),arp(sip=192.168.0.1,tip=192.168.0.2,op=1,sha=50:54:00:00:00:05,tha=00:00:00:00:00:00)'
4581
4582 AT_CHECK([ovs-appctl time/stop])
4583
4584 # Trace 10 ARP packets arriving on p3, to create MAC learning entries.
4585 for i in 0 1 2 3 4 5 6 7 8 9; do
4586     OFPROTO_TRACE(
4587       [ovs-dummy],
4588       [in_port(3),eth(src=50:54:00:00:00:0$i,dst=ff:ff:ff:ff:ff:ff),$arp],
4589       [-generate],
4590       [1,2,100])
4591     ovs-appctl time/warp 1000
4592 done
4593
4594 # Check for the MAC learning entries.
4595 AT_CHECK_UNQUOTED([ovs-appctl fdb/show br0 | sed 's/ *[[0-9]]\{1,\}$//' | sort],
4596   [0], [dnl
4597     3     0  50:54:00:00:00:00
4598     3     0  50:54:00:00:00:01
4599     3     0  50:54:00:00:00:02
4600     3     0  50:54:00:00:00:03
4601     3     0  50:54:00:00:00:04
4602     3     0  50:54:00:00:00:05
4603     3     0  50:54:00:00:00:06
4604     3     0  50:54:00:00:00:07
4605     3     0  50:54:00:00:00:08
4606     3     0  50:54:00:00:00:09
4607  port  VLAN  MAC                Age
4608 ])
4609
4610 # Trace another ARP packet on another MAC.
4611 OFPROTO_TRACE(
4612   [ovs-dummy],
4613   [in_port(3),eth(src=50:54:00:00:00:10,dst=ff:ff:ff:ff:ff:ff),$arp],
4614   [-generate],
4615   [1,2,100])
4616
4617 # Check that the new one chased the oldest one out of the table.
4618 AT_CHECK_UNQUOTED([ovs-appctl fdb/show br0 | sed 's/[[0-9]]\{1,\}$/?/' | sort],
4619   [0], [dnl
4620     3     0  50:54:00:00:00:01    ?
4621     3     0  50:54:00:00:00:02    ?
4622     3     0  50:54:00:00:00:03    ?
4623     3     0  50:54:00:00:00:04    ?
4624     3     0  50:54:00:00:00:05    ?
4625     3     0  50:54:00:00:00:06    ?
4626     3     0  50:54:00:00:00:07    ?
4627     3     0  50:54:00:00:00:08    ?
4628     3     0  50:54:00:00:00:09    ?
4629     3     0  50:54:00:00:00:10    ?
4630  port  VLAN  MAC                Age
4631 ])
4632 OVS_VSWITCHD_STOP
4633 AT_CLEANUP
4634
4635 AT_SETUP([ofproto-dpif - MAC table overflow fairness])
4636 OVS_VSWITCHD_START(
4637   [set bridge br0 fail-mode=standalone other-config:mac-table-size=10])
4638 ADD_OF_PORTS([br0], 1, 2, 3, 4, 5, 6)
4639
4640 arp='eth_type(0x0806),arp(sip=192.168.0.1,tip=192.168.0.2,op=1,sha=50:54:00:00:00:05,tha=00:00:00:00:00:00)'
4641
4642 AT_CHECK([ovs-appctl time/stop])
4643
4644 # Trace packets with 2 different source MACs arriving on each of the 5
4645 # ports, filling up the 10-entry learning table.
4646 for i in 0 1 2 3 4 5 6 7 8 9; do
4647     p=`expr $i / 2 + 1`
4648     ovs-appctl ofproto/trace ovs-dummy "in_port($p),eth(src=50:54:00:00:00:0$i,dst=ff:ff:ff:ff:ff:ff),$arp" -generate
4649     ovs-appctl time/warp 1000
4650 done
4651
4652 # Check for the MAC learning entries.
4653 AT_CHECK_UNQUOTED([ovs-appctl fdb/show br0 | sed 's/ *[[0-9]]\{1,\}$//' | sort],
4654   [0], [dnl
4655     1     0  50:54:00:00:00:00
4656     1     0  50:54:00:00:00:01
4657     2     0  50:54:00:00:00:02
4658     2     0  50:54:00:00:00:03
4659     3     0  50:54:00:00:00:04
4660     3     0  50:54:00:00:00:05
4661     4     0  50:54:00:00:00:06
4662     4     0  50:54:00:00:00:07
4663     5     0  50:54:00:00:00:08
4664     5     0  50:54:00:00:00:09
4665  port  VLAN  MAC                Age
4666 ])
4667
4668 # Now trace 16 new MACs on another port.
4669 for i in 0 1 2 3 4 5 6 7 8 9 a b c d e f; do
4670     ovs-appctl ofproto/trace ovs-dummy "in_port(6),eth(src=50:54:00:00:0$i:ff,dst=ff:ff:ff:ff:ff:ff),$arp" -generate
4671     ovs-appctl time/warp 1000
4672 done
4673
4674 # Check the results.
4675 #
4676 # Our eviction algorithm on overflow is that an arbitrary (but deterministic)
4677 # one of the ports with the most learned MACs loses the least recently used
4678 # one.  Thus, the new port will end up with 3 MACs, 3 of the old ports with 1
4679 # MAC each, and the other 2 of the old ports with 2 MACs each.
4680 #
4681 # (If someone changes lib/heap.c to do something different with equal-priority
4682 # nodes, then the output below could change, but it would still follow the
4683 # rules explained above.)
4684 AT_CHECK_UNQUOTED([ovs-appctl fdb/show br0 | sed 's/ *[[0-9]]\{1,\}$//' | sort],
4685   [0], [dnl
4686     1     0  50:54:00:00:00:01
4687     2     0  50:54:00:00:00:03
4688     3     0  50:54:00:00:00:04
4689     3     0  50:54:00:00:00:05
4690     4     0  50:54:00:00:00:07
4691     5     0  50:54:00:00:00:08
4692     5     0  50:54:00:00:00:09
4693     6     0  50:54:00:00:0d:ff
4694     6     0  50:54:00:00:0e:ff
4695     6     0  50:54:00:00:0f:ff
4696  port  VLAN  MAC                Age
4697 ])
4698 OVS_VSWITCHD_STOP
4699 AT_CLEANUP
4700
4701 # CHECK_SFLOW_SAMPLING_PACKET(LOOPBACK_ADDR)
4702 #
4703 # Test that sFlow samples packets correctly using IPv4/IPv6 sFlow collector
4704 m4_define([CHECK_SFLOW_SAMPLING_PACKET],
4705   [AT_XFAIL_IF([test "$IS_WIN32" = "yes"])
4706   OVS_VSWITCHD_START([set Bridge br0 fail-mode=standalone])
4707
4708   ON_EXIT([kill `cat test-sflow.pid`])
4709   AT_CHECK([ovstest test-sflow --log-file --detach --no-chdir --pidfile 0:$1 > sflow.log], [0], [], [ignore])
4710   AT_CAPTURE_FILE([sflow.log])
4711   SFLOW_PORT=`parse_listening_port < test-sflow.log`
4712   ovs-appctl time/stop
4713
4714   ADD_OF_PORTS([br0], 1, 2)
4715   ovs-vsctl \
4716      set Interface br0 options:ifindex=1002 -- \
4717      set Interface p1 options:ifindex=1004 -- \
4718      set Interface p2 options:ifindex=1003 -- \
4719      set Bridge br0 sflow=@sf -- \
4720      --id=@sf create sflow targets=\"$1:$SFLOW_PORT\" \
4721        header=128 sampling=1 polling=1 agent=$LOOPBACK_INTERFACE
4722
4723   dnl open with ARP packets to seed the bridge-learning.  The output
4724   dnl ifIndex numbers should be reported predictably after that.
4725   dnl Since we set sampling=1 we should see all of these packets
4726   dnl reported. Sorting the output by data-source and seqNo makes
4727   dnl it deterministic. Ensuring that we send at least two packets
4728   dnl into each port means we get to check the seq nos are
4729   dnl incrementing correctly.
4730   dnl because packets from different ports can be handled by separate
4731   dnl threads, put some sleeps
4732
4733   ovs-appctl netdev-dummy/receive p1 'in_port(2),eth(src=50:54:00:00:00:05,dst=FF:FF:FF:FF:FF:FF),eth_type(0x0806),arp(sip=192.168.0.2,tip=192.168.0.1,op=1,sha=50:54:00:00:00:05,tha=00:00:00:00:00:00)'
4734   sleep 1
4735   ovs-appctl netdev-dummy/receive p2 'in_port(1),eth(src=50:54:00:00:00:07,dst=FF:FF:FF:FF:FF:FF),eth_type(0x0806),arp(sip=192.168.0.1,tip=192.168.0.2,op=1,sha=50:54:00:00:00:07,tha=00:00:00:00:00:00)'
4736   sleep 1
4737   ovs-appctl netdev-dummy/receive p1 'in_port(2),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'
4738   sleep 1
4739   ovs-appctl netdev-dummy/receive p2 'in_port(1),eth(src=50:54:00:00:00:07,dst=50:54:00:00:00:05),eth_type(0x0800),ipv4(src=192.168.0.2,dst=192.168.0.1,proto=1,tos=0,ttl=64,frag=no),icmp(type=0,code=0)'
4740   ovs-appctl netdev-dummy/receive p2 'in_port(1),eth(src=50:54:00:00:00:07,dst=50:54:00:00:00:05),eth_type(0x86dd),ipv6(src=fe80::1,dst=fe80::2,label=0,proto=10,tclass=0x70,hlimit=128,frag=no)'
4741
4742   dnl sleep long enough to get more than one counter sample
4743   dnl from each datasource so we can check sequence numbers
4744   ovs-appctl time/warp 3000 100
4745   OVS_VSWITCHD_STOP
4746   ovs-appctl -t test-sflow exit
4747
4748   AT_CHECK_UNQUOTED([[sort sflow.log | $EGREP 'HEADER|ERROR' | sed 's/ /\
4749         /g']], [0], [dnl
4750 HEADER
4751         dgramSeqNo=1
4752         ds=127.0.0.1>2:1000
4753         fsSeqNo=1
4754         in_vlan=0
4755         in_priority=0
4756         out_vlan=0
4757         out_priority=0
4758         meanSkip=1
4759         samplePool=1
4760         dropEvents=0
4761         in_ifindex=1004
4762         in_format=0
4763         out_ifindex=2
4764         out_format=2
4765         hdr_prot=1
4766         pkt_len=64
4767         stripped=4
4768         hdr_len=60
4769         hdr=FF-FF-FF-FF-FF-FF-50-54-00-00-00-05-08-06-00-01-08-00-06-04-00-01-50-54-00-00-00-05-C0-A8-00-02-00-00-00-00-00-00-C0-A8-00-01-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00
4770 HEADER
4771         dgramSeqNo=1
4772         ds=127.0.0.1>2:1000
4773         fsSeqNo=2
4774         in_vlan=0
4775         in_priority=0
4776         out_vlan=0
4777         out_priority=0
4778         meanSkip=1
4779         samplePool=2
4780         dropEvents=0
4781         in_ifindex=1003
4782         in_format=0
4783         out_ifindex=2
4784         out_format=2
4785         hdr_prot=1
4786         pkt_len=64
4787         stripped=4
4788         hdr_len=60
4789         hdr=FF-FF-FF-FF-FF-FF-50-54-00-00-00-07-08-06-00-01-08-00-06-04-00-01-50-54-00-00-00-07-C0-A8-00-01-00-00-00-00-00-00-C0-A8-00-02-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00
4790 HEADER
4791         dgramSeqNo=1
4792         ds=127.0.0.1>2:1000
4793         fsSeqNo=3
4794         in_vlan=0
4795         in_priority=0
4796         out_vlan=0
4797         out_priority=0
4798         meanSkip=1
4799         samplePool=3
4800         dropEvents=0
4801         in_ifindex=1004
4802         in_format=0
4803         out_ifindex=1003
4804         out_format=0
4805         hdr_prot=1
4806         pkt_len=64
4807         stripped=4
4808         hdr_len=60
4809         hdr=50-54-00-00-00-07-50-54-00-00-00-05-08-00-45-00-00-1C-00-00-00-00-40-01-F9-8D-C0-A8-00-01-C0-A8-00-02-08-00-F7-FF-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00
4810 HEADER
4811         dgramSeqNo=1
4812         ds=127.0.0.1>2:1000
4813         fsSeqNo=4
4814         in_vlan=0
4815         in_priority=0
4816         out_vlan=0
4817         out_priority=0
4818         meanSkip=1
4819         samplePool=4
4820         dropEvents=0
4821         in_ifindex=1003
4822         in_format=0
4823         out_ifindex=1004
4824         out_format=0
4825         hdr_prot=1
4826         pkt_len=64
4827         stripped=4
4828         hdr_len=60
4829         hdr=50-54-00-00-00-05-50-54-00-00-00-07-08-00-45-00-00-1C-00-00-00-00-40-01-F9-8D-C0-A8-00-02-C0-A8-00-01-00-00-FF-FF-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00
4830 HEADER
4831         dgramSeqNo=1
4832         ds=127.0.0.1>2:1000
4833         fsSeqNo=5
4834         in_vlan=0
4835         in_priority=0
4836         out_vlan=0
4837         out_priority=0
4838         meanSkip=1
4839         samplePool=5
4840         dropEvents=0
4841         in_ifindex=1003
4842         in_format=0
4843         out_ifindex=1004
4844         out_format=0
4845         hdr_prot=1
4846         pkt_len=64
4847         stripped=4
4848         hdr_len=60
4849         hdr=50-54-00-00-00-05-50-54-00-00-00-07-86-DD-67-00-00-00-00-00-0A-80-FE-80-00-00-00-00-00-00-00-00-00-00-00-00-00-01-FE-80-00-00-00-00-00-00-00-00-00-00-00-00-00-02-00-00-00-00-00-00
4850 ])
4851
4852   AT_CHECK_UNQUOTED([[sort sflow.log | $EGREP 'IFCOUNTERS|ERROR|PORTNAME|OPENFLOWPORT' | head -18 | sed 's/ /\
4853         /g']], [0], [dnl
4854 IFCOUNTERS
4855         dgramSeqNo=2
4856         ds=127.0.0.1>0:1002
4857         csSeqNo=1
4858         ifindex=1002
4859         type=6
4860         ifspeed=100000000
4861         direction=0
4862         status=0
4863         in_octets=0
4864         in_unicasts=0
4865         in_multicasts=0
4866         in_broadcasts=4294967295
4867         in_discards=0
4868         in_errors=0
4869         in_unknownprotos=4294967295
4870         out_octets=120
4871         out_unicasts=2
4872         out_multicasts=4294967295
4873         out_broadcasts=4294967295
4874         out_discards=0
4875         out_errors=0
4876         promiscuous=0
4877 IFCOUNTERS
4878         dgramSeqNo=2
4879         ds=127.0.0.1>0:1003
4880         csSeqNo=1
4881         ifindex=1003
4882         type=6
4883         ifspeed=100000000
4884         direction=0
4885         status=0
4886         in_octets=138
4887         in_unicasts=3
4888         in_multicasts=0
4889         in_broadcasts=4294967295
4890         in_discards=0
4891         in_errors=0
4892         in_unknownprotos=4294967295
4893         out_octets=120
4894         out_unicasts=2
4895         out_multicasts=4294967295
4896         out_broadcasts=4294967295
4897         out_discards=0
4898         out_errors=0
4899         promiscuous=0
4900 IFCOUNTERS
4901         dgramSeqNo=2
4902         ds=127.0.0.1>0:1004
4903         csSeqNo=1
4904         ifindex=1004
4905         type=6
4906         ifspeed=100000000
4907         direction=0
4908         status=0
4909         in_octets=84
4910         in_unicasts=2
4911         in_multicasts=0
4912         in_broadcasts=4294967295
4913         in_discards=0
4914         in_errors=0
4915         in_unknownprotos=4294967295
4916         out_octets=180
4917         out_unicasts=3
4918         out_multicasts=4294967295
4919         out_broadcasts=4294967295
4920         out_discards=0
4921         out_errors=0
4922         promiscuous=0
4923 IFCOUNTERS
4924         dgramSeqNo=3
4925         ds=127.0.0.1>0:1002
4926         csSeqNo=2
4927         ifindex=1002
4928         type=6
4929         ifspeed=100000000
4930         direction=0
4931         status=0
4932         in_octets=0
4933         in_unicasts=0
4934         in_multicasts=0
4935         in_broadcasts=4294967295
4936         in_discards=0
4937         in_errors=0
4938         in_unknownprotos=4294967295
4939         out_octets=120
4940         out_unicasts=2
4941         out_multicasts=4294967295
4942         out_broadcasts=4294967295
4943         out_discards=0
4944         out_errors=0
4945         promiscuous=0
4946 IFCOUNTERS
4947         dgramSeqNo=3
4948         ds=127.0.0.1>0:1003
4949         csSeqNo=2
4950         ifindex=1003
4951         type=6
4952         ifspeed=100000000
4953         direction=0
4954         status=0
4955         in_octets=138
4956         in_unicasts=3
4957         in_multicasts=0
4958         in_broadcasts=4294967295
4959         in_discards=0
4960         in_errors=0
4961         in_unknownprotos=4294967295
4962         out_octets=120
4963         out_unicasts=2
4964         out_multicasts=4294967295
4965         out_broadcasts=4294967295
4966         out_discards=0
4967         out_errors=0
4968         promiscuous=0
4969 IFCOUNTERS
4970         dgramSeqNo=3
4971         ds=127.0.0.1>0:1004
4972         csSeqNo=2
4973         ifindex=1004
4974         type=6
4975         ifspeed=100000000
4976         direction=0
4977         status=0
4978         in_octets=84
4979         in_unicasts=2
4980         in_multicasts=0
4981         in_broadcasts=4294967295
4982         in_discards=0
4983         in_errors=0
4984         in_unknownprotos=4294967295
4985         out_octets=180
4986         out_unicasts=3
4987         out_multicasts=4294967295
4988         out_broadcasts=4294967295
4989         out_discards=0
4990         out_errors=0
4991         promiscuous=0
4992 OPENFLOWPORT
4993         datapath_id=18364758544493064720
4994         port_no=1
4995 OPENFLOWPORT
4996         datapath_id=18364758544493064720
4997         port_no=1
4998 OPENFLOWPORT
4999         datapath_id=18364758544493064720
5000         port_no=2
5001 OPENFLOWPORT
5002         datapath_id=18364758544493064720
5003         port_no=2
5004 OPENFLOWPORT
5005         datapath_id=18364758544493064720
5006         port_no=65534
5007 OPENFLOWPORT
5008         datapath_id=18364758544493064720
5009         port_no=65534
5010 PORTNAME
5011         portName=br0
5012 PORTNAME
5013         portName=br0
5014 PORTNAME
5015         portName=p1
5016 PORTNAME
5017         portName=p1
5018 PORTNAME
5019         portName=p2
5020 PORTNAME
5021         portName=p2
5022 ])])
5023
5024 AT_SETUP([ofproto-dpif - sFlow packet sampling - IPv4 collector])
5025 CHECK_SFLOW_SAMPLING_PACKET([127.0.0.1])
5026 AT_CLEANUP
5027
5028 AT_SETUP([ofproto-dpif - sFlow packet sampling - IPv6 collector])
5029 AT_SKIP_IF([test $HAVE_IPV6 = no])
5030 CHECK_SFLOW_SAMPLING_PACKET([[[::1]]])
5031 AT_CLEANUP
5032
5033 dnl Test sFlow LAG structures
5034 AT_SETUP([ofproto-dpif - sFlow packet sampling - LACP structures])
5035 AT_SKIP_IF([test "$IS_WIN32" = "yes"])
5036 OVS_VSWITCHD_START([dnl
5037                     add-bond br0 bond p1 p2 --                          \
5038                     set Port bond lacp=active bond-mode=active-backup   \
5039                     other_config:lacp-time="fast"                       \
5040                     other_config:lacp-system-id=11:22:33:44:55:66       \
5041                     other_config:lacp-system-priority=54321 --          \
5042                     set Interface p1 type=dummy                         \
5043                     other_config:lacp-port-id=11                        \
5044                     other_config:lacp-port-priority=111                 \
5045                     other_config:lacp-aggregation-key=3333 --           \
5046                     set Interface p2 type=dummy                         \
5047                     other_config:lacp-port-id=22                        \
5048                     other_config:lacp-port-priority=222                 \
5049                     other_config:lacp-aggregation-key=3333 ])
5050
5051 ON_EXIT([kill `cat test-sflow.pid`])
5052 AT_CHECK([ovstest test-sflow --log-file --detach --no-chdir --pidfile 0:127.0.0.1 > sflow.log], [0], [], [ignore])
5053 AT_CAPTURE_FILE([sflow.log])
5054 SFLOW_PORT=`parse_listening_port < test-sflow.log`
5055
5056 ovs-appctl time/stop
5057
5058 ovs-vsctl \
5059       set Interface p1 options:ifindex=1003 --                  \
5060       set Bridge br0 sflow=@sf --                               \
5061       --id=@sf create sflow targets=\"127.0.0.1:$SFLOW_PORT\"   \
5062       header=128 sampling=1 polling=1
5063
5064 dnl sleep long enough to get the sFlow datagram flushed out (may be delayed for up to 1 second)
5065 AT_CHECK([ovs-appctl time/warp 2000 100], [0], [ignore])
5066 AT_CHECK([ovs-appctl revalidator/purge], [0])
5067 OVS_VSWITCHD_STOP
5068 ovs-appctl -t test-sflow exit
5069 AT_CHECK([[sort sflow.log | $EGREP 'LACPCOUNTERS|ERROR' | head -n 1 | sed 's/ /\
5070         /g']], [0], [dnl
5071 LACPCOUNTERS
5072         sysID=11:22:33:44:55:66
5073         partnerID=00:00:00:00:00:00
5074         aggID=3333
5075         actorAdmin=0x7
5076         actorOper=0xbf
5077         partnerAdmin=0x0
5078         partnerOper=0x2
5079         LACPUDsRx=0
5080         markerPDUsRx=4294967295
5081         markerRespPDUsRx=4294967295
5082         unknownRx=4294967295
5083         illegalRx=0
5084         LACPUDsTx=1
5085         markerPDUsTx=4294967295
5086         markerRespPDUsTx=4294967295
5087 ])
5088
5089 AT_CLEANUP
5090
5091 AT_SETUP([ofproto-dpif - sFlow packet sampling - tunnel set])
5092 AT_XFAIL_IF([test "$IS_WIN32" = "yes"])
5093 OVS_VSWITCHD_START([set Bridge br0 fail-mode=standalone])
5094
5095 dnl set up sFlow logging
5096 dnl ON_EXIT([kill `cat test-sflow.pid`])
5097 AT_CHECK([ovstest test-sflow --log-file --detach --no-chdir --pidfile 0:127.0.0.1 > sflow.log], [0], [], [ignore])
5098 AT_CAPTURE_FILE([sflow.log])
5099 SFLOW_PORT=`parse_listening_port < test-sflow.log`
5100 ovs-appctl time/stop
5101
5102 OVS_VSWITCHD_DISABLE_TUNNEL_PUSH_POP
5103 AT_CHECK([ovs-vsctl add-port br0 gre0 -- set Interface gre0 type=gre \
5104                     options:remote_ip=1.1.1.1 options:key=456 ofport_request=3])
5105 AT_CHECK([ovs-vsctl add-port br0 p1 -- set Interface p1 type=dummy ofport_request=4])
5106
5107 AT_CHECK([ovs-ofctl add-flow br0 action=3])
5108
5109 dnl enable sflow
5110 ovs-vsctl \
5111    set Bridge br0 sflow=@sf -- \
5112    --id=@sf create sflow targets=\"127.0.0.1:$SFLOW_PORT\" \
5113      header=128 sampling=1 polling=0
5114
5115 dnl introduce a packet that will be flooded to the tunnel
5116 AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(4),eth(src=50:54:00:00:00:09,dst=50:54:00:00:00:0a),eth_type(0x0800),ipv4(src=10.10.10.2,dst=10.10.10.1,proto=1,tos=1,ttl=128,frag=no),icmp(type=8,code=0)'])
5117
5118 dnl sleep long enough to get the sFlow datagram flushed out (may be delayed for up to 1 second)
5119 for i in `seq 1 30`; do
5120     ovs-appctl time/warp 100
5121 done
5122
5123 ovs-appctl -t test-sflow exit
5124
5125 AT_CHECK_UNQUOTED([[sort sflow.log | $EGREP 'HEADER|ERROR' | sed 's/ /\
5126         /g']], [0], [dnl
5127 HEADER
5128         dgramSeqNo=1
5129         ds=127.0.0.1>2:1000
5130         fsSeqNo=1
5131         tunnel4_out_length=0
5132         tunnel4_out_protocol=47
5133         tunnel4_out_src=0.0.0.0
5134         tunnel4_out_dst=1.1.1.1
5135         tunnel4_out_src_port=0
5136         tunnel4_out_dst_port=0
5137         tunnel4_out_tcp_flags=0
5138         tunnel4_out_tos=1
5139         tunnel_out_vni=456
5140         in_vlan=0
5141         in_priority=0
5142         out_vlan=0
5143         out_priority=0
5144         meanSkip=1
5145         samplePool=1
5146         dropEvents=0
5147         in_ifindex=0
5148         in_format=0
5149         out_ifindex=1
5150         out_format=2
5151         hdr_prot=1
5152         pkt_len=64
5153         stripped=4
5154         hdr_len=60
5155         hdr=50-54-00-00-00-0A-50-54-00-00-00-09-08-00-45-01-00-1C-00-00-00-00-80-01-12-CA-0A-0A-0A-02-0A-0A-0A-01-08-00-F7-FF-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00
5156 ])
5157
5158 OVS_VSWITCHD_STOP
5159 AT_CLEANUP
5160
5161 AT_SETUP([ofproto-dpif - sFlow packet sampling - tunnel push])
5162 AT_XFAIL_IF([test "$IS_WIN32" = "yes"])
5163
5164 OVS_VSWITCHD_START([add-port br0 p0 -- set Interface p0 type=dummy ofport_request=1 options:ifindex=1010])
5165
5166 dnl set up sFlow logging
5167 dnl ON_EXIT([kill `cat test-sflow.pid`])
5168 AT_CHECK([ovstest test-sflow --log-file --detach --no-chdir --pidfile 0:127.0.0.1 > sflow.log], [0], [], [ignore])
5169 AT_CAPTURE_FILE([sflow.log])
5170 SFLOW_PORT=`parse_listening_port < test-sflow.log`
5171 ovs-appctl time/stop
5172
5173 AT_CHECK([ovs-appctl vlog/set dpif:dbg dpif_netdev:dbg])
5174 AT_CHECK([ovs-vsctl add-br int-br -- set bridge int-br datapath_type=dummy], [0])
5175 AT_CHECK([ovs-vsctl -- add-port int-br t1 -- set Interface t1 type=gre \
5176                        options:remote_ip=1.1.2.92 options:key=456 ofport_request=4\
5177                     -- add-port int-br vm1 -- set Interface vm1 type=dummy \
5178                        options:ifindex=2011 ofport_request=5
5179                        ], [0])
5180
5181 AT_CHECK([ovs-appctl dpif/show], [0], [dnl
5182 dummy@ovs-dummy: hit:0 missed:0
5183         br0:
5184                 br0 65534/100: (dummy)
5185                 p0 1/1: (dummy: ifindex=1010)
5186         int-br:
5187                 int-br 65534/2: (dummy)
5188                 t1 4/4: (gre: key=456, remote_ip=1.1.2.92)
5189                 vm1 5/3: (dummy: ifindex=2011)
5190 ])
5191
5192 dnl set up route to 1.1.2.92 via br0 and action=normal
5193 AT_CHECK([ovs-appctl ovs/route/add 1.1.2.92/24 br0], [0], [OK
5194 ])
5195 AT_CHECK([ovs-appctl ovs/route/add 192.168.0.0/16 br0], [0], [OK
5196 ])
5197 AT_CHECK([ovs-appctl netdev-dummy/ip4addr br0 1.1.2.88/24], [0], [OK
5198 ])
5199 AT_CHECK([ovs-ofctl add-flow br0 action=normal])
5200
5201 dnl Prime ARP Cache for 1.1.2.92
5202 AT_CHECK([ovs-appctl netdev-dummy/receive br0 'recirc_id(0),in_port(100),eth(src=f8:bc:12:44:34:b6,dst=ff:ff:ff:ff:ff:ff),eth_type(0x0806),arp(sip=1.1.2.92,tip=1.1.2.88,op=1,sha=f8:bc:12:44:34:b6,tha=00:00:00:00:00:00)'])
5203
5204 dnl configure sflow on int-br only
5205 ovs-vsctl \
5206    set Bridge int-br sflow=@sf -- \
5207    --id=@sf create sflow targets=\"127.0.0.1:$SFLOW_PORT\" \
5208      header=128 sampling=1 polling=0
5209
5210 dnl add rule for int-br to force packet onto tunnel. There is no ifindex
5211 dnl for this port so the sFlow output will just report that it went to
5212 dnl 1 output (out_format=2, out_ifindex=1)
5213 AT_CHECK([ovs-ofctl add-flow int-br "actions=4"])
5214
5215 AT_CHECK([ovs-appctl netdev-dummy/receive vm1 'in_port(3),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:0a),eth_type(0x0800),ipv4(src=192.168.1.1,dst=192.168.2.2,proto=1,tos=0,ttl=128,frag=no),icmp(type=8,code=0)'])
5216
5217 dnl sleep long enough to get the sFlow datagram flushed out (may be delayed for up to 1 second)
5218 for i in `seq 1 30`; do
5219     ovs-appctl time/warp 100
5220 done
5221
5222 ovs-appctl -t test-sflow exit
5223
5224 AT_CHECK_UNQUOTED([[sort sflow.log | $EGREP 'HEADER|ERROR' | sed 's/ /\
5225         /g']], [0], [dnl
5226 HEADER
5227         dgramSeqNo=1
5228         ds=127.0.0.1>2:1000
5229         fsSeqNo=1
5230         tunnel4_out_length=0
5231         tunnel4_out_protocol=47
5232         tunnel4_out_src=1.1.2.88
5233         tunnel4_out_dst=1.1.2.92
5234         tunnel4_out_src_port=0
5235         tunnel4_out_dst_port=0
5236         tunnel4_out_tcp_flags=0
5237         tunnel4_out_tos=0
5238         tunnel_out_vni=456
5239         in_vlan=0
5240         in_priority=0
5241         out_vlan=0
5242         out_priority=0
5243         meanSkip=1
5244         samplePool=1
5245         dropEvents=0
5246         in_ifindex=2011
5247         in_format=0
5248         out_ifindex=1
5249         out_format=2
5250         hdr_prot=1
5251         pkt_len=64
5252         stripped=4
5253         hdr_len=60
5254         hdr=50-54-00-00-00-0A-50-54-00-00-00-05-08-00-45-00-00-1C-00-00-00-00-80-01-B6-8D-C0-A8-01-01-C0-A8-02-02-08-00-F7-FF-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00
5255 ])
5256
5257 OVS_VSWITCHD_STOP
5258 AT_CLEANUP
5259
5260 AT_SETUP([ofproto-dpif - sFlow packet sampling - MPLS])
5261 OVS_VSWITCHD_START
5262 AT_CHECK([ovs-appctl vlog/set dpif:dbg dpif_netdev:dbg])
5263 ADD_OF_PORTS([br0], [1], [2])
5264 AT_DATA([flows.txt], [dnl
5265 table=0 dl_src=50:54:00:00:00:09 actions=push_mpls:0x8847,set_mpls_label:789,set_mpls_tc:4,set_mpls_ttl:32,2
5266 table=0 dl_src=50:54:00:00:00:0b actions=pop_mpls:0x0800,2
5267 ])
5268 AT_CHECK([ovs-ofctl add-flows br0 flows.txt])
5269
5270 dnl set up sFlow logging
5271 dnl ON_EXIT([kill `cat test-sflow.pid`])
5272 AT_CHECK([ovstest test-sflow --log-file --detach --no-chdir --pidfile 0:127.0.0.1 > sflow.log], [0], [], [ignore])
5273 AT_CAPTURE_FILE([sflow.log])
5274 SFLOW_PORT=`parse_listening_port < test-sflow.log`
5275 ovs-appctl time/stop
5276
5277 dnl configure sflow
5278 ovs-vsctl \
5279    set Bridge br0 sflow=@sf -- \
5280    --id=@sf create sflow targets=\"127.0.0.1:$SFLOW_PORT\" \
5281      header=128 sampling=1 polling=0
5282
5283 AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:09,dst=50:54:00:00:00:0a),eth_type(0x8847),mpls(label=11,tc=3,ttl=64,bos=1)'])
5284 AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:09,dst=50:54:00:00:00:0a),eth_type(0x0800)'])
5285
5286 dnl sleep long enough to get the sFlow datagram flushed out (may be delayed for up to 1 second)
5287 for i in `seq 1 30`; do
5288     ovs-appctl time/warp 100
5289 done
5290
5291 ovs-appctl -t test-sflow exit
5292
5293 AT_CHECK_UNQUOTED([[sort sflow.log | $EGREP 'HEADER|ERROR' | sed 's/ /\
5294         /g']], [0], [dnl
5295 HEADER
5296         dgramSeqNo=1
5297         ds=127.0.0.1>2:1000
5298         fsSeqNo=1
5299         mpls_label_0=789
5300         mpls_tc_0=4
5301         mpls_ttl_0=32
5302         mpls_bos_0=0
5303         mpls_label_1=11
5304         mpls_tc_1=3
5305         mpls_ttl_1=64
5306         mpls_bos_1=1
5307         in_vlan=0
5308         in_priority=0
5309         out_vlan=0
5310         out_priority=0
5311         meanSkip=1
5312         samplePool=1
5313         dropEvents=0
5314         in_ifindex=0
5315         in_format=0
5316         out_ifindex=1
5317         out_format=2
5318         hdr_prot=1
5319         pkt_len=64
5320         stripped=4
5321         hdr_len=60
5322         hdr=50-54-00-00-00-0A-50-54-00-00-00-09-88-47-00-00-B7-40-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00
5323 HEADER
5324         dgramSeqNo=1
5325         ds=127.0.0.1>2:1000
5326         fsSeqNo=2
5327         mpls_label_0=789
5328         mpls_tc_0=4
5329         mpls_ttl_0=32
5330         mpls_bos_0=1
5331         in_vlan=0
5332         in_priority=0
5333         out_vlan=0
5334         out_priority=0
5335         meanSkip=1
5336         samplePool=2
5337         dropEvents=0
5338         in_ifindex=0
5339         in_format=0
5340         out_ifindex=1
5341         out_format=2
5342         hdr_prot=1
5343         pkt_len=64
5344         stripped=4
5345         hdr_len=60
5346         hdr=50-54-00-00-00-0A-50-54-00-00-00-09-08-00-45-00-00-14-00-00-00-00-00-00-BA-EB-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00
5347 ])
5348
5349 OVS_VSWITCHD_STOP
5350 AT_CLEANUP
5351
5352
5353 # CHECK_NETFLOW_EXPIRATION(LOOPBACK_ADDR)
5354 #
5355 # Test that basic NetFlow reports flow statistics correctly:
5356 # The initial packet of a flow are correctly accounted.
5357 # Later packets within a flow are correctly accounted.
5358 # Flow actions changing (in this case, due to MAC learning)
5359 # cause a record to be sent.
5360 m4_define([CHECK_NETFLOW_EXPIRATION],
5361   [OVS_VSWITCHD_START([set Bridge br0 fail-mode=standalone])
5362   ADD_OF_PORTS([br0], 1, 2)
5363
5364   ovs-appctl time/stop
5365   ON_EXIT([kill `cat test-netflow.pid`])
5366   AT_CHECK([ovstest test-netflow --log-file --detach --no-chdir --pidfile 0:$1 > netflow.log], [0], [], [ignore])
5367   AT_CAPTURE_FILE([netflow.log])
5368   NETFLOW_PORT=`parse_listening_port < test-netflow.log`
5369
5370   ovs-vsctl \
5371      set Bridge br0 netflow=@nf -- \
5372      --id=@nf create NetFlow targets=\"$1:$NETFLOW_PORT\" \
5373        engine_id=1 engine_type=2 active_timeout=30 add-id-to-interface=false
5374
5375   for delay in 1000 30000; do
5376       ovs-appctl netdev-dummy/receive p1 'in_port(2),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'
5377       sleep 1  # ensure the order in which these two packets are processed
5378       ovs-appctl netdev-dummy/receive p2 'in_port(1),eth(src=50:54:00:00:00:07,dst=50:54:00:00:00:05),eth_type(0x0800),ipv4(src=192.168.0.2,dst=192.168.0.1,proto=1,tos=0,ttl=64,frag=no),icmp(type=0,code=0)'
5379
5380       ovs-appctl time/warp $delay
5381   done
5382
5383   ovs-appctl time/warp 6000
5384   ovs-appctl revalidator/wait
5385   OVS_VSWITCHD_STOP
5386   ovs-appctl -t test-netflow exit
5387
5388   AT_CHECK([test `grep "192.168.0.1 > 192.168.0.2, if 1 > 65535, 1 pkts, 60 bytes, ICMP 8:0" netflow.log | wc -l` -eq 1])
5389
5390   AT_CHECK([test `grep "192.168.0.1 > 192.168.0.2, if 1 > 2, 1 pkts, 60 bytes, ICMP 8:0" netflow.log | wc -l` -eq 1])
5391
5392   combined=`grep "192.168.0.2 > 192.168.0.1, if 2 > 1, 2 pkts, 120 bytes, ICMP 0:0" netflow.log | wc -l`
5393   separate=`grep "192.168.0.2 > 192.168.0.1, if 2 > 1, 1 pkts, 60 bytes, ICMP 0:0" netflow.log | wc -l`
5394   AT_CHECK([test $separate = 2 || test $combined = 1], [0])])
5395
5396 AT_SETUP([ofproto-dpif - NetFlow flow expiration - IPv4 collector])
5397 CHECK_NETFLOW_EXPIRATION([127.0.0.1])
5398 AT_CLEANUP
5399
5400 AT_SETUP([ofproto-dpif - NetFlow flow expiration - IPv6 collector])
5401 AT_SKIP_IF([test $HAVE_IPV6 = no])
5402 CHECK_NETFLOW_EXPIRATION([[[::1]]])
5403 AT_CLEANUP
5404
5405 # CHECK_NETFLOW_ACTIVE_EXPIRATION(LOOPBACK_ADDR)
5406 #
5407 # Test that basic NetFlow reports active expirations correctly.
5408 m4_define([CHECK_NETFLOW_ACTIVE_EXPIRATION],
5409   [OVS_VSWITCHD_START([set Bridge br0 fail-mode=standalone])
5410   ADD_OF_PORTS([br0], 1, 2)
5411
5412   ON_EXIT([kill `cat test-netflow.pid`])
5413   AT_CHECK([ovstest test-netflow --log-file --detach --no-chdir --pidfile 0:$1 > netflow.log], [0], [], [ignore])
5414   AT_CAPTURE_FILE([netflow.log])
5415   NETFLOW_PORT=`parse_listening_port < test-netflow.log`
5416
5417   ovs-vsctl \
5418      set Bridge br0 netflow=@nf -- \
5419      --id=@nf create NetFlow targets=\"$1:$NETFLOW_PORT\" \
5420        engine_id=1 engine_type=2 active_timeout=10 add-id-to-interface=false
5421
5422   AT_CHECK([ovs-appctl time/stop])
5423   n=1
5424   while test $n -le 60; do
5425       n=`expr $n + 1`
5426
5427       ovs-appctl netdev-dummy/receive p1 'in_port(2),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=6,tos=0,ttl=64,frag=no),tcp(src=1234,dst=80)'
5428       ovs-appctl netdev-dummy/receive p2 'in_port(1),eth(src=50:54:00:00:00:07,dst=50:54:00:00:00:05),eth_type(0x0800),ipv4(src=192.168.0.2,dst=192.168.0.1,proto=6,tos=0,ttl=64,frag=no),tcp(src=80,dst=1234)'
5429
5430       ovs-appctl time/warp 1000
5431   done
5432
5433   ovs-appctl time/warp 10000
5434
5435   ovs-appctl revalidator/wait
5436   OVS_VSWITCHD_STOP
5437   ovs-appctl -t test-netflow exit
5438
5439   # Count the number of reported packets:
5440   # - From source to destination before MAC learning kicks in (just one).
5441   # - From source to destination after that.
5442   # - From destination to source.
5443   n_learn=0
5444   n_in=0
5445   n_out=0
5446   n_other=0
5447   n_recs=0
5448   none=0
5449   while read line; do
5450       pkts=`echo "$line" | sed 's/.*, \([[0-9]]*\) pkts,.*/\1/'`
5451       case $pkts in
5452            [[0-9]]*) ;;
5453        *) continue ;;
5454       esac
5455
5456       case $line in
5457           "seq "*": 192.168.0.1 > 192.168.0.2, if 1 > 65535, "*" pkts, "*" bytes, TCP 1234 > 80, time "*)
5458               counter=n_learn
5459           ;;
5460       "seq "*": 192.168.0.1 > 192.168.0.2, if 1 > 2, "*" pkts, "*" bytes, TCP 1234 > 80, time "*)
5461           counter=n_in
5462           ;;
5463       "seq "*": 192.168.0.2 > 192.168.0.1, if 2 > 1, "*" pkts, "*" bytes, TCP 80 > 1234, time "*)
5464           counter=n_out
5465           ;;
5466       *)
5467           counter=n_other
5468           ;;
5469       esac
5470       eval $counter=\`expr \$$counter + \$pkts\`
5471       n_recs=`expr $n_recs + 1`
5472   done < netflow.log
5473
5474   # There should be exactly 1 MAC learning packet,
5475   # exactly 59 other packets in that direction,
5476   # and exactly 60 packets in the other direction.
5477   AT_CHECK([echo $n_learn $n_in $n_out $n_other], [0], [1 59 60 0
5478 ])])
5479
5480 AT_SETUP([ofproto-dpif - NetFlow active expiration - IPv4 collector])
5481 CHECK_NETFLOW_ACTIVE_EXPIRATION([127.0.0.1])
5482 AT_CLEANUP
5483
5484 AT_SETUP([ofproto-dpif - NetFlow active expiration - IPv6 collector])
5485 AT_SKIP_IF([test $HAVE_IPV6 = no])
5486 CHECK_NETFLOW_ACTIVE_EXPIRATION([[[::1]]])
5487 AT_CLEANUP
5488
5489 AT_SETUP([ofproto-dpif - flow stats])
5490 OVS_VSWITCHD_START
5491 AT_CHECK([ovs-ofctl add-flow br0 "ip,actions=NORMAL"])
5492 AT_CHECK([ovs-ofctl add-flow br0 "icmp,actions=NORMAL"])
5493
5494 ovs-appctl time/stop
5495
5496 for i in `seq 1 10`; do
5497     ovs-appctl netdev-dummy/receive br0 'in_port(0),eth(src=50:54:00:00:00:07,dst=50:54:00:00:00:05),eth_type(0x0800),ipv4(src=192.168.0.2,dst=192.168.0.1,proto=6,tos=0,ttl=64,frag=no)'
5498 done
5499
5500 AT_CHECK([ovs-appctl time/warp 1000], [0], [ignore])
5501 AT_CHECK([ovs-appctl revalidator/purge], [0])
5502 AT_CHECK([ovs-ofctl dump-flows br0], [0], [stdout])
5503 AT_CHECK([STRIP_XIDS stdout | sed -n 's/duration=[[0-9]]*\.[[0-9]]*s/duration=0.0s/p' | sort], [0], [dnl
5504  cookie=0x0, duration=0.0s, table=0, n_packets=0, n_bytes=0, idle_age=1, icmp actions=NORMAL
5505  cookie=0x0, duration=0.0s, table=0, n_packets=10, n_bytes=600, idle_age=1, ip actions=NORMAL
5506 ])
5507 OVS_VSWITCHD_STOP
5508 AT_CLEANUP
5509
5510 AT_SETUP([ofproto-dpif - flow stats, set-n-threads])
5511 OVS_VSWITCHD_START
5512 AT_CHECK([ovs-ofctl add-flow br0 "ip,actions=NORMAL"])
5513 AT_CHECK([ovs-ofctl add-flow br0 "icmp,actions=NORMAL"])
5514
5515 ovs-appctl time/stop
5516
5517 for i in `seq 1 10`; do
5518     ovs-appctl netdev-dummy/receive br0 'in_port(0),eth(src=50:54:00:00:00:07,dst=50:54:00:00:00:05),eth_type(0x0800),ipv4(src=192.168.0.2,dst=192.168.0.1,proto=6,tos=0,ttl=64,frag=no)'
5519 done
5520
5521 ovs-appctl time/warp 100
5522 AT_CHECK([ovs-vsctl set Open_vSwitch . other-config:n-revalidator-threads=2])
5523 ovs-appctl time/warp 1000
5524
5525 AT_CHECK([ovs-ofctl dump-flows br0], [0], [stdout])
5526 AT_CHECK([STRIP_XIDS stdout | sed -n 's/duration=[[0-9]]*\.[[0-9]]*s/duration=0.0s/p' | sort], [0], [dnl
5527  cookie=0x0, duration=0.0s, table=0, n_packets=0, n_bytes=0, idle_age=1, icmp actions=NORMAL
5528  cookie=0x0, duration=0.0s, table=0, n_packets=10, n_bytes=600, idle_age=1, ip actions=NORMAL
5529 ])
5530 OVS_VSWITCHD_STOP
5531 AT_CLEANUP
5532
5533 AT_SETUP([ofproto-dpif - idle_age and hard_age increase over time])
5534 OVS_VSWITCHD_START
5535
5536 # get_ages DURATION HARD IDLE
5537 #
5538 # Fetch the flow duration, hard age, and idle age into the variables
5539 # whose names are given as arguments.  Rounds DURATION down to the
5540 # nearest integer.  If hard_age doesn't appear in the output, sets
5541 # HARD to "none".  If idle_age doesn't appear in the output, sets IDLE
5542 # to 0.
5543 get_ages () {
5544     AT_CHECK([ovs-ofctl dump-flows br0], [0], [stdout])
5545
5546     duration=`sed -n 's/.*duration=\([[0-9]]*\)\(\.[[0-9]]*\)\{0,1\}s.*/\1/p' stdout`
5547     AT_CHECK([[expr X"$duration" : 'X[0-9][0-9]*$']], [0], [ignore])
5548     AS_VAR_COPY([$1], [duration])
5549
5550     hard=`sed -n 's/.*hard_age=\([[0-9]]*\),.*/\1/p' stdout`
5551     if test X"$hard" = X; then
5552         hard=none
5553     else
5554         AT_CHECK([[expr X"$hard" : 'X[0-9][0-9]*$']], [0], [ignore])
5555     fi
5556     AS_VAR_COPY([$2], [hard])
5557
5558     idle=`sed -n 's/.*idle_age=\([[0-9]]*\),.*/\1/p' stdout`
5559     if test X"$idle" = X; then
5560         idle=0
5561     else
5562         AT_CHECK([[expr X"$idle" : 'X[0-9][0-9]*$']], [0], [ignore])
5563     fi
5564     AS_VAR_COPY([$3], [idle])
5565 }
5566
5567 # Add a flow and get its initial hard and idle age.
5568 AT_CHECK([ovs-ofctl add-flow br0 hard_timeout=199,idle_timeout=188,actions=drop])
5569 get_ages duration1 hard1 idle1
5570
5571 ovs-appctl time/stop
5572 # Warp time forward by 10 seconds, then modify the flow's actions.
5573 ovs-appctl time/warp 10000
5574 get_ages duration2 hard2 idle2
5575 AT_CHECK([ovs-ofctl mod-flows br0 actions=flood])
5576
5577 # Warp time forward by 10 seconds.
5578 ovs-appctl time/warp 10000
5579 get_ages duration3 hard3 idle3
5580
5581 # Warp time forward 10 more seconds, then pass some packets through the flow,
5582 # then warp forward a few more times because idle times are only updated
5583 # occasionally.
5584 ovs-appctl time/warp 10000
5585 ovs-appctl netdev-dummy/receive br0 'in_port(0),eth(src=50:54:00:00:00:07,dst=50:54:00:00:00:05),eth_type(0x0800),ipv4(src=192.168.0.2,dst=192.168.0.1,proto=6,tos=0,ttl=64,frag=no),tcp(src=80,dst=1234)'
5586 ovs-appctl time/warp 3000 1000
5587 sleep 1
5588 get_ages duration4 hard4 idle4
5589
5590 printf "duration: %4s => %4s => %4s => %4s\n" $duration1 $duration2 $duration3 $duration4
5591 printf "hard_age: %4s => %4s => %4s => %4s\n" $hard1 $hard2 $hard3 $hard4
5592 printf "idle_age: %4s => %4s => %4s => %4s\n" $idle1 $idle2 $idle3 $idle4
5593
5594 # Duration should increase steadily over time.
5595 AT_CHECK([test $duration1 -lt $duration2])
5596 AT_CHECK([test $duration2 -lt $duration3])
5597 AT_CHECK([test $duration3 -lt $duration4])
5598
5599 # Hard age should be "none" initially because it's the same as flow_duration,
5600 # then it should increase.
5601 AT_CHECK([test $hard1 = none])
5602 AT_CHECK([test $hard2 = none])
5603 AT_CHECK([test $hard3 != none])
5604 AT_CHECK([test $hard4 != none])
5605 AT_CHECK([test $hard3 -lt $hard4])
5606
5607 # Idle age should increase from 1 to 2 to 3, then decrease.
5608 AT_CHECK([test $idle1 -lt $idle2])
5609 AT_CHECK([test $idle2 -lt $idle3])
5610 AT_CHECK([test $idle3 -gt $idle4])
5611
5612 # Check some invariant relationships.
5613 AT_CHECK([test $duration1 = $idle1])
5614 AT_CHECK([test $duration2 = $idle2])
5615 AT_CHECK([test $duration3 = $idle3])
5616 AT_CHECK([test $idle3 -gt $hard3])
5617 AT_CHECK([test $idle4 -lt $hard4])
5618 AT_CHECK([test $hard4 -lt $duration4])
5619
5620 OVS_VSWITCHD_STOP
5621 AT_CLEANUP
5622
5623 AT_SETUP([ofproto-dpif - fin_timeout])
5624 OVS_VSWITCHD_START
5625 ovs-appctl time/stop
5626 AT_CHECK([ovs-ofctl add-flow br0 'idle_timeout=60,actions=fin_timeout(idle_timeout=5)'])
5627 AT_CHECK([ovs-ofctl dump-flows br0 | ofctl_strip], [0],
5628 [NXST_FLOW reply:
5629  idle_timeout=60, actions=fin_timeout(idle_timeout=5)
5630 ])
5631
5632 # Check that a TCP SYN packet does not change the timeout.  (Because
5633 # flow stats updates are mainly what implements the fin_timeout
5634 # feature, we warp forward a couple of times to ensure that flow stats
5635 # run before re-checking the flow table.)
5636 AT_CHECK([ovs-appctl netdev-dummy/receive br0 0021853763af0026b98cb0f908004500003c2e2440004006465dac11370dac11370b828b0016751e267b00000000a00216d017360000020405b40402080a2d25085f0000000001030307])
5637 AT_CHECK([ovs-appctl time/warp 1000 && ovs-appctl time/warp 1000], [0], [warped
5638 warped
5639 ])
5640 AT_CHECK([ovs-appctl revalidator/purge], [0])
5641 AT_CHECK([ovs-ofctl dump-flows br0 | ofctl_strip], [0],
5642 [NXST_FLOW reply:
5643  n_packets=1, n_bytes=74, idle_timeout=60, actions=fin_timeout(idle_timeout=5)
5644 ])
5645 # Check that a TCP FIN packet does change the timeout.
5646 AT_CHECK([ovs-appctl netdev-dummy/receive br0 0021853763af0026b98cb0f90800451000342e3e40004006463bac11370dac11370b828b0016751e319dfc96399b801100717ae800000101080a2d250a9408579588])
5647 AT_CHECK([ovs-appctl time/warp 1000 && ovs-appctl time/warp 1000], [0], [warped
5648 warped
5649 ])
5650 AT_CHECK([ovs-ofctl dump-flows br0 | ofctl_strip], [0],
5651 [NXST_FLOW reply:
5652  n_packets=2, n_bytes=140, idle_timeout=5, actions=fin_timeout(idle_timeout=5)
5653 ])
5654 OVS_VSWITCHD_STOP
5655 AT_CLEANUP
5656
5657 AT_SETUP([ofproto-dpif - ovs-appctl dpif/dump-dps])
5658 OVS_VSWITCHD_START([add-br br1 -- set bridge br1 datapath-type=dummy])
5659 ADD_OF_PORTS([br0], [1], [2])
5660 ADD_OF_PORTS([br1], [3])
5661
5662 AT_CHECK([ovs-appctl dpif/dump-dps], [0], [dnl
5663 dummy@br0
5664 dummy@br1
5665 ])
5666 OVS_VSWITCHD_STOP
5667 AT_CLEANUP
5668
5669 AT_SETUP([ofproto-dpif - ovs-appctl dpif/show])
5670 OVS_VSWITCHD_START([add-br br1 -- set bridge br1 datapath-type=dummy])
5671 ADD_OF_PORTS([br0], [1], [2])
5672 ADD_OF_PORTS([br1], [3])
5673
5674 AT_CHECK([ovs-appctl dpif/show], [0], [dnl
5675 dummy@ovs-dummy: hit:0 missed:0
5676         br0:
5677                 br0 65534/100: (dummy)
5678                 p1 1/1: (dummy)
5679                 p2 2/2: (dummy)
5680         br1:
5681                 br1 65534/101: (dummy)
5682                 p3 3/3: (dummy)
5683 ])
5684 OVS_VSWITCHD_STOP
5685 AT_CLEANUP
5686
5687 AT_SETUP([ofproto-dpif - ovs-appctl dpif/dump-flows])
5688 # bump max-idle to avoid the flows being reclaimed behind us
5689 OVS_VSWITCHD_START([add-br br1 -- \
5690                     set bridge br1 datapath-type=dummy fail-mode=secure -- \
5691                     set Open_vSwitch . other_config:max-idle=10000])
5692 ADD_OF_PORTS([br0], [1], [2])
5693 ADD_OF_PORTS([br1], [3])
5694
5695 AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'])
5696 AT_CHECK([ovs-appctl netdev-dummy/receive p2 'in_port(2),eth(src=50:54:00:00:00:07,dst=50:54:00:00:00:05),eth_type(0x0800),ipv4(src=192.168.0.2,dst=192.168.0.1,proto=1,tos=0,ttl=64,frag=no),icmp(type=0,code=0)'])
5697 AT_CHECK([ovs-appctl netdev-dummy/receive p3 'in_port(3),eth(src=50:54:00:00:00:09,dst=50:54:00:00:00:0a),eth_type(0x0800),ipv4(src=10.0.0.2,dst=10.0.0.1,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'])
5698 ovs-appctl revalidator/wait
5699 AT_CHECK([ovs-appctl dpif/dump-flows br0 | STRIP_UFID | STRIP_USED | sort], [0], [dnl
5700 recirc_id(0),in_port(1),eth_type(0x0800),ipv4(frag=no), packets:0, bytes:0, used:never, actions:drop
5701 recirc_id(0),in_port(2),eth_type(0x0800),ipv4(frag=no), packets:0, bytes:0, used:never, actions:drop
5702 ])
5703
5704 AT_CHECK([ovs-appctl dpif/dump-flows br1 | STRIP_UFID | STRIP_USED | sort], [0], [dnl
5705 recirc_id(0),in_port(3),eth_type(0x0800),ipv4(frag=no), packets:0, bytes:0, used:never, actions:drop
5706 ])
5707
5708 AT_CHECK([ovs-appctl dpif/dump-flows -m br0 | STRIP_UFID | STRIP_USED | sort], [0], [dnl
5709 skb_priority(0/0),skb_mark(0/0),recirc_id(0),dp_hash(0/0),in_port(p1),eth(src=50:54:00:00:00:05/00:00:00:00:00:00,dst=50:54:00:00:00:07/00:00:00:00:00:00),eth_type(0x0800),ipv4(src=192.168.0.1/0.0.0.0,dst=192.168.0.2/0.0.0.0,proto=1/0,tos=0/0,ttl=64/0,frag=no),icmp(type=8/0,code=0/0), packets:0, bytes:0, used:never, actions:drop
5710 skb_priority(0/0),skb_mark(0/0),recirc_id(0),dp_hash(0/0),in_port(p2),eth(src=50:54:00:00:00:07/00:00:00:00:00:00,dst=50:54:00:00:00:05/00:00:00:00:00:00),eth_type(0x0800),ipv4(src=192.168.0.2/0.0.0.0,dst=192.168.0.1/0.0.0.0,proto=1/0,tos=0/0,ttl=64/0,frag=no),icmp(type=0/0,code=0/0), packets:0, bytes:0, used:never, actions:drop
5711 ])
5712
5713 AT_CHECK([ovs-appctl dpif/dump-flows -m br1 | STRIP_UFID | STRIP_USED | sort], [0], [dnl
5714 skb_priority(0/0),skb_mark(0/0),recirc_id(0),dp_hash(0/0),in_port(p3),eth(src=50:54:00:00:00:09/00:00:00:00:00:00,dst=50:54:00:00:00:0a/00:00:00:00:00:00),eth_type(0x0800),ipv4(src=10.0.0.2/0.0.0.0,dst=10.0.0.1/0.0.0.0,proto=1/0,tos=0/0,ttl=64/0,frag=no),icmp(type=8/0,code=0/0), packets:0, bytes:0, used:never, actions:drop
5715 ])
5716
5717 OVS_VSWITCHD_STOP
5718 AT_CLEANUP
5719
5720 AT_SETUP([ofproto-dpif - ovs-appctl dpif/get-flow])
5721
5722 OVS_VSWITCHD_START([add-br br1 -- \
5723                     set bridge br1 datapath-type=dummy fail-mode=secure -- \
5724                     set Open_vSwitch . other_config:max-idle=10000])
5725 ADD_OF_PORTS([br0], [1], [2])
5726
5727 AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'])
5728 ovs-appctl revalidator/wait
5729 AT_CHECK([ovs-appctl dpif/dump-flows -m br0], [0], [stdout])
5730
5731 UFID=`sed -n 's/\(ufid:[[-0-9a-fA-F]]*\).*/\1/p' stdout`
5732 AT_CHECK([ovs-appctl dpctl/get-flow $UFID], [0], [dnl
5733 recirc_id(0),in_port(1),eth_type(0x0800),ipv4(frag=no), packets:0, bytes:0, used:never, actions:drop
5734 ])
5735
5736 OVS_VSWITCHD_STOP
5737 AT_CLEANUP
5738
5739 AT_SETUP([ofproto-dpif - MPLS actions that result in a userspace action])
5740 OVS_VSWITCHD_START([dnl
5741    add-port br0 p1 -- set Interface p1 type=dummy
5742 ])
5743 AT_CHECK([ovs-appctl vlog/set dpif:dbg dpif_netdev:dbg])
5744 ON_EXIT([kill `cat ovs-ofctl.pid`])
5745
5746 AT_CAPTURE_FILE([ofctl_monitor.log])
5747 AT_DATA([flows.txt], [dnl
5748 dl_src=60:66:66:66:66:00 actions=push_mpls:0x8847,controller
5749 dl_src=60:66:66:66:66:01 actions=pop_mpls:0x8849,controller
5750 ])
5751 AT_CHECK([ovs-ofctl add-flows br0 flows.txt])
5752
5753 dnl Packet is sent to userspace because a MPLS push or pop action is applied to
5754 dnl a packet with 2 MPLS LSEs but dpif-netdev can't handle any labels.
5755 dnl
5756 dnl The input is a frame with two MPLS labels which tcpdump -vve shows as:
5757 dnl 60:66:66:66:66:00 > 50:54:00:00:00:07, ethertype MPLS unicast (0x8847), length 74: MPLS (label 20, exp 0, ttl 32)
5758 dnl         (label 20, exp 0, [S], ttl 32)
5759 dnl         (tos 0x0, ttl 64, id 0, offset 0, flags [none], proto TCP (6), length 44, bad cksum 3b78 (->f978)!)
5760 dnl     192.168.0.1.80 > 192.168.0.2.0: Flags [none], cksum 0x7744 (correct), seq 42:46, win 10000, length 4
5761
5762 for dl_src in 00 01; do
5763     AT_CHECK([ovs-appctl netdev-dummy/receive p1 "505400000007 6066666666$dl_src 8847 00014020 00014120 45 00 00 2c 00 00 00 00 40 06 3b 78 c0 a8 00 01 c0 a8 00 02 00 50 00 00 00 00 00 2a 00 00 00 2a 50 00 27 10 77 44 00 00 48 4f 47 45"])
5764 done
5765 sleep 1  # wait for the datapath flow installed
5766 AT_CHECK_UNQUOTED([cat ovs-vswitchd.log | STRIP_UFID | FILTER_FLOW_INSTALL | STRIP_USED], [0], [dnl
5767 recirc_id=0,mpls,in_port=1,dl_src=60:66:66:66:66:00,mpls_label=20,mpls_tc=0,mpls_ttl=32,mpls_bos=0,mpls_lse1=82208, actions:userspace(pid=0,slow_path(controller))
5768 recirc_id=0,mpls,in_port=1,dl_src=60:66:66:66:66:01,mpls_bos=0,mpls_lse1=82208, actions:userspace(pid=0,slow_path(controller))
5769 ])
5770
5771 OVS_VSWITCHD_STOP
5772 AT_CLEANUP
5773
5774
5775 AT_SETUP([ofproto-dpif - MPLS actions that result in a drop])
5776 OVS_VSWITCHD_START([dnl
5777    add-port br0 p1 -- set Interface p1 type=dummy
5778 ])
5779 AT_CHECK([ovs-appctl vlog/set dpif:dbg dpif_netdev:dbg])
5780 ON_EXIT([kill `cat ovs-ofctl.pid`])
5781
5782 AT_CAPTURE_FILE([ofctl_monitor.log])
5783 AT_DATA([flows.txt], [dnl
5784 dl_src=60:66:66:66:66:00 actions=push_mpls:0x8847,controller
5785 dl_src=60:66:66:66:66:01 actions=pop_mpls:0x8849,controller
5786 ])
5787 AT_CHECK([ovs-ofctl add-flows br0 flows.txt])
5788
5789 dnl Packet is dropped because an MPLS PUSH action is applied to a packet with
5790 dnl 4 MPLS LSEs but ovs-vswtichd can only handle up to 3 MPLS LSEs and thus
5791 dnl can't determine the resulting MPLS label after MPLS push/pop actions.
5792 dnl
5793 dnl The input is a frame with two MPLS headers which tcpdump -vve shows as:
5794 dnl 60:66:66:66:66:01 > 50:54:00:00:00:07, ethertype MPLS unicast (0x8847), length 74: MPLS (label 20, exp 0, ttl 32)
5795 dnl         (label 20, exp 0, ttl 32)
5796 dnl         (label 20, exp 0, ttl 32)
5797 dnl         (label 20, exp 0, [S], ttl 32)
5798 dnl         (tos 0x0, ttl 64, id 0, offset 0, flags [none], proto TCP (6), length 44, bad cksum 3b78 (->f978)!)
5799 dnl     192.168.0.1.80 > 192.168.0.2.0: Flags [none], cksum 0x7744 (correct), seq 42:46, win 10000, length 4
5800
5801 for dl_src in 00 01; do
5802     AT_CHECK([ovs-appctl netdev-dummy/receive p1 "505400000007 6066666666$dl_src 8847 00014020 00014120 45 00 00 2c 00 00 00 00 40 06 3b 78 c0 a8 00 01 c0 a8 00 02 00 50 00 00 00 00 00 2a 00 00 00 2a 50 00 27 10 77 44 00 00 48 4f 47 45"])
5803 done
5804 sleep 1  # wait for the datapath flow installed
5805 AT_CHECK_UNQUOTED([cat ovs-vswitchd.log | STRIP_UFID | FILTER_FLOW_INSTALL | STRIP_USED], [0], [dnl
5806 recirc_id=0,mpls,in_port=1,dl_src=60:66:66:66:66:00,mpls_label=20,mpls_tc=0,mpls_ttl=32,mpls_bos=0,mpls_lse1=82208, actions:userspace(pid=0,slow_path(controller))
5807 recirc_id=0,mpls,in_port=1,dl_src=60:66:66:66:66:01,mpls_bos=0,mpls_lse1=82208, actions:userspace(pid=0,slow_path(controller))
5808 ])
5809
5810 OVS_VSWITCHD_STOP
5811 AT_CLEANUP
5812
5813 AT_SETUP([ofproto-dpif - patch ports])
5814 OVS_VSWITCHD_START([add-br br1 \
5815 -- set bridge br1 datapath-type=dummy fail-mode=secure \
5816 -- add-port br1 pbr1 -- set int pbr1 type=patch options:peer=pbr0 \
5817 -- add-port br0 pbr0 -- set int pbr0 type=patch options:peer=pbr1])
5818
5819 ADD_OF_PORTS([br0], [2])
5820 ADD_OF_PORTS([br1], [3])
5821
5822 AT_CHECK([ovs-appctl upcall/disable-ufid], [0], [Datapath dumping tersely using UFID disabled
5823 ], [])
5824 AT_CHECK([ovs-appctl time/stop])
5825 AT_CHECK([ovs-appctl vlog/set dpif:dbg dpif_netdev:dbg])
5826
5827 AT_CHECK([ovs-ofctl add-flow br0 actions=LOCAL,output:1,output:2])
5828 AT_CHECK([ovs-ofctl add-flow br1 actions=LOCAL,output:1,output:3])
5829
5830 for i in $(seq 1 10); do
5831     ovs-appctl netdev-dummy/receive br0 'in_port(100),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'
5832     if [[ $i -eq 1 ]]; then
5833         sleep 1
5834     fi
5835 done
5836
5837 for i in $(seq 1 5); do
5838     ovs-appctl netdev-dummy/receive br1 'in_port(101),eth(src=50:54:00:00:00:07,dst=50:54:00:00:00:05),eth_type(0x0800),ipv4(src=192.168.0.2,dst=192.168.0.1,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'
5839     if [[ $i -eq 1 ]]; then
5840         sleep 1
5841     fi
5842 done
5843
5844 AT_CHECK([ovs-appctl time/warp 500], [0],
5845 [warped
5846 ])
5847 sleep 1  # wait for log writer
5848
5849 AT_CHECK([ovs-appctl dpif/show], [0], [dnl
5850 dummy@ovs-dummy: hit:13 missed:2
5851         br0:
5852                 br0 65534/100: (dummy)
5853                 p2 2/2: (dummy)
5854                 pbr0 1/none: (patch: peer=pbr1)
5855         br1:
5856                 br1 65534/101: (dummy)
5857                 p3 3/3: (dummy)
5858                 pbr1 1/none: (patch: peer=pbr0)
5859 ])
5860
5861 AT_CHECK([cat ovs-vswitchd.log | STRIP_UFID | FILTER_FLOW_INSTALL | STRIP_USED], [0], [dnl
5862 recirc_id=0,ip,in_port=100,nw_frag=no, actions:101,3,2
5863 recirc_id=0,ip,in_port=101,nw_frag=no, actions:100,2,3
5864 ])
5865
5866 AT_CHECK([cat ovs-vswitchd.log | grep -e 'in_port(100).*packets:9' | STRIP_UFID | FILTER_FLOW_DUMP], [0], [dnl
5867 skb_priority(0/0),skb_mark(0/0),recirc_id(0),dp_hash(0/0),in_port(100),eth(src=50:54:00:00:00:05/00:00:00:00:00:00,dst=50:54:00:00:00:07/00:00:00:00:00:00),eth_type(0x0800),ipv4(src=192.168.0.1/0.0.0.0,dst=192.168.0.2/0.0.0.0,proto=1/0,tos=0/0,ttl=64/0,frag=no),icmp(type=8/0,code=0/0), packets:9, bytes:540, used:0.0s, actions:101,3,2
5868 ])
5869 AT_CHECK([cat ovs-vswitchd.log | grep -e 'in_port(101).*packets:4' | STRIP_UFID | FILTER_FLOW_DUMP], [0], [dnl
5870 skb_priority(0/0),skb_mark(0/0),recirc_id(0),dp_hash(0/0),in_port(101),eth(src=50:54:00:00:00:07/00:00:00:00:00:00,dst=50:54:00:00:00:05/00:00:00:00:00:00),eth_type(0x0800),ipv4(src=192.168.0.2/0.0.0.0,dst=192.168.0.1/0.0.0.0,proto=1/0,tos=0/0,ttl=64/0,frag=no),icmp(type=8/0,code=0/0), packets:4, bytes:240, used:0.0s, actions:100,2,3
5871 ])
5872
5873 AT_CHECK([ovs-ofctl dump-ports br0 pbr0], [0], [dnl
5874 OFPST_PORT reply (xid=0x4): 1 ports
5875   port  1: rx pkts=5, bytes=300, drop=0, errs=0, frame=0, over=0, crc=0
5876            tx pkts=10, bytes=600, drop=0, errs=0, coll=0
5877 ])
5878
5879 AT_CHECK([ovs-ofctl dump-ports br1 pbr1], [0], [dnl
5880 OFPST_PORT reply (xid=0x4): 1 ports
5881   port  1: rx pkts=10, bytes=600, drop=0, errs=0, frame=0, over=0, crc=0
5882            tx pkts=5, bytes=300, drop=0, errs=0, coll=0
5883 ])
5884
5885 OVS_VSWITCHD_STOP
5886 AT_CLEANUP
5887
5888 AT_SETUP([ofproto-dpif - patch ports - stack])
5889 OVS_VSWITCHD_START([add-br br1 \
5890 -- set bridge br1 datapath-type=dummy fail-mode=secure \
5891 -- add-port br1 pbr1 -- set int pbr1 type=patch options:peer=pbr0 \
5892 -- add-port br0 pbr0 -- set int pbr0 type=patch options:peer=pbr1])
5893
5894 ADD_OF_PORTS([br0], [2])
5895 ADD_OF_PORTS([br1], [3])
5896
5897 AT_CHECK([ovs-appctl upcall/disable-ufid], [0], [Datapath dumping tersely using UFID disabled
5898 ], [])
5899 AT_CHECK([ovs-appctl time/stop])
5900 AT_CHECK([ovs-appctl vlog/set dpif:dbg dpif_netdev:dbg])
5901
5902 AT_CHECK([ovs-ofctl add-flow br0 "ip actions=push:OXM_OF_IN_PORT[[0..31]],output:1,pop:OXM_OF_IPV4_SRC[[0..31]],output:2"])
5903 # Try to pop from empty stack, and push and leave data to stack.
5904 AT_CHECK([ovs-ofctl add-flow br1 "ip actions=pop:OXM_OF_IPV4_DST[[0..31]],push:NXM_NX_REG1[[0..31]],LOCAL"])
5905
5906 ovs-appctl netdev-dummy/receive br0 'in_port(100),eth(src=50:54:00:00:00:05,dst=50:54:00:00:00:07),eth_type(0x0800),ipv4(src=192.168.0.1,dst=192.168.0.2,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'
5907
5908 AT_CHECK([ovs-appctl time/warp 500], [0],
5909 [warped
5910 ])
5911
5912 OVS_WAIT_UNTIL([test `grep flow_add ovs-vswitchd.log | wc -l` -ge 1])
5913
5914 AT_CHECK([ovs-appctl dpif/show], [0], [dnl
5915 dummy@ovs-dummy: hit:0 missed:1
5916         br0:
5917                 br0 65534/100: (dummy)
5918                 p2 2/2: (dummy)
5919                 pbr0 1/none: (patch: peer=pbr1)
5920         br1:
5921                 br1 65534/101: (dummy)
5922                 p3 3/3: (dummy)
5923                 pbr1 1/none: (patch: peer=pbr0)
5924 ])
5925
5926 AT_CHECK([cat ovs-vswitchd.log | STRIP_UFID | FILTER_FLOW_INSTALL | STRIP_USED], [0], [dnl
5927 recirc_id=0,ip,in_port=100,nw_src=192.168.0.1,nw_frag=no, actions:101,set(ipv4(src=255.255.255.254)),2
5928 ])
5929
5930 AT_CHECK([cat ovs-vswitchd.log | grep -e '|nx_match|WARN|' | sed "s/^.*|WARN|//"], [0], [dnl
5931 Failed to pop from an empty stack. On flow
5932 ])
5933
5934 OVS_VSWITCHD_STOP(["/Failed to pop from an empty stack/d"])
5935 AT_CLEANUP
5936
5937 AT_SETUP([ofproto-dpif - port duration])
5938 OVS_VSWITCHD_START([set Bridge br0 protocols=OpenFlow13])
5939 ADD_OF_PORTS([br0], 1, 2)
5940
5941 ovs-appctl time/stop
5942 ovs-appctl time/warp 10000
5943
5944 AT_CHECK([ovs-ofctl -O openflow13 dump-ports br0], [0], [stdout])
5945 AT_CHECK([sed -n 's/=[[0-9]][[0-9]]\(\.[[0-9]][[0-9]]*\)\{0,1\}s/=?s/p' stdout], [0],
5946 [dnl
5947            duration=?s
5948            duration=?s
5949            duration=?s
5950 ])
5951 OVS_VSWITCHD_STOP
5952 AT_CLEANUP
5953
5954 dnl ----------------------------------------------------------------------
5955 AT_BANNER([ofproto-dpif -- megaflows])
5956
5957 AT_SETUP([ofproto-dpif megaflow - port classification])
5958 OVS_VSWITCHD_START
5959 AT_CHECK([ovs-appctl vlog/set dpif:dbg dpif_netdev:dbg])
5960 ADD_OF_PORTS([br0], [1], [2])
5961 AT_DATA([flows.txt], [dnl
5962 table=0 in_port=1 actions=output(2)
5963 ])
5964 AT_CHECK([ovs-ofctl add-flows br0 flows.txt])
5965 AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:09,dst=50:54:00:00:00:0a),eth_type(0x0800),ipv4(src=10.0.0.2,dst=10.0.0.1,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'])
5966 sleep 1
5967 AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:0b,dst=50:54:00:00:00:0c),eth_type(0x0800),ipv4(src=10.0.0.4,dst=10.0.0.3,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'])
5968 sleep 1
5969 AT_CHECK([cat ovs-vswitchd.log | FILTER_FLOW_INSTALL | STRIP_XOUT], [0], [dnl
5970 recirc_id=0,ip,in_port=1,nw_frag=no, actions: <del>
5971 ])
5972 OVS_VSWITCHD_STOP
5973 AT_CLEANUP
5974
5975 AT_SETUP([ofproto-dpif megaflow - L2 classification])
5976 OVS_VSWITCHD_START
5977 AT_CHECK([ovs-appctl vlog/set dpif:dbg dpif_netdev:dbg])
5978 ADD_OF_PORTS([br0], [1], [2])
5979 AT_DATA([flows.txt], [dnl
5980 table=0 in_port=1,dl_src=50:54:00:00:00:09 actions=output(2)
5981 ])
5982 AT_CHECK([ovs-ofctl add-flows br0 flows.txt])
5983 AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:09,dst=50:54:00:00:00:0a),eth_type(0x0800),ipv4(src=10.0.0.2,dst=10.0.0.1,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'])
5984 AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:0b,dst=50:54:00:00:00:0c),eth_type(0x0800),ipv4(src=10.0.0.4,dst=10.0.0.3,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'])
5985 sleep 1
5986 AT_CHECK([cat ovs-vswitchd.log | FILTER_FLOW_INSTALL | STRIP_XOUT], [0], [dnl
5987 recirc_id=0,ip,in_port=1,dl_src=50:54:00:00:00:09,nw_frag=no, actions: <del>
5988 recirc_id=0,ip,in_port=1,dl_src=50:54:00:00:00:0b/ff:ff:00:00:00:02,nw_frag=no, actions: <del>
5989 ])
5990 OVS_VSWITCHD_STOP
5991 AT_CLEANUP
5992
5993 AT_SETUP([ofproto-dpif megaflow - L3 classification])
5994 OVS_VSWITCHD_START
5995 AT_CHECK([ovs-appctl vlog/set dpif:dbg dpif_netdev:dbg])
5996 ADD_OF_PORTS([br0], [1], [2])
5997 AT_CHECK([ovs-vsctl set Bridge br0 flow_tables:0=@N1 -- --id=@N1 create Flow_Table name=t0 prefixes=nw_dst,nw_src], [0], [ignore], [])
5998 AT_DATA([flows.txt], [dnl
5999 table=0 in_port=1,icmp,nw_src=10.0.0.4 actions=output(2)
6000 ])
6001 AT_CHECK([ovs-ofctl add-flows br0 flows.txt])
6002 AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:09,dst=50:54:00:00:00:0a),eth_type(0x0800),ipv4(src=10.0.0.2,dst=10.0.0.1,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'])
6003 AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:0b,dst=50:54:00:00:00:0c),eth_type(0x0800),ipv4(src=10.0.0.4,dst=10.0.0.3,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'])
6004 sleep 1
6005 AT_CHECK([cat ovs-vswitchd.log | FILTER_FLOW_INSTALL | STRIP_XOUT], [0], [dnl
6006 recirc_id=0,icmp,in_port=1,nw_src=10.0.0.4,nw_frag=no, actions: <del>
6007 recirc_id=0,ip,in_port=1,nw_src=10.0.0.2/0.0.0.2,nw_frag=no, actions: <del>
6008 ])
6009 OVS_VSWITCHD_STOP
6010 AT_CLEANUP
6011
6012 AT_SETUP([ofproto-dpif megaflow - IPv6 classification])
6013 OVS_VSWITCHD_START
6014 AT_CHECK([ovs-appctl vlog/set dpif:dbg dpif_netdev:dbg])
6015 ADD_OF_PORTS([br0], [1], [2])
6016 AT_CHECK([ovs-vsctl set Bridge br0 flow_tables:0=@N1 -- --id=@N1 create Flow_Table name=t0 prefixes=ipv6_dst,ipv6_src], [0], [ignore], [])
6017 AT_DATA([flows.txt], [dnl
6018 table=0 in_port=1,ipv6,ipv6_src=2001:db8:3c4d:1:2:3:4:5 actions=output(2)
6019 ])
6020 AT_CHECK([ovs-ofctl add-flows br0 flows.txt])
6021 AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:07,dst=50:54:00:00:00:05),eth_type(0x86dd),ipv6(src=2001:db8:3c4d:1:2:3:4:5,dst=fe80::2,label=0,proto=10,tclass=0x70,hlimit=128,frag=no)'])
6022 AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:09,dst=50:54:00:00:00:0a),eth_type(0x86dd),ipv6(src=2001:db8:3c4d:5:4:3:2:1,dst=2001:db8:3c4d:1:2:3:4:1,label=0,proto=99,tclass=0x70,hlimit=64,frag=no)'])
6023 sleep 1
6024 AT_CHECK([cat ovs-vswitchd.log | FILTER_FLOW_INSTALL | STRIP_XOUT], [0], [dnl
6025 recirc_id=0,ipv6,in_port=1,ipv6_src=2001:db8:3c4d:1:2:3:4:5,nw_frag=no, actions: <del>
6026 recirc_id=0,ipv6,in_port=1,ipv6_src=2001:db8:3c4d:5:4:3:2:1/0:0:0:4::,nw_frag=no, actions: <del>
6027 ])
6028 OVS_VSWITCHD_STOP
6029 AT_CLEANUP
6030
6031 AT_SETUP([ofproto-dpif megaflow - L4 classification])
6032 OVS_VSWITCHD_START
6033 AT_CHECK([ovs-appctl vlog/set dpif:dbg dpif_netdev:dbg])
6034 ADD_OF_PORTS([br0], [1], [2])
6035 AT_DATA([flows.txt], [dnl
6036 table=0 in_port=1,icmp,icmp_type=8 actions=output(2)
6037 ])
6038 AT_CHECK([ovs-ofctl add-flows br0 flows.txt])
6039 AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:09,dst=50:54:00:00:00:0a),eth_type(0x0800),ipv4(src=10.0.0.2,dst=10.0.0.1,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'])
6040 sleep 1
6041 AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:0b,dst=50:54:00:00:00:0c),eth_type(0x0800),ipv4(src=10.0.0.4,dst=10.0.0.3,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'])
6042 sleep 1
6043 AT_CHECK([cat ovs-vswitchd.log | FILTER_FLOW_INSTALL | STRIP_XOUT], [0], [dnl
6044 recirc_id=0,icmp,in_port=1,nw_frag=no,icmp_type=0x8/0xff, actions: <del>
6045 ])
6046 OVS_VSWITCHD_STOP
6047 AT_CLEANUP
6048
6049 AT_SETUP([ofproto-dpif megaflow - normal])
6050 OVS_VSWITCHD_START
6051 AT_CHECK([ovs-appctl vlog/set dpif:dbg dpif_netdev:dbg])
6052 ADD_OF_PORTS([br0], [1], [2])
6053 AT_CHECK([ovs-ofctl add-flow br0 action=normal])
6054 AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:09,dst=50:54:00:00:00:0a),eth_type(0x0800),ipv4(src=10.0.0.2,dst=10.0.0.1,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'])
6055 AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:0b,dst=50:54:00:00:00:0c),eth_type(0x0800),ipv4(src=10.0.0.4,dst=10.0.0.3,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'])
6056 sleep 1
6057 AT_CHECK([cat ovs-vswitchd.log | FILTER_FLOW_INSTALL | STRIP_XOUT], [0], [dnl
6058 recirc_id=0,ip,in_port=1,vlan_tci=0x0000/0x1fff,dl_src=50:54:00:00:00:09,dl_dst=50:54:00:00:00:0a,nw_frag=no, actions: <del>
6059 recirc_id=0,ip,in_port=1,vlan_tci=0x0000/0x1fff,dl_src=50:54:00:00:00:0b,dl_dst=50:54:00:00:00:0c,nw_frag=no, actions: <del>
6060 ])
6061 OVS_VSWITCHD_STOP
6062 AT_CLEANUP
6063
6064 AT_SETUP([ofproto-dpif megaflow - mpls])
6065 OVS_VSWITCHD_START
6066 AT_CHECK([ovs-appctl vlog/set dpif:dbg dpif_netdev:dbg])
6067 ADD_OF_PORTS([br0], [1], [2])
6068 AT_DATA([flows.txt], [dnl
6069 table=0 dl_src=50:54:00:00:00:09 actions=push_mpls:0x8847,2
6070 table=0 dl_src=50:54:00:00:00:0b actions=pop_mpls:0x0800,2
6071 ])
6072 AT_CHECK([ovs-ofctl add-flows br0 flows.txt])
6073 AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:09,dst=50:54:00:00:00:0a),eth_type(0x8847),mpls(label=11,tc=3,ttl=64,bos=1)'])
6074 AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:0b,dst=50:54:00:00:00:0a),eth_type(0x8847),mpls(label=11,tc=3,ttl=64,bos=1)'])
6075 sleep 1
6076 AT_CHECK([cat ovs-vswitchd.log | FILTER_FLOW_INSTALL | STRIP_XOUT], [0], [dnl
6077 recirc_id=0,mpls,in_port=1,dl_src=50:54:00:00:00:09,mpls_label=11,mpls_tc=3,mpls_ttl=64,mpls_bos=1, actions: <del>
6078 recirc_id=0,mpls,in_port=1,dl_src=50:54:00:00:00:0b,mpls_bos=1, actions: <del>
6079 ])
6080 OVS_VSWITCHD_STOP
6081 AT_CLEANUP
6082
6083 # CHECK_MEGAFLOW_NETFLOW(LOOPBACK_ADDR)
6084 m4_define([CHECK_MEGAFLOW_NETFLOW],
6085   [OVS_VSWITCHD_START
6086   AT_CHECK([ovs-appctl vlog/set dpif:dbg dpif_netdev:dbg])
6087   ADD_OF_PORTS([br0], [1], [2])
6088
6089   dnl NetFlow configuration disables wildcarding relevant fields
6090   ON_EXIT([kill `cat test-netflow.pid`])
6091   AT_CHECK([ovstest test-netflow --log-file --detach --no-chdir --pidfile 0:$1 > netflow.log], [0], [], [ignore])
6092   AT_CAPTURE_FILE([netflow.log])
6093   NETFLOW_PORT=`parse_listening_port < test-netflow.log`
6094   ovs-vsctl \
6095      set Bridge br0 netflow=@nf -- \
6096      --id=@nf create NetFlow targets=\"$1:$NETFLOW_PORT\" \
6097        engine_id=1 engine_type=2 active_timeout=30 add-id-to-interface=false
6098
6099   AT_CHECK([ovs-ofctl add-flow br0 action=normal])
6100   AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:09,dst=50:54:00:00:00:0a),eth_type(0x0800),ipv4(src=10.0.0.2,dst=10.0.0.1,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'])
6101   AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:0b,dst=50:54:00:00:00:0c),eth_type(0x0800),ipv4(src=10.0.0.4,dst=10.0.0.3,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'])
6102   sleep 1
6103   AT_CHECK([cat ovs-vswitchd.log | FILTER_FLOW_INSTALL | STRIP_XOUT], [0], [dnl
6104 recirc_id=0,icmp,in_port=1,vlan_tci=0x0000/0x1fff,dl_src=50:54:00:00:00:09,dl_dst=50:54:00:00:00:0a,nw_src=10.0.0.2,nw_dst=10.0.0.1,nw_tos=0,nw_frag=no,icmp_type=0x8/0xff,icmp_code=0x0/0xff, actions: <del>
6105 recirc_id=0,icmp,in_port=1,vlan_tci=0x0000/0x1fff,dl_src=50:54:00:00:00:0b,dl_dst=50:54:00:00:00:0c,nw_src=10.0.0.4,nw_dst=10.0.0.3,nw_tos=0,nw_frag=no,icmp_type=0x8/0xff,icmp_code=0x0/0xff, actions: <del>
6106 ])
6107   OVS_VSWITCHD_STOP])
6108
6109 AT_SETUP([ofproto-dpif megaflow - netflow - IPv4 collector])
6110 CHECK_MEGAFLOW_NETFLOW([127.0.0.1], [IPv4])
6111 AT_CLEANUP
6112
6113 AT_SETUP([ofproto-dpif megaflow - netflow - IPv6 collector])
6114 AT_SKIP_IF([test $HAVE_IPV6 = no])
6115 CHECK_MEGAFLOW_NETFLOW([[[::1]]], [IPv6])
6116 AT_CLEANUP
6117
6118 AT_SETUP([ofproto-dpif megaflow - normal, active-backup bonding])
6119 OVS_VSWITCHD_START(
6120   [add-port br0 p1 -- set Interface p1 type=dummy ofport_request=1 -- \
6121    add-bond br0 bond0 p2 p3 bond_mode=active-backup -- \
6122    set interface p2 type=dummy ofport_request=2 -- \
6123    set interface p3 type=dummy ofport_request=3])
6124 AT_CHECK([ovs-appctl netdev-dummy/set-admin-state up], 0, [OK
6125 ])
6126 AT_CHECK([ovs-appctl vlog/set dpif:dbg dpif_netdev:dbg])
6127
6128 AT_CHECK([ovs-ofctl add-flow br0 action=normal])
6129 AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:09,dst=50:54:00:00:00:0a),eth_type(0x0800),ipv4(src=10.0.0.2,dst=10.0.0.1,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'])
6130 AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:0b,dst=50:54:00:00:00:0c),eth_type(0x0800),ipv4(src=10.0.0.4,dst=10.0.0.3,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'])
6131 sleep 1
6132 AT_CHECK([cat ovs-vswitchd.log | FILTER_FLOW_INSTALL | STRIP_XOUT], [0], [dnl
6133 recirc_id=0,ip,in_port=1,vlan_tci=0x0000/0x1fff,dl_src=50:54:00:00:00:09,dl_dst=50:54:00:00:00:0a,nw_frag=no, actions: <del>
6134 recirc_id=0,ip,in_port=1,vlan_tci=0x0000/0x1fff,dl_src=50:54:00:00:00:0b,dl_dst=50:54:00:00:00:0c,nw_frag=no, actions: <del>
6135 ])
6136 OVS_VSWITCHD_STOP
6137 AT_CLEANUP
6138
6139 AT_SETUP([ofproto-dpif megaflow - normal, balance-slb bonding])
6140 OVS_VSWITCHD_START(
6141   [add-port br0 p1 -- set Interface p1 type=dummy ofport_request=1 -- \
6142    add-bond br0 bond0 p2 p3 bond_mode=balance-slb -- \
6143    set interface p2 type=dummy ofport_request=2 -- \
6144    set interface p3 type=dummy ofport_request=3])
6145 AT_CHECK([ovs-appctl netdev-dummy/set-admin-state up], 0, [OK
6146 ])
6147 AT_CHECK([ovs-appctl vlog/set dpif:dbg dpif_netdev:dbg])
6148
6149 AT_CHECK([ovs-ofctl add-flow br0 action=normal])
6150 AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:09,dst=50:54:00:00:00:0a),eth_type(0x0800),ipv4(src=10.0.0.2,dst=10.0.0.1,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'])
6151 AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:0b,dst=50:54:00:00:00:0c),eth_type(0x0800),ipv4(src=10.0.0.4,dst=10.0.0.3,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'])
6152 sleep 1
6153 AT_CHECK([cat ovs-vswitchd.log | FILTER_FLOW_INSTALL | STRIP_XOUT], [0], [dnl
6154 recirc_id=0,ip,in_port=1,vlan_tci=0x0000/0x1fff,dl_src=50:54:00:00:00:09,dl_dst=50:54:00:00:00:0a,nw_frag=no, actions: <del>
6155 recirc_id=0,ip,in_port=1,vlan_tci=0x0000/0x1fff,dl_src=50:54:00:00:00:0b,dl_dst=50:54:00:00:00:0c,nw_frag=no, actions: <del>
6156 ])
6157 OVS_VSWITCHD_STOP
6158 AT_CLEANUP
6159
6160 AT_SETUP([ofproto-dpif megaflow - normal, balance-tcp bonding])
6161 # Create bond0 on br0 with interfaces p0 and p1
6162 #    and bond1 on br1 with interfaces p2 and p3
6163 # with p0 patched to p2 and p1 patched to p3.
6164 OVS_VSWITCHD_START(
6165   [add-bond br0 bond0 p0 p1 bond_mode=balance-tcp lacp=active \
6166                             other-config:lacp-time=fast \
6167                             other-config:bond-rebalance-interval=0 -- \
6168    set interface p0 type=patch options:peer=p2 ofport_request=1 -- \
6169    set interface p1 type=patch options:peer=p3 ofport_request=2 -- \
6170    add-br br1 -- \
6171    set bridge br1 other-config:hwaddr=aa:66:aa:66:00:00 -- \
6172    set bridge br1 datapath-type=dummy other-config:datapath-id=1234 \
6173                   fail-mode=secure -- \
6174    add-bond br1 bond1 p2 p3 bond_mode=balance-tcp lacp=active \
6175                             other-config:lacp-time=fast \
6176                             other-config:bond-rebalance-interval=0 -- \
6177    set interface p2 type=patch options:peer=p0 ofport_request=3 -- \
6178    set interface p3 type=patch options:peer=p1 ofport_request=4 --])
6179
6180 AT_CHECK([ovs-appctl netdev-dummy/set-admin-state up], 0, [OK
6181 ])
6182 AT_CHECK([ovs-appctl vlog/set dpif:dbg dpif_netdev:dbg])
6183 ADD_OF_PORTS([br0], [7])
6184 AT_CHECK([ovs-ofctl add-flow br0 action=normal])
6185 AT_CHECK([ovs-ofctl add-flow br1 action=normal])
6186 ovs-appctl time/stop
6187 ovs-appctl time/warp 5000
6188 AT_CHECK([ovs-appctl netdev-dummy/receive p7 'in_port(1),eth(src=50:54:00:00:00:09,dst=50:54:00:00:00:0a),eth_type(0x0800),ipv4(src=10.0.0.2,dst=10.0.0.1,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'])
6189 AT_CHECK([ovs-appctl netdev-dummy/receive p7 'in_port(1),eth(src=50:54:00:00:00:0b,dst=50:54:00:00:00:0c),eth_type(0x0800),ipv4(src=10.0.0.4,dst=10.0.0.3,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'])
6190 sleep 1
6191 AT_CHECK([cat ovs-vswitchd.log | FILTER_FLOW_INSTALL | STRIP_XOUT], [0], [dnl
6192 recirc_id=0,ip,in_port=7,vlan_tci=0x0000/0x1fff,dl_src=50:54:00:00:00:09,dl_dst=50:54:00:00:00:0a,nw_frag=no, actions: <del>
6193 recirc_id=0,ip,in_port=7,vlan_tci=0x0000/0x1fff,dl_src=50:54:00:00:00:0b,dl_dst=50:54:00:00:00:0c,nw_frag=no, actions: <del>
6194 ])
6195 OVS_VSWITCHD_STOP
6196 AT_CLEANUP
6197
6198 AT_SETUP([ofproto-dpif megaflow - resubmit port action])
6199 OVS_VSWITCHD_START
6200 AT_CHECK([ovs-appctl vlog/set dpif:dbg dpif_netdev:dbg])
6201 ADD_OF_PORTS([br0], [1], [2])
6202 AT_DATA([flows.txt], [dnl
6203 table=0 in_port=1,ip actions=resubmit(90)
6204 table=0 in_port=90,dl_src=50:54:00:00:00:09 actions=output(2)
6205 ])
6206 AT_CHECK([ovs-ofctl add-flows br0 flows.txt])
6207 AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:09,dst=50:54:00:00:00:0a),eth_type(0x0800),ipv4(src=10.0.0.2,dst=10.0.0.1,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'])
6208 AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:0b,dst=50:54:00:00:00:0c),eth_type(0x0800),ipv4(src=10.0.0.4,dst=10.0.0.3,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'])
6209 sleep 1
6210 AT_CHECK([cat ovs-vswitchd.log | FILTER_FLOW_INSTALL | STRIP_XOUT], [0], [dnl
6211 recirc_id=0,ip,in_port=1,dl_src=50:54:00:00:00:09,nw_frag=no, actions: <del>
6212 recirc_id=0,ip,in_port=1,dl_src=50:54:00:00:00:0b/ff:ff:00:00:00:02,nw_frag=no, actions: <del>
6213 ])
6214 OVS_VSWITCHD_STOP
6215 AT_CLEANUP
6216
6217 AT_SETUP([ofproto-dpif megaflow - resubmit table action])
6218 OVS_VSWITCHD_START
6219 AT_CHECK([ovs-appctl vlog/set dpif:dbg dpif_netdev:dbg])
6220 ADD_OF_PORTS([br0], [1], [2])
6221 AT_DATA([flows.txt], [dnl
6222 table=0 in_port=1,ip actions=resubmit(,1)
6223 table=1 dl_src=50:54:00:00:00:09 actions=output(2)
6224 ])
6225 AT_CHECK([ovs-ofctl add-flows br0 flows.txt])
6226 AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:09,dst=50:54:00:00:00:0a),eth_type(0x0800),ipv4(src=10.0.0.2,dst=10.0.0.1,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'])
6227 AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:0b,dst=50:54:00:00:00:0c),eth_type(0x0800),ipv4(src=10.0.0.4,dst=10.0.0.3,proto=
6228 1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'])
6229 sleep 1
6230 AT_CHECK([cat ovs-vswitchd.log | FILTER_FLOW_INSTALL | STRIP_XOUT], [0], [dnl
6231 recirc_id=0,ip,in_port=1,dl_src=50:54:00:00:00:09,nw_frag=no, actions: <del>
6232 recirc_id=0,ip,in_port=1,dl_src=50:54:00:00:00:0b,nw_frag=no, actions: <del>
6233 ])
6234 OVS_VSWITCHD_STOP
6235 AT_CLEANUP
6236
6237 AT_SETUP([ofproto-dpif megaflow - goto_table action])
6238 OVS_VSWITCHD_START
6239 AT_CHECK([ovs-appctl vlog/set dpif:dbg dpif_netdev:dbg])
6240 ADD_OF_PORTS([br0], [1], [2])
6241 AT_DATA([flows.txt], [dnl
6242 table=0 in_port=1,ip actions=goto_table(1)
6243 table=1 dl_src=50:54:00:00:00:09 actions=output(2)
6244 ])
6245 AT_CHECK([ovs-ofctl -O OpenFlow12 add-flows br0 flows.txt])
6246 AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:09,dst=50:54:00:00:00:0a),eth_type(0x0800),ipv4(src=10.0.0.2,dst=10.0.0.1,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'])
6247 AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:0b,dst=50:54:00:00:00:0c),eth_type(0x0800),ipv4(src=10.0.0.4,dst=10.0.0.3,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'])
6248 sleep 1
6249 AT_CHECK([cat ovs-vswitchd.log | FILTER_FLOW_INSTALL | STRIP_XOUT], [0], [dnl
6250 recirc_id=0,ip,in_port=1,dl_src=50:54:00:00:00:09,nw_frag=no, actions: <del>
6251 recirc_id=0,ip,in_port=1,dl_src=50:54:00:00:00:0b,nw_frag=no, actions: <del>
6252 ])
6253 OVS_VSWITCHD_STOP
6254 AT_CLEANUP
6255
6256 AT_SETUP([ofproto-dpif megaflow - mirroring, select_all])
6257 OVS_VSWITCHD_START
6258 AT_CHECK([ovs-appctl vlog/set dpif:dbg dpif_netdev:dbg])
6259 ADD_OF_PORTS([br0], [1], [2], [3])
6260 ovs-vsctl \
6261         set Bridge br0 mirrors=@m --\
6262         --id=@p3 get Port p3 --\
6263         --id=@m create Mirror name=mymirror select_all=true output_port=@p3
6264
6265 AT_DATA([flows.txt], [dnl
6266 in_port=1 actions=output:2
6267 ])
6268 AT_CHECK([ovs-ofctl add-flows br0 flows.txt])
6269 AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:09,dst=50:54:00:00:00:0a),eth_type(0x0800),ipv4(src=10.0.0.2,dst=10.0.0.1,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'])
6270 sleep 1
6271 AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:0b,dst=50:54:00:00:00:0c),eth_type(0x0800),ipv4(src=10.0.0.4,dst=10.0.0.3,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'])
6272 sleep 1
6273 AT_CHECK([cat ovs-vswitchd.log | FILTER_FLOW_INSTALL | STRIP_XOUT], [0], [dnl
6274 recirc_id=0,ip,in_port=1,nw_frag=no, actions: <del>
6275 ])
6276 OVS_VSWITCHD_STOP
6277 AT_CLEANUP
6278
6279 AT_SETUP([ofproto-dpif megaflow - mirroring, select_vlan])
6280 OVS_VSWITCHD_START
6281 AT_CHECK([ovs-appctl vlog/set dpif:dbg dpif_netdev:dbg])
6282 ADD_OF_PORTS([br0], [1], [2], [3])
6283 ovs-vsctl \
6284         set Bridge br0 mirrors=@m --\
6285         --id=@p2 get Port p2 -- --id=@p3 get Port p3 --\
6286         --id=@m create Mirror name=mymirror select_all=true select_vlan=11 output_port=@p3
6287
6288 AT_DATA([flows.txt], [dnl
6289 in_port=1 actions=output:2
6290 ])
6291 AT_CHECK([ovs-ofctl add-flows br0 flows.txt])
6292 AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:09,dst=50:54:00:00:00:0a),eth_type(0x8100),vlan(vid=11,pcp=7),encap(eth_type(0x0800),ipv4(src=10.0.0.2,dst=10.0.0.1,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0))'])
6293 AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:0b,dst=50:54:00:00:00:0c),eth_type(0x0800),ipv4(src=10.0.0.4,dst=10.0.0.3,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'])
6294 sleep 1
6295 AT_CHECK([cat ovs-vswitchd.log | FILTER_FLOW_INSTALL | STRIP_XOUT], [0], [dnl
6296 recirc_id=0,ip,in_port=1,dl_vlan=11,nw_frag=no, actions: <del>
6297 recirc_id=0,ip,in_port=1,vlan_tci=0x0000/0x1fff,nw_frag=no, actions: <del>
6298 ])
6299 OVS_VSWITCHD_STOP
6300 AT_CLEANUP
6301
6302 AT_SETUP([ofproto-dpif megaflow - move action])
6303 OVS_VSWITCHD_START
6304 AT_CHECK([ovs-appctl vlog/set dpif:dbg dpif_netdev:dbg])
6305 ADD_OF_PORTS([br0], [1], [2])
6306 AT_DATA([flows.txt], [dnl
6307 table=0 in_port=1 ip,actions=move:NXM_OF_IP_SRC[[]]->NXM_NX_REG0[[]],resubmit(90)
6308 table=0 in_port=90 ip,actions=move:NXM_NX_REG0[[]]->NXM_NX_REG1[[]],resubmit(91)
6309 table=0 in_port=91 reg0=0x0a000002,actions=output(2)
6310 ])
6311 AT_CHECK([ovs-ofctl add-flows br0 flows.txt])
6312 AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:09,dst=50:54:00:00:00:0a),eth_type(0x0800),ipv4(src=10.0.0.2,dst=10.0.0.1,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'])
6313 AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:0b,dst=50:54:00:00:00:0c),eth_type(0x0800),ipv4(src=10.0.0.4,dst=10.0.0.3,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'])
6314 sleep 1
6315 AT_CHECK([cat ovs-vswitchd.log | FILTER_FLOW_INSTALL | STRIP_XOUT], [0], [dnl
6316 recirc_id=0,ip,in_port=1,nw_src=10.0.0.2,nw_frag=no, actions: <del>
6317 recirc_id=0,ip,in_port=1,nw_src=10.0.0.4,nw_frag=no, actions: <del>
6318 ])
6319 OVS_VSWITCHD_STOP
6320 AT_CLEANUP
6321
6322 AT_SETUP([ofproto-dpif megaflow - push action])
6323 OVS_VSWITCHD_START
6324 AT_CHECK([ovs-appctl vlog/set dpif:dbg dpif_netdev:dbg])
6325 ADD_OF_PORTS([br0], [1], [2])
6326 AT_DATA([flows.txt], [dnl
6327 table=0 in_port=1 ip,actions=push:NXM_OF_IP_SRC[[]],output(2)
6328 ])
6329 AT_CHECK([ovs-ofctl add-flows br0 flows.txt])
6330 AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:09,dst=50:54:00:00:00:0a),eth_type(0x0800),ipv4(src=10.0.0.2,dst=10.0.0.1,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'])
6331 AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:0b,dst=50:54:00:00:00:0c),eth_type(0x0800),ipv4(src=10.0.0.4,dst=10.0.0.3,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'])
6332 sleep 1
6333 AT_CHECK([cat ovs-vswitchd.log | FILTER_FLOW_INSTALL | STRIP_XOUT], [0], [dnl
6334 recirc_id=0,ip,in_port=1,nw_src=10.0.0.2,nw_frag=no, actions: <del>
6335 recirc_id=0,ip,in_port=1,nw_src=10.0.0.4,nw_frag=no, actions: <del>
6336 ])
6337 OVS_VSWITCHD_STOP
6338 AT_CLEANUP
6339
6340 AT_SETUP([ofproto-dpif megaflow - learning])
6341 OVS_VSWITCHD_START
6342 AT_CHECK([ovs-appctl vlog/set dpif:dbg dpif_netdev:dbg])
6343 ADD_OF_PORTS([br0], [1], [2])
6344 AT_DATA([flows.txt], [dnl
6345 table=0 in_port=1 actions=load:2->NXM_NX_REG0[[0..15]],learn(table=1,priority=65535,NXM_OF_ETH_SRC[[]],NXM_OF_VLAN_TCI[[0..11]],output:NXM_NX_REG0[[0..15]]),output:2
6346 ])
6347 AT_CHECK([ovs-ofctl add-flows br0 flows.txt])
6348 ovs-appctl time/stop
6349 # We send each packet twice because the first packet in each flow causes the
6350 # flow table to change and thus revalidations, which (depending on timing)
6351 # can keep a megaflow from being installed.  The revalidations are done by
6352 # the second iteration, allowing the flows to be installed.
6353 for i in 1 2; do
6354     AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:09,dst=50:54:00:00:00:0a),eth_type(0x0800),ipv4(src=10.0.0.2,dst=10.0.0.1,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'])
6355     AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:0b,dst=50:54:00:00:00:0c),eth_type(0x0800),ipv4(src=10.0.0.4,dst=10.0.0.3,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'])
6356     ovs-appctl time/warp 100
6357 done
6358 sleep 1
6359 dnl The original flow is missing due to a revalidation.
6360 AT_CHECK([cat ovs-vswitchd.log | FILTER_FLOW_INSTALL | STRIP_XOUT], [0], [dnl
6361 recirc_id=0,ip,in_port=1,vlan_tci=0x0000/0x1fff,dl_src=50:54:00:00:00:09,nw_frag=no, actions: <del>
6362 recirc_id=0,ip,in_port=1,vlan_tci=0x0000/0x1fff,dl_src=50:54:00:00:00:0b,nw_frag=no, actions: <del>
6363 ])
6364 OVS_VSWITCHD_STOP
6365 AT_CLEANUP
6366
6367 AT_SETUP([ofproto-dpif megaflow - tunnels])
6368 OVS_VSWITCHD_START(
6369   [add-port br0 p1 -- set Interface p1 type=dummy ofport_request=1])
6370 AT_CHECK([ovs-appctl vlog/set dpif:dbg dpif_netdev:dbg])
6371 AT_CHECK([ovs-vsctl add-port br0 p2 -- set Interface p2 type=gre \
6372      options:remote_ip=1.1.1.1 ofport_request=2 options:key=flow])
6373 AT_CHECK([ovs-vsctl add-port br0 p3 -- set Interface p3 type=dummy \
6374           ofport_request=3])
6375 AT_CHECK([ovs-vsctl add-port br0 p4 -- set Interface p4 type=gre \
6376      options:remote_ip=1.1.1.2 options:tos=inherit options:ttl=inherit \
6377      ofport_request=4 options:key=flow])
6378 AT_DATA([flows.txt], [dnl
6379 in_port=1,actions=output(2)
6380 in_port=3,actions=output(4)
6381 ])
6382 AT_CHECK([ovs-ofctl add-flows br0 flows.txt])
6383 dnl ECN bits are always copied out, but don't use 0x3 (CE), since that
6384 dnl will cause the packet to be dropped.
6385 AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:09,dst=50:54:00:00:00:0a),eth_type(0x0800),ipv4(src=10.0.0.2,dst=10.0.0.1,proto=1,tos=0xfd,ttl=128,frag=no),icmp(type=8,code=0)'])
6386 sleep 1
6387 AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:0b,dst=50:54:00:00:00:0c),eth_type(0x0800),ipv4(src=10.0.0.4,dst=10.0.0.3,proto=1,tos=0x1,ttl=64,frag=no),icmp(type=8,code=0)'])
6388 AT_CHECK([ovs-appctl netdev-dummy/receive p3 'in_port(3),eth(src=50:54:00:00:00:09,dst=50:54:00:00:00:0a),eth_type(0x0800),ipv4(src=10.0.0.2,dst=10.0.0.1,proto=1,tos=0xfd,ttl=128,frag=no),icmp(type=8,code=0)'])
6389 sleep 1
6390 AT_CHECK([ovs-appctl netdev-dummy/receive p3 'in_port(3),eth(src=50:54:00:00:00:0b,dst=50:54:00:00:00:0c),eth_type(0x0800),ipv4(src=10.0.0.4,dst=10.0.0.3,proto=1,tos=0x1,ttl=64,frag=no),icmp(type=8,code=0)'])
6391 sleep 1
6392 AT_CHECK([cat ovs-vswitchd.log | FILTER_FLOW_INSTALL | STRIP_XOUT], [0], [dnl
6393 recirc_id=0,ip,in_port=1,nw_ecn=1,nw_frag=no, actions: <del>
6394 recirc_id=0,ip,in_port=3,nw_tos=0,nw_ecn=1,nw_ttl=64,nw_frag=no, actions: <del>
6395 recirc_id=0,ip,in_port=3,nw_tos=252,nw_ecn=1,nw_ttl=128,nw_frag=no, actions: <del>
6396 ])
6397 OVS_VSWITCHD_STOP
6398 AT_CLEANUP
6399
6400 AT_SETUP([ofproto-dpif megaflow - dec_ttl])
6401 OVS_VSWITCHD_START
6402 AT_CHECK([ovs-appctl vlog/set dpif:dbg dpif_netdev:dbg])
6403 ADD_OF_PORTS([br0], [1], [2])
6404 AT_CHECK([ovs-vsctl set Bridge br0 flow_tables:0=@N1 -- --id=@N1 create Flow_Table name=t0 prefixes=nw_dst,nw_src], [0], [ignore], [])
6405 AT_DATA([flows.txt], [dnl
6406 table=0 in_port=1,icmp,nw_src=10.0.0.4 actions=dec_ttl,output(2)
6407 ])
6408 AT_CHECK([ovs-ofctl add-flows br0 flows.txt])
6409 AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:09,dst=50:54:00:00:00:0a),eth_type(0x0800),ipv4(src=10.0.0.2,dst=10.0.0.1,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'])
6410 AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:0b,dst=50:54:00:00:00:0c),eth_type(0x0800),ipv4(src=10.0.0.4,dst=10.0.0.3,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'])
6411 sleep 1
6412 AT_CHECK([cat ovs-vswitchd.log | FILTER_FLOW_INSTALL | STRIP_XOUT], [0], [dnl
6413 recirc_id=0,icmp,in_port=1,nw_src=10.0.0.4,nw_ttl=64,nw_frag=no, actions: <del>
6414 recirc_id=0,ip,in_port=1,nw_src=10.0.0.2/0.0.0.2,nw_frag=no, actions: <del>
6415 ])
6416 OVS_VSWITCHD_STOP
6417 AT_CLEANUP
6418
6419 AT_SETUP([ofproto-dpif megaflow - set dl_dst])
6420 OVS_VSWITCHD_START
6421 AT_CHECK([ovs-appctl vlog/set dpif:dbg dpif_netdev:dbg])
6422 ADD_OF_PORTS([br0], [1], [2])
6423 AT_DATA([flows.txt], [dnl
6424 table=0 in_port=1 actions=mod_dl_dst(50:54:00:00:00:0a),output(2)
6425 ])
6426 AT_CHECK([ovs-ofctl add-flows br0 flows.txt])
6427 AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:09,dst=50:54:00:00:00:0a),eth_type(0x0800),ipv4(src=10.0.0.2,dst=10.0.0.1,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'])
6428 AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:0b,dst=50:54:00:00:00:0c),eth_type(0x0800),ipv4(src=10.0.0.4,dst=10.0.0.3,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'])
6429 sleep 1
6430 dnl The first packet is essentially a no-op, as the new destination MAC is the
6431 dnl same as the original.  The second entry actually updates the destination
6432 dnl MAC.
6433 AT_CHECK([cat ovs-vswitchd.log | STRIP_UFID | FILTER_FLOW_INSTALL | STRIP_USED], [0], [dnl
6434 recirc_id=0,ip,in_port=1,dl_dst=50:54:00:00:00:0a,nw_frag=no, actions:2
6435 recirc_id=0,ip,in_port=1,dl_dst=50:54:00:00:00:0c,nw_frag=no, actions:set(eth(dst=50:54:00:00:00:0a)),2
6436 ])
6437 OVS_VSWITCHD_STOP
6438 AT_CLEANUP
6439
6440 AT_SETUP([ofproto-dpif megaflow - disabled])
6441 OVS_VSWITCHD_START
6442 AT_CHECK([ovs-appctl vlog/set dpif:dbg dpif_netdev:dbg])
6443 ADD_OF_PORTS([br0], [1], [2])
6444 AT_DATA([flows.txt], [dnl
6445 table=0 in_port=1,ip,nw_dst=10.0.0.1 actions=output(2)
6446 table=0 in_port=1,ip,nw_dst=10.0.0.3 actions=drop
6447 ])
6448 AT_CHECK([ovs-appctl upcall/disable-megaflows], [0], [megaflows disabled
6449 ], [])
6450 AT_CHECK([ovs-appctl upcall/disable-ufid], [0], [Datapath dumping tersely using UFID disabled
6451 ], [])
6452 AT_CHECK([ovs-appctl vlog/set dpif_netdev:dbg], [0], [], [])
6453 AT_CHECK([ovs-ofctl add-flows br0 flows.txt])
6454 for i in 1 2 3 4; do
6455     AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:09,dst=50:54:00:00:00:0a),eth_type(0x0800),ipv4(src=10.0.0.2,dst=10.0.0.1,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'])
6456     AT_CHECK([ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:0b,dst=50:54:00:00:00:0c),eth_type(0x0800),ipv4(src=10.0.0.4,dst=10.0.0.3,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0)'])
6457     if [[ $i -eq 1 ]]; then
6458         sleep 1
6459     fi
6460 done
6461 sleep 1
6462 AT_CHECK([cat ovs-vswitchd.log | STRIP_UFID | FILTER_FLOW_INSTALL | STRIP_USED], [0], [dnl
6463 pkt_mark=0,recirc_id=0,dp_hash=0,skb_priority=0,icmp,in_port=1,vlan_tci=0x0000,dl_src=50:54:00:00:00:09,dl_dst=50:54:00:00:00:0a,nw_src=10.0.0.2,nw_dst=10.0.0.1,nw_tos=0,nw_ecn=0,nw_ttl=64,icmp_type=8,icmp_code=0, actions:2
6464 pkt_mark=0,recirc_id=0,dp_hash=0,skb_priority=0,icmp,in_port=1,vlan_tci=0x0000,dl_src=50:54:00:00:00:0b,dl_dst=50:54:00:00:00:0c,nw_src=10.0.0.4,nw_dst=10.0.0.3,nw_tos=0,nw_ecn=0,nw_ttl=64,icmp_type=8,icmp_code=0, actions:drop
6465 ])
6466 AT_CHECK([cat ovs-vswitchd.log | STRIP_UFID | FILTER_FLOW_DUMP | grep 'packets:3'], [0], [dnl
6467 skb_priority(0),skb_mark(0),recirc_id(0),dp_hash(0),in_port(1),eth(src=50:54:00:00:00:09,dst=50:54:00:00:00:0a),eth_type(0x0800),ipv4(src=10.0.0.2,dst=10.0.0.1,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0), packets:3, bytes:180, used:0.0s, actions:2
6468 skb_priority(0),skb_mark(0),recirc_id(0),dp_hash(0),in_port(1),eth(src=50:54:00:00:00:0b,dst=50:54:00:00:00:0c),eth_type(0x0800),ipv4(src=10.0.0.4,dst=10.0.0.3,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0), packets:3, bytes:180, used:0.0s, actions:drop
6469 ])
6470 OVS_VSWITCHD_STOP
6471 AT_CLEANUP
6472
6473 AT_SETUP([ofproto-dpif - datapath port number change])
6474 OVS_VSWITCHD_START([set Bridge br0 fail-mode=standalone])
6475 ADD_OF_PORTS([br0], 1)
6476
6477 # Trace a flow that should output to p1.
6478 AT_CHECK([ovs-appctl ofproto/trace br0 in_port=LOCAL,dl_src=10:20:30:40:50:60],
6479   [0], [stdout])
6480 AT_CHECK([tail -1 stdout], [0], [Datapath actions: 1
6481 ])
6482
6483 # Change p1's port number to 5.
6484 AT_CHECK([ovs-appctl dpif-dummy/change-port-number ovs-dummy p1 5])
6485
6486 # Trace a flow that should output to p1 in its new location.
6487 AT_CHECK([ovs-appctl ofproto/trace br0 in_port=LOCAL,dl_src=10:20:30:40:50:60],
6488   [0], [stdout])
6489 AT_CHECK([tail -1 stdout], [0], [Datapath actions: 5
6490 ])
6491 OVS_VSWITCHD_STOP
6492 AT_CLEANUP
6493
6494 # Tests the bundling with various bfd and cfm configurations.
6495 AT_SETUP([ofproto - bundle with variable bfd/cfm config])
6496 OVS_VSWITCHD_START([add-br br1 -- set bridge br1 datapath-type=dummy -- \
6497                     add-bond br0 br0bond p0 p2 bond-mode=active-backup -- \
6498                     add-bond br1 br1bond p1 p3 bond-mode=active-backup -- \
6499                     set Interface p1 type=patch options:peer=p0 ofport_request=2 -- \
6500                     set Interface p3 type=patch options:peer=p2 ofport_request=4 -- \
6501                     set Interface p0 type=patch options:peer=p1 ofport_request=1 -- \
6502                     set Interface p2 type=patch options:peer=p3 ofport_request=3 -- \
6503                     set Interface p0 bfd:enable=true bfd:min_tx=300 bfd:min_rx=300 -- \
6504                     set Interface p0 cfm_mpid=1 -- \
6505                     set Interface p1 bfd:enable=true bfd:min_tx=500 bfd:min_rx=500])
6506
6507 ovs-appctl time/stop
6508 # advance the clock to stablize everything.
6509 ovs-appctl time/warp 5000 100
6510 # cfm/show should show 'recv' fault.
6511 AT_CHECK([ovs-appctl cfm/show | sed -n '/^.*fault:.*/p'], [0], [dnl
6512         fault: recv
6513 ])
6514 # bfd/show should show 'up'.
6515 AT_CHECK([ovs-appctl bfd/show | sed -n '/^.*Session State:.*/p'], [0], [dnl
6516         Local Session State: up
6517         Remote Session State: up
6518         Local Session State: up
6519         Remote Session State: up
6520 ])
6521 # bond/show should show 'may-enable: true' for all slaves.
6522 AT_CHECK([ovs-appctl bond/show | sed -n '/^.*may_enable:.*/p'], [0], [dnl
6523         may_enable: true
6524         may_enable: true
6525         may_enable: true
6526         may_enable: true
6527 ])
6528
6529 # now disable the bfd on p1.
6530 AT_CHECK([ovs-vsctl set Interface p1 bfd:enable=false])
6531 # advance the clock to stablize everything.
6532 ovs-appctl time/warp 5000 100
6533 # cfm/show should show 'recv' fault.
6534 AT_CHECK([ovs-appctl cfm/show | sed -n '/^.*fault:.*/p'], [0], [dnl
6535         fault: recv
6536 ])
6537 # bfd/show should show 'down'.
6538 AT_CHECK([ovs-appctl bfd/show | sed -n '/^.*Session State:.*/p'], [0], [dnl
6539         Local Session State: down
6540         Remote Session State: down
6541 ])
6542 # bond/show should show 'may-enable: false' for p0.
6543 AT_CHECK([ovs-appctl bond/show br0bond | sed -n '/^.*may_enable:.*/p'], [0], [dnl
6544         may_enable: false
6545         may_enable: true
6546 ])
6547
6548 # now enable the bfd on p1 and disable bfd on p0.
6549 AT_CHECK([ovs-vsctl set Interface p1 bfd:enable=true])
6550 AT_CHECK([ovs-vsctl set Interface p0 bfd:enable=false])
6551 # advance the clock to stablize everything.
6552 ovs-appctl time/warp 5000 100
6553 # cfm/show should show 'recv' fault.
6554 AT_CHECK([ovs-appctl cfm/show | sed -n '/^.*fault:.*/p'], [0], [dnl
6555         fault: recv
6556 ])
6557 # bfd/show should show 'down'.
6558 AT_CHECK([ovs-appctl bfd/show | sed -n '/^.*Session State:.*/p'], [0], [dnl
6559         Local Session State: down
6560         Remote Session State: down
6561 ])
6562 # bond/show should show 'may-enable: false' for p0 and p1.
6563 AT_CHECK([ovs-appctl bond/show | sed -n '/^.*may_enable:.*/p'], [0], [dnl
6564         may_enable: false
6565         may_enable: true
6566         may_enable: false
6567         may_enable: true
6568 ])
6569
6570 OVS_VSWITCHD_STOP
6571 AT_CLEANUP
6572
6573 AT_SETUP([ofproto-dpif - ofproto-dpif-monitor 1])
6574 OVS_VSWITCHD_START([add-port br0 p0 -- set interface p0 type=gre options:remote_ip=1.2.3.4])
6575
6576 # enable bfd on p0.
6577 AT_CHECK([ovs-vsctl set interface p0 bfd:enable=true])
6578 # check log.
6579 OVS_WAIT_UNTIL([grep "monitor thread created" ovs-vswitchd.log])
6580 # disable bfd on p0.
6581 AT_CHECK([ovs-vsctl set interface p0 bfd:enable=false])
6582 # check log.
6583 OVS_WAIT_UNTIL([grep "monitor thread terminated" ovs-vswitchd.log])
6584 AT_CHECK([cat ovs-vswitchd.log | sed -e '/^.*ofproto_dpif_monitor.*$/d' > ovs-vswitchd.log])
6585
6586 # enable cfm on p0.
6587 AT_CHECK([ovs-vsctl set interface p0 cfm_mpid=10])
6588 # check log.
6589 OVS_WAIT_UNTIL([grep "monitor thread created" ovs-vswitchd.log])
6590 # disable cfm on p0.
6591 AT_CHECK([ovs-vsctl remove interface p0 cfm_mpid 10])
6592 # check log.
6593 OVS_WAIT_UNTIL([grep "monitor thread terminated" ovs-vswitchd.log])
6594 AT_CHECK([cat ovs-vswitchd.log | sed -e '/^.*ofproto_dpif_monitor.*$/d' > ovs-vswitchd.log])
6595
6596 # enable both bfd and cfm on p0.
6597 AT_CHECK([ovs-vsctl set interface p0 bfd:enable=true cfm_mpid=10])
6598 # check log.
6599 OVS_WAIT_UNTIL([grep "monitor thread created" ovs-vswitchd.log])
6600 # disable bfd on p0.
6601 AT_CHECK([ovs-vsctl set interface p0 bfd:enable=false])
6602 # check log, there should not be the log of thread terminated.
6603 AT_CHECK([sed -n "s/^.*|ofproto_dpif_monitor(monitor[[0-9]]*)|INFO|\(.* terminated\)$/\1/p" ovs-vswitchd.log], [0], [dnl
6604 ])
6605 # reenable bfd on p0.
6606 AT_CHECK([ovs-vsctl set interface p0 bfd:enable=true])
6607 # check log, should still be on log of thread created.
6608 AT_CHECK([sed -n "s/^.*|ofproto_dpif_monitor(monitor[[0-9]]*)|INFO|\(.* created\)$/\1/p" ovs-vswitchd.log], [0], [dnl
6609 monitor thread created
6610 ])
6611 # disable bfd and cfm together.
6612 AT_CHECK([ovs-vsctl set interface p0 bfd:enable=false -- remove interface p0 cfm_mpid 10])
6613 # check log.
6614 OVS_WAIT_UNTIL([grep "monitor thread terminated" ovs-vswitchd.log])
6615
6616 OVS_VSWITCHD_STOP
6617 AT_CLEANUP
6618
6619 # this test helps avoid the deadlock between the main thread and monitor thread.
6620 AT_SETUP([ofproto-dpif - ofproto-dpif-monitor 2])
6621 OVS_VSWITCHD_START
6622
6623 for i in `seq 1 199`
6624 do
6625     AT_CHECK([ovs-vsctl add-port br0 p$i -- set interface p$i type=gre options:remote_ip=1.2.3.4 options:key=$i bfd:enable=true])
6626 done
6627
6628 OVS_VSWITCHD_STOP
6629 AT_CLEANUP
6630 \f
6631 AT_BANNER([ofproto-dpif - flow translation resource limits])
6632
6633 AT_SETUP([ofproto-dpif - infinite resubmit])
6634 OVS_VSWITCHD_START
6635 AT_CHECK([ovs-ofctl add-flow br0 actions=resubmit:1,resubmit:2,output:3])
6636 AT_CHECK([ovs-appctl -vpoll_loop:off ofproto/trace br0 'eth_dst=ff:ff:ff:ff:ff:ff'],
6637   [0], [stdout])
6638 AT_CHECK([tail -1 stdout], [0], [Datapath actions: drop
6639 ])
6640 AT_CHECK([grep -c 'resubmit actions recursed over 64 times' ovs-vswitchd.log],
6641   [0], [1
6642 ])
6643 OVS_VSWITCHD_STOP(["/resubmit actions recursed/d"])
6644 AT_CLEANUP
6645
6646 AT_SETUP([ofproto-dpif - exponential resubmit chain])
6647 OVS_VSWITCHD_START
6648 ADD_OF_PORTS([br0], 1)
6649 (for i in `seq 1 64`; do
6650      j=`expr $i + 1`
6651      echo "in_port=$i, actions=resubmit:$j, resubmit:$j, local"
6652  done
6653  echo "in_port=65, actions=local") > flows
6654  AT_CHECK([ovs-ofctl add-flows br0 flows])
6655 AT_CHECK([ovs-appctl -vpoll_loop:off ofproto/trace br0 'in_port=1'], [0], [stdout])
6656 AT_CHECK([grep -c 'over 4096 resubmit actions' ovs-vswitchd.log], [0], [1
6657 ])
6658 OVS_VSWITCHD_STOP(["/over.*resubmit actions/d"])
6659 AT_CLEANUP
6660
6661 AT_SETUP([ofproto-dpif - too many output actions])
6662 OVS_VSWITCHD_START
6663 ADD_OF_PORTS([br0], 1)
6664 (for i in `seq 1 12`; do
6665      j=`expr $i + 1`
6666      echo "in_port=$i, actions=resubmit:$j, resubmit:$j, local"
6667  done
6668  echo "in_port=13, actions=local,local,local,local,local,local,local,local") > flows
6669 AT_CHECK([ovs-ofctl add-flows br0 flows])
6670 AT_CHECK([ovs-appctl -vpoll_loop:off ofproto/trace br0 'in_port=1'], [0], [stdout])
6671 AT_CHECK([grep -c -e '- Uses action(s) not supported by datapath' stdout],
6672   [0], [1
6673 ])
6674 AT_CHECK([grep -c 'resubmits yielded over 64 kB of actions' ovs-vswitchd.log], [0], [1
6675 ])
6676 OVS_VSWITCHD_STOP(["/resubmits yielded over 64 kB of actions/d"])
6677 AT_CLEANUP
6678
6679 AT_SETUP([ofproto-dpif - stack too deep])
6680 OVS_VSWITCHD_START
6681 ADD_OF_PORTS([br0], 1)
6682 (for i in `seq 1 12`; do
6683      j=`expr $i + 1`
6684      echo "in_port=$i, actions=resubmit:$j, resubmit:$j, local"
6685  done
6686  push="push:NXM_NX_REG0[[]]"
6687  echo "in_port=13, actions=$push,$push,$push,$push,$push,$push,$push,$push") > flows
6688  AT_CHECK([ovs-ofctl add-flows br0 flows])
6689 AT_CHECK([ovs-appctl -vpoll_loop:off ofproto/trace br0 'in_port=1'], [0], [stdout])
6690 AT_CHECK([grep -c 'resubmits yielded over 64 kB of stack' ovs-vswitchd.log], [0], [1
6691 ])
6692 OVS_VSWITCHD_STOP(["/resubmits yielded over 64 kB of stack/d"])
6693 AT_CLEANUP
6694
6695
6696 AT_SETUP([ofproto-dpif packet-out controller])
6697 OVS_VSWITCHD_START
6698 ADD_OF_PORTS([br0], 1, 2)
6699
6700 AT_CHECK([ovs-ofctl add-flow br0 'dl_dst=50:54:00:00:00:0a actions=controller'])
6701
6702 AT_CAPTURE_FILE([ofctl_monitor.log])
6703 AT_CHECK([ovs-ofctl monitor br0 65534 invalid_ttl --detach --no-chdir --pidfile 2> ofctl_monitor.log])
6704
6705 for i in 1 2 3; do
6706         AT_CHECK([ovs-ofctl -O OpenFlow13 packet-out br0 CONTROLLER controller '50540000000a5054000000091234'])
6707 done
6708
6709 OVS_WAIT_UNTIL([ovs-appctl -t ovs-ofctl exit])
6710 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
6711 NXT_PACKET_IN (xid=0x0): total_len=14 in_port=CONTROLLER (via action) data_len=14 (unbuffered)
6712 vlan_tci=0x0000,dl_src=50:54:00:00:00:09,dl_dst=50:54:00:00:00:0a,dl_type=0x1234
6713 dnl
6714 NXT_PACKET_IN (xid=0x0): total_len=14 in_port=CONTROLLER (via action) data_len=14 (unbuffered)
6715 vlan_tci=0x0000,dl_src=50:54:00:00:00:09,dl_dst=50:54:00:00:00:0a,dl_type=0x1234
6716 dnl
6717 NXT_PACKET_IN (xid=0x0): total_len=14 in_port=CONTROLLER (via action) data_len=14 (unbuffered)
6718 vlan_tci=0x0000,dl_src=50:54:00:00:00:09,dl_dst=50:54:00:00:00:0a,dl_type=0x1234
6719 ])
6720
6721 AT_CHECK([ovs-ofctl dump-flows br0 | ofctl_strip | sort], [0], [dnl
6722  dl_dst=50:54:00:00:00:0a actions=CONTROLLER:65535
6723 NXST_FLOW reply:
6724 ])
6725
6726 (echo "OFPST_TABLE reply (OF1.3) (xid=0x2):
6727   table 0:
6728     active=1, lookup=0, matched=0"
6729  x=1
6730  while test $x -lt 254; do
6731    echo "
6732   table $x:
6733     active=0, lookup=0, matched=0"
6734    x=`expr $x + 1`
6735  done) > expout
6736 AT_CHECK([ovs-ofctl -O OpenFlow13 dump-tables br0 ], [0], [expout])
6737
6738 OVS_VSWITCHD_STOP
6739 AT_CLEANUP
6740
6741 AT_SETUP([ofproto-dpif packet-out controller (patch port)])
6742 OVS_VSWITCHD_START(
6743   [-- \
6744    add-port br0 p1 -- \
6745    set interface p1 type=patch options:peer=p2 -- \
6746    add-br br1 -- \
6747    set bridge br1 datapath-type=dummy -- \
6748    set bridge br1 fail-mode=secure -- \
6749    set bridge br1 protocols='[OpenFlow10,OpenFlow11,OpenFlow12,OpenFlow13]' -- \
6750    add-port br1 p2 -- \
6751    set interface p2 type=patch options:peer=p1 --])
6752
6753 AT_CAPTURE_FILE([ofctl_monitor.log])
6754 AT_CHECK([ovs-ofctl monitor br1 65534 invalid_ttl --detach --no-chdir --pidfile 2> ofctl_monitor.log])
6755
6756 for i in 1 2 3; do
6757         AT_CHECK([ovs-ofctl -O OpenFlow13 packet-out br0 CONTROLLER output:1 '50540000000a5054000000091234'])
6758 done
6759
6760 OVS_WAIT_UNTIL([ovs-appctl -t ovs-ofctl exit])
6761 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
6762 NXT_PACKET_IN (xid=0x0): cookie=0x0 total_len=14 in_port=1 (via no_match) data_len=14 (unbuffered)
6763 vlan_tci=0x0000,dl_src=50:54:00:00:00:09,dl_dst=50:54:00:00:00:0a,dl_type=0x1234
6764 dnl
6765 NXT_PACKET_IN (xid=0x0): cookie=0x0 total_len=14 in_port=1 (via no_match) data_len=14 (unbuffered)
6766 vlan_tci=0x0000,dl_src=50:54:00:00:00:09,dl_dst=50:54:00:00:00:0a,dl_type=0x1234
6767 dnl
6768 NXT_PACKET_IN (xid=0x0): cookie=0x0 total_len=14 in_port=1 (via no_match) data_len=14 (unbuffered)
6769 vlan_tci=0x0000,dl_src=50:54:00:00:00:09,dl_dst=50:54:00:00:00:0a,dl_type=0x1234
6770 ])
6771
6772 (printf "OFPST_TABLE reply (OF1.3) (xid=0x2):"
6773  x=0
6774  while test $x -lt 254; do
6775    echo "
6776   table $x:
6777     active=0, lookup=0, matched=0"
6778    x=`expr $x + 1`
6779  done) > expout
6780 AT_CHECK([ovs-ofctl -O OpenFlow13 dump-tables br0 ], [0], [expout])
6781
6782 (echo "OFPST_TABLE reply (OF1.3) (xid=0x2):
6783   table 0:
6784     active=0, lookup=3, matched=0"
6785  x=1
6786  while test $x -lt 254; do
6787    echo "
6788   table $x:
6789     active=0, lookup=0, matched=0"
6790    x=`expr $x + 1`
6791  done) > expout
6792 AT_CHECK([ovs-ofctl -O OpenFlow13 dump-tables br1 ], [0], [expout])
6793
6794 OVS_VSWITCHD_STOP
6795 AT_CLEANUP
6796
6797
6798 AT_SETUP([ofproto-dpif packet-out goto_table])
6799 OVS_VSWITCHD_START
6800 ADD_OF_PORTS([br0], 1, 2)
6801
6802 AT_DATA([flows.txt], [dnl
6803 table=0 dl_dst=50:54:00:00:00:0a actions=goto_table(1)
6804 table=1 dl_dst=50:54:00:00:00:0a actions=controller
6805 ])
6806 AT_CHECK([ovs-ofctl -O OpenFlow13 add-flows br0 flows.txt])
6807
6808 AT_CAPTURE_FILE([ofctl_monitor.log])
6809 AT_CHECK([ovs-ofctl monitor br0 65534 invalid_ttl --detach --no-chdir --pidfile 2> ofctl_monitor.log])
6810
6811 for i in 1 2 3; do
6812     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:09,dst=50:54:00:00:00:0a),eth_type(0x1234)'
6813 done
6814
6815 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
6816 OVS_WAIT_UNTIL([ovs-appctl -t ovs-ofctl exit])
6817 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
6818 NXT_PACKET_IN (xid=0x0): table_id=1 cookie=0x0 total_len=60 in_port=1 (via action) data_len=60 (unbuffered)
6819 vlan_tci=0x0000,dl_src=50:54:00:00:00:09,dl_dst=50:54:00:00:00:0a,dl_type=0x1234
6820 dnl
6821 NXT_PACKET_IN (xid=0x0): table_id=1 cookie=0x0 total_len=60 in_port=1 (via action) data_len=60 (unbuffered)
6822 vlan_tci=0x0000,dl_src=50:54:00:00:00:09,dl_dst=50:54:00:00:00:0a,dl_type=0x1234
6823 dnl
6824 NXT_PACKET_IN (xid=0x0): table_id=1 cookie=0x0 total_len=60 in_port=1 (via action) data_len=60 (unbuffered)
6825 vlan_tci=0x0000,dl_src=50:54:00:00:00:09,dl_dst=50:54:00:00:00:0a,dl_type=0x1234
6826 ])
6827
6828 AT_CHECK([ovs-appctl revalidator/purge], [0])
6829 AT_CHECK([ovs-ofctl -O OpenFlow13 dump-flows br0 | ofctl_strip | sort], [0], [dnl
6830  n_packets=3, n_bytes=180, dl_dst=50:54:00:00:00:0a actions=goto_table:1
6831  table=1, n_packets=3, n_bytes=180, dl_dst=50:54:00:00:00:0a actions=CONTROLLER:65535
6832 OFPST_FLOW reply (OF1.3):
6833 ])
6834
6835 (echo "OFPST_TABLE reply (OF1.3) (xid=0x2):
6836   table 0:
6837     active=1, lookup=3, matched=3
6838
6839   table 1:
6840     active=1, lookup=3, matched=3"
6841  x=2
6842  while test $x -lt 254; do
6843    echo "
6844   table $x:
6845     active=0, lookup=0, matched=0"
6846    x=`expr $x + 1`
6847  done) > expout
6848 AT_CHECK([ovs-ofctl -O OpenFlow13 dump-tables br0 ], [0], [expout])
6849
6850 OVS_VSWITCHD_STOP
6851 AT_CLEANUP
6852
6853
6854 AT_SETUP([ofproto-dpif packet-out table-miss (continue)])
6855 OVS_VSWITCHD_START
6856 ADD_OF_PORTS([br0], 1, 2)
6857
6858 AT_CHECK([ovs-ofctl -O OpenFlow11 add-flow br0 'table=1 dl_dst=50:54:00:00:00:0a actions=controller'])
6859 AT_CHECK([ovs-ofctl -O OpenFlow11 mod-table br0 all continue])
6860
6861 AT_CAPTURE_FILE([ofctl_monitor.log])
6862 AT_CHECK([ovs-ofctl monitor br0 65534 invalid_ttl --detach --no-chdir --pidfile 2> ofctl_monitor.log])
6863
6864 for i in 1 2 3; do
6865     ovs-appctl netdev-dummy/receive p1 'in_port(1),eth(src=50:54:00:00:00:09,dst=50:54:00:00:00:0a),eth_type(0x1234)'
6866 done
6867
6868 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 6])
6869 OVS_WAIT_UNTIL([ovs-appctl -t ovs-ofctl exit])
6870 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
6871 NXT_PACKET_IN (xid=0x0): table_id=1 cookie=0x0 total_len=60 in_port=1 (via action) data_len=60 (unbuffered)
6872 vlan_tci=0x0000,dl_src=50:54:00:00:00:09,dl_dst=50:54:00:00:00:0a,dl_type=0x1234
6873 dnl
6874 NXT_PACKET_IN (xid=0x0): table_id=1 cookie=0x0 total_len=60 in_port=1 (via action) data_len=60 (unbuffered)
6875 vlan_tci=0x0000,dl_src=50:54:00:00:00:09,dl_dst=50:54:00:00:00:0a,dl_type=0x1234
6876 dnl
6877 NXT_PACKET_IN (xid=0x0): table_id=1 cookie=0x0 total_len=60 in_port=1 (via action) data_len=60 (unbuffered)
6878 vlan_tci=0x0000,dl_src=50:54:00:00:00:09,dl_dst=50:54:00:00:00:0a,dl_type=0x1234
6879 ])
6880
6881 AT_CHECK([ovs-appctl revalidator/purge], [0])
6882 AT_CHECK([ovs-ofctl -O OpenFlow11 dump-flows br0 | ofctl_strip | sort], [0], [dnl
6883  table=1, n_packets=3, n_bytes=180, dl_dst=50:54:00:00:00:0a actions=CONTROLLER:65535
6884 OFPST_FLOW reply (OF1.1):
6885 ])
6886
6887 (echo "OFPST_TABLE reply (OF1.3) (xid=0x2):
6888   table 0:
6889     active=0, lookup=3, matched=0
6890
6891   table 1:
6892     active=1, lookup=3, matched=3"
6893  x=2
6894  while test $x -lt 254; do
6895    echo "
6896   table $x:
6897     active=0, lookup=0, matched=0"
6898    x=`expr $x + 1`
6899  done) > expout
6900 AT_CHECK([ovs-ofctl -O OpenFlow13 dump-tables br0 ], [0], [expout])
6901
6902 OVS_VSWITCHD_STOP
6903 AT_CLEANUP
6904
6905 AT_SETUP([ofproto-dpif - ICMPv6])
6906 OVS_VSWITCHD_START
6907 ADD_OF_PORTS([br0], 1)
6908
6909 AT_CAPTURE_FILE([ofctl_monitor.log])
6910
6911 AT_CHECK([ovs-ofctl monitor br0 65534 --detach --no-chdir --pidfile 2> ofctl_monitor.log])
6912
6913 ovs-appctl netdev-dummy/receive p1 '0060970769ea0000860580da86dd6000000000203afffe80000000000000020086fffe0580dafe80000000000000026097fffe0769ea870068bd00000000fe80000000000000026097fffe0769ea01010000860580da'
6914
6915 OVS_WAIT_UNTIL([ovs-appctl -t ovs-ofctl exit])
6916
6917 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
6918 NXT_PACKET_IN (xid=0x0): cookie=0x0 total_len=86 in_port=1 (via no_match) data_len=86 (unbuffered)
6919 icmp6,vlan_tci=0x0000,dl_src=00:00:86:05:80:da,dl_dst=00:60:97:07:69:ea,ipv6_src=fe80::200:86ff:fe05:80da,ipv6_dst=fe80::260:97ff:fe07:69ea,ipv6_label=0x00000,nw_tos=0,nw_ecn=0,nw_ttl=255,icmp_type=135,icmp_code=0,nd_target=fe80::260:97ff:fe07:69ea,nd_sll=00:00:86:05:80:da,nd_tll=00:00:00:00:00:00 icmp6_csum:68bd
6920 ])
6921
6922 OVS_VSWITCHD_STOP
6923 AT_CLEANUP
6924
6925 AT_SETUP([ofproto-dpif - Neighbor Discovery set-field with checksum update])
6926 OVS_VSWITCHD_START
6927 ADD_OF_PORTS([br0], 1)
6928 AT_CHECK([ovs-ofctl add-flow br0 icmp6,icmpv6_type=135,action=set_field:fe80::1-\>nd_target,set_field:32:21:14:86:11:74-\>nd_sll,output:controller])
6929
6930 AT_CAPTURE_FILE([ofctl_monitor.log])
6931
6932 AT_CHECK([ovs-ofctl monitor br0 65534 --detach --no-chdir --pidfile 2> ofctl_monitor.log])
6933
6934 ovs-appctl netdev-dummy/receive p1 '0060970769ea0000860580da86dd6000000000203afffe80000000000000020086fffe0580dafe80000000000000026097fffe0769ea870068bd00000000fe80000000000000026097fffe0769ea01010000860580da'
6935
6936 OVS_WAIT_UNTIL([ovs-appctl -t ovs-ofctl exit])
6937
6938 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
6939 NXT_PACKET_IN (xid=0x0): cookie=0x0 total_len=86 in_port=1 (via action) data_len=86 (unbuffered)
6940 icmp6,vlan_tci=0x0000,dl_src=00:00:86:05:80:da,dl_dst=00:60:97:07:69:ea,ipv6_src=fe80::200:86ff:fe05:80da,ipv6_dst=fe80::260:97ff:fe07:69ea,ipv6_label=0x00000,nw_tos=0,nw_ecn=0,nw_ttl=255,icmp_type=135,icmp_code=0,nd_target=fe80::1,nd_sll=32:21:14:86:11:74,nd_tll=00:00:00:00:00:00 icmp6_csum:19d3
6941 ])
6942
6943 OVS_VSWITCHD_STOP
6944 AT_CLEANUP
6945
6946 # Tests the exact match of CFI bit in installed datapath flows matching VLAN.
6947 AT_SETUP([ofproto-dpif - vlan matching])
6948 OVS_VSWITCHD_START(
6949   [add-port br0 p0 -- set Interface p0 type=dummy ofport_request=1])
6950 AT_CHECK([ovs-appctl vlog/set dpif:dbg dpif_netdev:dbg])
6951
6952 AT_CHECK([ovs-ofctl del-flows br0])
6953 AT_CHECK([ovs-ofctl add-flow br0 "vlan_tci=0x000a/0x0fff,action=output:local"])
6954
6955 AT_CHECK([ovs-appctl netdev-dummy/receive p0 'in_port(1),eth(src=50:54:00:00:00:09,dst=50:54:00:00:00:0a),eth_type(0x8100),vlan(vid=10,pcp=0),encap(eth_type(0x0800),ipv4(src=10.0.0.2,dst=10.0.0.1,proto=1,tos=0,ttl=64,frag=no),icmp(type=8,code=0))'])
6956
6957 AT_CHECK([cat ovs-vswitchd.log | grep 'in_port=[[1]]' | FILTER_FLOW_INSTALL | STRIP_XOUT], [0], [dnl
6958 recirc_id=0,ip,in_port=1,dl_vlan=10,nw_frag=no, actions: <del>
6959 ])
6960 OVS_VSWITCHD_STOP
6961 AT_CLEANUP