return boot_dev;
 }
 #endif
+
+bool arch_check_dst_in_secure(void *start, ulong size)
+{
+       ulong ns_end = CFG_SYS_SDRAM_BASE + PHYS_SDRAM_SIZE;
+#ifdef PHYS_SDRAM_2_SIZE
+       ns_end += PHYS_SDRAM_2_SIZE;
+#endif
+
+       if ((ulong)start < CFG_SYS_SDRAM_BASE || (ulong)start + size > ns_end)
+               return true;
+
+       return false;
+}
+
+void *arch_get_container_trampoline(void)
+{
+       return (void *)((ulong)CFG_SYS_SDRAM_BASE + PHYS_SDRAM_SIZE - SZ_16M);
+}
 
 #include <asm/mach-imx/ahab.h>
 #endif
 
+__weak bool arch_check_dst_in_secure(void *start, ulong size)
+{
+       return false;
+}
+
+__weak void *arch_get_container_trampoline(void)
+{
+       return NULL;
+}
+
 static struct boot_img_t *read_auth_image(struct spl_image_info *spl_image,
                                          struct spl_load_info *info,
                                          struct container_hdr *container,
 {
        struct boot_img_t *images;
        ulong offset, overhead, size;
+       void *buf, *trampoline;
 
        if (image_index > container->num_images) {
                debug("Invalid image number\n");
 
        debug("%s: container: %p offset: %lu size: %lu\n", __func__,
              container, offset, size);
-       if (info->read(info, offset, size,
-                      map_sysmem(images[image_index].dst - overhead,
-                                 images[image_index].size)) <
-           images[image_index].size) {
-               printf("%s wrong\n", __func__);
-               return NULL;
+
+       buf = map_sysmem(images[image_index].dst - overhead, images[image_index].size);
+       if (IS_ENABLED(CONFIG_SPL_IMX_CONTAINER_USE_TRAMPOLINE) &&
+           arch_check_dst_in_secure(buf, size)) {
+               trampoline = arch_get_container_trampoline();
+               if (!trampoline) {
+                       printf("%s: trampoline size is zero\n", __func__);
+                       return NULL;
+               }
+
+               if (info->read(info, offset, size, trampoline) < images[image_index].size) {
+                       printf("%s: failed to load image to a trampoline buffer\n", __func__);
+                       return NULL;
+               }
+
+               memcpy(buf, trampoline, images[image_index].size);
+       } else {
+               if (info->read(info, offset, size, buf) < images[image_index].size) {
+                               printf("%s: failed to load image to a non-secure region\n", __func__);
+                       return NULL;
+               }
        }
 
 #ifdef CONFIG_AHAB_BOOT