mirror of
				https://source.denx.de/u-boot/u-boot.git
				synced 2025-10-24 22:11:26 +02:00 
			
		
		
		
	In order to set own exception handlers, a table with the exception vectors must be built in DRAM and the CPU EBase register must be set to the base address of this table. Reserve the space above the stack and use gd->irq_sp as storage for the exception base address. Signed-off-by: Daniel Schwierzeck <daniel.schwierzeck@gmail.com>
		
			
				
	
	
		
			20 lines
		
	
	
		
			374 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			20 lines
		
	
	
		
			374 B
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * SPDX-License-Identifier:	GPL-2.0+
 | |
|  */
 | |
| 
 | |
| #include <common.h>
 | |
| 
 | |
| DECLARE_GLOBAL_DATA_PTR;
 | |
| 
 | |
| int arch_reserve_stacks(void)
 | |
| {
 | |
| 	/* reserve space for exception vector table */
 | |
| 	gd->start_addr_sp -= 0x500;
 | |
| 	gd->start_addr_sp &= ~0xFFF;
 | |
| 	gd->irq_sp = gd->start_addr_sp;
 | |
| 	debug("Reserving %d Bytes for exception vector at: %08lx\n",
 | |
| 	      0x500, gd->start_addr_sp);
 | |
| 
 | |
| 	return 0;
 | |
| }
 |