summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
-rw-r--r--ryu/lib/ofctl_v1_4.py73
1 files changed, 55 insertions, 18 deletions
diff --git a/ryu/lib/ofctl_v1_4.py b/ryu/lib/ofctl_v1_4.py
index fc339819..060562b0 100644
--- a/ryu/lib/ofctl_v1_4.py
+++ b/ryu/lib/ofctl_v1_4.py
@@ -242,10 +242,18 @@ def get_desc_stats(dp, waiters):
return desc
-def get_queue_stats(dp, waiters):
- ofp = dp.ofproto
- stats = dp.ofproto_parser.OFPQueueStatsRequest(dp, 0, ofp.OFPP_ANY,
- ofp.OFPQ_ALL)
+def get_queue_stats(dp, waiters, port_no=None, queue_id=None):
+ if port_no is None:
+ port_no = dp.ofproto.OFPP_ANY
+ else:
+ port_no = UTIL.ofp_port_from_user(port_no)
+ if queue_id is None:
+ queue_id = dp.ofproto.OFPQ_ALL
+ else:
+ queue_id = UTIL.ofp_queue_from_user(queue_id)
+
+ stats = dp.ofproto_parser.OFPQueueStatsRequest(
+ dp, 0, port_no, queue_id)
msgs = []
ofctl_utils.send_stats_request(dp, stats, waiters, msgs, LOG)
@@ -267,9 +275,14 @@ def get_queue_stats(dp, waiters):
def get_queue_desc_stats(dp, waiters, port_no=None, queue_id=None):
- ofp = dp.ofproto
- port_no = port_no if port_no else ofp.OFPP_ANY
- queue_id = queue_id if queue_id else ofp.OFPQ_ALL
+ if port_no is None:
+ port_no = dp.ofproto.OFPP_ANY
+ else:
+ port_no = UTIL.ofp_port_from_user(port_no)
+ if queue_id is None:
+ queue_id = dp.ofproto.OFPQ_ALL
+ else:
+ queue_id = UTIL.ofp_queue_from_user(queue_id)
stats = dp.ofproto_parser.OFPQueueDescStatsRequest(
dp, 0, port_no, queue_id)
@@ -444,9 +457,13 @@ def get_table_features(dp, waiters):
return desc
-def get_port_stats(dp, waiters):
- stats = dp.ofproto_parser.OFPPortStatsRequest(
- dp, 0, dp.ofproto.OFPP_ANY)
+def get_port_stats(dp, waiters, port_no=None):
+ if port_no is None:
+ port_no = dp.ofproto.OFPP_ANY
+ else:
+ port_no = UTIL.ofp_port_from_user(port_no)
+
+ stats = dp.ofproto_parser.OFPPortStatsRequest(dp, 0, port_no)
msgs = []
ofctl_utils.send_stats_request(dp, stats, waiters, msgs, LOG)
@@ -466,9 +483,14 @@ def get_port_stats(dp, waiters):
return ports
-def get_meter_stats(dp, waiters):
+def get_meter_stats(dp, waiters, meter_id=None):
+ if meter_id is None:
+ meter_id = dp.ofproto.OFPM_ALL
+ else:
+ meter_id = UTIL.ofp_meter_from_user(meter_id)
+
stats = dp.ofproto_parser.OFPMeterStatsRequest(
- dp, 0, dp.ofproto.OFPM_ALL)
+ dp, 0, meter_id)
msgs = []
ofctl_utils.send_stats_request(dp, stats, waiters, msgs, LOG)
@@ -521,14 +543,19 @@ def get_meter_features(dp, waiters):
return features
-def get_meter_config(dp, waiters):
+def get_meter_config(dp, waiters, meter_id=None):
flags = {dp.ofproto.OFPMF_KBPS: 'KBPS',
dp.ofproto.OFPMF_PKTPS: 'PKTPS',
dp.ofproto.OFPMF_BURST: 'BURST',
dp.ofproto.OFPMF_STATS: 'STATS'}
+ if meter_id is None:
+ meter_id = dp.ofproto.OFPM_ALL
+ else:
+ meter_id = UTIL.ofp_meter_from_user(meter_id)
+
stats = dp.ofproto_parser.OFPMeterConfigStatsRequest(
- dp, 0, dp.ofproto.OFPM_ALL)
+ dp, 0, meter_id)
msgs = []
ofctl_utils.send_stats_request(dp, stats, waiters, msgs, LOG)
@@ -553,9 +580,14 @@ def get_meter_config(dp, waiters):
return configs
-def get_group_stats(dp, waiters):
+def get_group_stats(dp, waiters, group_id=None):
+ if group_id is None:
+ group_id = dp.ofproto.OFPG_ALL
+ else:
+ group_id = UTIL.ofp_group_from_user(group_id)
+
stats = dp.ofproto_parser.OFPGroupStatsRequest(
- dp, 0, dp.ofproto.OFPG_ALL)
+ dp, 0, group_id)
msgs = []
ofctl_utils.send_stats_request(dp, stats, waiters, msgs, LOG)
@@ -662,8 +694,13 @@ def get_group_desc(dp, waiters):
return descs
-def get_port_desc(dp, waiters):
- stats = dp.ofproto_parser.OFPPortDescStatsRequest(dp, 0)
+def get_port_desc(dp, waiters, port_no=None):
+ if port_no is None:
+ port_no = dp.ofproto.OFPP_ANY
+ else:
+ port_no = UTIL.ofp_port_from_user(port_no)
+
+ stats = dp.ofproto_parser.OFPPortDescStatsRequest(dp, 0, port_no)
msgs = []
ofctl_utils.send_stats_request(dp, stats, waiters, msgs, LOG)