kexec failure gives more detailed reason
Bug: 272365447
Test: apply https://android-review.git.corp.google.com/c/platform/external/scudo/+/247547
Build aosp_cf_x86_64_phone, and run the microdroid VM.
It fails with the following message:
[ 1.353364] Failed to load panic kernel: Cannot assign requested
address
[ 1.353678] Image size too big?
/system/etc/microdroid_crashdump_kernel:2262528 bytes,
/system/etc/microdroid_crashdump_initrd.img:10584832 bytes
Change-Id: I290c589b084ddb0a51a4e6018dfdf69e8505d341
diff --git a/microdroid/kdump/kexec.c b/microdroid/kdump/kexec.c
index 8d88951..d3e8e02 100644
--- a/microdroid/kdump/kexec.c
+++ b/microdroid/kdump/kexec.c
@@ -23,6 +23,7 @@
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
+#include <sys/stat.h>
#include <sys/syscall.h>
#include <sys/types.h>
#include <unistd.h>
@@ -53,6 +54,20 @@
if (syscall(SYS_kexec_file_load, open_checked(KERNEL), open_checked(INITRD), cmdline_len,
CMDLINE, KEXEC_FILE_ON_CRASH) == -1) {
fprintf(stderr, "Failed to load panic kernel: %s\n", strerror(errno));
+ if (errno == EADDRNOTAVAIL) {
+ struct stat st;
+ off_t kernel_size = 0;
+ off_t initrd_size = 0;
+
+ if (stat(KERNEL, &st) == 0) {
+ kernel_size = st.st_size;
+ }
+ if (stat(INITRD, &st) == 0) {
+ initrd_size = st.st_size;
+ }
+ fprintf(stderr, "Image size too big? %s:%ld bytes, %s:%ld bytes", KERNEL, kernel_size,
+ INITRD, initrd_size);
+ }
return 1;
}
return 0;