123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149 |
- /*
- * Copyright (C) 2016 Stefan Roese <sr@denx.de>
- *
- * SPDX-License-Identifier: GPL-2.0+
- */
- #include <common.h>
- #include <dm.h>
- #include <fdtdec.h>
- #include <libfdt.h>
- #include <asm/io.h>
- #include <asm/system.h>
- #include <asm/arch/cpu.h>
- #include <asm/arch/soc.h>
- #include <asm/armv8/mmu.h>
- DECLARE_GLOBAL_DATA_PTR;
- /*
- * Not all memory is mapped in the MMU. So we need to restrict the
- * memory size so that U-Boot does not try to access it. Also, the
- * internal registers are located at 0xf000.0000 - 0xffff.ffff.
- * Currently only 2GiB are mapped for system memory. This is what
- * we pass to the U-Boot subsystem here.
- */
- #define USABLE_RAM_SIZE 0x80000000
- ulong board_get_usable_ram_top(ulong total_size)
- {
- if (gd->ram_size > USABLE_RAM_SIZE)
- return USABLE_RAM_SIZE;
- return gd->ram_size;
- }
- /*
- * On ARMv8, MBus is not configured in U-Boot. To enable compilation
- * of the already implemented drivers, lets add a dummy version of
- * this function so that linking does not fail.
- */
- const struct mbus_dram_target_info *mvebu_mbus_dram_info(void)
- {
- return NULL;
- }
- /* DRAM init code ... */
- static const void *get_memory_reg_prop(const void *fdt, int *lenp)
- {
- int offset;
- offset = fdt_path_offset(fdt, "/memory");
- if (offset < 0)
- return NULL;
- return fdt_getprop(fdt, offset, "reg", lenp);
- }
- int dram_init(void)
- {
- const void *fdt = gd->fdt_blob;
- const fdt32_t *val;
- int ac, sc, len;
- ac = fdt_address_cells(fdt, 0);
- sc = fdt_size_cells(fdt, 0);
- if (ac < 0 || sc < 1 || sc > 2) {
- printf("invalid address/size cells\n");
- return -EINVAL;
- }
- val = get_memory_reg_prop(fdt, &len);
- if (len / sizeof(*val) < ac + sc)
- return -EINVAL;
- val += ac;
- gd->ram_size = fdtdec_get_number(val, sc);
- debug("DRAM size = %08lx\n", (unsigned long)gd->ram_size);
- return 0;
- }
- void dram_init_banksize(void)
- {
- const void *fdt = gd->fdt_blob;
- const fdt32_t *val;
- int ac, sc, cells, len, i;
- val = get_memory_reg_prop(fdt, &len);
- if (len < 0)
- return;
- ac = fdt_address_cells(fdt, 0);
- sc = fdt_size_cells(fdt, 0);
- if (ac < 1 || sc > 2 || sc < 1 || sc > 2) {
- printf("invalid address/size cells\n");
- return;
- }
- cells = ac + sc;
- len /= sizeof(*val);
- for (i = 0; i < CONFIG_NR_DRAM_BANKS && len >= cells;
- i++, len -= cells) {
- gd->bd->bi_dram[i].start = fdtdec_get_number(val, ac);
- val += ac;
- gd->bd->bi_dram[i].size = fdtdec_get_number(val, sc);
- val += sc;
- debug("DRAM bank %d: start = %08lx, size = %08lx\n",
- i, (unsigned long)gd->bd->bi_dram[i].start,
- (unsigned long)gd->bd->bi_dram[i].size);
- }
- }
- int arch_cpu_init(void)
- {
- /* Nothing to do (yet) */
- return 0;
- }
- int arch_early_init_r(void)
- {
- struct udevice *dev;
- int ret;
- int i;
- /*
- * Loop over all MISC uclass drivers to call the comphy code
- * and init all CP110 devices enabled in the DT
- */
- i = 0;
- while (1) {
- /* Call the comphy code via the MISC uclass driver */
- ret = uclass_get_device(UCLASS_MISC, i++, &dev);
- /* We're done, once no further CP110 device is found */
- if (ret)
- break;
- }
- /* Cause the SATA device to do its early init */
- uclass_first_device(UCLASS_AHCI, &dev);
- return 0;
- }
|