mirror of
https://github.com/AsahiLinux/u-boot
synced 2024-11-14 08:57:58 +00:00
ee422142f4
CFE checks CPU Thread in a different way (using register $22): mfc0 t1, C0_BCM_CONFIG, 3 # $22 li t2, CP0_CMT_TPID # (1 << 31) and t1, t2 bnez t1, 2f # if we are running on thread 1, skip init nop Signed-off-by: Álvaro Fernández Rojas <noltari@gmail.com> Reviewed-by: Simon Glass <sjg@chromium.org>
37 lines
661 B
C
37 lines
661 B
C
/*
|
|
* Copyright (C) 2016 Daniel Schwierzeck <daniel.schwierzeck@gmail.com>
|
|
* Copyright (C) 2017 Álvaro Fernández Rojas <noltari@gmail.com>
|
|
*
|
|
* SPDX-License-Identifier: GPL-2.0+
|
|
*/
|
|
|
|
#include <common.h>
|
|
#include <ram.h>
|
|
#include <dm.h>
|
|
|
|
DECLARE_GLOBAL_DATA_PTR;
|
|
|
|
int dram_init(void)
|
|
{
|
|
struct ram_info ram;
|
|
struct udevice *dev;
|
|
int err;
|
|
|
|
err = uclass_get_device(UCLASS_RAM, 0, &dev);
|
|
if (err) {
|
|
debug("DRAM init failed: %d\n", err);
|
|
return 0;
|
|
}
|
|
|
|
err = ram_get_info(dev, &ram);
|
|
if (err) {
|
|
debug("Cannot get DRAM size: %d\n", err);
|
|
return 0;
|
|
}
|
|
|
|
debug("SDRAM base=%zx, size=%x\n", ram.base, ram.size);
|
|
|
|
gd->ram_size = ram.size;
|
|
|
|
return 0;
|
|
}
|