1cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng/* Common core note type descriptions for Linux.
2cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng   Copyright (C) 2007, 2008 Red Hat, Inc.
3cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng   This file is part of Red Hat elfutils.
4cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
5cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng   Red Hat elfutils is free software; you can redistribute it and/or modify
6cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng   it under the terms of the GNU General Public License as published by the
7cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng   Free Software Foundation; version 2 of the License.
8cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
9cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng   Red Hat elfutils is distributed in the hope that it will be useful, but
10cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng   WITHOUT ANY WARRANTY; without even the implied warranty of
11cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
12cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng   General Public License for more details.
13cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
14cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng   You should have received a copy of the GNU General Public License along
15cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng   with Red Hat elfutils; if not, write to the Free Software Foundation,
16cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng   Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301 USA.
17cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
18cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng   Red Hat elfutils is an included package of the Open Invention Network.
19cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng   An included package of the Open Invention Network is a package for which
20cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng   Open Invention Network licensees cross-license their patents.  No patent
21cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng   license is granted, either expressly or impliedly, by designation as an
22cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng   included package.  Should you wish to participate in the Open Invention
23cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng   Network licensing program, please visit www.openinventionnetwork.com
24cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng   <http://www.openinventionnetwork.com>.  */
25cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
26cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng/* The including CPU_corenote.c file provides prstatus_regs and
27cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng   defines macros ULONG, [PUG]ID_T, and ALIGN_*, TYPE_*.
28cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
29cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng   Here we describe the common layout used in <linux/elfcore.h>.  */
30cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
31cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng#define	CHAR			int8_t
32cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng#define	ALIGN_CHAR		1
33cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng#define	TYPE_CHAR		ELF_T_BYTE
34cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng#define	SHORT			uint16_t
35cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng#define ALIGN_SHORT		2
36cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng#define TYPE_SHORT		ELF_T_HALF
37cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng#define	INT			int32_t
38cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng#define ALIGN_INT		4
39cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng#define TYPE_INT		ELF_T_SWORD
40cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
41cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng#define FIELD(type, name) type name __attribute__ ((aligned (ALIGN_##type)))
42cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
43cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Chengstruct EBLHOOK(siginfo)
44cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng{
45cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  FIELD (INT, si_signo);
46cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  FIELD (INT, si_code);
47cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  FIELD (INT, si_errno);
48cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng};
49cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
50cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Chengstruct EBLHOOK(timeval)
51cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng{
52cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  FIELD (ULONG, tv_sec);
53cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  FIELD (ULONG, tv_usec);
54cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng};
55cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
56cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng/* On sparc64, tv_usec (suseconds_t) is actually 32 bits with 32 bits padding.
57cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng   The 'T'|0x80 value for .format indicates this as a special kludge.  */
58cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng#if SUSECONDS_HALF
59cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng# define TIMEVAL_FIELD(name)	FIELD (time, ULONG, name, 'T'|0x80, .count = 2)
60cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng#else
61cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng# define TIMEVAL_FIELD(name)	FIELD (time, ULONG, name, 'T', .count = 2)
62cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng#endif
63cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
64cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
65cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Chengstruct EBLHOOK(prstatus)
66cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng{
67cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  struct EBLHOOK(siginfo) pr_info;
68cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  FIELD (SHORT, pr_cursig);
69cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  FIELD (ULONG, pr_sigpend);
70cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  FIELD (ULONG, pr_sighold);
71cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  FIELD (PID_T, pr_pid);
72cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  FIELD (PID_T, pr_ppid);
73cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  FIELD (PID_T, pr_pgrp);
74cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  FIELD (PID_T, pr_sid);
75cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  struct EBLHOOK(timeval) pr_utime;
76cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  struct EBLHOOK(timeval) pr_stime;
77cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  struct EBLHOOK(timeval) pr_cutime;
78cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  struct EBLHOOK(timeval) pr_cstime;
79cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  FIELD (ULONG, pr_reg[PRSTATUS_REGS_SIZE / sizeof (ULONG)]);
80cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  FIELD (INT, pr_fpvalid);
81cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng};
82cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
83cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng#define	FNAMESZ	16
84cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng#define	PRARGSZ	80
85cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
86cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Chengstruct EBLHOOK(prpsinfo)
87cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng{
88cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  FIELD (CHAR, pr_state);
89cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  FIELD (CHAR, pr_sname);
90cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  FIELD (CHAR, pr_zomb);
91cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  FIELD (CHAR, pr_nice);
92cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  FIELD (ULONG, pr_flag);
93cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  FIELD (UID_T, pr_uid);
94cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  FIELD (GID_T, pr_gid);
95cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  FIELD (PID_T, pr_pid);
96cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  FIELD (PID_T, pr_ppid);
97cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  FIELD (PID_T, pr_pgrp);
98cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  FIELD (PID_T, pr_sid);
99cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  FIELD (CHAR, pr_fname[FNAMESZ]);
100cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  FIELD (CHAR, pr_psargs[PRARGSZ]);
101cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng};
102cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
103cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng#undef	FIELD
104cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
105cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng#define FIELD(igroup, itype, item, fmt, ...)			\
106cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    {								\
107cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      .name = #item,						\
108cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      .group = #igroup,					\
109cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      .offset = offsetof (struct EBLHOOK(prstatus), pr_##item),	\
110cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      .type = TYPE_##itype,					\
111cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      .format = fmt,						\
112cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      __VA_ARGS__						\
113cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    }
114cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
115cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Chengstatic const Ebl_Core_Item prstatus_items[] =
116cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  {
117cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    FIELD (signal, INT, info.si_signo, 'd'),
118cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    FIELD (signal, INT, info.si_code, 'd'),
119cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    FIELD (signal, INT, info.si_errno, 'd'),
120cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    FIELD (signal, SHORT, cursig, 'd'),
121cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    FIELD (signal, ULONG, sigpend, 'B'),
122cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    FIELD (signal, ULONG, sighold, 'B'),
123cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    FIELD (identity, PID_T, pid, 'd', .thread_identifier = true),
124cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    FIELD (identity, PID_T, ppid, 'd'),
125cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    FIELD (identity, PID_T, pgrp, 'd'),
126cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    FIELD (identity, PID_T, sid, 'd'),
127cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    TIMEVAL_FIELD (utime),
128cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    TIMEVAL_FIELD (stime),
129cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    TIMEVAL_FIELD (cutime),
130cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    TIMEVAL_FIELD (cstime),
131cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng#ifdef PRSTATUS_REGSET_ITEMS
132cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    PRSTATUS_REGSET_ITEMS,
133cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng#endif
134cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    FIELD (register, INT, fpvalid, 'd'),
135cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  };
136cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
137cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng#undef	FIELD
138cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
139cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng#define FIELD(igroup, itype, item, fmt, ...)			\
140cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    {								\
141cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      .name = #item,						\
142cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      .group = #igroup,					\
143cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      .offset = offsetof (struct EBLHOOK(prpsinfo), pr_##item),	\
144cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      .type = TYPE_##itype,					\
145cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      .format = fmt,						\
146cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      __VA_ARGS__						\
147cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    }
148cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
149cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Chengstatic const Ebl_Core_Item prpsinfo_items[] =
150cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  {
151cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    FIELD (state, CHAR, state, 'd'),
152cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    FIELD (state, CHAR, sname, 'c'),
153cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    FIELD (state, CHAR, zomb, 'd'),
154cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    FIELD (state, CHAR, nice, 'd'),
155cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    FIELD (state, ULONG, flag, 'x'),
156cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    FIELD (identity, UID_T, uid, 'd'),
157cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    FIELD (identity, GID_T, gid, 'd'),
158cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    FIELD (identity, PID_T, pid, 'd'),
159cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    FIELD (identity, PID_T, ppid, 'd'),
160cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    FIELD (identity, PID_T, pgrp, 'd'),
161cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    FIELD (identity, PID_T, sid, 'd'),
162cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    FIELD (command, CHAR, fname, 's', .count = FNAMESZ),
163cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    FIELD (command, CHAR, psargs, 's', .count = PRARGSZ),
164cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  };
165cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
166cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng#undef	FIELD
167cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
168cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Chengint
169cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben ChengEBLHOOK(core_note) (n_type, descsz,
170cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng		    regs_offset, nregloc, reglocs, nitems, items)
171cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng     GElf_Word n_type;
172cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng     GElf_Word descsz;
173cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng     GElf_Word *regs_offset;
174cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng     size_t *nregloc;
175cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng     const Ebl_Register_Location **reglocs;
176cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng     size_t *nitems;
177cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng     const Ebl_Core_Item **items;
178cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng{
179cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  switch (n_type)
180cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    {
181cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    case NT_PRSTATUS:
182cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      if (descsz != sizeof (struct EBLHOOK(prstatus)))
183cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng	return 0;
184cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      *regs_offset = offsetof (struct EBLHOOK(prstatus), pr_reg);
185cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      *nregloc = sizeof prstatus_regs / sizeof prstatus_regs[0];
186cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      *reglocs = prstatus_regs;
187cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      *nitems = sizeof prstatus_items / sizeof prstatus_items[0];
188cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      *items = prstatus_items;
189cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      return 1;
190cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
191cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    case NT_PRPSINFO:
192cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      if (descsz != sizeof (struct EBLHOOK(prpsinfo)))
193cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng	return 0;
194cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      *regs_offset = 0;
195cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      *nregloc = 0;
196cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      *reglocs = NULL;
197cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      *nitems = sizeof prpsinfo_items / sizeof prpsinfo_items[0];
198cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      *items = prpsinfo_items;
199cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      return 1;
200cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
201cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng#define EXTRA_REGSET(type, size, table)					      \
202cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    case type:								      \
203cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      if (descsz != size)						      \
204cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng	return 0;							      \
205cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      *regs_offset = 0;							      \
206cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      *nregloc = sizeof table / sizeof table[0];			      \
207cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      *reglocs = table;							      \
208cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      *nitems = 0;							      \
209cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      *items = NULL;							      \
210cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      return 1;
211cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
212cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng#ifdef FPREGSET_SIZE
213cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    EXTRA_REGSET (NT_FPREGSET, FPREGSET_SIZE, fpregset_regs)
214cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng#endif
215cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
216cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng#ifdef EXTRA_NOTES
217cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    EXTRA_NOTES
218cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng#endif
219cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    }
220cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
221cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  return 0;
222cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng}
223