summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/core/ndisc/nm-ndisc.c19
-rw-r--r--src/core/nm-core-utils.c4
-rw-r--r--src/libnm-client-aux-extern/nm-libnm-aux.c4
-rw-r--r--src/nmcli/devices.c13
4 files changed, 22 insertions, 18 deletions
diff --git a/src/core/ndisc/nm-ndisc.c b/src/core/ndisc/nm-ndisc.c
index 39a4df4824..20dd21212d 100644
--- a/src/core/ndisc/nm-ndisc.c
+++ b/src/core/ndisc/nm-ndisc.c
@@ -10,6 +10,7 @@
#include <arpa/inet.h>
#include <stdlib.h>
+#include "libnm-glib-aux/nm-random-utils.h"
#include "libnm-platform/nm-platform-utils.h"
#include "libnm-platform/nm-platform.h"
#include "libnm-platform/nmp-netns.h"
@@ -858,7 +859,7 @@ solicit_retransmit_time_jitter(gint32 solicit_retransmit_time_msec)
ten_percent = NM_MAX(1, solicit_retransmit_time_msec / 10);
return solicit_retransmit_time_msec - ten_percent
- + ((gint32) (g_random_int() % (2u * ((guint32) ten_percent))));
+ + ((gint32) (nm_random_u32() % (2u * ((guint32) ten_percent))));
}
static gboolean
@@ -936,7 +937,7 @@ solicit_timer_start(NMNDisc *ndisc)
* a suitable delay in 2021. Wait only up to 250 msec instead. */
delay_msec =
- g_random_int() % ((guint32) (NM_NDISC_RFC4861_MAX_RTR_SOLICITATION_DELAY * 1000 / 4));
+ nm_random_u32() % ((guint32) (NM_NDISC_RFC4861_MAX_RTR_SOLICITATION_DELAY * 1000 / 4));
_LOGD("solicit: schedule sending first solicitation (of %d) in %.3f seconds",
priv->config.router_solicitations,
@@ -974,8 +975,9 @@ announce_router(NMNDisc *ndisc)
/* Schedule next initial announcement retransmit. */
priv->send_ra_id =
- g_timeout_add_seconds(g_random_int_range(NM_NDISC_ROUTER_ADVERT_DELAY,
- NM_NDISC_ROUTER_ADVERT_INITIAL_INTERVAL),
+ g_timeout_add_seconds(nm_random_u64_range_full(NM_NDISC_ROUTER_ADVERT_DELAY,
+ NM_NDISC_ROUTER_ADVERT_INITIAL_INTERVAL,
+ FALSE),
(GSourceFunc) announce_router,
ndisc);
} else {
@@ -1009,10 +1011,9 @@ announce_router_initial(NMNDisc *ndisc)
/* Schedule the initial send rather early. Clamp the delay by minimal
* delay and not the initial advert internal so that we start fast. */
if (G_LIKELY(!priv->send_ra_id)) {
- priv->send_ra_id =
- g_timeout_add_seconds(g_random_int_range(0, NM_NDISC_ROUTER_ADVERT_DELAY),
- (GSourceFunc) announce_router,
- ndisc);
+ priv->send_ra_id = g_timeout_add_seconds(nm_random_u64_range(NM_NDISC_ROUTER_ADVERT_DELAY),
+ (GSourceFunc) announce_router,
+ ndisc);
}
}
@@ -1028,7 +1029,7 @@ announce_router_solicited(NMNDisc *ndisc)
nm_clear_g_source(&priv->send_ra_id);
if (!priv->send_ra_id) {
- priv->send_ra_id = g_timeout_add(g_random_int_range(0, NM_NDISC_ROUTER_ADVERT_DELAY_MS),
+ priv->send_ra_id = g_timeout_add(nm_random_u64_range(NM_NDISC_ROUTER_ADVERT_DELAY_MS),
(GSourceFunc) announce_router,
ndisc);
}
diff --git a/src/core/nm-core-utils.c b/src/core/nm-core-utils.c
index 9448ba7b03..53afaa547a 100644
--- a/src/core/nm-core-utils.c
+++ b/src/core/nm-core-utils.c
@@ -3673,9 +3673,7 @@ _hw_addr_eth_complete(struct ether_addr *addr,
nm_assert((ouis == NULL) ^ (ouis_len != 0));
if (ouis) {
- /* g_random_int() is good enough here. It uses a static GRand instance
- * that is seeded from /dev/urandom. */
- oui = ouis[g_random_int() % ouis_len];
+ oui = ouis[nm_random_u64_range(ouis_len)];
g_free(ouis);
} else {
if (!nm_utils_hwaddr_aton(current_mac_address, &oui, ETH_ALEN))
diff --git a/src/libnm-client-aux-extern/nm-libnm-aux.c b/src/libnm-client-aux-extern/nm-libnm-aux.c
index 82a75de697..5855bc299b 100644
--- a/src/libnm-client-aux-extern/nm-libnm-aux.c
+++ b/src/libnm-client-aux-extern/nm-libnm-aux.c
@@ -4,6 +4,8 @@
#include "nm-libnm-aux.h"
+#include "libnm-glib-aux/nm-random-utils.h"
+
/*****************************************************************************/
NMClient *
@@ -101,7 +103,7 @@ nmc_client_new_waitsync(GCancellable *cancellable,
* code no longer uses that, we hardly test those code paths. But they should
* work just the same. Randomly use instead the sync initialization in a debug
* build... */
- if ((g_random_int() % 2) == 0) {
+ if (nm_random_bool()) {
gboolean success;
va_start(ap, first_property_name);
diff --git a/src/nmcli/devices.c b/src/nmcli/devices.c
index f71a7d036d..4a0c3ab8a8 100644
--- a/src/nmcli/devices.c
+++ b/src/nmcli/devices.c
@@ -17,6 +17,7 @@
#include <linux/if_ether.h>
#include "libnm-glib-aux/nm-secret-utils.h"
+#include "libnm-glib-aux/nm-random-utils.h"
#include "common.h"
#include "connections.h"
#include "libnmc-base/nm-client-utils.h"
@@ -4098,10 +4099,11 @@ generate_wpa_key(char *key, size_t len)
/* generate a 8-chars ASCII WPA key */
for (i = 0; i < WPA_PASSKEY_SIZE; i++) {
int c;
- c = g_random_int_range(33, 126);
- /* too many non alphanumeric characters are hard to remember for humans */
- while (!g_ascii_isalnum(c))
- c = g_random_int_range(33, 126);
+
+ do {
+ c = nm_random_u64_range_full(33, 126, TRUE);
+ /* too many non alphanumeric characters are hard to remember for humans */
+ } while (g_ascii_isalnum(c));
key[i] = (char) c;
}
@@ -4120,7 +4122,8 @@ generate_wep_key(char *key, size_t len)
/* generate a 10-digit hex WEP key */
for (i = 0; i < 10; i++) {
int digit;
- digit = g_random_int_range(0, 16);
+
+ digit = nm_random_u64_range_full(0, 16, TRUE);
key[i] = hexdigits[digit];
}
key[10] = '\0';