X-Git-Url: http://git.efficios.com/?a=blobdiff_plain;f=opcodes%2Fz8kgen.c;h=495112151ed6d935ce3313ff98bdcde5bcaeeae2;hb=c8f89a3423101b25e57bc8fd55b060ce2ac45a55;hp=8d418f7be3f76183c75c9aba70475f8a65477f9a;hpb=815c0482cbdf89fce2ac7d4d8df9908fcac2e1a0;p=deliverable%2Fbinutils-gdb.git diff --git a/opcodes/z8kgen.c b/opcodes/z8kgen.c index 8d418f7be3..495112151e 100644 --- a/opcodes/z8kgen.c +++ b/opcodes/z8kgen.c @@ -1,4 +1,4 @@ -/* Copyright 2001, 2002, 2003, 2005, 2007, 2009 Free Software Foundation, Inc. +/* Copyright (C) 2001-2015 Free Software Foundation, Inc. This file is part of the GNU opcodes library. @@ -17,10 +17,10 @@ Free Software Foundation, 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA. */ -/* This program generates z8k-opc.h. Compile with -fwritable-strings. */ +/* This program generates z8k-opc.h. */ -#include #include "sysdep.h" +#include #include "libiberty.h" #define BYTE_INFO_LEN 10 @@ -32,7 +32,8 @@ struct op char type; char *bits; char *name; - char *flavor; + /* Unique number for stable sorting. */ + int id; }; #define iswhite(x) ((x) == ' ' || (x) == '\t') @@ -512,15 +513,14 @@ static struct op opt[] = {"-ZS---", 17, 32, "0101 1100 ddN0 1000 address_dst", "testl address_dst(rd)", 0}, {"-ZS---", 13, 32, "1001 1100 dddd 1000", "testl rrd", 0}, - {"-ZSV--", 25, 8, "1011 1000 ddN0 1000 0000 aaaa ssN0 0000", "trdb @rd,@rs,rba", 0}, - {"-ZSV--", 25, 8, "1011 1000 ddN0 1100 0000 aaaa ssN0 0000", "trdrb @rd,@rs,rba", 0}, - {"-ZSV--", 25, 8, "1011 1000 ddN0 0000 0000 rrrr ssN0 0000", "trib @rd,@rs,rbr", 0}, - {"-ZSV--", 25, 8, "1011 1000 ddN0 0100 0000 rrrr ssN0 0000", "trirb @rd,@rs,rbr", 0}, - {"-ZSV--", 25, 8, "1011 1000 aaN0 1010 0000 rrrr bbN0 0000", "trtdb @ra,@rb,rbr", 0}, - {"-ZSV--", 25, 8, "1011 1000 aaN0 1110 0000 rrrr bbN0 1110", "trtdrb @ra,@rb,rbr", 0}, - {"-ZSV--", 25, 8, "1011 1000 aaN0 0010 0000 rrrr bbN0 0000", "trtib @ra,@rb,rbr", 0}, - {"-ZSV--", 25, 8, "1011 1000 aaN0 0110 0000 rrrr bbN0 1110", "trtirb @ra,@rb,rbr", 0}, - {"-ZSV--", 25, 8, "1011 1000 aaN0 1010 0000 rrrr bbN0 0000", "trtrb @ra,@rb,rbr", 0}, + {"---V--", 25, 8, "1011 1000 ddN0 1000 0000 rrrr ssN0 0000", "trdb @rd,@rs,rr", 0}, + {"---V--", 25, 8, "1011 1000 ddN0 1100 0000 rrrr ssN0 0000", "trdrb @rd,@rs,rr", 0}, + {"---V--", 25, 8, "1011 1000 ddN0 0000 0000 rrrr ssN0 0000", "trib @rd,@rs,rr", 0}, + {"---V--", 25, 8, "1011 1000 ddN0 0100 0000 rrrr ssN0 0000", "trirb @rd,@rs,rr", 0}, + {"-Z-V--", 25, 8, "1011 1000 aaN0 1010 0000 rrrr bbN0 0000", "trtdb @ra,@rb,rr", 0}, + {"-Z-V--", 25, 8, "1011 1000 aaN0 1110 0000 rrrr bbN0 1110", "trtdrb @ra,@rb,rr", 0}, + {"-Z-V--", 25, 8, "1011 1000 aaN0 0010 0000 rrrr bbN0 0000", "trtib @ra,@rb,rr", 0}, + {"-Z-V--", 25, 8, "1011 1000 aaN0 0110 0000 rrrr bbN0 1110", "trtirb @ra,@rb,rr", 0}, {"--S---", 11, 16, "0000 1101 ddN0 0110", "tset @rd", 0}, {"--S---", 14, 16, "0100 1101 0000 0110 address_dst", "tset address_dst", 0}, @@ -547,7 +547,6 @@ static struct op opt[] = {"------", 7, 32, "1000 1100 dddd 0001", "ldctlb rbd,ctrl", 0}, {"CZSVDH", 7, 32, "1000 1100 ssss 1001", "ldctlb ctrl,rbs", 0}, - {"*", 4, 8, "1000 1000 ssss dddd", "xorb rbd,rbs", 0}, {"*", 0, 0, 0, 0, 0} }; @@ -574,7 +573,7 @@ func (const void *p1, const void *p2) int ret = strcmp (a->name, b->name); if (ret != 0) return ret; - return p1 > p2 ? 1 : -1; + return a->id > b->id ? 1 : -1; } @@ -826,9 +825,12 @@ chewname (char **name) return nargs; } -static void +static char * sub (char *x, char c) { + /* Create copy. */ + char *ret = xstrdup (x); + x = ret; while (*x) { if (x[0] == c && x[1] == c && @@ -839,6 +841,7 @@ sub (char *x, char c) } x++; } + return ret; } @@ -909,9 +912,14 @@ static void internal (void) { int c = count (); - struct op *new_op = xmalloc (sizeof (struct op) * c); + int id; + struct op *new_op = xmalloc (sizeof (struct op) * (c + 1)); struct op *p = opt; - memcpy (new_op, p, c * sizeof (struct op)); + memcpy (new_op, p, (c + 1) * sizeof (struct op)); + + /* Assign unique id. */ + for (id = 0; id < c; id++) + new_op[id].id = id; /* Sort all names in table alphabetically. */ qsort (new_op, c, sizeof (struct op), func); @@ -937,15 +945,15 @@ internal (void) /* Skip the r and sub the string. */ s++; c = s[1]; - sub (p->bits, c); + p->bits = sub (p->bits, c); } if (s[0] == '(' && s[3] == ')') { - sub (p->bits, s[2]); + p->bits = sub (p->bits, s[2]); } if (s[0] == '(') { - sub (p->bits, s[-1]); + p->bits = sub (p->bits, s[-1]); } s++; @@ -962,19 +970,24 @@ static void gas (void) { int c = count (); + int id; struct op *p = opt; int idx = -1; char *oldname = ""; - struct op *new_op = xmalloc (sizeof (struct op) * c); + struct op *new_op = xmalloc (sizeof (struct op) * (c + 1)); + + memcpy (new_op, p, (c + 1) * sizeof (struct op)); - memcpy (new_op, p, c * sizeof (struct op)); + /* Assign unique id. */ + for (id = 0; id < c; id++) + new_op[id].id = id; /* Sort all names in table alphabetically. */ qsort (new_op, c, sizeof (struct op), func); printf ("/* DO NOT EDIT! -*- buffer-read-only: t -*-\n"); printf (" This file is automatically generated by z8kgen. */\n\n"); - printf ("/* Copyright 2007, 2009 Free Software Foundation, Inc.\n\ + printf ("/* Copyright (C) 2007-2015 Free Software Foundation, Inc.\n\ \n\ This file is part of the GNU opcodes library.\n\ \n\ @@ -1284,7 +1297,7 @@ gas (void) printf ("#ifdef DEFINE_TABLE\n"); printf ("const opcode_entry_type z8k_table[] = {\n"); - while (new_op->flags && new_op->flags[0]) + while (new_op->flags && new_op->flags[0] != '*') { int nargs; int length;