Fix: undefined operation on last_relay_viewer_session_id
authorMathieu Desnoyers <mathieu.desnoyers@efficios.com>
Tue, 2 Dec 2014 22:21:11 +0000 (17:21 -0500)
committerJérémie Galarneau <jeremie.galarneau@efficios.com>
Mon, 12 Jan 2015 17:00:13 +0000 (12:00 -0500)
Triggers compiler warning on 32-bit build.

Signed-off-by: Mathieu Desnoyers <mathieu.desnoyers@efficios.com>
Signed-off-by: Jérémie Galarneau <jeremie.galarneau@efficios.com>
src/bin/lttng-relayd/live.c

index f86670e9c618de16958d4e49bf41d2995026f70f..81b90939c9e713570ef34670ce3524d3cd9c8bc1 100644 (file)
@@ -732,7 +732,12 @@ int viewer_connect(struct relay_connection *conn)
        reply.major = htobe32(reply.major);
        reply.minor = htobe32(reply.minor);
        if (conn->type == RELAY_VIEWER_COMMAND) {
-               reply.viewer_session_id = htobe64(++last_relay_viewer_session_id);
+               /*
+                * Increment outside of htobe64 macro, because can be used more than once
+                * within the macro, and thus the operation may be undefined.
+                */
+               last_relay_viewer_session_id++;
+               reply.viewer_session_id = htobe64(last_relay_viewer_session_id);
        }
 
        health_code_update();
This page took 0.026571 seconds and 4 git commands to generate.