Re: [PATCH] Try reduce the number of sprintf's

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On 07/11/12 09:17 +0100, Jan Friesse wrote:
NACK

Angus Salkeld napsal(a):
Signed-off-by: Angus Salkeld <asalkeld@xxxxxxxxxx>
---
 exec/totempg.c  |  2 +-
 exec/totemrrp.c | 22 +++++++++++++---------
 2 files changed, 14 insertions(+), 10 deletions(-)

diff --git a/exec/totempg.c b/exec/totempg.c
index eb0ef7e..08dc0fa 100644
--- a/exec/totempg.c
+++ b/exec/totempg.c
@@ -1428,7 +1428,7 @@ 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) ",
+		snprintf (one_iface, 64, "r(%d) ip(%s) ",
 			i, totemip_print (&interfaces[i]));

^^^ Why magic constant?

Only because it is used in this function - but I can create a #define


 		strcat (iface_string, one_iface);
 	}
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);


_______________________________________________
discuss mailing list
discuss@xxxxxxxxxxxx
http://lists.corosync.org/mailman/listinfo/discuss


[Index of Archives]     [Linux Clusters]     [Corosync Project]     [Linux USB Devel]     [Linux Audio Users]     [Photo]     [Yosemite News]    [Yosemite Photos]    [Linux Kernel]     [Linux SCSI]     [X.Org]

  Powered by Linux