summaryrefslogtreecommitdiff
path: root/gdb/config/m88k/tm-cxux.h
blob: b74f1224f5102182d3777317e798f6c4e06cbf05 (plain)
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
/* Target definitions for m88k running Harris CX/UX.
   Copyright 1993, 1994 Free Software Foundation, Inc.

   This file is part of GDB.

   This program is free software; you can redistribute it and/or modify
   it under the terms of the GNU General Public License as published by
   the Free Software Foundation; either version 2 of the License, or
   (at your option) any later version.

   This program is distributed in the hope that it will be useful,
   but WITHOUT ANY WARRANTY; without even the implied warranty of
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
   GNU General Public License for more details.

   You should have received a copy of the GNU General Public License
   along with this program; if not, write to the Free Software
   Foundation, Inc., 59 Temple Place - Suite 330,
   Boston, MA 02111-1307, USA.  */

#define HARRIS_TARGET 1

#define CXUX_TARGET 1

/* Type of X registers, as supplied by the OS */

typedef struct
  {
    long w1, w2, w3, w4;
  }
X_REGISTER_RAW_TYPE;

#define X_REGISTER_VIRTUAL_TYPE double

#include "m88k/tm-m88k.h"

#define ADD_SHARED_SYMBOL_FILES(args,have_tty)  add_shared_symbol_files ()

#define CONVERT_REGISTER_ADDRESS

/* Always allocate space for both, but recognize that the m88100 has no
   FP_REGS.  */

#undef ARCH_NUM_REGS
#define ARCH_NUM_REGS (target_is_m88110 ? (GP_REGS + FP_REGS) : (GP_REGS))

/* Don't need this grotesquerie.  */

#undef SHIFT_INST_REGS

/* Extended registers are treated as 16 bytes by Harris' OS's. 
   We treat them as 16 bytes here for consistency's sake.  */

#undef REGISTER_RAW_SIZE
#define REGISTER_RAW_SIZE(N) ((N) < XFP_REGNUM ? 4 : 16)

#undef REGISTER_BYTE
#define REGISTER_BYTE(N) \
  ((N) >= XFP_REGNUM \
   ? (((GP_REGS) * REGISTER_RAW_SIZE(0)) + \
      (((N) - XFP_REGNUM) * REGISTER_RAW_SIZE(XFP_REGNUM))) \
   : ((N) * REGISTER_RAW_SIZE(0)))