Signed-off-by: FUJITA Tomonori <[email protected]>
---
ryu/ofproto/ofproto_v1_0.py | 9 +++++++++
ryu/ofproto/ofproto_v1_0_parser.py | 36 ++++++++++++++++++++++++++++++++++++
2 files changed, 45 insertions(+), 0 deletions(-)
diff --git a/ryu/ofproto/ofproto_v1_0.py b/ryu/ofproto/ofproto_v1_0.py
index 3052664..90bfdf4 100644
--- a/ryu/ofproto/ofproto_v1_0.py
+++ b/ryu/ofproto/ofproto_v1_0.py
@@ -238,6 +238,7 @@ NXAST_REG_MOVE = 6
NXAST_REG_LOAD = 7
NXAST_SET_TUNNEL64 = 9
NXAST_MULTIPATH = 10
+NXAST_BUNDLE_LOAD = 13
NXAST_RESUBMIT_TABLE = 14
NX_ACTION_RESUBMIT_PACK_STR = '!HHIHHB3x'
@@ -264,6 +265,10 @@ NX_ACTION_MULTIPATH_PACK_STR = '!HHIHHH2xHHI2xHI'
NX_ACTION_MULTIPATH_SIZE = 32
assert calcsize(NX_ACTION_MULTIPATH_PACK_STR) == NX_ACTION_MULTIPATH_SIZE
+NX_ACTION_BUNDLE_LOAD_PACK_STR = '!HHIHHHHIHHI4x'
+NX_ACTION_BUNDLE_LOAD_SIZE = 32
+assert calcsize(NX_ACTION_BUNDLE_LOAD_PACK_STR) == NX_ACTION_BUNDLE_LOAD_SIZE
+
NX_ACTION_HEADER_PACK_STR = '!HHIH'
NX_ACTION_HEADER_SIZE = 10
assert calcsize(NX_ACTION_HEADER_PACK_STR) == NX_ACTION_HEADER_SIZE
@@ -634,3 +639,7 @@ NX_MP_ALG_MODULO_N = 0
NX_MP_ALG_HASH_THRESHOLD = 1
NX_MP_ALG_HRW = 2
NX_MP_ALG_ITER_HASH = 3
+
+# enum nx_bd_algorithm
+NX_BD_ALG_ACTIVE_BACKUP = 0
+NX_BD_ALG_HRW = 1
diff --git a/ryu/ofproto/ofproto_v1_0_parser.py
b/ryu/ofproto/ofproto_v1_0_parser.py
index 60ffd14..651275c 100644
--- a/ryu/ofproto/ofproto_v1_0_parser.py
+++ b/ryu/ofproto/ofproto_v1_0_parser.py
@@ -580,6 +580,42 @@ class NXActionMultipath(NXActionHeader):
dst)
[email protected]_nx_action_subtype(ofproto_v1_0.NXAST_BUNDLE_LOAD)
+class NXActionBundleLoad(NXActionHeader):
+ def __init__(self, algorithm, fields, basis, slave_type, n_slaves,
+ ofs_nbits, dst, slaves):
+ super(NXActionBundleLoad, self).__init__(
+ ofproto_v1_0.NXAST_BUNDLE_LOAD,
+ ofproto_v1_0.NX_ACTION_BUNDLE_LOAD_SIZE)
+ self.algorithm = algorithm
+ self.fields = fields
+ self.basis = basis
+ self.slave_type = slave_type
+ self.n_slaves = n_slaves
+ self.ofs_nbits = ofs_nbits
+ self.dst = dst
+ self.slaves = slaves
+
+ def serialize(self, buf, offset):
+ slave_offset = offset + ofproto_v1_0.NX_ACTION_BUNDLE_LOAD_SIZE
+
+ for s in self.slaves:
+ msg_pack_into('!H', buf, slave_offset, s)
+ slave_offset += 2
+ self.len += 2
+
+ pad_len = self.len % 8
+ if pad_len != 0:
+ self.len += pad_len
+ msg_pack_into('%dx' % pad_len, buf, slave_offset)
+
+ msg_pack_into(ofproto_v1_0.NX_ACTION_BUNDLE_LOAD_PACK_STR, buf,
+ offset, self.type, self.len, self.vendor, self.subtype,
+ self.algorithm, self.fields, self.basis,
+ self.slave_type, self.n_slaves,
+ self.ofs_nbits, self.dst)
+
+
class OFPDescStats(collections.namedtuple('OFPDescStats',
('mfr_desc', 'hw_desc', 'sw_desc', 'serial_num', 'dp_desc'))):
@classmethod
--
1.7.4.4
------------------------------------------------------------------------------
Live Security Virtual Conference
Exclusive live event will cover all the ways today's security and
threat landscape has changed and how IT managers can respond. Discussions
will include endpoint security, mobile security and the latest in malware
threats. http://www.accelacomm.com/jaw/sfrnl04242012/114/50122263/
_______________________________________________
Ryu-devel mailing list
[email protected]
https://lists.sourceforge.net/lists/listinfo/ryu-devel