162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-only 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * Bootwrapper for ePAPR compliant firmwares 462306a36Sopenharmony_ci * 562306a36Sopenharmony_ci * Copyright 2010 David Gibson <david@gibson.dropbear.id.au>, IBM Corporation. 662306a36Sopenharmony_ci * 762306a36Sopenharmony_ci * Based on earlier bootwrappers by: 862306a36Sopenharmony_ci * (c) Benjamin Herrenschmidt <benh@kernel.crashing.org>, IBM Corp,\ 962306a36Sopenharmony_ci * and 1062306a36Sopenharmony_ci * Scott Wood <scottwood@freescale.com> 1162306a36Sopenharmony_ci * Copyright (c) 2007 Freescale Semiconductor, Inc. 1262306a36Sopenharmony_ci */ 1362306a36Sopenharmony_ci 1462306a36Sopenharmony_ci#include "ops.h" 1562306a36Sopenharmony_ci#include "stdio.h" 1662306a36Sopenharmony_ci#include "io.h" 1762306a36Sopenharmony_ci#include <libfdt.h> 1862306a36Sopenharmony_ci 1962306a36Sopenharmony_ciBSS_STACK(4096); 2062306a36Sopenharmony_ci 2162306a36Sopenharmony_ci#define EPAPR_SMAGIC 0x65504150 2262306a36Sopenharmony_ci#define EPAPR_EMAGIC 0x45504150 2362306a36Sopenharmony_ci 2462306a36Sopenharmony_cistatic unsigned epapr_magic; 2562306a36Sopenharmony_cistatic unsigned long ima_size; 2662306a36Sopenharmony_cistatic unsigned long fdt_addr; 2762306a36Sopenharmony_ci 2862306a36Sopenharmony_cistatic void platform_fixups(void) 2962306a36Sopenharmony_ci{ 3062306a36Sopenharmony_ci if ((epapr_magic != EPAPR_EMAGIC) 3162306a36Sopenharmony_ci && (epapr_magic != EPAPR_SMAGIC)) 3262306a36Sopenharmony_ci fatal("r6 contained 0x%08x instead of ePAPR magic number\n", 3362306a36Sopenharmony_ci epapr_magic); 3462306a36Sopenharmony_ci 3562306a36Sopenharmony_ci if (ima_size < (unsigned long)_end) 3662306a36Sopenharmony_ci printf("WARNING: Image loaded outside IMA!" 3762306a36Sopenharmony_ci " (_end=%p, ima_size=0x%lx)\n", _end, ima_size); 3862306a36Sopenharmony_ci if (ima_size < fdt_addr) 3962306a36Sopenharmony_ci printf("WARNING: Device tree address is outside IMA!" 4062306a36Sopenharmony_ci "(fdt_addr=0x%lx, ima_size=0x%lx)\n", fdt_addr, 4162306a36Sopenharmony_ci ima_size); 4262306a36Sopenharmony_ci if (ima_size < fdt_addr + fdt_totalsize((void *)fdt_addr)) 4362306a36Sopenharmony_ci printf("WARNING: Device tree extends outside IMA!" 4462306a36Sopenharmony_ci " (fdt_addr=0x%lx, size=0x%x, ima_size=0x%lx\n", 4562306a36Sopenharmony_ci fdt_addr, fdt_totalsize((void *)fdt_addr), ima_size); 4662306a36Sopenharmony_ci} 4762306a36Sopenharmony_ci 4862306a36Sopenharmony_civoid epapr_platform_init(unsigned long r3, unsigned long r4, unsigned long r5, 4962306a36Sopenharmony_ci unsigned long r6, unsigned long r7) 5062306a36Sopenharmony_ci{ 5162306a36Sopenharmony_ci epapr_magic = r6; 5262306a36Sopenharmony_ci ima_size = r7; 5362306a36Sopenharmony_ci fdt_addr = r3; 5462306a36Sopenharmony_ci 5562306a36Sopenharmony_ci /* FIXME: we should process reserve entries */ 5662306a36Sopenharmony_ci 5762306a36Sopenharmony_ci simple_alloc_init(_end, ima_size - (unsigned long)_end, 32, 64); 5862306a36Sopenharmony_ci 5962306a36Sopenharmony_ci fdt_init((void *)fdt_addr); 6062306a36Sopenharmony_ci 6162306a36Sopenharmony_ci serial_console_init(); 6262306a36Sopenharmony_ci platform_ops.fixups = platform_fixups; 6362306a36Sopenharmony_ci} 64