if (ret < 0) {
LTTNG_THROW_POSIX(
- fmt::format("Failed to get true random data using getrandom(): size={}",
- size),
+ lttng::format("Failed to get true random data using getrandom(): size={}",
+ size),
errno);
}
}
+#elif defined(HAVE_ARC4RANDOM)
+
+#include <stdlib.h>
+
+/*
+ * According to the MacOS / FreeBSD manpage, this function never fails nor blocks.
+ */
+void getrandom_nonblock(char *out_data, std::size_t size)
+{
+ arc4random_buf(out_data, size);
+}
#else /* defined(__linux__) && defined(SYS_getrandom) && defined(HAVE_SYS_RANDOM_H) */
__attribute__((noreturn)) void getrandom_nonblock(char *out_data __attribute__((unused)),
std::size_t size __attribute__((unused)))
try {
urandom.read(&seed, sizeof(seed));
} catch (const std::exception& e) {
- LTTNG_THROW_RANDOM_PRODUCTION_ERROR(fmt::format(
+ LTTNG_THROW_RANDOM_PRODUCTION_ERROR(lttng::format(
"Failed to read from `/dev/urandom`: size={}: {}", sizeof(seed), e.what()));
}
return lttng::random::produce_true_random_seed();
} catch (const std::exception& e) {
WARN("%s",
- fmt::format(
+ lttng::format(
"Failed to produce a random seed using getrandom(), falling back to pseudo-random device seed generation which will block until its pool is initialized: {}",
e.what())
.c_str());
produce_random_seed_from_urandom();
} catch (const std::exception& e) {
WARN("%s",
- fmt::format("Failed to produce a random seed from the urandom device: {}",
- e.what())
+ lttng::format("Failed to produce a random seed from the urandom device: {}",
+ e.what())
.c_str());
}