This commit was generated by cvs2svn to track changes on a CVS vendor
[deliverable/binutils-gdb.git] / sim / igen / misc.c
1 /* This file is part of the program psim.
2
3 Copyright (C) 1994-1995, Andrew Cagney <cagney@highland.com.au>
4
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.
9
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.
14
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.
18
19 */
20
21
22 #include <stdio.h>
23 #include <stdarg.h>
24 #include <ctype.h>
25
26 #include "config.h"
27 #include "misc.h"
28
29 #ifdef HAVE_STDLIB_H
30 #include <stdlib.h>
31 #endif
32
33 #ifdef HAVE_STRING_H
34 #include <string.h>
35 #else
36 #ifdef HAVE_STRINGS_H
37 #include <strings.h>
38 #endif
39 #endif
40
41 void
42 error (char *msg, ...)
43 {
44 va_list ap;
45 va_start(ap, msg);
46 vprintf(msg, ap);
47 va_end(ap);
48 exit (1);
49 }
50
51 void *
52 zalloc(long size)
53 {
54 void *memory = malloc(size);
55 if (memory == NULL)
56 error("zalloc failed\n");
57 memset(memory, 0, size);
58 return memory;
59 }
60
61 void
62 dumpf (int indent, char *msg, ...)
63 {
64 va_list ap;
65 for (; indent > 0; indent--)
66 printf(" ");
67 va_start(ap, msg);
68 vprintf(msg, ap);
69 va_end(ap);
70 }
71
72
73 unsigned long long
74 a2i(const char *a)
75 {
76 int neg = 0;
77 int base = 10;
78 unsigned long long num = 0;
79 int looping;
80
81 while (isspace (*a))
82 a++;
83
84 if (*a == '-') {
85 neg = 1;
86 a++;
87 }
88
89 if (*a == '0') {
90 if (a[1] == 'x' || a[1] == 'X') {
91 a += 2;
92 base = 16;
93 } else if (a[1] == 'b' || a[1] == 'b') {
94 a += 2;
95 base = 2;
96 }
97 else
98 base = 8;
99 }
100
101 looping = 1;
102 while (looping) {
103 int ch = *a++;
104
105 switch (base) {
106 default:
107 looping = 0;
108 break;
109
110 case 2:
111 if (ch >= '0' && ch <= '1') {
112 num = (num * 2) + (ch - '0');
113 } else {
114 looping = 0;
115 }
116 break;
117
118 case 10:
119 if (ch >= '0' && ch <= '9') {
120 num = (num * 10) + (ch - '0');
121 } else {
122 looping = 0;
123 }
124 break;
125
126 case 8:
127 if (ch >= '0' && ch <= '7') {
128 num = (num * 8) + (ch - '0');
129 } else {
130 looping = 0;
131 }
132 break;
133
134 case 16:
135 if (ch >= '0' && ch <= '9') {
136 num = (num * 16) + (ch - '0');
137 } else if (ch >= 'a' && ch <= 'f') {
138 num = (num * 16) + (ch - 'a' + 10);
139 } else if (ch >= 'A' && ch <= 'F') {
140 num = (num * 16) + (ch - 'A' + 10);
141 } else {
142 looping = 0;
143 }
144 break;
145 }
146 }
147
148 if (neg)
149 num = - num;
150
151 return num;
152 }
153
154 unsigned
155 target_a2i(int ms_bit_nr,
156 const char *a)
157 {
158 if (ms_bit_nr)
159 return (ms_bit_nr - a2i(a));
160 else
161 return a2i(a);
162 }
163
164 unsigned
165 i2target(int ms_bit_nr,
166 unsigned bit)
167 {
168 if (ms_bit_nr)
169 return ms_bit_nr - bit;
170 else
171 return bit;
172 }
173
174
175 int
176 name2i(const char *names,
177 const name_map *map)
178 {
179 const name_map *curr;
180 const char *name = names;
181 while (*name != '\0') {
182 /* find our name */
183 char *end = strchr(name, ',');
184 char *next;
185 int len;
186 if (end == NULL) {
187 end = strchr(name, '\0');
188 next = end;
189 }
190 else {
191 next = end + 1;
192 }
193 len = end - name;
194 /* look it up */
195 curr = map;
196 while (curr->name != NULL) {
197 if (strncmp(curr->name, name, len) == 0
198 && strlen(curr->name) == len)
199 return curr->i;
200 curr++;
201 }
202 name = next;
203 }
204 /* nothing found, possibly return a default */
205 curr = map;
206 while (curr->name != NULL)
207 curr++;
208 if (curr->i >= 0)
209 return curr->i;
210 else
211 error("%s contains no valid names\n", names);
212 return 0;
213 }
214
215 const char *
216 i2name(const int i,
217 const name_map *map)
218 {
219 while (map->name != NULL) {
220 if (map->i == i)
221 return map->name;
222 map++;
223 }
224 error("map lookup failed for %d\n", i);
225 return NULL;
226 }
This page took 0.034845 seconds and 5 git commands to generate.