1da0c48c4Sopenharmony_ci/* M68K specific core note handling.
2da0c48c4Sopenharmony_ci   This file is part of elfutils.
3da0c48c4Sopenharmony_ci
4da0c48c4Sopenharmony_ci   This file is free software; you can redistribute it and/or modify
5da0c48c4Sopenharmony_ci   it under the terms of either
6da0c48c4Sopenharmony_ci
7da0c48c4Sopenharmony_ci     * the GNU Lesser General Public License as published by the Free
8da0c48c4Sopenharmony_ci       Software Foundation; either version 3 of the License, or (at
9da0c48c4Sopenharmony_ci       your option) any later version
10da0c48c4Sopenharmony_ci
11da0c48c4Sopenharmony_ci   or
12da0c48c4Sopenharmony_ci
13da0c48c4Sopenharmony_ci     * the GNU General Public License as published by the Free
14da0c48c4Sopenharmony_ci       Software Foundation; either version 2 of the License, or (at
15da0c48c4Sopenharmony_ci       your option) any later version
16da0c48c4Sopenharmony_ci
17da0c48c4Sopenharmony_ci   or both in parallel, as here.
18da0c48c4Sopenharmony_ci
19da0c48c4Sopenharmony_ci   elfutils is distributed in the hope that it will be useful, but
20da0c48c4Sopenharmony_ci   WITHOUT ANY WARRANTY; without even the implied warranty of
21da0c48c4Sopenharmony_ci   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
22da0c48c4Sopenharmony_ci   General Public License for more details.
23da0c48c4Sopenharmony_ci
24da0c48c4Sopenharmony_ci   You should have received copies of the GNU General Public License and
25da0c48c4Sopenharmony_ci   the GNU Lesser General Public License along with this program.  If
26da0c48c4Sopenharmony_ci   not, see <http://www.gnu.org/licenses/>.  */
27da0c48c4Sopenharmony_ci
28da0c48c4Sopenharmony_ci
29da0c48c4Sopenharmony_ci#ifdef HAVE_CONFIG_H
30da0c48c4Sopenharmony_ci# include <config.h>
31da0c48c4Sopenharmony_ci#endif
32da0c48c4Sopenharmony_ci
33da0c48c4Sopenharmony_ci#include <elf.h>
34da0c48c4Sopenharmony_ci#include <inttypes.h>
35da0c48c4Sopenharmony_ci#include <stddef.h>
36da0c48c4Sopenharmony_ci#include <stdio.h>
37da0c48c4Sopenharmony_ci#include <sys/time.h>
38da0c48c4Sopenharmony_ci
39da0c48c4Sopenharmony_ci#define BACKEND	m68k_
40da0c48c4Sopenharmony_ci#include "libebl_CPU.h"
41da0c48c4Sopenharmony_ci
42da0c48c4Sopenharmony_cistatic const Ebl_Register_Location prstatus_regs[] =
43da0c48c4Sopenharmony_ci  {
44da0c48c4Sopenharmony_ci    { .offset = 0, .regno = 1, .count = 14, .bits = 32 }, /* d1-d7, a0-a6 */
45da0c48c4Sopenharmony_ci    { .offset = 14 * 4, .regno = 0, .count = 1, .bits = 32 }, /* d0 */
46da0c48c4Sopenharmony_ci    { .offset = 15 * 4, .regno = 15, .count = 1, .bits = 32 }, /* a7 */
47da0c48c4Sopenharmony_ci    { .offset = 18 * 4, .regno = 24, .count = 1, .bits = 32 } /* pc */
48da0c48c4Sopenharmony_ci  };
49da0c48c4Sopenharmony_ci#define PRSTATUS_REGS_SIZE	(20 * 4)
50da0c48c4Sopenharmony_ci
51da0c48c4Sopenharmony_ci#define ULONG			uint32_t
52da0c48c4Sopenharmony_ci#define PID_T			int32_t
53da0c48c4Sopenharmony_ci#define	UID_T			uint16_t
54da0c48c4Sopenharmony_ci#define	GID_T			uint16_t
55da0c48c4Sopenharmony_ci#define ALIGN_INT		2
56da0c48c4Sopenharmony_ci#define ALIGN_ULONG		2
57da0c48c4Sopenharmony_ci#define ALIGN_PID_T		2
58da0c48c4Sopenharmony_ci#define ALIGN_UID_T		2
59da0c48c4Sopenharmony_ci#define ALIGN_GID_T		2
60da0c48c4Sopenharmony_ci#define ALIGN_PRSTATUS		2
61da0c48c4Sopenharmony_ci#define TYPE_ULONG		ELF_T_WORD
62da0c48c4Sopenharmony_ci#define TYPE_PID_T		ELF_T_SWORD
63da0c48c4Sopenharmony_ci#define TYPE_UID_T		ELF_T_HALF
64da0c48c4Sopenharmony_ci#define TYPE_GID_T		ELF_T_HALF
65da0c48c4Sopenharmony_ci
66da0c48c4Sopenharmony_cistatic const Ebl_Register_Location fpregset_regs[] =
67da0c48c4Sopenharmony_ci  {
68da0c48c4Sopenharmony_ci    { .offset = 0, .regno = 16, .count = 8, .bits = 96 }, /* fp0-fp7 */
69da0c48c4Sopenharmony_ci  };
70da0c48c4Sopenharmony_ci#define FPREGSET_SIZE	(27 * 4)
71da0c48c4Sopenharmony_ci
72da0c48c4Sopenharmony_ci#include "linux-core-note.c"
73