X-Git-Url: http://git.liburcu.org/?a=blobdiff_plain;f=src%2Fcommon%2Futils.c;h=f93a4f9d21da5078ccddf0e754e650ce886f9325;hb=7e7e8db8b9ca5d862f090ff2a3348e31dab612da;hp=fda43152d30905fc278515277f79a11eb0104282;hpb=d238c88d41dc79062091c0f84b1023e068c196e0;p=lttng-tools.git diff --git a/src/common/utils.c b/src/common/utils.c index fda43152d..f93a4f9d2 100644 --- a/src/common/utils.c +++ b/src/common/utils.c @@ -66,16 +66,15 @@ * but the /tmp/test1 does, the real path for /tmp/test1 is concatened with * /test2/test3 then returned. In normal time, realpath(3) fails if the end * point directory does not exist. - * In case resolved_path is NULL, the string returned was allocated in the - * function and thus need to be freed by the caller. The size argument allows - * to specify the size of the resolved_path argument if given, or the size to - * allocate. + * + * Return a newly-allocated string. */ -LTTNG_HIDDEN -char *utils_partial_realpath(const char *path, char *resolved_path, size_t size) +static +char *utils_partial_realpath(const char *path) { char *cut_path = NULL, *try_path = NULL, *try_path_prev = NULL; const char *next, *prev, *end; + char *resolved_path = NULL; /* Safety net */ if (path == NULL) { @@ -156,13 +155,11 @@ char *utils_partial_realpath(const char *path, char *resolved_path, size_t size) cut_path = NULL; } - /* Allocate memory for the resolved path if necessary */ + /* Allocate memory for the resolved path. */ + resolved_path = zmalloc(LTTNG_PATH_MAX); if (resolved_path == NULL) { - resolved_path = zmalloc(size); - if (resolved_path == NULL) { - PERROR("zmalloc resolved path"); - goto error; - } + PERROR("zmalloc resolved path"); + goto error; } /* @@ -186,7 +183,8 @@ char *utils_partial_realpath(const char *path, char *resolved_path, size_t size) } /* Concatenate the strings */ - snprintf(resolved_path, size, "%s%s", try_path_prev, cut_path); + snprintf(resolved_path, LTTNG_PATH_MAX, "%s%s", + try_path_prev, cut_path); /* Free the allocated memory */ free(cut_path); @@ -198,7 +196,7 @@ char *utils_partial_realpath(const char *path, char *resolved_path, size_t size) * return it as is */ } else { - strncpy(resolved_path, path, size); + strncpy(resolved_path, path, LTTNG_PATH_MAX); } /* Then we return the 'partially' resolved path */ @@ -300,7 +298,7 @@ int expand_double_slashes_dot_and_dotdot(char *path) * Copy the current token which is neither a '.' nor a '..'. */ path[expanded_path_len++] = '/'; - memcpy(&path[expanded_path_len], curr_char, curr_token_len); + memmove(&path[expanded_path_len], curr_char, curr_token_len); expanded_path_len += curr_token_len; } @@ -377,8 +375,13 @@ char *_utils_expand_path(const char *path, bool keep_symlink) if (keep_symlink) { /* Resolve partially our path */ - absolute_path = utils_partial_realpath(absolute_path, - absolute_path, LTTNG_PATH_MAX); + char *new_absolute_path = utils_partial_realpath(absolute_path); + if (!new_absolute_path) { + goto error; + } + + free(absolute_path); + absolute_path = new_absolute_path; } ret = expand_double_slashes_dot_and_dotdot(absolute_path); @@ -544,6 +547,7 @@ void utils_close_pipe(int *src) if (ret) { PERROR("close pipe"); } + src[i] = -1; } } @@ -739,7 +743,8 @@ int utils_stream_file_path(const char *path_name, const char *file_name, char count_str[MAX_INT_DEC_LEN(count) + 1] = {}; const char *path_separator; - if (path_name && path_name[strlen(path_name) - 1] == '/') { + if (path_name && (path_name[0] == '\0' || + path_name[strlen(path_name) - 1] == '/')) { path_separator = ""; } else { path_separator = "/"; @@ -765,74 +770,6 @@ int utils_stream_file_path(const char *path_name, const char *file_name, return ret; } -/* - * Create the stream file on disk. - * - * Return 0 on success or else a negative value. - */ -LTTNG_HIDDEN -int utils_create_stream_file(const char *path_name, char *file_name, uint64_t size, - uint64_t count, int uid, int gid, char *suffix) -{ - int ret, flags, mode; - char path[LTTNG_PATH_MAX]; - - ret = utils_stream_file_path(path_name, file_name, - size, count, suffix, path, sizeof(path)); - if (ret < 0) { - goto error; - } - - /* - * With the session rotation feature on the relay, we might need to seek - * and truncate a tracefile, so we need read and write access. - */ - flags = O_RDWR | O_CREAT | O_TRUNC; - /* Open with 660 mode */ - mode = S_IRUSR | S_IWUSR | S_IRGRP | S_IWGRP; - - if (uid < 0 || gid < 0) { - ret = open(path, flags, mode); - } else { - ret = run_as_open(path, flags, mode, uid, gid); - } - if (ret < 0) { - PERROR("open stream path %s", path); - } -error: - return ret; -} - -/* - * Unlink the stream tracefile from disk. - * - * Return 0 on success or else a negative value. - */ -LTTNG_HIDDEN -int utils_unlink_stream_file(const char *path_name, char *file_name, uint64_t size, - uint64_t count, int uid, int gid, char *suffix) -{ - int ret; - char path[LTTNG_PATH_MAX]; - - ret = utils_stream_file_path(path_name, file_name, size, count, suffix, - path, sizeof(path)); - if (ret < 0) { - goto error; - } - if (uid < 0 || gid < 0) { - ret = unlink(path); - } else { - ret = run_as_unlink(path, uid, gid); - } - if (ret < 0) { - goto error; - } -error: - DBG("utils_unlink_stream_file %s returns %d", path, ret); - return ret; -} - /** * Parse a string that represents a size in human readable format. It * supports decimal integers suffixed by 'k', 'K', 'M' or 'G'. @@ -1341,8 +1278,14 @@ int utils_get_group_id(const char *name, bool warn, gid_t *gid) } } if (ret) { - PERROR("Failed to get group file entry for group name \"%s\"", - name); + if (ret == ESRCH) { + DBG("Could not find group file entry for group name '%s'", + name); + } else { + PERROR("Failed to get group file entry for group name '%s'", + name); + } + ret = -1; goto error; }