static void orangefs_kernel_debug_init(void)
{
static char k_buffer[ORANGEFS_MAX_DEBUG_STRING_LEN] = { };
+ size_t len = strlen(kernel_debug_string);
gossip_debug(GOSSIP_DEBUGFS_DEBUG, "%s: start\n", __func__);
- if (strlen(kernel_debug_string) + 1 < ORANGEFS_MAX_DEBUG_STRING_LEN) {
- strcpy(k_buffer, kernel_debug_string);
- strcat(k_buffer, "\n");
+ if (len + 1 < ORANGEFS_MAX_DEBUG_STRING_LEN) {
+ memcpy(k_buffer, kernel_debug_string, len);
+ k_buffer[len] = '\n';
+ k_buffer[len + 1] = '\0';
} else {
- strcpy(k_buffer, "none\n");
+ strscpy(k_buffer, "none\n");
pr_info("%s: overflow 1!\n", __func__);
}
*/
static void orangefs_client_debug_init(void)
{
-
static char c_buffer[ORANGEFS_MAX_DEBUG_STRING_LEN] = { };
+ size_t len = strlen(client_debug_string);
gossip_debug(GOSSIP_DEBUGFS_DEBUG, "%s: start\n", __func__);
- if (strlen(client_debug_string) + 1 < ORANGEFS_MAX_DEBUG_STRING_LEN) {
- strcpy(c_buffer, client_debug_string);
- strcat(c_buffer, "\n");
+ if (len + 1 < ORANGEFS_MAX_DEBUG_STRING_LEN) {
+ memcpy(c_buffer, client_debug_string, len);
+ c_buffer[len] = '\n';
+ c_buffer[len + 1] = '\0';
} else {
- strcpy(c_buffer, "none\n");
+ strscpy(c_buffer, "none\n");
pr_info("%s: overflow! 2\n", __func__);
}
else if (len)
kernel_debug_string[len - 1] = '\0';
else if (type)
- strcpy(client_debug_string, "none");
+ strscpy(client_debug_string, "none");
else
- strcpy(kernel_debug_string, "none");
+ strscpy(kernel_debug_string, "none");
out:
gossip_debug(GOSSIP_UTILS_DEBUG, "%s: string:%s:\n", __func__, debug_string);
return;
-
}
static void do_k_string(void *k_mask, int index)
strcat(kernel_debug_string, ",");
} else {
gossip_err("%s: overflow!\n", __func__);
- strcpy(kernel_debug_string, ORANGEFS_ALL);
+ strscpy(kernel_debug_string, ORANGEFS_ALL);
goto out;
}
}
strcat(client_debug_string, ",");
} else {
gossip_err("%s: overflow!\n", __func__);
- strcpy(client_debug_string, ORANGEFS_ALL);
+ strscpy(client_debug_string, ORANGEFS_ALL);
goto out;
}
}
if ((c_mask->mask1 == cdm_array[client_all_index].mask1) &&
(c_mask->mask2 == cdm_array[client_all_index].mask2)) {
- strcpy(client_debug_string, ORANGEFS_ALL);
+ strscpy(client_debug_string, ORANGEFS_ALL);
rc = 1;
goto out;
}
if ((c_mask->mask1 == cdm_array[client_verbose_index].mask1) &&
(c_mask->mask2 == cdm_array[client_verbose_index].mask2)) {
- strcpy(client_debug_string, ORANGEFS_VERBOSE);
+ strscpy(client_debug_string, ORANGEFS_VERBOSE);
rc = 1;
goto out;
}
k_mask = (__u64 *) mask;
if (*k_mask >= s_kmod_keyword_mask_map[k_all_index].mask_val) {
- strcpy(kernel_debug_string, ORANGEFS_ALL);
+ strscpy(kernel_debug_string, ORANGEFS_ALL);
rc = 1;
goto out;
}