]> git.ipfire.org Git - thirdparty/tor.git/commitdiff
math: Replace naughty macro by an inline function
authorDavid Goulet <dgoulet@torproject.org>
Mon, 7 Nov 2022 15:01:47 +0000 (10:01 -0500)
committerDavid Goulet <dgoulet@torproject.org>
Mon, 7 Nov 2022 19:49:41 +0000 (14:49 -0500)
Part of #40708

Signed-off-by: David Goulet <dgoulet@torproject.org>
src/core/or/circuitlist.c
src/core/or/congestion_control_flow.c
src/core/or/congestion_control_vegas.c
src/lib/math/stats.h

index ddcb9bebe42beae6d526fb4fe79c56ba2a298929..d1c734bdd2088d247975c9caa33062178b17e369 100644 (file)
@@ -2245,13 +2245,17 @@ circuit_mark_for_close_, (circuit_t *circ, int reason, int line,
        * averaging and reporting unused and low-use circuits here */
       if (circ->ccontrol->max_rtt_usec != circ->ccontrol->min_rtt_usec) {
         stats_circ_close_ss_cwnd_ma_count++;
-        STATS_UPDATE_AVG(cc_stats_circ_close_ss_cwnd_ma,
-                   circ->ccontrol->cwnd, stats_circ_close_ss_cwnd_ma_count);
+        cc_stats_circ_close_ss_cwnd_ma =
+          stats_update_running_avg(cc_stats_circ_close_ss_cwnd_ma,
+                                   circ->ccontrol->cwnd,
+                                   stats_circ_close_ss_cwnd_ma_count);
       }
     } else {
       stats_circ_close_cwnd_ma_count++;
-      STATS_UPDATE_AVG(cc_stats_circ_close_cwnd_ma,
-                       circ->ccontrol->cwnd, stats_circ_close_cwnd_ma_count);
+      cc_stats_circ_close_cwnd_ma =
+        stats_update_running_avg(cc_stats_circ_close_cwnd_ma,
+                                 circ->ccontrol->cwnd,
+                                 stats_circ_close_cwnd_ma_count);
     }
   }
 
index cc120acd298971d2d4827109429e5b3bdbf614e5..729e67b9a3df9e0211e9da7e5a99c564fac22279 100644 (file)
@@ -486,8 +486,10 @@ flow_control_decide_xoff(edge_connection_t *stream)
       tor_trace(TR_SUBSYS(cc), TR_EV(flow_decide_xoff_sending), stream);
 
       cc_stats_flow_xoff_outbuf_ma_count++;
-      STATS_UPDATE_AVG(cc_stats_flow_xoff_outbuf_ma,
-                       total_buffered, cc_stats_flow_xoff_outbuf_ma_count);
+      cc_stats_flow_xoff_outbuf_ma =
+        stats_update_running_avg(cc_stats_flow_xoff_outbuf_ma,
+                                 total_buffered,
+                                 cc_stats_flow_xoff_outbuf_ma_count);
 
       circuit_send_stream_xoff(stream);
 
@@ -645,8 +647,10 @@ flow_control_decide_xon(edge_connection_t *stream, size_t n_written)
       tor_trace(TR_SUBSYS(cc), TR_EV(flow_decide_xon_rate_change), stream);
 
       cc_stats_flow_xon_outbuf_ma_count++;
-      STATS_UPDATE_AVG(cc_stats_flow_xon_outbuf_ma,
-                       total_buffered, cc_stats_flow_xon_outbuf_ma_count);
+      cc_stats_flow_xon_outbuf_ma =
+        stats_update_running_avg(cc_stats_flow_xon_outbuf_ma,
+                                 total_buffered,
+                                 cc_stats_flow_xon_outbuf_ma_count);
 
       circuit_send_stream_xon(stream);
     }
index 0aecf592aa0cd969f889790c045936188c807255..87f59d12fd6885626b516abb40dae20fc92d485e 100644 (file)
@@ -256,8 +256,9 @@ congestion_control_vegas_exit_slow_start(const circuit_t *circ,
 
   /* Update running cc->cwnd average for metrics. */
   stats_cwnd_exit_ss_ma_count++;
-  STATS_UPDATE_AVG(cc_stats_vegas_exit_ss_cwnd_ma,
-                   cc->cwnd, stats_cwnd_exit_ss_ma_count);
+  cc_stats_vegas_exit_ss_cwnd_ma =
+    stats_update_running_avg(cc_stats_vegas_exit_ss_cwnd_ma,
+                             cc->cwnd, stats_cwnd_exit_ss_ma_count);
 
   /* We need to report that slow start has exited ASAP,
    * for sbws bandwidth measurement. */
index fae93c62136c03b1f667fa2a1cf671ab127a8d20..328d61a9d68c6dfba53a26fdedd8c52517dbd11c 100644 (file)
 /** Update an average making it a "running average". The "avg" is the current
  * value that will be updated to the new one. The "value" is the new value to
  * add to the average and "n" is the new count as in including the "value". */
-#define STATS_UPDATE_AVG(avg, value, n) \
-  avg = ((avg) * ((n) - 1) + (value)) / (n)
+static inline double
+stats_update_running_avg(double avg, double value, double n)
+{
+  return ((avg * (n - 1)) + value) / n;
+}
 
 #endif /* !defined(TOR_STATS_H) */