log_internal(status, text_color, "%s:%i@%s: " format, __FILE__, __LINE__, __func__, ##__VA_ARGS__)
#define log_debug(...) log_full(EFI_SUCCESS, EFI_LIGHTGRAY, __VA_ARGS__)
#define log_info(...) log_full(EFI_SUCCESS, EFI_WHITE, __VA_ARGS__)
+#define log_warning_status(status, ...) log_full(status, EFI_YELLOW, __VA_ARGS__)
#define log_error_status(status, ...) log_full(status, EFI_LIGHTRED, __VA_ARGS__)
#define log_error(...) log_full(EFI_INVALID_PARAMETER, EFI_LIGHTRED, __VA_ARGS__)
#define log_oom() log_full(EFI_OUT_OF_RESOURCES, EFI_LIGHTRED, "Out of memory.")
return EFI_UNSUPPORTED;
err = rng->GetRNG(rng, NULL, size, ret);
+ /* On some systems the RNG might not be ready during early boot, handle gracefully and don't log. */
+ if (err == EFI_NOT_READY)
+ return err;
if (err != EFI_SUCCESS)
- return log_error_status(err, "Failed to acquire RNG data: %m");
+ return log_warning_status(err, "Failed to acquire RNG data, proceeding without: %m");
return EFI_SUCCESS;
}