[ovs-dev] [PATCH 62/63] ovs-ofpctl: Enable queue-stats for Open Flow 1.1 & 1.2

Simon Horman horms at verge.net.au
Wed Jun 27 08:20:38 UTC 2012


Signed-off-by: Simon Horman <horms at verge.net.au>

---

v5
* Initial Post
---
 utilities/ovs-ofctl.c | 41 ++++++++++++++++++++++++++++++++---------
 1 file changed, 32 insertions(+), 9 deletions(-)

diff --git a/utilities/ovs-ofctl.c b/utilities/ovs-ofctl.c
index 252d94f..f26356e 100644
--- a/utilities/ovs-ofctl.c
+++ b/utilities/ovs-ofctl.c
@@ -804,27 +804,50 @@ do_dump_aggregate(int argc, char *argv[])
 static void
 do_queue_stats(int argc, char *argv[])
 {
-    struct ofp10_queue_stats_request *req;
     struct ofpbuf *request;
     struct vconn *vconn;
+    uint16_t port_no;
+    uint16_t queue_id;
 
     open_vconn(argv[1], &vconn);
 
-    req = ofputil_make_stats_request(sizeof *req, OFP10_VERSION,
-                                     OFPST_QUEUE, 0, &request);
-
     if (argc > 2 && argv[2][0] && strcasecmp(argv[2], "all")) {
-        req->port_no = htons(str_to_port_no(vconn, argv[2]));
+        port_no = str_to_port_no(vconn, argv[2]);
     } else {
-        req->port_no = htons(OFPP_ALL);
+        port_no = OFPP_ALL;
     }
     if (argc > 3 && argv[3][0] && strcasecmp(argv[3], "all")) {
-        req->queue_id = htonl(atoi(argv[3]));
+        queue_id = atoi(argv[3]);
     } else {
-        req->queue_id = htonl(OFPQ_ALL);
+        queue_id = OFPQ_ALL;
+    }
+
+    switch (vconn_get_version(vconn)) {
+    case OFP12_VERSION:
+    case OFP11_VERSION: {
+        struct ofp11_queue_stats_request *req;
+
+        req = ofputil_make_stats_request(sizeof *req, vconn_get_version(vconn),
+                                         OFPST_QUEUE, 0, &request);
+        req->port_no = ofputil_port_to_ofp11(port_no);
+        req->queue_id = htonl(queue_id);
+        break;
     }
 
-    memset(req->pad, 0, sizeof req->pad);
+    case OFP10_VERSION: {
+        struct ofp10_queue_stats_request *req;
+
+        req = ofputil_make_stats_request(sizeof *req, vconn_get_version(vconn),
+                                         OFPST_QUEUE, 0, &request);
+        req->port_no = htons(port_no);
+        memset(req->pad, 0, sizeof req->pad);
+        req->queue_id = htonl(queue_id);
+        break;
+    }
+
+    default:
+        NOT_REACHED();
+    }
 
     dump_stats_transaction(vconn, request);
     vconn_close(vconn);
-- 
1.7.10.2.484.gcd07cc5




More information about the dev mailing list