xref: /openbmc/linux/arch/powerpc/boot/redboot-83xx.c (revision d2912cb1)
1d2912cb1SThomas Gleixner // SPDX-License-Identifier: GPL-2.0-only
259d13f9dSBryan O'Donoghue /*
359d13f9dSBryan O'Donoghue  * RedBoot firmware support
459d13f9dSBryan O'Donoghue  *
559d13f9dSBryan O'Donoghue  * Author: Scott Wood <scottwood@freescale.com>
659d13f9dSBryan O'Donoghue  *
759d13f9dSBryan O'Donoghue  * Copyright (c) 2007 Freescale Semiconductor, Inc.
859d13f9dSBryan O'Donoghue  * Copyright (c) 2008 Codehermit
959d13f9dSBryan O'Donoghue  */
1059d13f9dSBryan O'Donoghue 
1159d13f9dSBryan O'Donoghue #include "ops.h"
1259d13f9dSBryan O'Donoghue #include "stdio.h"
1359d13f9dSBryan O'Donoghue #include "redboot.h"
1459d13f9dSBryan O'Donoghue #include "fsl-soc.h"
1559d13f9dSBryan O'Donoghue #include "io.h"
1659d13f9dSBryan O'Donoghue 
1759d13f9dSBryan O'Donoghue static bd_t bd;
1859d13f9dSBryan O'Donoghue BSS_STACK(4096);
1959d13f9dSBryan O'Donoghue 
2059d13f9dSBryan O'Donoghue #define MHZ(x)	((x + 500000) / 1000000)
2159d13f9dSBryan O'Donoghue 
platform_fixups(void)2259d13f9dSBryan O'Donoghue static void platform_fixups(void)
2359d13f9dSBryan O'Donoghue {
2459d13f9dSBryan O'Donoghue 	void *node;
2559d13f9dSBryan O'Donoghue 
2659d13f9dSBryan O'Donoghue 	dt_fixup_memory(bd.bi_memstart, bd.bi_memsize);
2759d13f9dSBryan O'Donoghue 	dt_fixup_mac_addresses(bd.bi_enetaddr);
2859d13f9dSBryan O'Donoghue 	dt_fixup_cpu_clocks(bd.bi_intfreq, bd.bi_busfreq / 16, bd.bi_busfreq);
2959d13f9dSBryan O'Donoghue 
3059d13f9dSBryan O'Donoghue 	node = finddevice("/soc/cpm/brg");
3159d13f9dSBryan O'Donoghue 	if (node) {
3259d13f9dSBryan O'Donoghue 		printf("BRG clock-frequency <- 0x%x (%dMHz)\r\n",
3359d13f9dSBryan O'Donoghue 		       bd.bi_busfreq, MHZ(bd.bi_busfreq));
3459d13f9dSBryan O'Donoghue 		setprop(node, "clock-frequency",  &bd.bi_busfreq, 4);
3559d13f9dSBryan O'Donoghue 	}
3659d13f9dSBryan O'Donoghue 
3759d13f9dSBryan O'Donoghue }
3859d13f9dSBryan O'Donoghue 
platform_init(unsigned long r3,unsigned long r4,unsigned long r5,unsigned long r6,unsigned long r7)3959d13f9dSBryan O'Donoghue void platform_init(unsigned long r3, unsigned long r4, unsigned long r5,
4059d13f9dSBryan O'Donoghue 		   unsigned long r6, unsigned long r7)
4159d13f9dSBryan O'Donoghue {
4259d13f9dSBryan O'Donoghue 	memcpy(&bd, (char *)r3, sizeof(bd));
4359d13f9dSBryan O'Donoghue 
4459d13f9dSBryan O'Donoghue 	if (bd.bi_tag != 0x42444944)
4559d13f9dSBryan O'Donoghue 		return;
4659d13f9dSBryan O'Donoghue 
4759d13f9dSBryan O'Donoghue 	simple_alloc_init(_end,
4859d13f9dSBryan O'Donoghue 			  bd.bi_memstart + bd.bi_memsize - (unsigned long)_end,
4959d13f9dSBryan O'Donoghue 			  32, 64);
5059d13f9dSBryan O'Donoghue 
5159d13f9dSBryan O'Donoghue 	fdt_init(_dtb_start);
5259d13f9dSBryan O'Donoghue 	serial_console_init();
5359d13f9dSBryan O'Donoghue 	platform_ops.fixups = platform_fixups;
5459d13f9dSBryan O'Donoghue 
5559d13f9dSBryan O'Donoghue 	loader_info.cmdline = (char *)bd.bi_cmdline;
5659d13f9dSBryan O'Donoghue 	loader_info.cmdline_len = strlen((char *)bd.bi_cmdline);
5759d13f9dSBryan O'Donoghue }
58