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 16:59:52 +0000 (11:59 -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 2af71c18dfbf1a93b1997a1b1b546481a063eaa0..b1d8591fe80bc5efcef02767c142faa7797545b7 100644 (file)
@@ -733,7 +733,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.026793 seconds and 4 git commands to generate.