162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-only 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * Old U-boot compatibility for MPC5200 462306a36Sopenharmony_ci * 562306a36Sopenharmony_ci * Author: Grant Likely <grant.likely@secretlab.ca> 662306a36Sopenharmony_ci * 762306a36Sopenharmony_ci * Copyright (c) 2007 Secret Lab Technologies Ltd. 862306a36Sopenharmony_ci * Copyright (c) 2007 Freescale Semiconductor, Inc. 962306a36Sopenharmony_ci */ 1062306a36Sopenharmony_ci 1162306a36Sopenharmony_ci#include "ops.h" 1262306a36Sopenharmony_ci#include "stdio.h" 1362306a36Sopenharmony_ci#include "io.h" 1462306a36Sopenharmony_ci#include "cuboot.h" 1562306a36Sopenharmony_ci 1662306a36Sopenharmony_ci#define TARGET_PPC_MPC52xx 1762306a36Sopenharmony_ci#include "ppcboot.h" 1862306a36Sopenharmony_ci 1962306a36Sopenharmony_cistatic bd_t bd; 2062306a36Sopenharmony_ci 2162306a36Sopenharmony_cistatic void platform_fixups(void) 2262306a36Sopenharmony_ci{ 2362306a36Sopenharmony_ci void *soc, *reg; 2462306a36Sopenharmony_ci int div; 2562306a36Sopenharmony_ci u32 sysfreq; 2662306a36Sopenharmony_ci 2762306a36Sopenharmony_ci 2862306a36Sopenharmony_ci dt_fixup_memory(bd.bi_memstart, bd.bi_memsize); 2962306a36Sopenharmony_ci dt_fixup_mac_addresses(bd.bi_enetaddr); 3062306a36Sopenharmony_ci dt_fixup_cpu_clocks(bd.bi_intfreq, bd.bi_busfreq / 4, bd.bi_busfreq); 3162306a36Sopenharmony_ci 3262306a36Sopenharmony_ci /* Unfortunately, the specific model number is encoded in the 3362306a36Sopenharmony_ci * soc node name in existing dts files -- once that is fixed, 3462306a36Sopenharmony_ci * this can do a simple path lookup. 3562306a36Sopenharmony_ci */ 3662306a36Sopenharmony_ci soc = find_node_by_devtype(NULL, "soc"); 3762306a36Sopenharmony_ci if (!soc) 3862306a36Sopenharmony_ci soc = find_node_by_compatible(NULL, "fsl,mpc5200-immr"); 3962306a36Sopenharmony_ci if (!soc) 4062306a36Sopenharmony_ci soc = find_node_by_compatible(NULL, "fsl,mpc5200b-immr"); 4162306a36Sopenharmony_ci if (soc) { 4262306a36Sopenharmony_ci setprop(soc, "bus-frequency", &bd.bi_ipbfreq, 4362306a36Sopenharmony_ci sizeof(bd.bi_ipbfreq)); 4462306a36Sopenharmony_ci 4562306a36Sopenharmony_ci if (!dt_xlate_reg(soc, 0, (void*)®, NULL)) 4662306a36Sopenharmony_ci return; 4762306a36Sopenharmony_ci div = in_8(reg + 0x204) & 0x0020 ? 8 : 4; 4862306a36Sopenharmony_ci sysfreq = bd.bi_busfreq * div; 4962306a36Sopenharmony_ci setprop(soc, "system-frequency", &sysfreq, sizeof(sysfreq)); 5062306a36Sopenharmony_ci } 5162306a36Sopenharmony_ci} 5262306a36Sopenharmony_ci 5362306a36Sopenharmony_civoid platform_init(unsigned long r3, unsigned long r4, unsigned long r5, 5462306a36Sopenharmony_ci unsigned long r6, unsigned long r7) 5562306a36Sopenharmony_ci{ 5662306a36Sopenharmony_ci CUBOOT_INIT(); 5762306a36Sopenharmony_ci fdt_init(_dtb_start); 5862306a36Sopenharmony_ci serial_console_init(); 5962306a36Sopenharmony_ci platform_ops.fixups = platform_fixups; 6062306a36Sopenharmony_ci} 61