mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-03 05:18:29 +03:00
lvmlockd: fix snprintf warnings
This commit is contained in:
parent
0046c4e7a7
commit
81735b46d9
@ -2230,7 +2230,7 @@ static void *lockspace_thread_main(void *arg_in)
|
|||||||
struct action *act_op_free = NULL;
|
struct action *act_op_free = NULL;
|
||||||
struct list_head tmp_act;
|
struct list_head tmp_act;
|
||||||
struct list_head act_close;
|
struct list_head act_close;
|
||||||
char tmp_name[MAX_NAME+1];
|
char tmp_name[MAX_NAME+5];
|
||||||
int free_vg = 0;
|
int free_vg = 0;
|
||||||
int drop_vg = 0;
|
int drop_vg = 0;
|
||||||
int error = 0;
|
int error = 0;
|
||||||
@ -2624,8 +2624,10 @@ out_act:
|
|||||||
* blank or fill it with garbage, but instead set it to REM:<name>
|
* blank or fill it with garbage, but instead set it to REM:<name>
|
||||||
* to make it easier to follow progress of freeing is via log_debug.
|
* to make it easier to follow progress of freeing is via log_debug.
|
||||||
*/
|
*/
|
||||||
dm_strncpy(tmp_name, ls->name, sizeof(tmp_name));
|
memset(tmp_name, 0, sizeof(tmp_name));
|
||||||
snprintf(ls->name, sizeof(ls->name), "REM:%s", tmp_name);
|
memcpy(tmp_name, "REM:", 4);
|
||||||
|
strncpy(tmp_name+4, ls->name, sizeof(tmp_name)-4);
|
||||||
|
memcpy(ls->name, tmp_name, sizeof(ls->name));
|
||||||
pthread_mutex_unlock(&lockspaces_mutex);
|
pthread_mutex_unlock(&lockspaces_mutex);
|
||||||
|
|
||||||
/* worker_thread will join this thread, and free the ls */
|
/* worker_thread will join this thread, and free the ls */
|
||||||
|
@ -128,16 +128,18 @@ static int read_cluster_name(char *clustername)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#define MAX_VERSION 16
|
||||||
|
|
||||||
int lm_init_vg_dlm(char *ls_name, char *vg_name, uint32_t flags, char *vg_args)
|
int lm_init_vg_dlm(char *ls_name, char *vg_name, uint32_t flags, char *vg_args)
|
||||||
{
|
{
|
||||||
char clustername[MAX_ARGS+1];
|
char clustername[MAX_ARGS+1];
|
||||||
char lock_args_version[MAX_ARGS+1];
|
char lock_args_version[MAX_VERSION+1];
|
||||||
int rv;
|
int rv;
|
||||||
|
|
||||||
memset(clustername, 0, sizeof(clustername));
|
memset(clustername, 0, sizeof(clustername));
|
||||||
memset(lock_args_version, 0, sizeof(lock_args_version));
|
memset(lock_args_version, 0, sizeof(lock_args_version));
|
||||||
|
|
||||||
snprintf(lock_args_version, MAX_ARGS, "%u.%u.%u",
|
snprintf(lock_args_version, MAX_VERSION, "%u.%u.%u",
|
||||||
VG_LOCK_ARGS_MAJOR, VG_LOCK_ARGS_MINOR, VG_LOCK_ARGS_PATCH);
|
VG_LOCK_ARGS_MAJOR, VG_LOCK_ARGS_MINOR, VG_LOCK_ARGS_PATCH);
|
||||||
|
|
||||||
rv = read_cluster_name(clustername);
|
rv = read_cluster_name(clustername);
|
||||||
@ -149,7 +151,9 @@ int lm_init_vg_dlm(char *ls_name, char *vg_name, uint32_t flags, char *vg_args)
|
|||||||
return -EARGS;
|
return -EARGS;
|
||||||
}
|
}
|
||||||
|
|
||||||
snprintf(vg_args, MAX_ARGS, "%s:%s", lock_args_version, clustername);
|
rv = snprintf(vg_args, MAX_ARGS, "%s:%s", lock_args_version, clustername);
|
||||||
|
if (rv >= MAX_ARGS)
|
||||||
|
log_debug("init_vg_dlm vg_args may be too long %d %s", rv, vg_args);
|
||||||
rv = 0;
|
rv = 0;
|
||||||
|
|
||||||
log_debug("init_vg_dlm done %s vg_args %s", ls_name, vg_args);
|
log_debug("init_vg_dlm done %s vg_args %s", ls_name, vg_args);
|
||||||
|
@ -500,13 +500,15 @@ static int get_sizes_lockspace(char *path, int *sector_size, int *align_size)
|
|||||||
* version and lv name, and returns the real lock_args in vg_args.
|
* version and lv name, and returns the real lock_args in vg_args.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#define MAX_VERSION 16
|
||||||
|
|
||||||
int lm_init_vg_sanlock(char *ls_name, char *vg_name, uint32_t flags, char *vg_args)
|
int lm_init_vg_sanlock(char *ls_name, char *vg_name, uint32_t flags, char *vg_args)
|
||||||
{
|
{
|
||||||
struct sanlk_lockspace ss;
|
struct sanlk_lockspace ss;
|
||||||
struct sanlk_resourced rd;
|
struct sanlk_resourced rd;
|
||||||
struct sanlk_disk disk;
|
struct sanlk_disk disk;
|
||||||
char lock_lv_name[MAX_ARGS+1];
|
char lock_lv_name[MAX_ARGS+1];
|
||||||
char lock_args_version[MAX_ARGS+1];
|
char lock_args_version[MAX_VERSION+1];
|
||||||
const char *gl_name = NULL;
|
const char *gl_name = NULL;
|
||||||
uint32_t daemon_version;
|
uint32_t daemon_version;
|
||||||
uint32_t daemon_proto;
|
uint32_t daemon_proto;
|
||||||
@ -526,7 +528,7 @@ int lm_init_vg_sanlock(char *ls_name, char *vg_name, uint32_t flags, char *vg_ar
|
|||||||
return -EARGS;
|
return -EARGS;
|
||||||
}
|
}
|
||||||
|
|
||||||
snprintf(lock_args_version, MAX_ARGS, "%u.%u.%u",
|
snprintf(lock_args_version, MAX_VERSION, "%u.%u.%u",
|
||||||
VG_LOCK_ARGS_MAJOR, VG_LOCK_ARGS_MINOR, VG_LOCK_ARGS_PATCH);
|
VG_LOCK_ARGS_MAJOR, VG_LOCK_ARGS_MINOR, VG_LOCK_ARGS_PATCH);
|
||||||
|
|
||||||
/* see comment above about input vg_args being only lock_lv_name */
|
/* see comment above about input vg_args being only lock_lv_name */
|
||||||
@ -543,7 +545,9 @@ int lm_init_vg_sanlock(char *ls_name, char *vg_name, uint32_t flags, char *vg_ar
|
|||||||
if (daemon_test) {
|
if (daemon_test) {
|
||||||
if (!gl_lsname_sanlock[0])
|
if (!gl_lsname_sanlock[0])
|
||||||
strncpy(gl_lsname_sanlock, ls_name, MAX_NAME);
|
strncpy(gl_lsname_sanlock, ls_name, MAX_NAME);
|
||||||
snprintf(vg_args, MAX_ARGS, "%s:%s", lock_args_version, lock_lv_name);
|
rv = snprintf(vg_args, MAX_ARGS, "%s:%s", lock_args_version, lock_lv_name);
|
||||||
|
if (rv >= MAX_ARGS)
|
||||||
|
log_debug("init_vg_san vg_args may be too long %d %s", rv, vg_args);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -635,7 +639,9 @@ int lm_init_vg_sanlock(char *ls_name, char *vg_name, uint32_t flags, char *vg_ar
|
|||||||
if (!strcmp(gl_name, R_NAME_GL))
|
if (!strcmp(gl_name, R_NAME_GL))
|
||||||
strncpy(gl_lsname_sanlock, ls_name, MAX_NAME);
|
strncpy(gl_lsname_sanlock, ls_name, MAX_NAME);
|
||||||
|
|
||||||
snprintf(vg_args, MAX_ARGS, "%s:%s", lock_args_version, lock_lv_name);
|
rv = snprintf(vg_args, MAX_ARGS, "%s:%s", lock_args_version, lock_lv_name);
|
||||||
|
if (rv >= MAX_ARGS)
|
||||||
|
log_debug("init_vg_san vg_args may be too long %d %s", rv, vg_args);
|
||||||
|
|
||||||
log_debug("S %s init_vg_san done vg_args %s", ls_name, vg_args);
|
log_debug("S %s init_vg_san done vg_args %s", ls_name, vg_args);
|
||||||
|
|
||||||
@ -692,7 +698,7 @@ int lm_init_lv_sanlock(char *ls_name, char *vg_name, char *lv_name,
|
|||||||
{
|
{
|
||||||
struct sanlk_resourced rd;
|
struct sanlk_resourced rd;
|
||||||
char lock_lv_name[MAX_ARGS+1];
|
char lock_lv_name[MAX_ARGS+1];
|
||||||
char lock_args_version[MAX_ARGS+1];
|
char lock_args_version[MAX_VERSION+1];
|
||||||
uint64_t offset;
|
uint64_t offset;
|
||||||
int rv;
|
int rv;
|
||||||
|
|
||||||
@ -707,7 +713,7 @@ int lm_init_lv_sanlock(char *ls_name, char *vg_name, char *lv_name,
|
|||||||
return rv;
|
return rv;
|
||||||
}
|
}
|
||||||
|
|
||||||
snprintf(lock_args_version, MAX_ARGS, "%u.%u.%u",
|
snprintf(lock_args_version, MAX_VERSION, "%u.%u.%u",
|
||||||
LV_LOCK_ARGS_MAJOR, LV_LOCK_ARGS_MINOR, LV_LOCK_ARGS_PATCH);
|
LV_LOCK_ARGS_MAJOR, LV_LOCK_ARGS_MINOR, LV_LOCK_ARGS_PATCH);
|
||||||
|
|
||||||
if (daemon_test) {
|
if (daemon_test) {
|
||||||
|
Loading…
Reference in New Issue
Block a user