18c2ecf20Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-only
28c2ecf20Sopenharmony_ci/*
38c2ecf20Sopenharmony_ci * RedBoot firmware support
48c2ecf20Sopenharmony_ci *
58c2ecf20Sopenharmony_ci * Author: Scott Wood <scottwood@freescale.com>
68c2ecf20Sopenharmony_ci *
78c2ecf20Sopenharmony_ci * Copyright (c) 2007 Freescale Semiconductor, Inc.
88c2ecf20Sopenharmony_ci * Copyright (c) 2008 Codehermit
98c2ecf20Sopenharmony_ci */
108c2ecf20Sopenharmony_ci
118c2ecf20Sopenharmony_ci#include "ops.h"
128c2ecf20Sopenharmony_ci#include "stdio.h"
138c2ecf20Sopenharmony_ci#include "redboot.h"
148c2ecf20Sopenharmony_ci#include "fsl-soc.h"
158c2ecf20Sopenharmony_ci#include "io.h"
168c2ecf20Sopenharmony_ci
178c2ecf20Sopenharmony_cistatic bd_t bd;
188c2ecf20Sopenharmony_ciBSS_STACK(4096);
198c2ecf20Sopenharmony_ci
208c2ecf20Sopenharmony_ci#define MHZ(x)	((x + 500000) / 1000000)
218c2ecf20Sopenharmony_ci
228c2ecf20Sopenharmony_cistatic void platform_fixups(void)
238c2ecf20Sopenharmony_ci{
248c2ecf20Sopenharmony_ci	void *node;
258c2ecf20Sopenharmony_ci
268c2ecf20Sopenharmony_ci	dt_fixup_memory(bd.bi_memstart, bd.bi_memsize);
278c2ecf20Sopenharmony_ci	dt_fixup_mac_addresses(bd.bi_enetaddr);
288c2ecf20Sopenharmony_ci	dt_fixup_cpu_clocks(bd.bi_intfreq, bd.bi_busfreq / 16, bd.bi_busfreq);
298c2ecf20Sopenharmony_ci
308c2ecf20Sopenharmony_ci	node = finddevice("/soc/cpm/brg");
318c2ecf20Sopenharmony_ci	if (node) {
328c2ecf20Sopenharmony_ci		printf("BRG clock-frequency <- 0x%x (%dMHz)\r\n",
338c2ecf20Sopenharmony_ci		       bd.bi_busfreq, MHZ(bd.bi_busfreq));
348c2ecf20Sopenharmony_ci		setprop(node, "clock-frequency",  &bd.bi_busfreq, 4);
358c2ecf20Sopenharmony_ci	}
368c2ecf20Sopenharmony_ci
378c2ecf20Sopenharmony_ci}
388c2ecf20Sopenharmony_ci
398c2ecf20Sopenharmony_civoid platform_init(unsigned long r3, unsigned long r4, unsigned long r5,
408c2ecf20Sopenharmony_ci		   unsigned long r6, unsigned long r7)
418c2ecf20Sopenharmony_ci{
428c2ecf20Sopenharmony_ci	memcpy(&bd, (char *)r3, sizeof(bd));
438c2ecf20Sopenharmony_ci
448c2ecf20Sopenharmony_ci	if (bd.bi_tag != 0x42444944)
458c2ecf20Sopenharmony_ci		return;
468c2ecf20Sopenharmony_ci
478c2ecf20Sopenharmony_ci	simple_alloc_init(_end,
488c2ecf20Sopenharmony_ci			  bd.bi_memstart + bd.bi_memsize - (unsigned long)_end,
498c2ecf20Sopenharmony_ci			  32, 64);
508c2ecf20Sopenharmony_ci
518c2ecf20Sopenharmony_ci	fdt_init(_dtb_start);
528c2ecf20Sopenharmony_ci	serial_console_init();
538c2ecf20Sopenharmony_ci	platform_ops.fixups = platform_fixups;
548c2ecf20Sopenharmony_ci
558c2ecf20Sopenharmony_ci	loader_info.cmdline = (char *)bd.bi_cmdline;
568c2ecf20Sopenharmony_ci	loader_info.cmdline_len = strlen((char *)bd.bi_cmdline);
578c2ecf20Sopenharmony_ci}
58