[PATCH 22/57][Arm][GAS] Add support for MVE instructions: vmlaldav, vmlalv, vmlsldav...
[binutils-gdb.git] / sim / ppc / misc.c
blob8c21bd38b1b8d374fe6142bdfde6133b16d252d5
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 3 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, see <http://www.gnu.org/licenses/>.
21 #include <stdio.h>
22 #include <stdarg.h>
23 #include <ctype.h>
25 #include "build-config.h"
26 #include "misc.h"
28 #ifdef HAVE_STDLIB_H
29 #include <stdlib.h>
30 #endif
32 #ifdef HAVE_STRING_H
33 #include <string.h>
34 #else
35 #ifdef HAVE_STRINGS_H
36 #include <strings.h>
37 #endif
38 #endif
40 void
41 error (char *msg, ...)
43 va_list ap;
44 va_start(ap, msg);
45 vprintf(msg, ap);
46 va_end(ap);
47 exit (1);
50 void *
51 zalloc(long size)
53 void *memory = malloc(size);
54 if (memory == NULL)
55 error("zalloc failed\n");
56 memset(memory, 0, size);
57 return memory;
60 void
61 dumpf (int indent, char *msg, ...)
63 va_list ap;
64 for (; indent > 0; indent--)
65 printf(" ");
66 va_start(ap, msg);
67 vprintf(msg, ap);
68 va_end(ap);
72 unsigned
73 a2i(const char *a)
75 int neg = 0;
76 int base = 10;
77 unsigned num = 0;
78 int looping;
80 while (isspace (*a))
81 a++;
83 if (*a == '-') {
84 neg = 1;
85 a++;
88 if (*a == '0') {
89 if (a[1] == 'x' || a[1] == 'X') {
90 a += 2;
91 base = 16;
93 else
94 base = 8;
97 looping = 1;
98 while (looping) {
99 int ch = *a++;
101 switch (base) {
102 default:
103 looping = 0;
104 break;
106 case 10:
107 if (ch >= '0' && ch <= '9') {
108 num = (num * 10) + (ch - '0');
109 } else {
110 looping = 0;
112 break;
114 case 8:
115 if (ch >= '0' && ch <= '7') {
116 num = (num * 8) + (ch - '0');
117 } else {
118 looping = 0;
120 break;
122 case 16:
123 if (ch >= '0' && ch <= '9') {
124 num = (num * 16) + (ch - '0');
125 } else if (ch >= 'a' && ch <= 'f') {
126 num = (num * 16) + (ch - 'a' + 10);
127 } else if (ch >= 'A' && ch <= 'F') {
128 num = (num * 16) + (ch - 'A' + 10);
129 } else {
130 looping = 0;
132 break;
136 if (neg)
137 num = - num;
139 return num;
142 unsigned
143 target_a2i(int ms_bit_nr,
144 const char *a)
146 if (ms_bit_nr)
147 return (ms_bit_nr - a2i(a));
148 else
149 return a2i(a);
152 unsigned
153 i2target(int ms_bit_nr,
154 unsigned bit)
156 if (ms_bit_nr)
157 return ms_bit_nr - bit;
158 else
159 return bit;
164 name2i(const char *names,
165 const name_map *map)
167 const name_map *curr;
168 const char *name = names;
169 while (*name != '\0') {
170 /* find our name */
171 char *end = strchr(name, ',');
172 char *next;
173 int len;
174 if (end == NULL) {
175 end = strchr(name, '\0');
176 next = end;
178 else {
179 next = end + 1;
181 len = end - name;
182 /* look it up */
183 curr = map;
184 while (curr->name != NULL) {
185 if (strncmp(curr->name, name, len) == 0
186 && strlen(curr->name) == len)
187 return curr->i;
188 curr++;
190 name = next;
192 /* nothing found, possibly return a default */
193 curr = map;
194 while (curr->name != NULL)
195 curr++;
196 if (curr->i >= 0)
197 return curr->i;
198 else
199 error("%s contains no valid names\n", names);
200 return 0;
203 const char *
204 i2name(const int i,
205 const name_map *map)
207 while (map->name != NULL) {
208 if (map->i == i)
209 return map->name;
210 map++;
212 error("map lookup failed for %d\n", i);
213 return NULL;