18c2ecf20Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-only
28c2ecf20Sopenharmony_ci/*
38c2ecf20Sopenharmony_ci * Embedded Planet EP8248E with PlanetCore firmware
48c2ecf20Sopenharmony_ci *
58c2ecf20Sopenharmony_ci * Author: Scott Wood <scottwood@freescale.com>
68c2ecf20Sopenharmony_ci *
78c2ecf20Sopenharmony_ci * Copyright (c) 2007 Freescale Semiconductor, Inc.
88c2ecf20Sopenharmony_ci */
98c2ecf20Sopenharmony_ci
108c2ecf20Sopenharmony_ci#include "ops.h"
118c2ecf20Sopenharmony_ci#include "stdio.h"
128c2ecf20Sopenharmony_ci#include "planetcore.h"
138c2ecf20Sopenharmony_ci#include "pq2.h"
148c2ecf20Sopenharmony_ci
158c2ecf20Sopenharmony_cistatic char *table;
168c2ecf20Sopenharmony_cistatic u64 mem_size;
178c2ecf20Sopenharmony_ci
188c2ecf20Sopenharmony_ci#include <io.h>
198c2ecf20Sopenharmony_ci
208c2ecf20Sopenharmony_cistatic void platform_fixups(void)
218c2ecf20Sopenharmony_ci{
228c2ecf20Sopenharmony_ci	u64 val;
238c2ecf20Sopenharmony_ci
248c2ecf20Sopenharmony_ci	dt_fixup_memory(0, mem_size);
258c2ecf20Sopenharmony_ci	planetcore_set_mac_addrs(table);
268c2ecf20Sopenharmony_ci
278c2ecf20Sopenharmony_ci	if (!planetcore_get_decimal(table, PLANETCORE_KEY_CRYSTAL_HZ, &val)) {
288c2ecf20Sopenharmony_ci		printf("No PlanetCore crystal frequency key.\r\n");
298c2ecf20Sopenharmony_ci		return;
308c2ecf20Sopenharmony_ci	}
318c2ecf20Sopenharmony_ci
328c2ecf20Sopenharmony_ci	pq2_fixup_clocks(val);
338c2ecf20Sopenharmony_ci}
348c2ecf20Sopenharmony_ci
358c2ecf20Sopenharmony_civoid platform_init(unsigned long r3, unsigned long r4, unsigned long r5,
368c2ecf20Sopenharmony_ci                   unsigned long r6, unsigned long r7)
378c2ecf20Sopenharmony_ci{
388c2ecf20Sopenharmony_ci	table = (char *)r3;
398c2ecf20Sopenharmony_ci	planetcore_prepare_table(table);
408c2ecf20Sopenharmony_ci
418c2ecf20Sopenharmony_ci	if (!planetcore_get_decimal(table, PLANETCORE_KEY_MB_RAM, &mem_size))
428c2ecf20Sopenharmony_ci		return;
438c2ecf20Sopenharmony_ci
448c2ecf20Sopenharmony_ci	mem_size *= 1024 * 1024;
458c2ecf20Sopenharmony_ci	simple_alloc_init(_end, mem_size - (unsigned long)_end, 32, 64);
468c2ecf20Sopenharmony_ci
478c2ecf20Sopenharmony_ci	fdt_init(_dtb_start);
488c2ecf20Sopenharmony_ci
498c2ecf20Sopenharmony_ci	planetcore_set_stdout_path(table);
508c2ecf20Sopenharmony_ci	serial_console_init();
518c2ecf20Sopenharmony_ci	platform_ops.fixups = platform_fixups;
528c2ecf20Sopenharmony_ci}
53