1cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng/* Register names and numbers for PowerPC DWARF.
2cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng   Copyright (C) 2005, 2006, 2007 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#ifdef HAVE_CONFIG_H
27cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng# include <config.h>
28cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng#endif
29cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
30cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng#include <string.h>
31cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng#include <dwarf.h>
32cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
33cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng#define BACKEND ppc_
34cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng#include "libebl_CPU.h"
35cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
36cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Chengssize_t
37cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Chengppc_register_info (Ebl *ebl __attribute__ ((unused)),
38cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng		   int regno, char *name, size_t namelen,
39cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng		   const char **prefix, const char **setname,
40cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng		   int *bits, int *type)
41cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng{
42cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  if (name == NULL)
43cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    return 1156;
44cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
45cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  if (regno < 0 || regno > 1155 || namelen < 8)
46cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    return -1;
47cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
48cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  *prefix = NULL;
49cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  *bits = ebl->machine == EM_PPC64 ? 64 : 32;
50cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  *type = (regno < 32 ? DW_ATE_signed
51cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng	   : regno < 64 ? DW_ATE_float : DW_ATE_unsigned);
52cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
53cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  if (regno < 32 || regno == 64 || regno == 66)
54cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    *setname = "integer";
55cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  else if (regno < 64 || regno == 65)
56cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    {
57cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      *setname = "FPU";
58cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      if (ebl->machine != EM_PPC64 && regno < 64)
59cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng	*bits = 64;
60cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    }
61cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  else if (regno == 67 || regno == 356 || regno == 612 || regno >= 1124)
62cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    {
63cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      *setname = "vector";
64cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      *bits = regno >= 1124 ? 128 : 32;
65cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    }
66cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  else
67cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    *setname = "privileged";
68cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
69cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  switch (regno)
70cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    {
71cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    case 0 ... 9:
72cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      name[0] = 'r';
73cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      name[1] = regno + '0';
74cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      namelen = 2;
75cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      break;
76cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
77cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    case 10 ... 31:
78cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      name[0] = 'r';
79cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      name[1] = regno / 10 + '0';
80cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      name[2] = regno % 10 + '0';
81cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      namelen = 3;
82cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      break;
83cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
84cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    case 32 + 0 ... 32 + 9:
85cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      name[0] = 'f';
86cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      name[1] = (regno - 32) + '0';
87cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      namelen = 2;
88cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      break;
89cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
90cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    case 32 + 10 ... 32 + 31:
91cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      name[0] = 'f';
92cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      name[1] = (regno - 32) / 10 + '0';
93cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      name[2] = (regno - 32) % 10 + '0';
94cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      namelen = 3;
95cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      break;
96cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
97cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    case 64:
98cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      return stpcpy (name, "cr") + 1 - name;
99cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    case 65:
100cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      return stpcpy (name, "fpscr") + 1 - name;
101cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    case 66:
102cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      return stpcpy (name, "msr") + 1 - name;
103cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    case 67:			/* XXX unofficial assignment */
104cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      return stpcpy (name, "vscr") + 1 - name;
105cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
106cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    case 70 + 0 ... 70 + 9:
107cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      name[0] = 's';
108cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      name[1] = 'r';
109cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      name[2] = (regno - 70) + '0';
110cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      namelen = 3;
111cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      break;
112cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
113cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    case 70 + 10 ... 70 + 15:
114cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      name[0] = 's';
115cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      name[1] = 'r';
116cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      name[2] = (regno - 70) / 10 + '0';
117cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      name[3] = (regno - 70) % 10 + '0';
118cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      namelen = 4;
119cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      break;
120cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
121cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    case 101:
122cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      return stpcpy (name, "xer") + 1 - name;
123cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    case 108:
124cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      return stpcpy (name, "lr") + 1 - name;
125cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    case 109:
126cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      return stpcpy (name, "ctr") + 1 - name;
127cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    case 118:
128cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      return stpcpy (name, "dsisr") + 1 - name;
129cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    case 119:
130cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      return stpcpy (name, "dar") + 1 - name;
131cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    case 122:
132cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      return stpcpy (name, "dec") + 1 - name;
133cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    case 356:
134cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      return stpcpy (name, "vrsave") + 1 - name;
135cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    case 612:
136cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      return stpcpy (name, "spefscr") + 1 - name;
137cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    case 100:
138cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      if (*bits == 32)
139cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng	return stpcpy (name, "mq") + 1 - name;
140cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
141cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    case 102 ... 107:
142cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      name[0] = 's';
143cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      name[1] = 'p';
144cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      name[2] = 'r';
145cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      name[3] = (regno - 100) + '0';
146cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      namelen = 4;
147cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      break;
148cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
149cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    case 110 ... 117:
150cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    case 120 ... 121:
151cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    case 123 ... 199:
152cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      name[0] = 's';
153cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      name[1] = 'p';
154cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      name[2] = 'r';
155cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      name[3] = (regno - 100) / 10 + '0';
156cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      name[4] = (regno - 100) % 10 + '0';
157cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      namelen = 5;
158cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      break;
159cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
160cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    case 200 ... 355:
161cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    case 357 ... 611:
162cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    case 613 ... 999:
163cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      name[0] = 's';
164cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      name[1] = 'p';
165cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      name[2] = 'r';
166cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      name[3] = (regno - 100) / 100 + '0';
167cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      name[4] = ((regno - 100) % 100 / 10) + '0';
168cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      name[5] = (regno - 100) % 10 + '0';
169cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      namelen = 6;
170cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      break;
171cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
172cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    case 1124 + 0 ... 1124 + 9:
173cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      name[0] = 'v';
174cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      name[1] = 'r';
175cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      name[2] = (regno - 1124) + '0';
176cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      namelen = 3;
177cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      break;
178cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
179cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    case 1124 + 10 ... 1124 + 31:
180cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      name[0] = 'v';
181cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      name[1] = 'r';
182cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      name[2] = (regno - 1124) / 10 + '0';
183cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      name[3] = (regno - 1124) % 10 + '0';
184cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      namelen = 4;
185cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      break;
186cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
187cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    default:
188cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      *setname = NULL;
189cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng      return 0;
190cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng    }
191cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
192cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  name[namelen++] = '\0';
193cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng  return namelen;
194cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng}
195cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng
196cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng__typeof (ppc_register_info)
197cc6695e2684ce93cdf8bd2da63d55d2cf49ff076Ben Cheng     ppc64_register_info __attribute__ ((alias ("ppc_register_info")));
198