Add ustcomm_trace_info struct and support functions to ustcomm
[ust.git] / libustcomm / ustcomm.c
index 2c547abeb0039d7627da808a23e52df565a34148..7d0fe000155525669e28afaff4931d2597c2ecc8 100644 (file)
@@ -621,6 +621,38 @@ char * ustcomm_restore_ptr(char *ptr, char *data_field, int data_field_size)
        return data_field + (long)ptr;
 }
 
+int ustcomm_pack_trace_info(struct ustcomm_header *header,
+                           struct ustcomm_trace_info *trace_inf,
+                           const char *trace)
+{
+       int offset = 0;
+
+       trace_inf->trace = ustcomm_print_data(trace_inf->data,
+                                             sizeof(trace_inf->data),
+                                             &offset,
+                                             trace);
+
+       if (trace_inf->trace == USTCOMM_POISON_PTR) {
+               return -ENOMEM;
+       }
+
+       header->size = COMPUTE_MSG_SIZE(trace_inf, offset);
+
+       return 0;
+}
+
+
+int ustcomm_unpack_trace_info(struct ustcomm_trace_info *trace_inf)
+{
+       trace_inf->trace = ustcomm_restore_ptr(trace_inf->trace,
+                                              trace_inf->data,
+                                              sizeof(trace_inf->data));
+       if (!trace_inf->trace) {
+               return -EINVAL;
+       }
+
+       return 0;
+}
 
 int ustcomm_pack_channel_info(struct ustcomm_header *header,
                              struct ustcomm_channel_info *ch_inf,
@@ -775,52 +807,3 @@ int ustcomm_unpack_sock_path(struct ustcomm_sock_path *sock_path_inf)
        return 0;
 }
 
-int ustcomm_send_ch_req(int sock, char *channel, int command,
-                       struct ustcomm_header *recv_header,
-                       char *recv_data)
-{
-       struct ustcomm_header send_header;
-       struct ustcomm_channel_info ch_info;
-       int result;
-
-       result = ustcomm_pack_channel_info(&send_header,
-                                          &ch_info,
-                                          channel);
-       if (result < 0) {
-               return result;
-       }
-
-       send_header.command = command;
-
-       return ustcomm_req(sock,
-                          &send_header,
-                          (char *)&ch_info,
-                          recv_header,
-                          recv_data);
-}
-
-int ustcomm_send_buf_req(int sock, char *channel, int ch_cpu,
-                        int command,
-                        struct ustcomm_header *recv_header,
-                        char *recv_data)
-{
-       struct ustcomm_header send_header;
-       struct ustcomm_buffer_info buf_info;
-       int result;
-
-       result = ustcomm_pack_buffer_info(&send_header,
-                                         &buf_info,
-                                         channel,
-                                         ch_cpu);
-       if (result < 0) {
-               return result;
-       }
-
-       send_header.command = command;
-
-       return ustcomm_req(sock,
-                          &send_header,
-                          (char *)&buf_info,
-                          recv_header,
-                          recv_data);
-}
This page took 0.023727 seconds and 4 git commands to generate.