162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-or-later 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * Motload compatibility for the Emerson/Artesyn MVME7100 462306a36Sopenharmony_ci * 562306a36Sopenharmony_ci * Copyright 2016 Elettra-Sincrotrone Trieste S.C.p.A. 662306a36Sopenharmony_ci * 762306a36Sopenharmony_ci * Author: Alessio Igor Bogani <alessio.bogani@elettra.eu> 862306a36Sopenharmony_ci */ 962306a36Sopenharmony_ci 1062306a36Sopenharmony_ci#include "ops.h" 1162306a36Sopenharmony_ci#include "stdio.h" 1262306a36Sopenharmony_ci#include "cuboot.h" 1362306a36Sopenharmony_ci 1462306a36Sopenharmony_ci#define TARGET_86xx 1562306a36Sopenharmony_ci#define TARGET_HAS_ETH1 1662306a36Sopenharmony_ci#define TARGET_HAS_ETH2 1762306a36Sopenharmony_ci#define TARGET_HAS_ETH3 1862306a36Sopenharmony_ci#include "ppcboot.h" 1962306a36Sopenharmony_ci 2062306a36Sopenharmony_cistatic bd_t bd; 2162306a36Sopenharmony_ci 2262306a36Sopenharmony_ciBSS_STACK(16384); 2362306a36Sopenharmony_ci 2462306a36Sopenharmony_cistatic void mvme7100_fixups(void) 2562306a36Sopenharmony_ci{ 2662306a36Sopenharmony_ci void *devp; 2762306a36Sopenharmony_ci unsigned long busfreq = bd.bi_busfreq * 1000000; 2862306a36Sopenharmony_ci 2962306a36Sopenharmony_ci dt_fixup_cpu_clocks(bd.bi_intfreq * 1000000, busfreq / 4, busfreq); 3062306a36Sopenharmony_ci 3162306a36Sopenharmony_ci devp = finddevice("/soc@f1000000"); 3262306a36Sopenharmony_ci if (devp) 3362306a36Sopenharmony_ci setprop(devp, "bus-frequency", &busfreq, sizeof(busfreq)); 3462306a36Sopenharmony_ci 3562306a36Sopenharmony_ci devp = finddevice("/soc/serial@4500"); 3662306a36Sopenharmony_ci if (devp) 3762306a36Sopenharmony_ci setprop(devp, "clock-frequency", &busfreq, sizeof(busfreq)); 3862306a36Sopenharmony_ci 3962306a36Sopenharmony_ci dt_fixup_memory(bd.bi_memstart, bd.bi_memsize); 4062306a36Sopenharmony_ci 4162306a36Sopenharmony_ci dt_fixup_mac_address_by_alias("ethernet0", bd.bi_enetaddr); 4262306a36Sopenharmony_ci dt_fixup_mac_address_by_alias("ethernet1", bd.bi_enet1addr); 4362306a36Sopenharmony_ci dt_fixup_mac_address_by_alias("ethernet2", bd.bi_enet2addr); 4462306a36Sopenharmony_ci dt_fixup_mac_address_by_alias("ethernet3", bd.bi_enet3addr); 4562306a36Sopenharmony_ci} 4662306a36Sopenharmony_ci 4762306a36Sopenharmony_civoid platform_init(unsigned long r3, unsigned long r4, unsigned long r5, 4862306a36Sopenharmony_ci unsigned long r6, unsigned long r7) 4962306a36Sopenharmony_ci{ 5062306a36Sopenharmony_ci CUBOOT_INIT(); 5162306a36Sopenharmony_ci fdt_init(_dtb_start); 5262306a36Sopenharmony_ci serial_console_init(); 5362306a36Sopenharmony_ci platform_ops.fixups = mvme7100_fixups; 5462306a36Sopenharmony_ci} 55