diff options
author | H. Peter Anvin <hpa@zytor.com> | 2007-09-10 18:58:40 +0000 |
---|---|---|
committer | H. Peter Anvin <hpa@zytor.com> | 2007-09-10 18:58:40 +0000 |
commit | d555a64a7fda8c0d31a041ac2d59dfdc947e7012 (patch) | |
tree | f8539be06f14c4f895d954f5025f617e05cbd0f5 /tokhash.pl | |
parent | a80241f58a9f35cd1ec83205713bd603b178df1c (diff) | |
download | nasm-d555a64a7fda8c0d31a041ac2d59dfdc947e7012.tar.gz nasm-d555a64a7fda8c0d31a041ac2d59dfdc947e7012.tar.bz2 nasm-d555a64a7fda8c0d31a041ac2d59dfdc947e7012.zip |
tokhash: adjust table types to reduce size
Adjust the sizes of data types to reduce the total size of the tokhash
data structure.
Diffstat (limited to 'tokhash.pl')
-rwxr-xr-x | tokhash.pl | 18 |
1 files changed, 11 insertions, 7 deletions
@@ -32,14 +32,14 @@ while (defined($line = <ID>)) { # Single instruction token if (!defined($tokens{$token})) { $tokens{$token} = scalar @tokendata; - push(@tokendata, "\"${token}\", TOKEN_INSN, I_${insn}, 0"); + push(@tokendata, "\"${token}\", TOKEN_INSN, 0, I_${insn}"); } } else { # Conditional instruction foreach $cc (@conditions) { if (!defined($tokens{$token.$cc})) { $tokens{$token.$cc} = scalar @tokendata; - push(@tokendata, "\"${token}${cc}\", TOKEN_INSN, I_${insn}, C_\U$cc\E"); + push(@tokendata, "\"${token}${cc}\", TOKEN_INSN, C_\U$cc\E, I_${insn}"); } } } @@ -71,7 +71,7 @@ while (defined($line = <RD>)) { die "Duplicate definition: $reg\n"; } $tokens{$reg} = scalar @tokendata; - push(@tokendata, "\"${reg}\", TOKEN_REG, R_\U${reg}\E, 0"); + push(@tokendata, "\"${reg}\", TOKEN_REG, 0, R_\U${reg}\E"); if (defined($reg_prefix)) { $reg_nr++; @@ -138,10 +138,14 @@ print "\n"; print "#define rot(x,y) (((uint32_t)(x) << (y))+((uint32_t)(x) >> (32-(y))))\n"; print "\n"; +# These somewhat odd sizes and ordering thereof are due to the +# relative ranges of the types; this makes it fit in 16 bytes on +# 64-bit machines and 12 bytes on 32-bit machines. print "struct tokendata {\n"; print " const char *string;\n"; -print " int tokentype;\n"; -print " int i1, i2;\n"; +print " int16_t tokentype;\n"; +print " uint16_t aux;\n"; +print " uint32_t num;\n"; print "};\n"; print "\n"; @@ -199,7 +203,7 @@ print " data = &tokendata[ix];\n"; print " if (strcmp(data->string, token))\n"; print " return -1;\n"; print "\n"; -print " tv->t_integer = data->i1;\n"; -print " tv->t_inttwo = data->i2;\n"; +print " tv->t_integer = data->num;\n"; +print " tv->t_inttwo = data->aux;\n"; print " return tv->t_type = data->tokentype;\n"; print "}\n"; |