summaryrefslogtreecommitdiff
path: root/gdb/features/mips-dsp-linux.c
blob: d9d928c80128f16e61e62a352b57c8f733f0c843 (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
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
/* THIS FILE IS GENERATED.  -*- buffer-read-only: t -*- vi:set ro:
  Original: mips-dsp-linux.xml */

#include "defs.h"
#include "osabi.h"
#include "target-descriptions.h"

const struct target_desc *tdesc_mips_dsp_linux;
static void
initialize_tdesc_mips_dsp_linux (void)
{
  target_desc_up result = allocate_target_description ();
  set_tdesc_architecture (result.get (), bfd_scan_arch ("mips"));

  set_tdesc_osabi (result.get (), osabi_from_tdesc_string ("GNU/Linux"));

  struct tdesc_feature *feature;

  feature = tdesc_create_feature (result.get (), "org.gnu.gdb.mips.cpu");
  tdesc_create_reg (feature, "r0", 0, 1, NULL, 32, "int");
  tdesc_create_reg (feature, "r1", 1, 1, NULL, 32, "int");
  tdesc_create_reg (feature, "r2", 2, 1, NULL, 32, "int");
  tdesc_create_reg (feature, "r3", 3, 1, NULL, 32, "int");
  tdesc_create_reg (feature, "r4", 4, 1, NULL, 32, "int");
  tdesc_create_reg (feature, "r5", 5, 1, NULL, 32, "int");
  tdesc_create_reg (feature, "r6", 6, 1, NULL, 32, "int");
  tdesc_create_reg (feature, "r7", 7, 1, NULL, 32, "int");
  tdesc_create_reg (feature, "r8", 8, 1, NULL, 32, "int");
  tdesc_create_reg (feature, "r9", 9, 1, NULL, 32, "int");
  tdesc_create_reg (feature, "r10", 10, 1, NULL, 32, "int");
  tdesc_create_reg (feature, "r11", 11, 1, NULL, 32, "int");
  tdesc_create_reg (feature, "r12", 12, 1, NULL, 32, "int");
  tdesc_create_reg (feature, "r13", 13, 1, NULL, 32, "int");
  tdesc_create_reg (feature, "r14", 14, 1, NULL, 32, "int");
  tdesc_create_reg (feature, "r15", 15, 1, NULL, 32, "int");
  tdesc_create_reg (feature, "r16", 16, 1, NULL, 32, "int");
  tdesc_create_reg (feature, "r17", 17, 1, NULL, 32, "int");
  tdesc_create_reg (feature, "r18", 18, 1, NULL, 32, "int");
  tdesc_create_reg (feature, "r19", 19, 1, NULL, 32, "int");
  tdesc_create_reg (feature, "r20", 20, 1, NULL, 32, "int");
  tdesc_create_reg (feature, "r21", 21, 1, NULL, 32, "int");
  tdesc_create_reg (feature, "r22", 22, 1, NULL, 32, "int");
  tdesc_create_reg (feature, "r23", 23, 1, NULL, 32, "int");
  tdesc_create_reg (feature, "r24", 24, 1, NULL, 32, "int");
  tdesc_create_reg (feature, "r25", 25, 1, NULL, 32, "int");
  tdesc_create_reg (feature, "r26", 26, 1, NULL, 32, "int");
  tdesc_create_reg (feature, "r27", 27, 1, NULL, 32, "int");
  tdesc_create_reg (feature, "r28", 28, 1, NULL, 32, "int");
  tdesc_create_reg (feature, "r29", 29, 1, NULL, 32, "int");
  tdesc_create_reg (feature, "r30", 30, 1, NULL, 32, "int");
  tdesc_create_reg (feature, "r31", 31, 1, NULL, 32, "int");
  tdesc_create_reg (feature, "lo", 33, 1, NULL, 32, "int");
  tdesc_create_reg (feature, "hi", 34, 1, NULL, 32, "int");
  tdesc_create_reg (feature, "pc", 37, 1, NULL, 32, "int");

  feature = tdesc_create_feature (result.get (), "org.gnu.gdb.mips.cp0");
  tdesc_create_reg (feature, "status", 32, 1, NULL, 32, "int");
  tdesc_create_reg (feature, "badvaddr", 35, 1, NULL, 32, "int");
  tdesc_create_reg (feature, "cause", 36, 1, NULL, 32, "int");

  feature = tdesc_create_feature (result.get (), "org.gnu.gdb.mips.fpu");
  tdesc_create_reg (feature, "f0", 38, 1, NULL, 32, "ieee_single");
  tdesc_create_reg (feature, "f1", 39, 1, NULL, 32, "ieee_single");
  tdesc_create_reg (feature, "f2", 40, 1, NULL, 32, "ieee_single");
  tdesc_create_reg (feature, "f3", 41, 1, NULL, 32, "ieee_single");
  tdesc_create_reg (feature, "f4", 42, 1, NULL, 32, "ieee_single");
  tdesc_create_reg (feature, "f5", 43, 1, NULL, 32, "ieee_single");
  tdesc_create_reg (feature, "f6", 44, 1, NULL, 32, "ieee_single");
  tdesc_create_reg (feature, "f7", 45, 1, NULL, 32, "ieee_single");
  tdesc_create_reg (feature, "f8", 46, 1, NULL, 32, "ieee_single");
  tdesc_create_reg (feature, "f9", 47, 1, NULL, 32, "ieee_single");
  tdesc_create_reg (feature, "f10", 48, 1, NULL, 32, "ieee_single");
  tdesc_create_reg (feature, "f11", 49, 1, NULL, 32, "ieee_single");
  tdesc_create_reg (feature, "f12", 50, 1, NULL, 32, "ieee_single");
  tdesc_create_reg (feature, "f13", 51, 1, NULL, 32, "ieee_single");
  tdesc_create_reg (feature, "f14", 52, 1, NULL, 32, "ieee_single");
  tdesc_create_reg (feature, "f15", 53, 1, NULL, 32, "ieee_single");
  tdesc_create_reg (feature, "f16", 54, 1, NULL, 32, "ieee_single");
  tdesc_create_reg (feature, "f17", 55, 1, NULL, 32, "ieee_single");
  tdesc_create_reg (feature, "f18", 56, 1, NULL, 32, "ieee_single");
  tdesc_create_reg (feature, "f19", 57, 1, NULL, 32, "ieee_single");
  tdesc_create_reg (feature, "f20", 58, 1, NULL, 32, "ieee_single");
  tdesc_create_reg (feature, "f21", 59, 1, NULL, 32, "ieee_single");
  tdesc_create_reg (feature, "f22", 60, 1, NULL, 32, "ieee_single");
  tdesc_create_reg (feature, "f23", 61, 1, NULL, 32, "ieee_single");
  tdesc_create_reg (feature, "f24", 62, 1, NULL, 32, "ieee_single");
  tdesc_create_reg (feature, "f25", 63, 1, NULL, 32, "ieee_single");
  tdesc_create_reg (feature, "f26", 64, 1, NULL, 32, "ieee_single");
  tdesc_create_reg (feature, "f27", 65, 1, NULL, 32, "ieee_single");
  tdesc_create_reg (feature, "f28", 66, 1, NULL, 32, "ieee_single");
  tdesc_create_reg (feature, "f29", 67, 1, NULL, 32, "ieee_single");
  tdesc_create_reg (feature, "f30", 68, 1, NULL, 32, "ieee_single");
  tdesc_create_reg (feature, "f31", 69, 1, NULL, 32, "ieee_single");
  tdesc_create_reg (feature, "fcsr", 70, 1, "float", 32, "int");
  tdesc_create_reg (feature, "fir", 71, 1, "float", 32, "int");

  feature = tdesc_create_feature (result.get (), "org.gnu.gdb.mips.dsp");
  tdesc_create_reg (feature, "hi1", 72, 1, NULL, 32, "int");
  tdesc_create_reg (feature, "lo1", 73, 1, NULL, 32, "int");
  tdesc_create_reg (feature, "hi2", 74, 1, NULL, 32, "int");
  tdesc_create_reg (feature, "lo2", 75, 1, NULL, 32, "int");
  tdesc_create_reg (feature, "hi3", 76, 1, NULL, 32, "int");
  tdesc_create_reg (feature, "lo3", 77, 1, NULL, 32, "int");
  tdesc_create_reg (feature, "dspctl", 78, 1, NULL, 32, "int");

  feature = tdesc_create_feature (result.get (), "org.gnu.gdb.mips.linux");
  tdesc_create_reg (feature, "restart", 79, 1, "system", 32, "int");

  tdesc_mips_dsp_linux = result.release ();
}