81 lines
		
	
	
	
		
			2.4 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
		
		
			
		
	
	
			81 lines
		
	
	
	
		
			2.4 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
|   | /* a.out coredump register dumper
 | ||
|  |  * | ||
|  |  * Copyright (C) 2007 Red Hat, Inc. All Rights Reserved. | ||
|  |  * Written by David Howells (dhowells@redhat.com) | ||
|  |  * | ||
|  |  * This program is free software; you can redistribute it and/or | ||
|  |  * modify it under the terms of the GNU General Public Licence | ||
|  |  * as published by the Free Software Foundation; either version | ||
|  |  * 2 of the Licence, or (at your option) any later version. | ||
|  |  */ | ||
|  | 
 | ||
|  | #ifndef _ASM_A_OUT_CORE_H
 | ||
|  | #define _ASM_A_OUT_CORE_H
 | ||
|  | 
 | ||
|  | #ifdef __KERNEL__
 | ||
|  | 
 | ||
|  | #include <linux/user.h>
 | ||
|  | 
 | ||
|  | /*
 | ||
|  |  * Fill in the user structure for an ECOFF core dump. | ||
|  |  */ | ||
|  | static inline void aout_dump_thread(struct pt_regs *pt, struct user *dump) | ||
|  | { | ||
|  | 	/* switch stack follows right below pt_regs: */ | ||
|  | 	struct switch_stack * sw = ((struct switch_stack *) pt) - 1; | ||
|  | 
 | ||
|  | 	dump->magic = CMAGIC; | ||
|  | 	dump->start_code  = current->mm->start_code; | ||
|  | 	dump->start_data  = current->mm->start_data; | ||
|  | 	dump->start_stack = rdusp() & ~(PAGE_SIZE - 1); | ||
|  | 	dump->u_tsize = ((current->mm->end_code - dump->start_code) | ||
|  | 			 >> PAGE_SHIFT); | ||
|  | 	dump->u_dsize = ((current->mm->brk + PAGE_SIZE-1 - dump->start_data) | ||
|  | 			 >> PAGE_SHIFT); | ||
|  | 	dump->u_ssize = (current->mm->start_stack - dump->start_stack | ||
|  | 			 + PAGE_SIZE-1) >> PAGE_SHIFT; | ||
|  | 
 | ||
|  | 	/*
 | ||
|  | 	 * We store the registers in an order/format that is | ||
|  | 	 * compatible with DEC Unix/OSF/1 as this makes life easier | ||
|  | 	 * for gdb. | ||
|  | 	 */ | ||
|  | 	dump->regs[EF_V0]  = pt->r0; | ||
|  | 	dump->regs[EF_T0]  = pt->r1; | ||
|  | 	dump->regs[EF_T1]  = pt->r2; | ||
|  | 	dump->regs[EF_T2]  = pt->r3; | ||
|  | 	dump->regs[EF_T3]  = pt->r4; | ||
|  | 	dump->regs[EF_T4]  = pt->r5; | ||
|  | 	dump->regs[EF_T5]  = pt->r6; | ||
|  | 	dump->regs[EF_T6]  = pt->r7; | ||
|  | 	dump->regs[EF_T7]  = pt->r8; | ||
|  | 	dump->regs[EF_S0]  = sw->r9; | ||
|  | 	dump->regs[EF_S1]  = sw->r10; | ||
|  | 	dump->regs[EF_S2]  = sw->r11; | ||
|  | 	dump->regs[EF_S3]  = sw->r12; | ||
|  | 	dump->regs[EF_S4]  = sw->r13; | ||
|  | 	dump->regs[EF_S5]  = sw->r14; | ||
|  | 	dump->regs[EF_S6]  = sw->r15; | ||
|  | 	dump->regs[EF_A3]  = pt->r19; | ||
|  | 	dump->regs[EF_A4]  = pt->r20; | ||
|  | 	dump->regs[EF_A5]  = pt->r21; | ||
|  | 	dump->regs[EF_T8]  = pt->r22; | ||
|  | 	dump->regs[EF_T9]  = pt->r23; | ||
|  | 	dump->regs[EF_T10] = pt->r24; | ||
|  | 	dump->regs[EF_T11] = pt->r25; | ||
|  | 	dump->regs[EF_RA]  = pt->r26; | ||
|  | 	dump->regs[EF_T12] = pt->r27; | ||
|  | 	dump->regs[EF_AT]  = pt->r28; | ||
|  | 	dump->regs[EF_SP]  = rdusp(); | ||
|  | 	dump->regs[EF_PS]  = pt->ps; | ||
|  | 	dump->regs[EF_PC]  = pt->pc; | ||
|  | 	dump->regs[EF_GP]  = pt->gp; | ||
|  | 	dump->regs[EF_A0]  = pt->r16; | ||
|  | 	dump->regs[EF_A1]  = pt->r17; | ||
|  | 	dump->regs[EF_A2]  = pt->r18; | ||
|  | 	memcpy((char *)dump->regs + EF_SIZE, sw->fp, 32 * 8); | ||
|  | } | ||
|  | 
 | ||
|  | #endif /* __KERNEL__ */
 | ||
|  | #endif /* _ASM_A_OUT_CORE_H */
 |