summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorSimon Horman <horms@verge.net.au>2012-03-13 09:06:20 +0900
committerFUJITA Tomonori <fujita.tomonori@lab.ntt.co.jp>2012-03-13 21:41:34 -0700
commit07b1afbcfafa01f1e95abea0e0874551eda483d8 (patch)
treed6e90b6706c59cc125b156d70c7d52af4c545c6b
parent3d780e2ce8e18792572c0a0c4fa2be36e1f50024 (diff)
NXM: Add MFIPDSCP and MFIPECN classes
This is to handle IP_DSCP and IP_ECN NXM fields respectively. This will be used when sending NXT_FLOW_MOD messages. Signed-off-by: Simon Horman <horms@verge.net.au> Signed-off-by: FUJITA Tomonori <fujita.tomonori@lab.ntt.co.jp>
-rw-r--r--ryu/ofproto/nx_match.py49
-rw-r--r--ryu/ofproto/ofproto_v1_0.py4
2 files changed, 52 insertions, 1 deletions
diff --git a/ryu/ofproto/nx_match.py b/ryu/ofproto/nx_match.py
index cb402f1e..48f731ec 100644
--- a/ryu/ofproto/nx_match.py
+++ b/ryu/ofproto/nx_match.py
@@ -33,6 +33,8 @@ FWW_DL_DST = 1 << 3
FWW_DL_TYPE = 1 << 4
# No corresponding OFPFW_* bits
FWW_ETH_MCAST = 1 << 1
+FWW_NW_DSCP = 1 << 6
+FWW_NW_ECN = 1 << 7
FWW_ALL = (1 << 13) - 1
# Ethernet types, for set_dl_type()
@@ -42,9 +44,12 @@ ETH_TYPE_VLAN = 0x8100
ETH_TYPE_IPV6 = 0x86dd
ETH_TYPE_LACP = 0x8809
+IP_ECN_MASK = 0x03
+IP_DSCP_MASK = 0xfc
MF_PACK_STRING_BE64 = '!Q'
MF_PACK_STRING_BE16 = '!H'
+MF_PACK_STRING_8 = '!B'
MF_PACK_STRING_MAC = '!6s'
_MF_FIELDS = {}
@@ -126,6 +131,11 @@ class ClsRule(object):
self.wc.wildcards &= ~FWW_DL_TYPE
self.flow.dl_type = dl_type
+ def set_nw_dscp(self, nw_dscp):
+ self.wc.wildcards &= ~FWW_NW_DSCP
+ self.flow.nw_tos &= ~IP_DSCP_MASK
+ self.flow.nw_tos |= nw_dscp & IP_DSCP_MASK
+
def set_tun_id(self, tun_id):
self.set_tun_id_masked(tun_id, UINT64_MAX)
@@ -133,6 +143,11 @@ class ClsRule(object):
self.wc.tun_id_mask = mask
self.flow.tun_id = tun_id & mask
+ def set_nw_ecn(self, nw_ecn):
+ self.wc.wildcards &= ~FWW_NW_ECN
+ self.flow.nw_tos &= ~IP_ECN_MASK
+ self.flow.nw_tos |= nw_ecn & IP_ECN_MASK
+
def _set_nxm_headers(nxm_headers):
'''Annotate corresponding NXM header'''
@@ -239,6 +254,18 @@ class MFEthType(MFField):
@_register_make
+@_set_nxm_headers([ofproto_v1_0.NXM_OF_IP_TOS])
+class MFIPDSCP(MFField):
+ @classmethod
+ def make(cls):
+ return cls(MF_PACK_STRING_8)
+
+ def put(self, buf, offset, rule):
+ return self._put(buf, offset,
+ rule.flow.nw_tos & IP_DSCP_MASK)
+
+
+@_register_make
@_set_nxm_headers([ofproto_v1_0.NXM_NX_TUN_ID, ofproto_v1_0.NXM_NX_TUN_ID_W])
class MFTunId(MFField):
@classmethod
@@ -249,6 +276,18 @@ class MFTunId(MFField):
return self.putm(buf, offset, rule.flow.tun_id, rule.wc.tun_id_mask)
+@_register_make
+@_set_nxm_headers([ofproto_v1_0.NXM_NX_IP_ECN])
+class MFIPECN(MFField):
+ @classmethod
+ def make(cls):
+ return cls(MF_PACK_STRING_8)
+
+ def put(self, buf, offset, rule):
+ return self._put(buf, offset,
+ rule.flow.nw_tos & IP_ECN_MASK)
+
+
def serialize_nxm_match(rule, buf, offset):
old_offset = offset
@@ -263,7 +302,15 @@ def serialize_nxm_match(rule, buf, offset):
offset += nxm_put(buf, offset, ofproto_v1_0.NXM_OF_ETH_TYPE, rule)
# XXX: 802.1Q
- # XXX: L3
+
+ # L3
+ if not rule.wc.wildcards & FWW_NW_DSCP:
+ offset += nxm_put(buf, offset, ofproto_v1_0.NXM_OF_IP_TOS, rule)
+ if not rule.wc.wildcards & FWW_NW_ECN:
+ offset += nxm_put(buf, offset, ofproto_v1_0.NXM_NX_IP_ECN, rule)
+ # XXX: IP Source and Destination
+ # XXX: IPv6
+ # XXX: ARP
# Tunnel Id
if rule.wc.tun_id_mask != 0:
diff --git a/ryu/ofproto/ofproto_v1_0.py b/ryu/ofproto/ofproto_v1_0.py
index ad051d56..7e97005f 100644
--- a/ryu/ofproto/ofproto_v1_0.py
+++ b/ryu/ofproto/ofproto_v1_0.py
@@ -522,7 +522,11 @@ NXM_OF_ETH_DST_W = nxm_header_w(0x0000, 1, 6)
NXM_OF_ETH_SRC = nxm_header(0x0000, 2, 6)
NXM_OF_ETH_TYPE = nxm_header(0x0000, 3, 2)
+NXM_OF_IP_TOS = nxm_header(0x0000, 5, 1)
+
NXM_NX_TUN_ID = nxm_header(0x0001, 16, 8)
NXM_NX_TUN_ID_W = nxm_header_w(0x0001, 16, 8)
+NXM_NX_IP_ECN = nxm_header(0x0001, 28, 1)
+
NXM_HEADER_PACK_STRING = '!I'