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