Signed-off-by: Angus Salkeld <asalkeld@xxxxxxxxxx> --- exec/totempg.c | 8 +++++--- exec/totemrrp.c | 22 +++++++++++++--------- 2 files changed, 18 insertions(+), 12 deletions(-) diff --git a/exec/totempg.c b/exec/totempg.c index eb0ef7e..3b89e3a 100644 --- a/exec/totempg.c +++ b/exec/totempg.c @@ -1408,10 +1408,11 @@ int totempg_ring_reenable (void) return (res); } +#define ONE_IFACE_LEN 63 const char *totempg_ifaces_print (unsigned int nodeid) { static char iface_string[256 * INTERFACE_MAX]; - char one_iface[64]; + char one_iface[ONE_IFACE_LEN+1]; struct totem_ip_address interfaces[INTERFACE_MAX]; char **status; unsigned int iface_count; @@ -1428,8 +1429,9 @@ const char *totempg_ifaces_print (unsigned int nodeid) res = totempg_ifaces_get (nodeid, interfaces, INTERFACE_MAX, &status, &iface_count); for (i = 0; i < iface_count; i++) { - sprintf (one_iface, "r(%d) ip(%s) ", - i, totemip_print (&interfaces[i])); + snprintf (one_iface, ONE_IFACE_LEN, + "r(%d) ip(%s) ", + i, totemip_print (&interfaces[i])); strcat (iface_string, one_iface); } return (iface_string); diff --git a/exec/totemrrp.c b/exec/totemrrp.c index 0623892..c3d654c 100644 --- a/exec/totemrrp.c +++ b/exec/totemrrp.c @@ -180,6 +180,7 @@ struct rrp_algo { }; +#define STATUS_STR_LEN 1024 struct totemrrp_instance { qb_loop_t *poll_handle; @@ -992,7 +993,7 @@ static void passive_monitor ( stats_set_interface_faulty (rrp_instance, i, passive_instance->faulty[i]); - sprintf (rrp_instance->status[i], + snprintf (rrp_instance->status[i], STATUS_STR_LEN, "Marking ringid %u interface %s FAULTY", i, totemnet_iface_print (rrp_instance->net_handles[i])); @@ -1314,10 +1315,10 @@ static void timer_function_active_problem_decrementer (void *context) problem_found = 1; active_instance->counter_problems[i] -= 1; if (active_instance->counter_problems[i] == 0) { - sprintf (rrp_instance->status[i], + snprintf (rrp_instance->status[i], STATUS_STR_LEN, "ring %d active with no faults", i); } else { - sprintf (rrp_instance->status[i], + snprintf (rrp_instance->status[i], STATUS_STR_LEN, "Decrementing problem counter for iface %s to [%d of %d]", totemnet_iface_print (rrp_instance->net_handles[i]), active_instance->counter_problems[i], @@ -1349,7 +1350,7 @@ static void timer_function_active_token_expired (void *context) if (active_instance->timer_problem_decrementer == 0) { active_timer_problem_decrementer_start (active_instance); } - sprintf (rrp_instance->status[i], + snprintf (rrp_instance->status[i], STATUS_STR_LEN, "Incrementing problem counter for seqid %d iface %s to [%d of %d]", active_instance->last_token_seq, totemnet_iface_print (rrp_instance->net_handles[i]), @@ -1375,7 +1376,7 @@ static void timer_function_active_token_expired (void *context) stats_set_interface_faulty (rrp_instance, i, active_instance->faulty[i]); - sprintf (rrp_instance->status[i], + snprintf (rrp_instance->status[i], STATUS_STR_LEN, "Marking seqid %d ringid %u interface %s FAULTY", active_instance->last_token_seq, i, @@ -1700,8 +1701,9 @@ static int totemrrp_algorithm_set ( } } for (i = 0; i < totem_config->interface_count; i++) { - instance->status[i] = malloc (1024); - sprintf (instance->status[i], "ring %d active with no faults", i); + instance->status[i] = malloc (STATUS_STR_LEN+1); + snprintf (instance->status[i], STATUS_STR_LEN, + "ring %d active with no faults", i); } return (res); } @@ -2108,10 +2110,12 @@ int totemrrp_ring_reenable ( if (iface_no == instance->interface_count) { for (i = 0; i < instance->interface_count; i++) { - sprintf (instance->status[i], "ring %d active with no faults", i); + snprintf (instance->status[i], STATUS_STR_LEN, + "ring %d active with no faults", i); } } else { - sprintf (instance->status[iface_no], "ring %d active with no faults", iface_no); + snprintf (instance->status[iface_no], STATUS_STR_LEN, + "ring %d active with no faults", iface_no); } return (res); -- 1.7.11.7 _______________________________________________ discuss mailing list discuss@xxxxxxxxxxxx http://lists.corosync.org/mailman/listinfo/discuss