summaryrefslogtreecommitdiffstats
path: root/drivers/of/fdt.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/of/fdt.c')
-rw-r--r--drivers/of/fdt.c15
1 files changed, 10 insertions, 5 deletions
diff --git a/drivers/of/fdt.c b/drivers/of/fdt.c
index 88760a0983a7..cd72a41fcab2 100644
--- a/drivers/of/fdt.c
+++ b/drivers/of/fdt.c
@@ -891,15 +891,20 @@ const void * __init of_flat_dt_match_machine(const void *default_match,
891} 891}
892 892
893#ifdef CONFIG_BLK_DEV_INITRD 893#ifdef CONFIG_BLK_DEV_INITRD
894#ifndef __early_init_dt_declare_initrd
895static void __early_init_dt_declare_initrd(unsigned long start, 894static void __early_init_dt_declare_initrd(unsigned long start,
896 unsigned long end) 895 unsigned long end)
897{ 896{
898 initrd_start = (unsigned long)__va(start); 897 /* ARM64 would cause a BUG to occur here when CONFIG_DEBUG_VM is
899 initrd_end = (unsigned long)__va(end); 898 * enabled since __va() is called too early. ARM64 does make use
900 initrd_below_start_ok = 1; 899 * of phys_initrd_start/phys_initrd_size so we can skip this
900 * conversion.
901 */
902 if (!IS_ENABLED(CONFIG_ARM64)) {
903 initrd_start = (unsigned long)__va(start);
904 initrd_end = (unsigned long)__va(end);
905 initrd_below_start_ok = 1;
906 }
901} 907}
902#endif
903 908
904/** 909/**
905 * early_init_dt_check_for_initrd - Decode initrd location from flat tree 910 * early_init_dt_check_for_initrd - Decode initrd location from flat tree