114 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			C
		
	
	
	
			
		
		
	
	
			114 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			C
		
	
	
	
| /* CPU specific code for the LEON3 CPU
 | |
|  *
 | |
|  * (C) Copyright 2007, 2015
 | |
|  * Daniel Hellstrom, Cobham Gaisler, daniel@gaisler.com
 | |
|  *
 | |
|  * SPDX-License-Identifier:	GPL-2.0+
 | |
|  */
 | |
| 
 | |
| #include <common.h>
 | |
| #include <watchdog.h>
 | |
| #include <command.h>
 | |
| #include <netdev.h>
 | |
| 
 | |
| #include <asm/io.h>
 | |
| #include <asm/processor.h>
 | |
| #include <ambapp.h>
 | |
| 
 | |
| DECLARE_GLOBAL_DATA_PTR;
 | |
| 
 | |
| extern void _reset_reloc(void);
 | |
| 
 | |
| int leon_cpu_cnt = 1;
 | |
| int leon_ver = 3;
 | |
| unsigned int leon_cpu_freq = CONFIG_SYS_CLK_FREQ;
 | |
| 
 | |
| int cpu_freq(void)
 | |
| {
 | |
| 	ambapp_ahbdev dev;
 | |
| 
 | |
| 	if (leon_ver == 3) {
 | |
| 		ambapp_ahbmst_find(&ambapp_plb, VENDOR_GAISLER,
 | |
| 			GAISLER_LEON3, 0, &dev);
 | |
| 	} else {
 | |
| 		ambapp_ahbmst_find(&ambapp_plb, VENDOR_GAISLER,
 | |
| 			GAISLER_LEON4, 0, &dev);
 | |
| 	}
 | |
| 
 | |
| 	leon_cpu_freq = ambapp_bus_freq(&ambapp_plb, dev.ahb_bus_index);
 | |
| 
 | |
| 	return 0;
 | |
| }
 | |
| 
 | |
| int checkcpu(void)
 | |
| {
 | |
| 	int cnt;
 | |
| 	char str[4];
 | |
| 
 | |
| 	/* check LEON version here */
 | |
| 	cnt = ambapp_ahbmst_count(&ambapp_plb, VENDOR_GAISLER, GAISLER_LEON3);
 | |
| 	if (cnt <= 0) {
 | |
| 		cnt = ambapp_ahbmst_count(&ambapp_plb, VENDOR_GAISLER,
 | |
| 			GAISLER_LEON4);
 | |
| 		if (cnt > 0)
 | |
| 			leon_ver = 4;
 | |
| 	}
 | |
| 
 | |
| 	cpu_freq();
 | |
| 
 | |
| 	str[0] = '\0';
 | |
| 	if (cnt > 1) {
 | |
| 		leon_cpu_cnt = cnt;
 | |
| 		str[0] = '0' + cnt;
 | |
| 		str[1] = 'x';
 | |
| 		str[2] = '\0';
 | |
| 	}
 | |
| 	printf("CPU: %sLEON%d @ %dMHz\n", str, leon_ver,
 | |
| 		leon_cpu_freq / 1000000);
 | |
| 
 | |
| 	return 0;
 | |
| }
 | |
| 
 | |
| #ifdef CONFIG_DISPLAY_CPUINFO
 | |
| 
 | |
| int print_cpuinfo(void)
 | |
| {
 | |
| 	printf("CPU:   LEON3\n");
 | |
| 	return 0;
 | |
| }
 | |
| 
 | |
| #endif
 | |
| 
 | |
| /* ------------------------------------------------------------------------- */
 | |
| 
 | |
| void cpu_reset(void)
 | |
| {
 | |
| 	/* Interrupts off */
 | |
| 	disable_interrupts();
 | |
| 
 | |
| 	/* jump to restart in flash */
 | |
| 	_reset_reloc();
 | |
| }
 | |
| 
 | |
| int do_reset(cmd_tbl_t * cmdtp, int flag, int argc, char * const argv[])
 | |
| {
 | |
| 	cpu_reset();
 | |
| 
 | |
| 	return 1;
 | |
| 
 | |
| }
 | |
| 
 | |
| u64 flash_read64(void *addr)
 | |
| {
 | |
| 	return __raw_readq(addr);
 | |
| }
 | |
| 
 | |
| /* ------------------------------------------------------------------------- */
 | |
| 
 | |
| #ifdef CONFIG_GRETH
 | |
| int cpu_eth_init(bd_t *bis)
 | |
| {
 | |
| 	return greth_initialize(bis);
 | |
| }
 | |
| #endif
 |