summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorYuichi Ito <ito.yuichi0@gmail.com>2014-01-23 13:03:27 +0900
committerFUJITA Tomonori <fujita.tomonori@lab.ntt.co.jp>2014-01-23 13:28:08 +0900
commit2867143933634cee58483364e798ec128fcdf23f (patch)
treea833f88d25ff19864e7bc6c2eeddbc1ef681f566
parent999d8d72204c87682b6cf615df57e42b66a4b157 (diff)
ofctl_v1_2/3: fix SET_FIELD action and some match fields
this patch fixes the following bugs: - "SET_FIELD" action caused an exception at mod_flow_entry command. - following match fields caused an exception at get_flow_stats command: * mpls_label, arp_spa, arp_tpa - following fields in "SET_FIELD" were displayed as classes: * eth_dst, eth_src, vlan_vid, mpls_label - "arp_spa" and "arp_tpa" were not displayed as IPv4 address Signed-off-by: Yuichi Ito <ito.yuichi0@gmail.com> Signed-off-by: FUJITA Tomonori <fujita.tomonori@lab.ntt.co.jp>
-rw-r--r--ryu/lib/ofctl_v1_2.py21
-rw-r--r--ryu/lib/ofctl_v1_3.py22
2 files changed, 37 insertions, 6 deletions
diff --git a/ryu/lib/ofctl_v1_2.py b/ryu/lib/ofctl_v1_2.py
index 2eca8508..273b387c 100644
--- a/ryu/lib/ofctl_v1_2.py
+++ b/ryu/lib/ofctl_v1_2.py
@@ -162,7 +162,7 @@ def action_to_str(act):
buf = 'PUSH_MPLS:' + str(act.ethertype)
elif action_type == ofproto_v1_2.OFPAT_POP_MPLS:
buf = 'POP_MPLS'
- elif action_type == ofproto_v1_2.OFPAT_OFPAT_SET_QUEUE:
+ elif action_type == ofproto_v1_2.OFPAT_SET_QUEUE:
buf = 'SET_QUEUE:' + str(act.queue_id)
elif action_type == ofproto_v1_2.OFPAT_GROUP:
buf = 'GROUP:' + str(act.group_id)
@@ -171,7 +171,17 @@ def action_to_str(act):
elif action_type == ofproto_v1_2.OFPAT_DEC_NW_TTL:
buf = 'DEC_NW_TTL'
elif action_type == ofproto_v1_2.OFPAT_SET_FIELD:
- buf = 'SET_FIELD: {%s:%s}' % (act.field, act.value)
+ if isinstance(act.field, ofproto_v1_2_parser.MTEthDst):
+ field = 'eth_dst'
+ elif isinstance(act.field, ofproto_v1_2_parser.MTEthSrc):
+ field = 'eth_src'
+ elif isinstance(act.field, ofproto_v1_2_parser.MTVlanVid):
+ field = 'vlan_vid'
+ elif isinstance(act.field, ofproto_v1_2_parser.MTMplsLabel):
+ field = 'mpls_label'
+ else:
+ field = '(Unknown field)'
+ buf = 'SET_FIELD: {%s:%s}' % (field, act.value)
else:
buf = 'UNKNOWN'
return buf
@@ -349,6 +359,10 @@ def match_to_str(ofmatch):
ofproto_v1_2.OXM_OF_TCP_DST: 'tp_dst',
ofproto_v1_2.OXM_OF_UDP_SRC: 'tp_src',
ofproto_v1_2.OXM_OF_UDP_DST: 'tp_dst',
+ ofproto_v1_2.OXM_OF_ARP_SPA: 'arp_spa',
+ ofproto_v1_2.OXM_OF_ARP_TPA: 'arp_tpa',
+ ofproto_v1_2.OXM_OF_ARP_SPA_W: 'arp_spa',
+ ofproto_v1_2.OXM_OF_ARP_TPA_W: 'arp_tpa',
ofproto_v1_2.OXM_OF_IPV6_SRC: 'ipv6_src',
ofproto_v1_2.OXM_OF_IPV6_DST: 'ipv6_dst',
ofproto_v1_2.OXM_OF_IPV6_SRC_W: 'ipv6_src',
@@ -359,7 +373,8 @@ def match_to_str(ofmatch):
key = keys[match_field.header]
if key == 'dl_src' or key == 'dl_dst':
value = mac.haddr_to_str(match_field.value)
- elif key == 'nw_src' or key == 'nw_dst':
+ elif key == 'nw_src' or key == 'nw_dst' or \
+ key == 'arp_spa' or key == 'arp_tpa':
value = match_ip_to_str(match_field.value, match_field.mask)
elif key == 'ipv6_src' or key == 'ipv6_dst':
value = match_ipv6_to_str(match_field.value, match_field.mask)
diff --git a/ryu/lib/ofctl_v1_3.py b/ryu/lib/ofctl_v1_3.py
index 4bb6ca24..eb9585b7 100644
--- a/ryu/lib/ofctl_v1_3.py
+++ b/ryu/lib/ofctl_v1_3.py
@@ -170,7 +170,7 @@ def action_to_str(act):
buf = 'PUSH_MPLS:' + str(act.ethertype)
elif action_type == ofproto_v1_3.OFPAT_POP_MPLS:
buf = 'POP_MPLS'
- elif action_type == ofproto_v1_3.OFPAT_OFPAT_SET_QUEUE:
+ elif action_type == ofproto_v1_3.OFPAT_SET_QUEUE:
buf = 'SET_QUEUE:' + str(act.queue_id)
elif action_type == ofproto_v1_3.OFPAT_GROUP:
pass
@@ -179,7 +179,17 @@ def action_to_str(act):
elif action_type == ofproto_v1_3.OFPAT_DEC_NW_TTL:
buf = 'DEC_NW_TTL'
elif action_type == ofproto_v1_3.OFPAT_SET_FIELD:
- buf = 'SET_FIELD: {%s:%s}' % (act.field, act.value)
+ if isinstance(act.field, ofproto_v1_3_parser.MTEthDst):
+ field = 'eth_dst'
+ elif isinstance(act.field, ofproto_v1_3_parser.MTEthSrc):
+ field = 'eth_src'
+ elif isinstance(act.field, ofproto_v1_3_parser.MTVlanVid):
+ field = 'vlan_vid'
+ elif isinstance(act.field, ofproto_v1_3_parser.MTMplsLabel):
+ field = 'mpls_label'
+ else:
+ field = '(Unknown field)'
+ buf = 'SET_FIELD: {%s:%s}' % (field, act.value)
elif action_type == ofproto_v1_3.OFPAT_PUSH_PBB:
buf = 'PUSH_PBB:' + str(act.ethertype)
elif action_type == ofproto_v1_3.OFPAT_POP_PBB:
@@ -383,8 +393,13 @@ def match_to_str(ofmatch):
ofproto_v1_3.OXM_OF_TCP_DST: 'tp_dst',
ofproto_v1_3.OXM_OF_UDP_SRC: 'tp_src',
ofproto_v1_3.OXM_OF_UDP_DST: 'tp_dst',
+ ofproto_v1_3.OXM_OF_MPLS_LABEL: 'mpls_label',
ofproto_v1_3.OXM_OF_METADATA: 'metadata',
ofproto_v1_3.OXM_OF_METADATA_W: 'metadata',
+ ofproto_v1_3.OXM_OF_ARP_SPA: 'arp_spa',
+ ofproto_v1_3.OXM_OF_ARP_TPA: 'arp_tpa',
+ ofproto_v1_3.OXM_OF_ARP_SPA_W: 'arp_spa',
+ ofproto_v1_3.OXM_OF_ARP_TPA_W: 'arp_tpa',
ofproto_v1_3.OXM_OF_IPV6_SRC: 'ipv6_src',
ofproto_v1_3.OXM_OF_IPV6_DST: 'ipv6_dst',
ofproto_v1_3.OXM_OF_IPV6_SRC_W: 'ipv6_src',
@@ -395,7 +410,8 @@ def match_to_str(ofmatch):
key = keys[match_field.header]
if key == 'dl_src' or key == 'dl_dst':
value = mac.haddr_to_str(match_field.value)
- elif key == 'nw_src' or key == 'nw_dst':
+ elif key == 'nw_src' or key == 'nw_dst' or \
+ key == 'arp_spa' or key == 'arp_tpa':
value = match_ip_to_str(match_field.value, match_field.mask)
elif key == 'ipv6_src' or key == 'ipv6_dst':
value = match_ipv6_to_str(match_field.value, match_field.mask)