hc
2023-10-25 6c2073b7aa40e29d0eca7d571dd7bc590c7ecaa7
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
/* 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>
#include <linux/mm_types.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 */