OFPErrorMsg.data usually contains the offending OpenFlow message,
but is an ASCII text string if its type is OFPET_HELLO_FAILED.

Signed-off-by: IWAMOTO Toshihiro <[email protected]>
---
 ryu/controller/ofp_handler.py | 5 ++++-
 1 file changed, 4 insertions(+), 1 deletion(-)

diff --git a/ryu/controller/ofp_handler.py b/ryu/controller/ofp_handler.py
index b524a28..70ffc8c 100644
--- a/ryu/controller/ofp_handler.py
+++ b/ryu/controller/ofp_handler.py
@@ -280,7 +280,10 @@ class OFPHandler(ryu.base.app_manager.RyuApp):
             hex(msg.type), hex(msg.code), utils.binary_str(msg.data),
             ofp.ofp_error_type_to_str(msg.type),
             ofp.ofp_error_code_to_str(msg.type, msg.code))
-        if len(msg.data) >= ofp.OFP_HEADER_SIZE:
+        if msg.type == ofp.OFPET_HELLO_FAILED:
+            self.logger.debug(
+                " `-- data: %s", msg.data.decode('ascii'))
+        elif len(msg.data) >= ofp.OFP_HEADER_SIZE:
             (version, msg_type, msg_len, xid) = ofproto_parser.header(msg.data)
             self.logger.debug(
                 " `-- data: version=%s, msg_type=%s, msg_len=%s, xid=%s\n"
-- 
2.1.4


------------------------------------------------------------------------------
Check out the vibrant tech community on one of the world's most 
engaging tech sites, SlashDot.org! http://sdm.link/slashdot
_______________________________________________
Ryu-devel mailing list
[email protected]
https://lists.sourceforge.net/lists/listinfo/ryu-devel

Reply via email to