mirror of
				https://github.com/smaeul/u-boot.git
				synced 2025-10-31 03:58:17 +00:00 
			
		
		
		
	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>
		
			
				
	
	
		
			38 lines
		
	
	
		
			661 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			38 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;
 | |
| }
 |