#include <linux/kexec.h>
 #include <linux/of.h>
 #include <linux/ima.h>
+#include <linux/reboot.h>
+#include <asm/page.h>
 #include "ima.h"
 
 #ifdef CONFIG_IMA_KEXEC
+static bool ima_kexec_update_registered;
 static struct seq_file ima_kexec_file;
+static void *ima_kexec_buffer;
 
 static void ima_free_kexec_file_buf(struct seq_file *sf)
 {
        kexec_dprintk("kexec measurement buffer for the loaded kernel at 0x%lx.\n",
                      kbuf.mem);
 }
+
+/*
+ * Called during kexec execute so that IMA can update the measurement list.
+ */
+static int ima_update_kexec_buffer(struct notifier_block *self,
+                                  unsigned long action, void *data)
+{
+       return NOTIFY_OK;
+}
+
+static struct notifier_block update_buffer_nb = {
+       .notifier_call = ima_update_kexec_buffer,
+       .priority = INT_MIN
+};
+
+/*
+ * Create a mapping for the source pages that contain the IMA buffer
+ * so we can update it later.
+ */
+void ima_kexec_post_load(struct kimage *image)
+{
+       if (ima_kexec_buffer) {
+               kimage_unmap_segment(ima_kexec_buffer);
+               ima_kexec_buffer = NULL;
+       }
+
+       if (!image->ima_buffer_addr)
+               return;
+
+       ima_kexec_buffer = kimage_map_segment(image,
+                                             image->ima_buffer_addr,
+                                             image->ima_buffer_size);
+       if (!ima_kexec_buffer) {
+               pr_err("Could not map measurements buffer.\n");
+               return;
+       }
+
+       if (!ima_kexec_update_registered) {
+               register_reboot_notifier(&update_buffer_nb);
+               ima_kexec_update_registered = true;
+       }
+}
+
 #endif /* IMA_KEXEC */
 
 /*