Fix I/O-related error values in ustctl
authorMathieu Desnoyers <mathieu.desnoyers@efficios.com>
Mon, 21 Jan 2013 15:56:33 +0000 (10:56 -0500)
committerMathieu Desnoyers <mathieu.desnoyers@efficios.com>
Mon, 21 Jan 2013 15:56:33 +0000 (10:56 -0500)
These internal ustctl API members document >=0 as OK values. Make sure
reply recv errors are returned as errors.

Clarify ustctl_create_stream() error values.

Signed-off-by: Mathieu Desnoyers <mathieu.desnoyers@efficios.com>
Acked-by: David Goulet <dgoulet@efficios.com>
include/lttng/ust-ctl.h
liblttng-ust-comm/lttng-ust-comm.c

index c2b255cd6cb6032cc113799754dc2a0b6f1085e7..11beabaadc63912f45774116c673a4f591fd82e0 100644 (file)
@@ -23,7 +23,7 @@
 
 /*
  * Error values: all the following functions return:
- * >= 0: Sucess (LTTNG_UST_OK)
+ * >= 0: Success (LTTNG_UST_OK)
  * < 0: error code.
  */
 int ustctl_register_done(int sock);
@@ -34,8 +34,6 @@ int ustctl_open_metadata(int sock, int session_handle,
 int ustctl_create_channel(int sock, int session_handle,
                struct lttng_ust_channel_attr *chops,
                struct lttng_ust_object_data **channel_data);
-int ustctl_create_stream(int sock, struct lttng_ust_object_data *channel_data,
-               struct lttng_ust_object_data **stream_data);
 int ustctl_create_event(int sock, struct lttng_ust_event *ev,
                struct lttng_ust_object_data *channel_data,
                struct lttng_ust_object_data **event_data);
@@ -50,6 +48,15 @@ int ustctl_disable(int sock, struct lttng_ust_object_data *object);
 int ustctl_start_session(int sock, int handle);
 int ustctl_stop_session(int sock, int handle);
 
+/*
+ * Return -ENOENT if no more stream is available for creation.
+ * Return 0 on success.
+ * Return negative error value on system error.
+ * Return positive error value on UST error.
+ */
+int ustctl_create_stream(int sock, struct lttng_ust_object_data *channel_data,
+               struct lttng_ust_object_data **stream_data);
+
 /*
  * ustctl_tracepoint_list returns a tracepoint list handle, or negative
  * error value.
index 9a67ea19ea7aef43d80e4558dfeeae4162b42616..db9910ded9c3fcf2a660fa77c5a35851df07fdc8 100644 (file)
@@ -435,7 +435,10 @@ int ustcomm_send_app_cmd(int sock,
        ret = ustcomm_send_app_msg(sock, lum);
        if (ret)
                return ret;
-       return ustcomm_recv_app_reply(sock, lur, lum->handle, lum->cmd);
+       ret = ustcomm_recv_app_reply(sock, lur, lum->handle, lum->cmd);
+       if (ret > 0)
+               return -EIO;
+       return ret;
 }
 
 /*
This page took 0.026906 seconds and 4 git commands to generate.