This patch changes libustctl to be socket instead of pid oriented.
The user is expected to connect to a pid using
ustctl_connect_pid(pid_t) which returns a socket file-descriptor and
then use the socket for the rest of the api. This reduces the amount
of open and closing systemcalls and also makes it possible for a
session daemon to detect process shutdown by the socket closing.
David, this ones for you. :-)
Signed-off-by: Nils Carlson <nils.carlson@ericsson.com>
Acked-by: Mathieu Desnoyers <mathieu.desnoyers@efficios.com>
};
extern pid_t *ustctl_get_online_pids(void);
-extern int ustctl_set_marker_state(const char *trace, const char *channel,
- const char *marker, int state, pid_t pid);
-extern int ustctl_set_subbuf_size(const char *trace, const char *channel,
- unsigned int subbuf_size, pid_t pid);
-extern int ustctl_set_subbuf_num(const char *trace, const char *channel,
- unsigned int num, pid_t pid);
-extern int ustctl_get_subbuf_size(const char *trace, const char *channel,
- pid_t pid);
-extern int ustctl_get_subbuf_num(const char *trace, const char *channel,
- pid_t pid);
-extern int ustctl_destroy_trace(const char *trace, pid_t pid);
-extern int ustctl_setup_and_start(const char *trace, pid_t pid);
-extern int ustctl_stop_trace(const char *trace, pid_t pid);
-extern int ustctl_create_trace(const char *trace, pid_t pid);
-extern int ustctl_start_trace(const char *trace, pid_t pid);
-extern int ustctl_alloc_trace(const char *trace, pid_t pid);
+
+extern int ustctl_connect_pid(pid_t pid);
+
+extern int ustctl_set_marker_state(int sock, const char *trace,
+ const char *channel, const char *marker,
+ int state);
+
+extern int ustctl_set_subbuf_size(int sock, const char *trace,
+ const char *channel,
+ unsigned int subbuf_size);
+
+extern int ustctl_set_subbuf_num(int sock, const char *trace,
+ const char *channel,
+ unsigned int num);
+
+extern int ustctl_get_subbuf_size(int sock, const char *trace,
+ const char *channel);
+
+extern int ustctl_get_subbuf_num(pid_t pid, const char *trace,
+ const char *channel);
+
+extern int ustctl_destroy_trace(int sock, const char *trace);
+
+extern int ustctl_setup_and_start(int sock, const char *trace);
+
+extern int ustctl_stop_trace(int sock, const char *trace);
+
+extern int ustctl_create_trace(int sock, const char *trace);
+
+extern int ustctl_start_trace(int sock, const char *trace);
+
+extern int ustctl_alloc_trace(int sock, const char *trace);
+
extern int ustctl_free_cmsf(struct marker_status *);
-extern unsigned int ustctl_count_nl(const char *);
-extern int ustctl_get_cmsf(struct marker_status **, pid_t);
extern int ustctl_free_tes(struct trace_event_status *);
-extern int ustctl_get_tes(struct trace_event_status **, pid_t);
-extern int ustctl_set_sock_path(const char *sock_path, pid_t pid);
-extern int ustctl_get_sock_path(char **sock_path, pid_t pid);
-extern int ustctl_force_switch(pid_t pid);
+extern unsigned int ustctl_count_nl(const char *);
+
+extern int ustctl_get_cmsf(int sock, struct marker_status **);
+
+extern int ustctl_get_tes(int sock, struct trace_event_status **);
+
+extern int ustctl_set_sock_path(int sock, const char *sock_path);
+
+extern int ustctl_get_sock_path(int sock, char **sock_path);
+
+extern int ustctl_force_switch(int sock, const char *trace);
#endif /* _USTCTL_H */
/* Copyright (C) 2009 Pierre-Marc Fournier, Philippe Proulx-Barrette
+ * Copyright (C) 2011 Ericsson AB
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
#include "ust/ustctl.h"
#include "usterr.h"
-static int do_cmd(const pid_t pid,
+static int do_cmd(int sock,
const struct ustcomm_header *req_header,
const char *req_data,
struct ustcomm_header *res_header,
char **res_data)
{
- int app_fd, result, saved_errno = 0;
+ int result, saved_errno = 0;
char *recv_buf;
- if (ustcomm_connect_app(pid, &app_fd)) {
- ERR("could not connect to PID %u", (unsigned int) pid);
- errno = ENOTCONN;
- return -1;
- }
-
recv_buf = zmalloc(USTCOMM_BUFFER_SIZE);
if (!recv_buf) {
saved_errno = ENOMEM;
- goto close_app_fd;
+ goto out;
}
- result = ustcomm_req(app_fd, req_header, req_data, res_header, recv_buf);
+ result = ustcomm_req(sock, req_header, req_data, res_header, recv_buf);
if (result > 0) {
saved_errno = -res_header->result;
if (res_header->size == 0 || saved_errno > 0) {
free(recv_buf);
}
-close_app_fd:
- close(app_fd);
-
+out:
errno = saved_errno;
-
if (errno) {
return -1;
}
return 0;
}
+int ustctl_connect_pid(pid_t pid)
+{
+ int sock;
+
+ if (ustcomm_connect_app(pid, &sock)) {
+ ERR("could not connect to PID %u", (unsigned int) pid);
+ errno = ENOTCONN;
+ return -1;
+ }
+
+ return sock;
+}
+
pid_t *ustctl_get_online_pids(void)
{
struct dirent *dirent;
* @param pid Traced process ID
* @return 0 if successful, or errors {USTCTL_ERR_GEN, USTCTL_ERR_ARG}
*/
-int ustctl_set_marker_state(const char *trace, const char *channel,
- const char *marker, int state, pid_t pid)
+int ustctl_set_marker_state(int sock, const char *trace, const char *channel,
+ const char *marker, int state)
{
struct ustcomm_header req_header, res_header;
struct ustcomm_marker_info marker_inf;
req_header.command = state ? ENABLE_MARKER : DISABLE_MARKER;
- return do_cmd(pid, &req_header, (char *)&marker_inf,
+ return do_cmd(sock, &req_header, (char *)&marker_inf,
&res_header, NULL);
}
* @param pid Traced process ID
* @return 0 if successful, or error
*/
-int ustctl_set_subbuf_size(const char *trace, const char *channel,
- unsigned int subbuf_size, pid_t pid)
+int ustctl_set_subbuf_size(int sock, const char *trace, const char *channel,
+ unsigned int subbuf_size)
{
struct ustcomm_header req_header, res_header;
struct ustcomm_channel_info ch_inf;
req_header.command = SET_SUBBUF_SIZE;
ch_inf.subbuf_size = subbuf_size;
- return do_cmd(pid, &req_header, (char *)&ch_inf,
+ return do_cmd(sock, &req_header, (char *)&ch_inf,
&res_header, NULL);
}
* @param pid Traced process ID
* @return 0 if successful, or error
*/
-int ustctl_set_subbuf_num(const char *trace, const char *channel,
- unsigned int num, pid_t pid)
+int ustctl_set_subbuf_num(int sock, const char *trace, const char *channel,
+ unsigned int num)
{
struct ustcomm_header req_header, res_header;
struct ustcomm_channel_info ch_inf;
req_header.command = SET_SUBBUF_NUM;
ch_inf.subbuf_num = num;
- return do_cmd(pid, &req_header, (char *)&ch_inf,
+ return do_cmd(sock, &req_header, (char *)&ch_inf,
&res_header, NULL);
}
-static int ustctl_get_subbuf_num_size(const char *trace, const char *channel,
- pid_t pid, int *num, int *size)
+
+static int ustctl_get_subbuf_num_size(int sock, const char *trace, const char *channel,
+ int *num, int *size)
{
struct ustcomm_header req_header, res_header;
struct ustcomm_channel_info ch_inf, *ch_inf_res;
req_header.command = GET_SUBBUF_NUM_SIZE;
- result = do_cmd(pid, &req_header, (char *)&ch_inf,
+ result = do_cmd(sock, &req_header, (char *)&ch_inf,
&res_header, (char **)&ch_inf_res);
if (result < 0) {
return -1;
* @param pid Traced process ID
* @return subbuf cnf if successful, or error
*/
-int ustctl_get_subbuf_num(const char *trace, const char *channel, pid_t pid)
+int ustctl_get_subbuf_num(int sock, const char *trace, const char *channel)
{
int num, size, result;
- result = ustctl_get_subbuf_num_size(trace, channel, pid,
+ result = ustctl_get_subbuf_num_size(sock, trace, channel,
&num, &size);
if (result < 0) {
errno = -result;
* @param pid Traced process ID
* @return subbuf size if successful, or error
*/
-int ustctl_get_subbuf_size(const char *trace, const char *channel, pid_t pid)
+int ustctl_get_subbuf_size(int sock, const char *trace, const char *channel)
{
int num, size, result;
- result = ustctl_get_subbuf_num_size(trace, channel, pid,
+ result = ustctl_get_subbuf_num_size(sock, trace, channel,
&num, &size);
if (result < 0) {
errno = -result;
return size;
}
-
-static int do_trace_cmd(const char *trace, pid_t pid, int command)
+static int do_trace_cmd(int sock, const char *trace, int command)
{
struct ustcomm_header req_header, res_header;
struct ustcomm_single_field trace_inf;
req_header.command = command;
- return do_cmd(pid, &req_header, (char *)&trace_inf, &res_header, NULL);
+ return do_cmd(sock, &req_header, (char *)&trace_inf, &res_header, NULL);
}
/**
* @param pid Traced process ID
* @return 0 if successful, or error USTCTL_ERR_GEN
*/
-int ustctl_destroy_trace(const char *trace, pid_t pid)
+int ustctl_destroy_trace(int sock, const char *trace)
{
- return do_trace_cmd(trace, pid, DESTROY_TRACE);
+ return do_trace_cmd(sock, trace, DESTROY_TRACE);
}
/**
* @param pid Traced process ID
* @return 0 if successful, or error USTCTL_ERR_GEN
*/
-int ustctl_setup_and_start(const char *trace, pid_t pid)
+int ustctl_setup_and_start(int sock, const char *trace)
{
- return do_trace_cmd(trace, pid, START);
+ return do_trace_cmd(sock, trace, START);
}
/**
* @param pid Traced process ID
* @return 0 if successful, or error USTCTL_ERR_GEN
*/
-int ustctl_create_trace(const char *trace, pid_t pid)
+int ustctl_create_trace(int sock, const char *trace)
{
- return do_trace_cmd(trace, pid, CREATE_TRACE);
+ return do_trace_cmd(sock, trace, CREATE_TRACE);
}
/**
* @param pid Traced process ID
* @return 0 if successful, or error USTCTL_ERR_GEN
*/
-int ustctl_start_trace(const char *trace, pid_t pid)
+int ustctl_start_trace(int sock, const char *trace)
{
- return do_trace_cmd(trace, pid, START_TRACE);
+ return do_trace_cmd(sock, trace, START_TRACE);
}
/**
* @param pid Traced process ID
* @return 0 if successful, or error USTCTL_ERR_GEN
*/
-int ustctl_alloc_trace(const char *trace, pid_t pid)
+int ustctl_alloc_trace(int sock, const char *trace)
{
- return do_trace_cmd(trace, pid, ALLOC_TRACE);
+ return do_trace_cmd(sock, trace, ALLOC_TRACE);
}
/**
* @param pid Traced process ID
* @return 0 if successful, or error USTCTL_ERR_GEN
*/
-int ustctl_stop_trace(const char *trace, pid_t pid)
+int ustctl_stop_trace(int sock, const char *trace)
{
- return do_trace_cmd(trace, pid, STOP_TRACE);
+ return do_trace_cmd(sock, trace, STOP_TRACE);
}
/**
* @param pid Targeted PID
* @return 0 if successful, or -1 on error
*/
-int ustctl_get_cmsf(struct marker_status **cmsf, const pid_t pid)
+int ustctl_get_cmsf(int sock, struct marker_status **cmsf)
{
struct ustcomm_header req_header, res_header;
char *big_str = NULL;
- int result, app_fd;
+ int result;
struct marker_status *tmp_cmsf = NULL;
unsigned int i = 0, cmsf_ind = 0;
return -1;
}
- if (ustcomm_connect_app(pid, &app_fd)) {
- ERR("could not connect to PID %u", (unsigned int) pid);
- return -1;
- }
-
req_header.command = LIST_MARKERS;
req_header.size = 0;
- result = ustcomm_send(app_fd, &req_header, NULL);
+ result = ustcomm_send(sock, &req_header, NULL);
if (result <= 0) {
- PERROR("error while requesting markers list for process %d", pid);
+ PERROR("error while requesting markers list");
return -1;
}
- result = ustcomm_recv_alloc(app_fd, &res_header, &big_str);
+ result = ustcomm_recv_alloc(sock, &res_header, &big_str);
if (result <= 0) {
ERR("error while receiving markers list");
return -1;
}
- close(app_fd);
-
tmp_cmsf = (struct marker_status *) zmalloc(sizeof(struct marker_status) *
(ustctl_count_nl(big_str) + 1));
if (tmp_cmsf == NULL) {
return 0;
}
-
/**
* Frees a TES array.
*
* @param pid Targeted PID
* @return 0 if successful, or -1 on error
*/
-int ustctl_get_tes(struct trace_event_status **tes,
- const pid_t pid)
+int ustctl_get_tes(int sock, struct trace_event_status **tes)
{
struct ustcomm_header req_header, res_header;
char *big_str = NULL;
- int result, app_fd;
+ int result;
struct trace_event_status *tmp_tes = NULL;
unsigned int i = 0, tes_ind = 0;
return -1;
}
- if (ustcomm_connect_app(pid, &app_fd)) {
- ERR("could not connect to PID %u", (unsigned int) pid);
- return -1;
- }
-
req_header.command = LIST_TRACE_EVENTS;
req_header.size = 0;
- result = ustcomm_send(app_fd, &req_header, NULL);
+ result = ustcomm_send(sock, &req_header, NULL);
if (result != 1) {
ERR("error while requesting trace_event list");
return -1;
}
- result = ustcomm_recv_alloc(app_fd, &res_header, &big_str);
+ result = ustcomm_recv_alloc(sock, &res_header, &big_str);
if (result != 1) {
ERR("error while receiving markers list");
return -1;
}
- close(app_fd);
-
tmp_tes = (struct trace_event_status *)
zmalloc(sizeof(struct trace_event_status) *
(ustctl_count_nl(big_str) + 1));
}
/**
- * Set socket path
+ * Set sock path
*
- * @param sock_path Socket path
+ * @param sock_path Sock path
* @param pid Traced process ID
* @return 0 if successful, or error
*/
-int ustctl_set_sock_path(const char *sock_path, pid_t pid)
+int ustctl_set_sock_path(int sock, const char *sock_path)
{
int result;
struct ustcomm_header req_header, res_header;
req_header.command = SET_SOCK_PATH;
- return do_cmd(pid, &req_header, (char *)&sock_path_msg,
+ return do_cmd(sock, &req_header, (char *)&sock_path_msg,
&res_header, NULL);
}
/**
- * Get socket path
+ * Get sock path
*
- * @param sock_path Pointer to where the socket path will be returned
+ * @param sock_path Pointer to where the sock path will be returned
* @param pid Traced process ID
* @return 0 if successful, or error
*/
-int ustctl_get_sock_path(char **sock_path, pid_t pid)
+int ustctl_get_sock_path(int sock, char **sock_path)
{
int result;
struct ustcomm_header req_header, res_header;
req_header.command = GET_SOCK_PATH;
req_header.size = 0;
- result = do_cmd(pid, &req_header, NULL, &res_header,
+ result = do_cmd(sock, &req_header, NULL, &res_header,
(char **)&sock_path_msg);
if (result < 0) {
return -1;
return 0;
}
-int ustctl_force_switch(pid_t pid)
+int ustctl_force_switch(int sock, const char *trace)
{
struct ustcomm_header req_header, res_header;
req_header.command = FORCE_SUBBUF_SWITCH;
req_header.size = 0;
- return do_cmd(pid, &req_header, NULL, &res_header, NULL);
+ return do_cmd(sock, &req_header, NULL, &res_header, NULL);
}
-
static void ustctl_function_tests(pid_t pid)
{
- int result;
+ int result, sock;
unsigned int subbuf_size, subbuf_num;
unsigned int new_subbuf_size, new_subbuf_num;
struct marker_status *marker_status, *ms_ptr;
printf("Connecting to pid %d\n", pid);
+ sock = ustctl_connect_pid(pid);
+ tap_ok(sock > 0, "ustctl_connect_pid");
+
/* marker status array functions */
- result = ustctl_get_cmsf(&marker_status, pid);
+ result = ustctl_get_cmsf(sock, &marker_status);
tap_ok(!result, "ustctl_get_cmsf");
result = 0;
tap_ok(!ustctl_free_cmsf(marker_status), "ustctl_free_cmsf");
/* Get and set the socket path */
- tap_ok(!ustctl_get_sock_path(&old_socket_path, pid),
+ tap_ok(!ustctl_get_sock_path(sock, &old_socket_path),
"ustctl_get_sock_path");
printf("Socket path: %s\n", old_socket_path);
- tap_ok(!ustctl_set_sock_path(tmp_ustd_socket, pid),
+ tap_ok(!ustctl_set_sock_path(sock, tmp_ustd_socket),
"ustctl_set_sock_path - set a new path");
- tap_ok(!ustctl_get_sock_path(&new_socket_path, pid),
+ tap_ok(!ustctl_get_sock_path(sock, &new_socket_path),
"ustctl_get_sock_path - get the new path");
tap_ok(!strcmp(new_socket_path, tmp_ustd_socket),
free(new_socket_path);
- tap_ok(!ustctl_set_sock_path(old_socket_path, pid),
+ tap_ok(!ustctl_set_sock_path(sock, old_socket_path),
"Reset the socket path");
free(old_socket_path);
/* Enable, disable markers */
- tap_ok(!ustctl_set_marker_state(trace, "ust", "bar", 1, pid),
+ tap_ok(!ustctl_set_marker_state(sock, trace, "ust", "bar", 1),
"ustctl_set_marker_state - existing marker ust bar");
/* Create and allocate a trace */
- tap_ok(!ustctl_create_trace(trace, pid), "ustctl_create_trace");
+ tap_ok(!ustctl_create_trace(sock, trace), "ustctl_create_trace");
- tap_ok(!ustctl_alloc_trace(trace, pid), "ustctl_alloc_trace");
+ tap_ok(!ustctl_alloc_trace(sock, trace), "ustctl_alloc_trace");
/* Get subbuf size and number */
- subbuf_num = ustctl_get_subbuf_num(trace, "ust", pid);
+ subbuf_num = ustctl_get_subbuf_num(sock, trace, "ust");
tap_ok(subbuf_num > 0, "ustctl_get_subbuf_num - %d sub-buffers",
subbuf_num);
- subbuf_size = ustctl_get_subbuf_size(trace, "ust", pid);
+ subbuf_size = ustctl_get_subbuf_size(sock, trace, "ust");
tap_ok(subbuf_size, "ustctl_get_subbuf_size - sub-buffer size is %d",
subbuf_size);
/* Start the trace */
- tap_ok(!ustctl_start_trace(trace, pid), "ustctl_start_trace");
+ tap_ok(!ustctl_start_trace(sock, trace), "ustctl_start_trace");
/* Stop the trace and destroy it*/
- tap_ok(!ustctl_stop_trace(trace, pid), "ustctl_stop_trace");
+ tap_ok(!ustctl_stop_trace(sock, trace), "ustctl_stop_trace");
- tap_ok(!ustctl_destroy_trace(trace, pid), "ustctl_destroy_trace");
+ tap_ok(!ustctl_destroy_trace(sock, trace), "ustctl_destroy_trace");
/* Create a new trace */
- tap_ok(!ustctl_create_trace(trace, pid), "ustctl_create_trace - create a new trace");
+ tap_ok(!ustctl_create_trace(sock, trace), "ustctl_create_trace - create a new trace");
printf("Setting new subbufer number and sizes (doubling)\n");
new_subbuf_num = 2 * subbuf_num;
new_subbuf_size = 2 * subbuf_size;
- tap_ok(!ustctl_set_subbuf_num(trace, "ust", new_subbuf_num, pid),
+ tap_ok(!ustctl_set_subbuf_num(sock, trace, "ust", new_subbuf_num),
"ustctl_set_subbuf_num");
- tap_ok(!ustctl_set_subbuf_size(trace, "ust", new_subbuf_size, pid),
+ tap_ok(!ustctl_set_subbuf_size(sock, trace, "ust", new_subbuf_size),
"ustctl_set_subbuf_size");
/* Allocate the new trace */
- tap_ok(!ustctl_alloc_trace(trace, pid), "ustctl_alloc_trace - allocate the new trace");
+ tap_ok(!ustctl_alloc_trace(sock, trace), "ustctl_alloc_trace - allocate the new trace");
/* Get subbuf size and number and compare with what was set */
- subbuf_num = ustctl_get_subbuf_num(trace, "ust", pid);
+ subbuf_num = ustctl_get_subbuf_num(sock, trace, "ust");
- subbuf_size = ustctl_get_subbuf_size(trace, "ust", pid);
+ subbuf_size = ustctl_get_subbuf_size(sock, trace, "ust");
tap_ok(subbuf_num == new_subbuf_num, "Set a new subbuf number, %d == %d",
subbuf_num, new_subbuf_num);
- result = ustctl_get_subbuf_size(trace, "ust", pid);
+ result = ustctl_get_subbuf_size(sock, trace, "ust");
tap_ok(subbuf_size == new_subbuf_size, "Set a new subbuf size, %d == %d",
subbuf_size, new_subbuf_size);
- tap_ok(!ustctl_destroy_trace(trace, pid), "ustctl_destroy_trace - without ever starting");
+ tap_ok(!ustctl_destroy_trace(sock, trace), "ustctl_destroy_trace - without ever starting");
/*
* Activate a non-existent marker, this should be possible as the marker
* can be loaded at a later time.
*/
- tap_ok(ustctl_set_marker_state(trace, "ustl", "blar", 1, pid) == 0,
+ tap_ok(ustctl_set_marker_state(sock, trace, "ustl", "blar", 1) == 0,
"Enable non-existent marker ustl blar");
printf("##### Tests that definetly should work are completed #####\n");
printf("############## Start expected failure cases ##############\n");
- tap_ok(ustctl_set_marker_state(trace, "ust","bar", 1, pid),
+ tap_ok(ustctl_set_marker_state(sock, trace, "ust","bar", 1),
"Enable already enabled marker ust/bar");
+
tap_ok(EEXIST == errno,
"Right error code for enabling an already enabled marker");
- tap_ok(ustctl_start_trace(trace, pid),
+ tap_ok(ustctl_start_trace(sock, trace),
"Start a non-existent trace");
- tap_ok(ustctl_destroy_trace(trace, pid),
+ tap_ok(ustctl_destroy_trace(sock, trace),
"Destroy non-existent trace");
exit(tap_status() ? EXIT_FAILURE : EXIT_SUCCESS);
int i, status;
pid_t parent_pid, child_pid;
- tap_plan(28);
+ tap_plan(29);
printf("Function tests for ustctl\n");
static int set_subbuf_size(int argc, char *argv[])
{
- int result = 0;
- pid_t pid;
+ int sock, result = 0;
char *channel = NULL;
unsigned int size;
- pid = parse_pid(argv[1]);
+ sock = parse_and_connect_pid(argv[1]);
if (scan_ch_and_num(argv[3], &channel, &size)) {
fprintf(stderr, "Failed to scan channel and size from"
free(channel);
return -1;
}
- if (ustctl_set_subbuf_size(argv[2], channel, size, pid)) {
+ if (ustctl_set_subbuf_size(sock, argv[2], channel, size)) {
ERR("error while trying to set the size of subbuffers "
- "for PID %u\n",
- pid);
+ "for PID %s\n",
+ argv[1]);
result = -1;
}
static int set_subbuf_num(int argc, char *argv[])
{
- int result = 0;
- pid_t pid;
+ int sock, result = 0;
char *channel = NULL;
unsigned int num;
- pid = parse_pid(argv[1]);
+ sock = parse_and_connect_pid(argv[1]);
if (scan_ch_and_num(argv[3], &channel, &num)) {
fprintf(stderr, "Failed to scan channel and number from"
free(channel);
return -1;
}
- if (ustctl_set_subbuf_num(argv[2], channel, num, pid)) {
- ERR("error while trying to set the number of subbuffers for PID %u\n",
- pid);
+ if (ustctl_set_subbuf_num(sock, argv[2], channel, num)) {
+ ERR("error while trying to set the number of subbuffers for PID %s\n",
+ argv[1]);
result = -1;
}
static int get_subbuf_size(int argc, char *argv[])
{
- pid_t pid;
+ int sock;
unsigned int size;
- pid = parse_pid(argv[1]);
+ sock = parse_and_connect_pid(argv[1]);
- if ((size = ustctl_get_subbuf_size(argv[2], argv[3], pid)) < 0) {
- ERR("error while trying to get the subbuffer size from PID %u\n",
- pid);
+ if ((size = ustctl_get_subbuf_size(sock, argv[2], argv[3])) < 0) {
+ ERR("error while trying to get the subbuffer size from PID %s\n",
+ argv[1]);
return -1;
}
static int get_subbuf_num(int argc, char *argv[])
{
- pid_t pid;
+ int sock;
unsigned int num;
- pid = parse_pid(argv[1]);
+ sock = parse_and_connect_pid(argv[1]);
- if ((num = ustctl_get_subbuf_num(argv[2], argv[3], pid)) < 0) {
- ERR("error while trying to get the subbuffer size from PID %u\n",
- pid);
+ if ((num = ustctl_get_subbuf_num(sock, argv[2], argv[3])) < 0) {
+ ERR("error while trying to get the subbuffer size from PID %s\n",
+ argv[1]);
return -1;
}
static int list_markers(int argc, char *argv[])
{
struct marker_status *cmsf = NULL;
- int i;
- pid_t pid;
+ int i, sock;
- pid = parse_pid(argv[1]);
+ sock = parse_and_connect_pid(argv[1]);
- if (ustctl_get_cmsf(&cmsf, pid)) {
- ERR("error while trying to list markers for PID %u\n", pid);
+ if (ustctl_get_cmsf(sock, &cmsf)) {
+ ERR("error while trying to list markers for PID %s\n", argv[1]);
return -1;
}
for (i = 0; cmsf[i].channel; i++) {
- printf("{PID: %u, channel/marker: %s/%s, "
+ printf("{PID: %s, channel/marker: %s/%s, "
"state: %u, fmt: %s}\n",
- (unsigned int) pid,
+ argv[1],
cmsf[i].channel,
cmsf[i].marker,
cmsf[i].state,
static int enable_marker(int argc, char *argv[])
{
- int i, result = 0;
- pid_t pid;
+ int i, sock, result = 0;
char *channel, *marker;
- pid = parse_pid(argv[1]);
+ sock = parse_and_connect_pid(argv[1]);
for (i = 3; i < argc; i++) {
channel = NULL;
if (marker)
free(marker);
}
- if (ustctl_set_marker_state(argv[2], channel, marker, 1, pid)) {
- PERROR("error while trying to enable marker %s with PID %u",
- argv[i], pid);
+ if (ustctl_set_marker_state(sock, argv[2], channel, marker, 1)) {
+ PERROR("error while trying to enable marker %s with PID %s",
+ argv[i], argv[1]);
result = -1;
}
free(channel);
static int disable_marker(int argc, char *argv[])
{
- int i, result = 0;
- pid_t pid;
+ int i, sock, result = 0;
char *channel, *marker;
- pid = parse_pid(argv[1]);
+ sock = parse_and_connect_pid(argv[1]);
for (i = 3; i < argc; i++) {
channel = NULL;
free(marker);
return -1;
}
- if (ustctl_set_marker_state(argv[2], channel, marker, 0, pid)) {
- PERROR("error while trying to disable marker %s with PID %u",
- argv[i], pid);
+ if (ustctl_set_marker_state(sock, argv[2], channel, marker, 0)) {
+ PERROR("error while trying to disable marker %s with PID %s",
+ argv[i], argv[1]);
result = -1;
}
free(channel);
#include "usterr.h"
-pid_t parse_pid(const char *pid_string)
+int parse_and_connect_pid(const char *pid_string)
{
pid_t pid;
+ int sock;
errno = 0;
pid = strtoull(pid_string, NULL, 10);
exit(EXIT_FAILURE);
}
- return pid;
+ sock = ustctl_connect_pid(pid);
+ if (sock < 0) {
+ perror("Failed to connect to process");
+ exit(EXIT_FAILURE);
+ }
+
+ return sock;
}
int scan_ch_marker(const char *channel_marker, char **channel, char **marker)
#ifndef __SCANNING_FUNCTIONS_H
#define __SCANNING_FUNCTIONS_H
-pid_t parse_pid(const char *pid_string);
+int parse_and_connect_pid(const char *pid_string);
int scan_ch_marker(const char *channel_marker, char **channel, char **marker);
static int create_trace(int argc, char *argv[])
{
- pid_t pid;
+ int sock;
- pid = parse_pid(argv[1]);
+ sock = parse_and_connect_pid(argv[1]);
- if (ustctl_create_trace(argv[2], pid)) {
- ERR("Failed to create trace %s for PID %u\n", argv[2], pid);
+ if (ustctl_create_trace(sock, argv[2])) {
+ ERR("Failed to create trace %s for PID %u\n", argv[2], argv[1]);
return -1;
}
static int alloc_trace(int argc, char *argv[])
{
- pid_t pid;
+ int sock;
- pid = parse_pid(argv[1]);
+ sock = parse_and_connect_pid(argv[1]);
- if (ustctl_alloc_trace(argv[2], pid)) {
- ERR("Failed to allocate trace %s for PID %u\n", argv[2], pid);
+ if (ustctl_alloc_trace(sock, argv[2])) {
+ ERR("Failed to allocate trace %s for PID %s\n", argv[2], argv[1]);
return -1;
}
return 0;
static int start_trace(int argc, char *argv[])
{
- pid_t pid;
+ int sock;
- pid = parse_pid(argv[1]);
+ sock = parse_and_connect_pid(argv[1]);
- if (ustctl_start_trace(argv[2], pid)) {
- ERR("Failed to start trace %s for PID %u\n", argv[2], pid);
+ if (ustctl_start_trace(sock, argv[2])) {
+ ERR("Failed to start trace %s for PID %s\n", argv[2], argv[1]);
return -1;
}
return 0;
static int stop_trace(int argc, char *argv[])
{
- pid_t pid;
+ int sock;
- pid = parse_pid(argv[1]);
+ sock = parse_and_connect_pid(argv[1]);
- if (ustctl_stop_trace(argv[2], pid)) {
- ERR("Failed to stop trace %s for PID %u\n", argv[2], pid);
+ if (ustctl_stop_trace(sock, argv[2])) {
+ ERR("Failed to stop trace %s for PID %s\n", argv[2], argv[1]);
return -1;
}
return 0;
static int destroy_trace(int argc, char *argv[])
{
- pid_t pid;
+ int sock;
- pid = parse_pid(argv[1]);
+ sock = parse_and_connect_pid(argv[1]);
- if (ustctl_destroy_trace(argv[2], pid)) {
- ERR("Failed to destroy trace %s for PID %u\n", argv[2], pid);
+ if (ustctl_destroy_trace(sock, argv[2])) {
+ ERR("Failed to destroy trace %s for PID %s\n", argv[2], argv[1]);
return -1;
}
return 0;
static int force_subbuf_switch(int argc, char *argv[])
{
- pid_t pid;
+ int sock;
- pid = parse_pid(argv[1]);
+ sock = parse_and_connect_pid(argv[1]);
- if (ustctl_force_switch(pid)) {
- ERR("error while trying to force switch for PID %u\n", pid);
+ if (ustctl_force_switch(sock, argv[2])) {
+ ERR("error while trying to force switch for PID %s\n", argv[1]);
return -1;
}
static int list_trace_events(int argc, char *argv[])
{
struct trace_event_status *tes = NULL;
- int i;
- pid_t pid;
+ int i, sock;
- pid = parse_pid(argv[1]);
+ sock = parse_and_connect_pid(argv[1]);
- if (ustctl_get_tes(&tes, pid)) {
+ if (ustctl_get_tes(sock, &tes)) {
ERR("error while trying to list "
- "trace_events for PID %u\n",
- pid);
+ "trace_events for PID %s\n",
+ argv[1]);
return -1;
}
i = 0;
for (i = 0; tes[i].name; i++) {
- printf("{PID: %u, trace_event: %s}\n",
- pid,
+ printf("{PID: %s, trace_event: %s}\n",
+ argv[1],
tes[i].name);
}
ustctl_free_tes(tes);
static int set_sock_path(int argc, char *argv[])
{
- pid_t pid;
+ int sock;
- pid = parse_pid(argv[1]);
+ sock = parse_and_connect_pid(argv[1]);
- if (ustctl_set_sock_path(argv[2], pid)) {
- ERR("error while trying to set sock path for PID %u\n", pid);
+ if (ustctl_set_sock_path(sock, argv[2])) {
+ ERR("error while trying to set sock path for PID %s\n", argv[1]);
return -1;
}
static int get_sock_path(int argc, char *argv[])
{
- pid_t pid;
+ int sock;
char *sock_path;
- pid = parse_pid(argv[1]);
+ sock = parse_and_connect_pid(argv[1]);
- if (ustctl_get_sock_path(&sock_path, pid)) {
- ERR("error while trying to get sock path for PID %u\n", pid);
+ if (ustctl_get_sock_path(sock, &sock_path)) {
+ ERR("error while trying to get sock path for PID %s\n", argv[1]);
return -1;
}
printf("The socket path is %s\n", sock_path);