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