examples: disable the message on the server example, measure the notify latency on...
authorFelix Fietkau <nbd@openwrt.org>
Sat, 15 Dec 2012 15:52:03 +0000 (16:52 +0100)
committerFelix Fietkau <nbd@openwrt.org>
Sat, 15 Dec 2012 15:52:03 +0000 (16:52 +0100)
Signed-off-by: Felix Fietkau <nbd@openwrt.org>
examples/client.c
examples/server.c

index 75c61a4255eb3372aca0fa93623e1f4ba959cc82..32ff9d3a174ec0dc1d774faa947cdcdc114f3fa2 100644 (file)
@@ -11,6 +11,7 @@
  * GNU General Public License for more details.
  */
 
+#include <sys/time.h>
 #include <unistd.h>
 
 #include "libubus.h"
@@ -31,14 +32,24 @@ static void test_client_notify_cb(struct uloop_timeout *timeout)
 {
        static int counter = 0;
        int err;
+       struct timeval tv1, tv2;
+       int max = 1000;
+       long delta;
+       int i = 0;
 
        blob_buf_init(&b, 0);
        blobmsg_add_u32(&b, "counter", counter++);
 
-       err = ubus_notify(ctx, &test_client_object, "ping", b.head, 1000);
+       gettimeofday(&tv1, NULL);
+       for (i = 0; i < max; i++)
+               err = ubus_notify(ctx, &test_client_object, "ping", b.head, 1000);
+       gettimeofday(&tv2, NULL);
        if (err)
                fprintf(stderr, "Notify failed: %s\n", ubus_strerror(err));
 
+       delta = (tv2.tv_sec - tv1.tv_sec) * 1000000 + (tv2.tv_usec - tv1.tv_usec);
+       fprintf(stderr, "Avg time per iteration: %ld usec\n", delta / max);
+
        uloop_timeout_set(timeout, 1000);
 }
 
index c5af1aa32f346cdf0e24d279cdf18a31c8fcf986..230048acaa3c6e9fb89696298f245775715e819b 100644 (file)
@@ -94,11 +94,13 @@ test_notify(struct ubus_context *ctx, struct ubus_object *obj,
            struct ubus_request_data *req, const char *method,
            struct blob_attr *msg)
 {
+#if 0
        char *str;
 
        str = blobmsg_format_json(msg, true);
        fprintf(stderr, "Received notification '%s': %s\n", method, str);
        free(str);
+#endif
 
        return 0;
 }