Sync usage with man page.
[netbsd-mini2440.git] / gnu / dist / gdb6 / sim / ppc / misc.c
blobd8e54ed497beb1ac06018f6866290e9e400c38f6
1 /* This file is part of the program psim.
3 Copyright (C) 1994-1997, Andrew Cagney <cagney@highland.com.au>
5 This program is free software; you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation; either version 2 of the License, or
8 (at your option) any later version.
10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 GNU General Public License for more details.
15 You should have received a copy of the GNU General Public License
16 along with this program; if not, write to the Free Software
17 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
22 #include <stdio.h>
23 #include <stdarg.h>
24 #include <ctype.h>
26 #include "config.h"
27 #include "misc.h"
29 #ifdef HAVE_STDLIB_H
30 #include <stdlib.h>
31 #endif
33 #ifdef HAVE_STRING_H
34 #include <string.h>
35 #else
36 #ifdef HAVE_STRINGS_H
37 #include <strings.h>
38 #endif
39 #endif
41 void
42 error (char *msg, ...)
44 va_list ap;
45 va_start(ap, msg);
46 vprintf(msg, ap);
47 va_end(ap);
48 exit (1);
51 void *
52 zalloc(long size)
54 void *memory = malloc(size);
55 if (memory == NULL)
56 error("zalloc failed\n");
57 memset(memory, 0, size);
58 return memory;
61 void
62 dumpf (int indent, char *msg, ...)
64 va_list ap;
65 for (; indent > 0; indent--)
66 printf(" ");
67 va_start(ap, msg);
68 vprintf(msg, ap);
69 va_end(ap);
73 unsigned
74 a2i(const char *a)
76 int neg = 0;
77 int base = 10;
78 unsigned num = 0;
79 int looping;
81 while (isspace (*a))
82 a++;
84 if (*a == '-') {
85 neg = 1;
86 a++;
89 if (*a == '0') {
90 if (a[1] == 'x' || a[1] == 'X') {
91 a += 2;
92 base = 16;
94 else
95 base = 8;
98 looping = 1;
99 while (looping) {
100 int ch = *a++;
102 switch (base) {
103 default:
104 looping = 0;
105 break;
107 case 10:
108 if (ch >= '0' && ch <= '9') {
109 num = (num * 10) + (ch - '0');
110 } else {
111 looping = 0;
113 break;
115 case 8:
116 if (ch >= '0' && ch <= '7') {
117 num = (num * 8) + (ch - '0');
118 } else {
119 looping = 0;
121 break;
123 case 16:
124 if (ch >= '0' && ch <= '9') {
125 num = (num * 16) + (ch - '0');
126 } else if (ch >= 'a' && ch <= 'f') {
127 num = (num * 16) + (ch - 'a' + 10);
128 } else if (ch >= 'A' && ch <= 'F') {
129 num = (num * 16) + (ch - 'A' + 10);
130 } else {
131 looping = 0;
133 break;
137 if (neg)
138 num = - num;
140 return num;
143 unsigned
144 target_a2i(int ms_bit_nr,
145 const char *a)
147 if (ms_bit_nr)
148 return (ms_bit_nr - a2i(a));
149 else
150 return a2i(a);
153 unsigned
154 i2target(int ms_bit_nr,
155 unsigned bit)
157 if (ms_bit_nr)
158 return ms_bit_nr - bit;
159 else
160 return bit;
165 name2i(const char *names,
166 const name_map *map)
168 const name_map *curr;
169 const char *name = names;
170 while (*name != '\0') {
171 /* find our name */
172 char *end = strchr(name, ',');
173 char *next;
174 int len;
175 if (end == NULL) {
176 end = strchr(name, '\0');
177 next = end;
179 else {
180 next = end + 1;
182 len = end - name;
183 /* look it up */
184 curr = map;
185 while (curr->name != NULL) {
186 if (strncmp(curr->name, name, len) == 0
187 && strlen(curr->name) == len)
188 return curr->i;
189 curr++;
191 name = next;
193 /* nothing found, possibly return a default */
194 curr = map;
195 while (curr->name != NULL)
196 curr++;
197 if (curr->i >= 0)
198 return curr->i;
199 else
200 error("%s contains no valid names\n", names);
201 return 0;
204 const char *
205 i2name(const int i,
206 const name_map *map)
208 while (map->name != NULL) {
209 if (map->i == i)
210 return map->name;
211 map++;
213 error("map lookup failed for %d\n", i);
214 return NULL;