1 AT_BANNER([OpenFlow actions])
3 AT_SETUP([OpenFlow 1.0 action translation])
4 AT_KEYWORDS([ofp-actions OF1.0])
5 AT_DATA([test-data], [dnl
9 # actions=CONTROLLER:1234
12 # actions=mod_vlan_vid:9
15 # actions=mod_vlan_pcp:6
21 # actions=mod_dl_src:00:11:22:33:44:55
22 0004 0010 001122334455 000000000000
24 # actions=mod_dl_dst:10:20:30:40:50:60
25 0005 0010 102030405060 000000000000
27 # actions=mod_nw_src:1.2.3.4
30 # actions=mod_nw_dst:192.168.0.1
33 # actions=mod_nw_tos:48
36 # actions=mod_tp_src:80
39 # actions=mod_tp_dst:443
42 # actions=enqueue:10:55
43 000b 0010 000a 000000000000 00000037
46 ffff 0010 00002320 0001 0005 00000000
48 # actions=set_tunnel:0x12345678
49 ffff 0010 00002320 0002 0000 12345678
51 # actions=set_queue:2309737729
52 ffff 0010 00002320 0004 0000 89abcd01
55 ffff 0010 00002320 0005 000000000000
57 # actions=move:NXM_OF_IN_PORT[]->NXM_OF_VLAN_TCI[]
58 ffff 0018 00002320 0006 0010 0000 0000 00000002 00000802
60 # actions=load:0xf009->NXM_OF_VLAN_TCI[]
61 ffff 0018 00002320 0007 000f 00000802 000000000000f009
63 # actions=note:11.e9.9a.ad.67.f3
64 ffff 0010 00002320 0008 11e99aad67f3
66 # actions=set_tunnel64:0xc426384d49c53d60
67 ffff 0018 00002320 0009 000000000000 c426384d49c53d60
69 # actions=set_tunnel64:0x885f3298
70 ffff 0018 00002320 0009 000000000000 00000000885f3298
72 # actions=write_metadata:0xfedcba9876543210
73 ffff 0020 00002320 0016 000000000000 fedcba9876543210 ffffffffffffffff
75 # actions=write_metadata:0xfedcba9876543210/0xffff0000ffff0000
76 ffff 0020 00002320 0016 000000000000 fedcba9876543210 ffff0000ffff0000
78 # actions=multipath(eth_src,50,modulo_n,1,0,NXM_NX_REG0[])
79 ffff 0020 00002320 000a 0000 0032 0000 0000 0000 0000 0000 0000 001f 00010004
81 # actions=bundle(eth_src,0,hrw,ofport,slaves:4,8)
82 ffff 0028 00002320 000c 0001 0000 0000 00000002 0002 0000 00000000 00000000 dnl
85 # actions=bundle_load(eth_src,0,hrw,ofport,NXM_NX_REG0[],slaves:4,8)
86 ffff 0028 00002320 000d 0001 0000 0000 00000002 0002 001f 00010004 00000000 dnl
89 # actions=resubmit(10,5)
90 ffff 0010 00002320 000e 000a 05 000000
92 # actions=output:NXM_NX_REG1[5..10]
93 ffff 0018 00002320 000f 0145 00010204 ffff 000000000000
95 # actions=learn(table=2,idle_timeout=10,hard_timeout=20,fin_idle_timeout=2,fin_hard_timeout=4,priority=80,cookie=0x123456789abcdef0,NXM_OF_VLAN_TCI[0..11],NXM_OF_ETH_DST[]=NXM_OF_ETH_SRC[],output:NXM_OF_IN_PORT[])
96 ffff 0048 00002320 0010 000a 0014 0050 123456789abcdef0 0000 02 00 0002 0004 dnl
97 000c 00000802 0000 00000802 0000 dnl
98 0030 00000406 0000 00000206 0000 dnl
99 1010 00000002 0000 dnl
103 ffff 0010 00002320 0011 000000000000
106 ffff 0010 00002320 0012 000000000000
108 # actions=fin_timeout(idle_timeout=10,hard_timeout=20)
109 ffff 0010 00002320 0013 000a 0014 0000
111 # actions=controller(reason=invalid_ttl,max_len=1234,id=5678)
112 ffff 0010 00002320 0014 04d2 162e 02 00
114 # actions=dec_ttl(32768,12345,90,765,1024)
115 ffff 0020 00002320 0015 000500000000 80003039005A02fd 0400000000000000
117 # actions=sample(probability=12345,collector_set_id=23456,obs_domain_id=34567,obs_point_id=45678)
118 ffff 0018 00002320 001d 3039 00005BA0 00008707 0000B26E
121 sed '/^[[#&]]/d' < test-data > input.txt
122 sed -n 's/^# //p; /^$/p' < test-data > expout
123 sed -n 's/^& //p' < test-data > experr
124 AT_CAPTURE_FILE([input.txt])
125 AT_CAPTURE_FILE([expout])
126 AT_CAPTURE_FILE([experr])
128 [ovs-ofctl '-vPATTERN:console:%c|%p|%m' parse-ofp10-actions < input.txt],
129 [0], [expout], [experr])
132 AT_SETUP([OpenFlow 1.1 action translation])
133 AT_KEYWORDS([ofp-actions OF1.1])
134 AT_DATA([test-data], [dnl
136 0000 0010 fffffffe 04d2 000000000000
138 # actions=CONTROLLER:1234
139 0000 0010 fffffffd 04d2 000000000000
141 # actions=set_vlan_vid:9
144 # actions=set_vlan_pcp:6
147 # actions=mod_dl_src:00:11:22:33:44:55
148 0003 0010 001122334455 000000000000
150 # actions=mod_dl_dst:10:20:30:40:50:60
151 0004 0010 102030405060 000000000000
153 # actions=mod_nw_src:1.2.3.4
156 # actions=mod_nw_dst:192.168.0.1
159 # actions=mod_nw_tos:48
162 # actions=mod_tp_src:80
165 # actions=mod_tp_dst:443
171 # actions=set_queue:2309737729
174 dnl 802.1ad isn't supported at the moment
175 dnl # actions=push_vlan:0x88a8
176 dnl 0011 0008 88a8 0000
177 # actions=push_vlan:0x8100
181 ffff 0010 00002320 0001 0005 00000000
183 # actions=set_tunnel:0x12345678
184 ffff 0010 00002320 0002 0000 12345678
187 ffff 0010 00002320 0005 000000000000
189 # actions=move:NXM_OF_IN_PORT[]->NXM_OF_VLAN_TCI[]
190 ffff 0018 00002320 0006 0010 0000 0000 00000002 00000802
192 # actions=load:0xf009->NXM_OF_VLAN_TCI[]
193 ffff 0018 00002320 0007 000f 00000802 000000000000f009
195 # actions=note:11.e9.9a.ad.67.f3
196 ffff 0010 00002320 0008 11e99aad67f3
198 # actions=set_tunnel64:0xc426384d49c53d60
199 ffff 0018 00002320 0009 000000000000 c426384d49c53d60
201 # actions=set_tunnel64:0x885f3298
202 ffff 0018 00002320 0009 000000000000 00000000885f3298
204 dnl OpenFlow 1.1 uses OFPIT_WRITE_METADATA to express the NXAST_WRITE_METADATA
205 dnl action instead, so parse-ofp11-actions will recognise and drop this action.
206 # actions=write_metadata:0xfedcba9876543210
239 ffff 0020 00002320 0016 000000000000 fedcba9876543210 ffffffffffffffff
241 dnl Write-Metadata duplicated.
242 & ofp_actions|WARN|duplicate write_metadata instruction not allowed, for OpenFlow 1.1+ compatibility
243 # bad OF1.1 actions: OFPBAC_UNSUPPORTED_ORDER
244 ffff 0020 00002320 0016 000000000000 fedcba9876543210 ffffffffffffffff ffff 0020 00002320 0016 000000000000 fedcba9876543210 ffffffffffffffff
246 dnl Write-Metadata in wrong position.
247 & ofp_actions|WARN|invalid instruction ordering: apply_actions must appear before write_metadata, for OpenFlow 1.1+ compatibility
248 # bad OF1.1 actions: OFPBAC_UNSUPPORTED_ORDER
249 ffff 0020 00002320 0016 000000000000 fedcba9876543210 ffffffffffffffff ffff 0010 00002320 0002 0000 12345678
251 # actions=multipath(eth_src,50,modulo_n,1,0,NXM_NX_REG0[])
252 ffff 0020 00002320 000a 0000 0032 0000 0000 0000 0000 0000 0000 001f 00010004
254 # actions=bundle(eth_src,0,hrw,ofport,slaves:4,8)
255 ffff 0028 00002320 000c 0001 0000 0000 00000002 0002 0000 00000000 00000000 dnl
258 # actions=bundle_load(eth_src,0,hrw,ofport,NXM_NX_REG0[],slaves:4,8)
259 ffff 0028 00002320 000d 0001 0000 0000 00000002 0002 001f 00010004 00000000 dnl
262 # actions=resubmit(10,5)
263 ffff 0010 00002320 000e 000a 05 000000
265 # actions=output:NXM_NX_REG1[5..10]
266 ffff 0018 00002320 000f 0145 00010204 ffff 000000000000
268 # actions=learn(table=2,idle_timeout=10,hard_timeout=20,fin_idle_timeout=2,fin_hard_timeout=4,priority=80,cookie=0x123456789abcdef0,NXM_OF_VLAN_TCI[0..11],NXM_OF_ETH_DST[]=NXM_OF_ETH_SRC[],output:NXM_OF_IN_PORT[])
269 ffff 0048 00002320 0010 000a 0014 0050 123456789abcdef0 0000 02 00 0002 0004 dnl
270 000c 00000802 0000 00000802 0000 dnl
271 0030 00000406 0000 00000206 0000 dnl
272 1010 00000002 0000 dnl
276 ffff 0010 00002320 0011 000000000000
280 ffff 0010 00002320 0012 000000000000
282 dnl OpenFlow 1.1 OFPAT_DEC_TTL
286 # actions=fin_timeout(idle_timeout=10,hard_timeout=20)
287 ffff 0010 00002320 0013 000a 0014 0000
289 # actions=controller(reason=invalid_ttl,max_len=1234,id=5678)
290 ffff 0010 00002320 0014 04d2 162e 02 00
292 # actions=dec_ttl(32768,12345,90,765,1024)
293 ffff 0020 00002320 0015 000500000000 80003039005A02fd 0400000000000000
295 # actions=sample(probability=12345,collector_set_id=23456,obs_domain_id=34567,obs_point_id=45678)
296 ffff 0018 00002320 001d 3039 00005BA0 00008707 0000B26E
299 sed '/^[[#&]]/d' < test-data > input.txt
300 sed -n 's/^# //p; /^$/p' < test-data > expout
301 sed -n 's/^& //p' < test-data > experr
302 AT_CAPTURE_FILE([input.txt])
303 AT_CAPTURE_FILE([expout])
304 AT_CAPTURE_FILE([experr])
306 [ovs-ofctl '-vPATTERN:console:%c|%p|%m' parse-ofp11-actions < input.txt],
307 [0], [expout], [experr])
310 AT_SETUP([OpenFlow 1.1 instruction translation])
311 AT_KEYWORDS([OF1.1 instruction ofp-actions])
312 AT_DATA([test-data], [dnl
314 0004 0018 00000000 dnl
315 0000 0010 fffffffe 04d2 000000000000
317 dnl Apply-Actions non-zero padding
329 dnl Check that an empty Apply-Actions instruction gets dropped.
341 dnl Duplicate instruction type:
342 # bad OF1.1 instructions: ONFBIC_DUP_INSTRUCTION
343 0004 0008 00000000 0004 0008 00000000
345 dnl Instructions not multiple of 8 in length.
346 & ofp_actions|WARN|OpenFlow message instructions length 9 is not a multiple of 8
347 # bad OF1.1 instructions: OFPBIC_BAD_LEN
348 0004 0009 01 00000000
350 dnl Goto-Table instruction too long.
351 # bad OF1.1 instructions: OFPBIC_BAD_LEN
352 0001 0010 01 000000 0000000000000000
354 dnl Goto-Table 1 instruction non-zero padding
355 # actions=goto_table:1
359 dnl Goto-Table 1 instruction go back to the previous table.
360 # bad OF1.1 instructions: OFPBRC_BAD_TABLE_ID
361 2,0001 0008 01 000000
364 # actions=goto_table:1
368 # actions=write_metadata:0xfedcba9876543210
369 0002 0018 00000000 fedcba9876543210 ffffffffffffffff
371 dnl Write-Metadata with mask.
372 # actions=write_metadata:0xfedcba9876543210/0xff00ff00ff00ff00
373 0002 0018 00000000 fedcba9876543210 ff00ff00ff00ff00
375 dnl Write-Metadata too short.
376 # bad OF1.1 instructions: OFPBIC_BAD_LEN
377 0002 0010 00000000 fedcba9876543210
379 dnl Write-Metadata too long.
380 # bad OF1.1 instructions: OFPBIC_BAD_LEN
381 0002 0020 00000000 fedcba9876543210 ffffffffffffffff 0000000000000000
383 dnl Write-Metadata duplicated.
384 # bad OF1.1 instructions: ONFBIC_DUP_INSTRUCTION
385 0002 0018 00000000 fedcba9876543210 ff00ff00ff00ff00 0002 0018 00000000 fedcba9876543210 ff00ff00ff00ff00
387 dnl Write-Metadata in wrong position (OpenFlow 1.1+ disregards the order
388 dnl and OVS reorders it to the canonical order)
389 # actions=write_metadata:0xfedcba9876543210,goto_table:1
417 0001 0008 01 000000 0002 0018 00000000 fedcba9876543210 ffffffffffffffff
419 dnl empty Write-Actions non-zero padding
420 # actions=write_actions(drop)
431 dnl Check that an empty Write-Actions instruction gets dropped.
432 # actions=write_actions(drop)
443 dnl Clear-Actions too-long
444 # bad OF1.1 instructions: OFPBIC_BAD_LEN
445 0005 0010 00000000 0000000000000000
447 dnl Clear-Actions non-zero padding
448 # actions=clear_actions
452 dnl Clear-Actions non-zero padding
453 # actions=clear_actions
458 # actions=clear_actions
461 dnl Experimenter actions not supported yet.
462 # bad OF1.1 instructions: OFPBIC_BAD_EXPERIMENTER
465 dnl Bad instruction number (0 not assigned).
466 # bad OF1.1 instructions: OFPBIC_UNKNOWN_INST
470 sed '/^[[#&]]/d' < test-data > input.txt
471 sed -n 's/^# //p; /^$/p' < test-data > expout
472 sed -n 's/^& //p' < test-data > experr
473 AT_CAPTURE_FILE([input.txt])
474 AT_CAPTURE_FILE([expout])
475 AT_CAPTURE_FILE([experr])
477 [ovs-ofctl '-vPATTERN:console:%c|%p|%m' parse-ofp11-instructions < input.txt],
478 [0], [expout], [experr])
481 AT_SETUP([ofp-actions - inconsistent MPLS actions])
483 dnl OK: Use fin_timeout action on TCP flow
484 AT_CHECK([ovs-ofctl -O OpenFlow11 -vwarn add-flow br0 'tcp actions=fin_timeout(idle_timeout=1)'])
485 dnl Bad: Use fin_timeout action on TCP flow that has been converted to MPLS
486 AT_CHECK([ovs-ofctl -O OpenFlow11 -vwarn add-flow br0 'tcp actions=push_mpls:0x8847,fin_timeout(idle_timeout=1)'],
488 ovs-ofctl: none of the usable flow formats (OpenFlow10,NXM) is among the allowed flow formats (OpenFlow11)