github.com/rohankumardubey/syslog-redirector-golang@v0.0.0-20140320174030-4859f03d829a/src/cmd/5l/optab.c (about)

     1  // Inferno utils/5l/optab.c
     2  // http://code.google.com/p/inferno-os/source/browse/utils/5l/optab.c
     3  //
     4  //	Copyright © 1994-1999 Lucent Technologies Inc.  All rights reserved.
     5  //	Portions Copyright © 1995-1997 C H Forsyth (forsyth@terzarima.net)
     6  //	Portions Copyright © 1997-1999 Vita Nuova Limited
     7  //	Portions Copyright © 2000-2007 Vita Nuova Holdings Limited (www.vitanuova.com)
     8  //	Portions Copyright © 2004,2006 Bruce Ellis
     9  //	Portions Copyright © 2005-2007 C H Forsyth (forsyth@terzarima.net)
    10  //	Revisions Copyright © 2000-2007 Lucent Technologies Inc. and others
    11  //	Portions Copyright © 2009 The Go Authors.  All rights reserved.
    12  //
    13  // Permission is hereby granted, free of charge, to any person obtaining a copy
    14  // of this software and associated documentation files (the "Software"), to deal
    15  // in the Software without restriction, including without limitation the rights
    16  // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
    17  // copies of the Software, and to permit persons to whom the Software is
    18  // furnished to do so, subject to the following conditions:
    19  //
    20  // The above copyright notice and this permission notice shall be included in
    21  // all copies or substantial portions of the Software.
    22  //
    23  // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
    24  // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
    25  // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL THE
    26  // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
    27  // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
    28  // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
    29  // THE SOFTWARE.
    30  
    31  #include	"l.h"
    32  
    33  Optab	optab[] =
    34  {
    35  	/* struct Optab:
    36  	  OPCODE,	from, prog->reg, to,		 type,size,param,flag */
    37  	{ ATEXT,	C_ADDR,	C_NONE,	C_LCON, 	 0, 0, 0 },
    38  	{ ATEXT,	C_ADDR,	C_REG,	C_LCON, 	 0, 0, 0 },
    39  
    40  	{ AADD,		C_REG,	C_REG,	C_REG,		 1, 4, 0 },
    41  	{ AADD,		C_REG,	C_NONE,	C_REG,		 1, 4, 0 },
    42  	{ AMOVW,	C_REG,	C_NONE,	C_REG,		 1, 4, 0 },
    43  	{ AMVN,		C_REG,	C_NONE,	C_REG,		 1, 4, 0 },
    44  	{ ACMP,		C_REG,	C_REG,	C_NONE,		 1, 4, 0 },
    45  
    46  	{ AADD,		C_RCON,	C_REG,	C_REG,		 2, 4, 0 },
    47  	{ AADD,		C_RCON,	C_NONE,	C_REG,		 2, 4, 0 },
    48  	{ AMOVW,	C_RCON,	C_NONE,	C_REG,		 2, 4, 0 },
    49  	{ AMVN,		C_RCON,	C_NONE,	C_REG,		 2, 4, 0 },
    50  	{ ACMP,		C_RCON,	C_REG,	C_NONE,		 2, 4, 0 },
    51  
    52  	{ AADD,		C_SHIFT,C_REG,	C_REG,		 3, 4, 0 },
    53  	{ AADD,		C_SHIFT,C_NONE,	C_REG,		 3, 4, 0 },
    54  	{ AMVN,		C_SHIFT,C_NONE,	C_REG,		 3, 4, 0 },
    55  	{ ACMP,		C_SHIFT,C_REG,	C_NONE,		 3, 4, 0 },
    56  
    57  	{ AMOVW,	C_RACON,C_NONE,	C_REG,		 4, 4, REGSP },
    58  
    59  	{ AB,		C_NONE,	C_NONE,	C_SBRA,		 5, 4, 0,	LPOOL },
    60  	{ ABL,		C_NONE,	C_NONE,	C_SBRA,		 5, 4, 0 },
    61  	{ ABX,		C_NONE,	C_NONE,	C_SBRA,		 74, 20, 0 },
    62  	{ ABEQ,		C_NONE,	C_NONE,	C_SBRA,		 5, 4, 0 },
    63  
    64  	{ AB,		C_NONE,	C_NONE,	C_ROREG,	 6, 4, 0,	LPOOL },
    65  	{ ABL,		C_NONE,	C_NONE,	C_ROREG,	 7, 4, 0 },
    66  	{ ABL,		C_REG,	C_NONE,	C_ROREG,	 7, 4, 0 },
    67  	{ ABX,		C_NONE,	C_NONE,	C_ROREG,	 75, 12, 0 },
    68  	{ ABXRET,	C_NONE,	C_NONE,	C_ROREG,	 76, 4, 0 },
    69  
    70  	{ ASLL,		C_RCON,	C_REG,	C_REG,		 8, 4, 0 },
    71  	{ ASLL,		C_RCON,	C_NONE,	C_REG,		 8, 4, 0 },
    72  
    73  	{ ASLL,		C_REG,	C_NONE,	C_REG,		 9, 4, 0 },
    74  	{ ASLL,		C_REG,	C_REG,	C_REG,		 9, 4, 0 },
    75  
    76  	{ ASWI,		C_NONE,	C_NONE,	C_NONE,		10, 4, 0 },
    77  	{ ASWI,		C_NONE,	C_NONE,	C_LOREG,	10, 4, 0 },
    78  	{ ASWI,		C_NONE,	C_NONE,	C_LCON,		10, 4, 0 },
    79  
    80  	{ AWORD,	C_NONE,	C_NONE,	C_LCON,		11, 4, 0 },
    81  	{ AWORD,	C_NONE,	C_NONE,	C_LCONADDR,	11, 4, 0 },
    82  	{ AWORD,	C_NONE,	C_NONE,	C_ADDR,		11, 4, 0 },
    83  
    84  	{ AMOVW,	C_NCON,	C_NONE,	C_REG,		12, 4, 0 },
    85  	{ AMOVW,	C_LCON,	C_NONE,	C_REG,		12, 4, 0,	LFROM },
    86  	{ AMOVW,	C_LCONADDR,	C_NONE,	C_REG,	12, 4, 0,	LFROM | LPCREL, 4},
    87  
    88  	{ AADD,		C_NCON,	C_REG,	C_REG,		13, 8, 0 },
    89  	{ AADD,		C_NCON,	C_NONE,	C_REG,		13, 8, 0 },
    90  	{ AMVN,		C_NCON,	C_NONE,	C_REG,		13, 8, 0 },
    91  	{ ACMP,		C_NCON,	C_REG,	C_NONE,		13, 8, 0 },
    92  	{ AADD,		C_LCON,	C_REG,	C_REG,		13, 8, 0,	LFROM },
    93  	{ AADD,		C_LCON,	C_NONE,	C_REG,		13, 8, 0,	LFROM },
    94  	{ AMVN,		C_LCON,	C_NONE,	C_REG,		13, 8, 0,	LFROM },
    95  	{ ACMP,		C_LCON,	C_REG,	C_NONE,		13, 8, 0,	LFROM },
    96  
    97  	{ AMOVB,	C_REG,	C_NONE,	C_REG,		 1, 4, 0 },
    98  	{ AMOVBS,	C_REG,	C_NONE,	C_REG,		14, 8, 0 },
    99  	{ AMOVBU,	C_REG,	C_NONE,	C_REG,		58, 4, 0 },
   100  	{ AMOVH,	C_REG,	C_NONE,	C_REG,		 1, 4, 0 },
   101  	{ AMOVHS,	C_REG,	C_NONE,	C_REG,		14, 8, 0 },
   102  	{ AMOVHU,	C_REG,	C_NONE,	C_REG,		14, 8, 0 },
   103  
   104  	{ AMUL,		C_REG,	C_REG,	C_REG,		15, 4, 0 },
   105  	{ AMUL,		C_REG,	C_NONE,	C_REG,		15, 4, 0 },
   106  
   107  	{ ADIV,		C_REG,	C_REG,	C_REG,		16, 4, 0 },
   108  	{ ADIV,		C_REG,	C_NONE,	C_REG,		16, 4, 0 },
   109  
   110  	{ AMULL,	C_REG,	C_REG,	C_REGREG,	17, 4, 0 },
   111  	{ AMULA,	C_REG,	C_REG,	C_REGREG2,	17, 4, 0 },
   112  
   113  	{ AMOVW,	C_REG,	C_NONE,	C_SAUTO,	20, 4, REGSP },
   114  	{ AMOVW,	C_REG,	C_NONE,	C_SOREG,	20, 4, 0 },
   115  	{ AMOVB,	C_REG,	C_NONE,	C_SAUTO,	20, 4, REGSP },
   116  	{ AMOVB,	C_REG,	C_NONE,	C_SOREG,	20, 4, 0 },
   117  	{ AMOVBS,	C_REG,	C_NONE,	C_SAUTO,	20, 4, REGSP },
   118  	{ AMOVBS,	C_REG,	C_NONE,	C_SOREG,	20, 4, 0 },
   119  	{ AMOVBU,	C_REG,	C_NONE,	C_SAUTO,	20, 4, REGSP },
   120  	{ AMOVBU,	C_REG,	C_NONE,	C_SOREG,	20, 4, 0 },
   121  
   122  	{ AMOVW,	C_SAUTO,C_NONE,	C_REG,		21, 4, REGSP },
   123  	{ AMOVW,	C_SOREG,C_NONE,	C_REG,		21, 4, 0 },
   124  	{ AMOVBU,	C_SAUTO,C_NONE,	C_REG,		21, 4, REGSP },
   125  	{ AMOVBU,	C_SOREG,C_NONE,	C_REG,		21, 4, 0 },
   126  
   127  	{ AMOVW,	C_REG,	C_NONE,	C_LAUTO,	30, 8, REGSP,	LTO },
   128  	{ AMOVW,	C_REG,	C_NONE,	C_LOREG,	30, 8, 0,	LTO },
   129  	{ AMOVW,	C_REG,	C_NONE,	C_ADDR,		64, 8, 0,	LTO | LPCREL, 4 },
   130  	{ AMOVB,	C_REG,	C_NONE,	C_LAUTO,	30, 8, REGSP,	LTO },
   131  	{ AMOVB,	C_REG,	C_NONE,	C_LOREG,	30, 8, 0,	LTO },
   132  	{ AMOVB,	C_REG,	C_NONE,	C_ADDR,		64, 8, 0,	LTO | LPCREL, 4 },
   133  	{ AMOVBS,	C_REG,	C_NONE,	C_LAUTO,	30, 8, REGSP,	LTO },
   134  	{ AMOVBS,	C_REG,	C_NONE,	C_LOREG,	30, 8, 0,	LTO },
   135  	{ AMOVBS,	C_REG,	C_NONE,	C_ADDR,		64, 8, 0,	LTO | LPCREL, 4 },
   136  	{ AMOVBU,	C_REG,	C_NONE,	C_LAUTO,	30, 8, REGSP,	LTO },
   137  	{ AMOVBU,	C_REG,	C_NONE,	C_LOREG,	30, 8, 0,	LTO },
   138  	{ AMOVBU,	C_REG,	C_NONE,	C_ADDR,		64, 8, 0,	LTO | LPCREL, 4 },
   139  
   140  	{ AMOVW,	C_LAUTO,C_NONE,	C_REG,		31, 8, REGSP,	LFROM },
   141  	{ AMOVW,	C_LOREG,C_NONE,	C_REG,		31, 8, 0,	LFROM },
   142  	{ AMOVW,	C_ADDR,	C_NONE,	C_REG,		65, 8, 0,	LFROM | LPCREL, 4 },
   143  	{ AMOVBU,	C_LAUTO,C_NONE,	C_REG,		31, 8, REGSP,	LFROM },
   144  	{ AMOVBU,	C_LOREG,C_NONE,	C_REG,		31, 8, 0,	LFROM },
   145  	{ AMOVBU,	C_ADDR,	C_NONE,	C_REG,		65, 8, 0,	LFROM | LPCREL, 4 },
   146  
   147  	{ AMOVW,	C_LACON,C_NONE,	C_REG,		34, 8, REGSP,	LFROM },
   148  
   149  	{ AMOVW,	C_PSR,	C_NONE,	C_REG,		35, 4, 0 },
   150  	{ AMOVW,	C_REG,	C_NONE,	C_PSR,		36, 4, 0 },
   151  	{ AMOVW,	C_RCON,	C_NONE,	C_PSR,		37, 4, 0 },
   152  
   153  	{ AMOVM,	C_LCON,	C_NONE,	C_SOREG,	38, 4, 0 },
   154  	{ AMOVM,	C_SOREG,C_NONE,	C_LCON,		39, 4, 0 },
   155  
   156  	{ ASWPW,	C_SOREG,C_REG,	C_REG,		40, 4, 0 },
   157  
   158  	{ ARFE,		C_NONE,	C_NONE,	C_NONE,		41, 4, 0 },
   159  
   160  	{ AMOVF,	C_FREG,	C_NONE,	C_FAUTO,	50, 4, REGSP },
   161  	{ AMOVF,	C_FREG,	C_NONE,	C_FOREG,	50, 4, 0 },
   162  
   163  	{ AMOVF,	C_FAUTO,C_NONE,	C_FREG,		51, 4, REGSP },
   164  	{ AMOVF,	C_FOREG,C_NONE,	C_FREG,		51, 4, 0 },
   165  
   166  	{ AMOVF,	C_FREG,	C_NONE,	C_LAUTO,	52, 12, REGSP,	LTO },
   167  	{ AMOVF,	C_FREG,	C_NONE,	C_LOREG,	52, 12, 0,	LTO },
   168  
   169  	{ AMOVF,	C_LAUTO,C_NONE,	C_FREG,		53, 12, REGSP,	LFROM },
   170  	{ AMOVF,	C_LOREG,C_NONE,	C_FREG,		53, 12, 0,	LFROM },
   171  
   172  	{ AMOVF,	C_FREG,	C_NONE,	C_ADDR,		68, 8, 0,	LTO | LPCREL, 4 },
   173  	{ AMOVF,	C_ADDR,	C_NONE,	C_FREG,		69, 8, 0,	LFROM | LPCREL, 4},
   174  
   175  	{ AADDF,	C_FREG,	C_NONE,	C_FREG,		54, 4, 0 },
   176  	{ AADDF,	C_FREG,	C_REG,	C_FREG,		54, 4, 0 },
   177  	{ AMOVF,	C_FREG, C_NONE, C_FREG,		54, 4, 0 },
   178  
   179  	{ AMOVW,	C_REG,	C_NONE,	C_FCR,		56, 4, 0 },
   180  	{ AMOVW,	C_FCR,	C_NONE,	C_REG,		57, 4, 0 },
   181  
   182  	{ AMOVW,	C_SHIFT,C_NONE,	C_REG,		59, 4, 0 },
   183  	{ AMOVBU,	C_SHIFT,C_NONE,	C_REG,		59, 4, 0 },
   184  
   185  	{ AMOVB,	C_SHIFT,C_NONE,	C_REG,		60, 4, 0 },
   186  	{ AMOVBS,	C_SHIFT,C_NONE,	C_REG,		60, 4, 0 },
   187  
   188  	{ AMOVW,	C_REG,	C_NONE,	C_SHIFT,	61, 4, 0 },
   189  	{ AMOVB,	C_REG,	C_NONE,	C_SHIFT,	61, 4, 0 },
   190  	{ AMOVBS,	C_REG,	C_NONE,	C_SHIFT,	61, 4, 0 },
   191  	{ AMOVBU,	C_REG,	C_NONE,	C_SHIFT,	61, 4, 0 },
   192  
   193  	{ ACASE,	C_REG,	C_NONE,	C_NONE,		62, 4, 0, LPCREL, 8 },
   194  	{ ABCASE,	C_NONE, C_NONE, C_SBRA,		63, 4, 0, LPCREL, 0 },
   195  
   196  	{ AMOVH,	C_REG,	C_NONE, C_HAUTO,	70, 4, REGSP,	0 },
   197  	{ AMOVH,	C_REG,	C_NONE,	C_HOREG,	70, 4, 0,	0 },
   198  	{ AMOVHS,	C_REG,	C_NONE, C_HAUTO,	70, 4, REGSP,	0 },
   199  	{ AMOVHS,	C_REG,	C_NONE,	C_HOREG,	70, 4, 0,	0 },
   200  	{ AMOVHU,	C_REG,	C_NONE, C_HAUTO,	70, 4, REGSP,	0 },
   201  	{ AMOVHU,	C_REG,	C_NONE,	C_HOREG,	70, 4, 0,	0 },
   202  
   203  	{ AMOVB,	C_HAUTO,C_NONE,	C_REG,		71, 4, REGSP,	0 },
   204  	{ AMOVB,	C_HOREG,C_NONE,	C_REG,		71, 4, 0,	0 },
   205  	{ AMOVBS,	C_HAUTO,C_NONE,	C_REG,		71, 4, REGSP,	0 },
   206  	{ AMOVBS,	C_HOREG,C_NONE,	C_REG,		71, 4, 0,	0 },
   207  	{ AMOVH,	C_HAUTO,C_NONE, C_REG,		71, 4, REGSP,	0 },
   208  	{ AMOVH,	C_HOREG,C_NONE,	C_REG,		71, 4, 0,	0 },
   209  	{ AMOVHS,	C_HAUTO,C_NONE, C_REG,		71, 4, REGSP,	0 },
   210  	{ AMOVHS,	C_HOREG,C_NONE,	C_REG,		71, 4, 0,	0 },
   211  	{ AMOVHU,	C_HAUTO,C_NONE, C_REG,		71, 4, REGSP,	0 },
   212  	{ AMOVHU,	C_HOREG,C_NONE,	C_REG,		71, 4, 0,	0 },
   213  
   214  	{ AMOVH,	C_REG,	C_NONE, C_LAUTO,	72, 8, REGSP,	LTO },
   215  	{ AMOVH,	C_REG,	C_NONE,	C_LOREG,	72, 8, 0,	LTO },
   216  	{ AMOVH,	C_REG,	C_NONE,	C_ADDR,	94, 8, 0,	LTO | LPCREL, 4 },
   217  	{ AMOVHS,	C_REG,	C_NONE, C_LAUTO,	72, 8, REGSP,	LTO },
   218  	{ AMOVHS,	C_REG,	C_NONE,	C_LOREG,	72, 8, 0,	LTO },
   219  	{ AMOVHS,	C_REG,	C_NONE,	C_ADDR,	94, 8, 0,	LTO | LPCREL, 4 },
   220  	{ AMOVHU,	C_REG,	C_NONE, C_LAUTO,	72, 8, REGSP,	LTO },
   221  	{ AMOVHU,	C_REG,	C_NONE,	C_LOREG,	72, 8, 0,	LTO },
   222  	{ AMOVHU,	C_REG,	C_NONE,	C_ADDR,	94, 8, 0,	LTO | LPCREL, 4 },
   223  
   224  	{ AMOVB,	C_LAUTO,C_NONE,	C_REG,		73, 8, REGSP,	LFROM },
   225  	{ AMOVB,	C_LOREG,C_NONE,	C_REG,		73, 8, 0,	LFROM },
   226  	{ AMOVB,	C_ADDR,	C_NONE,	C_REG,		93, 8, 0,	LFROM | LPCREL, 4 },
   227  	{ AMOVBS,	C_LAUTO,C_NONE,	C_REG,		73, 8, REGSP,	LFROM },
   228  	{ AMOVBS,	C_LOREG,C_NONE,	C_REG,		73, 8, 0,	LFROM },
   229  	{ AMOVBS,	C_ADDR,	C_NONE,	C_REG,		93, 8, 0,	LFROM | LPCREL, 4 },
   230  	{ AMOVH,	C_LAUTO,C_NONE, C_REG,		73, 8, REGSP,	LFROM },
   231  	{ AMOVH,	C_LOREG,C_NONE,	C_REG,		73, 8, 0,	LFROM },
   232  	{ AMOVH,	C_ADDR,	C_NONE,	C_REG,		93, 8, 0,	LFROM | LPCREL, 4 },
   233  	{ AMOVHS,	C_LAUTO,C_NONE, C_REG,		73, 8, REGSP,	LFROM },
   234  	{ AMOVHS,	C_LOREG,C_NONE,	C_REG,		73, 8, 0,	LFROM },
   235  	{ AMOVHS,	C_ADDR,	C_NONE,	C_REG,		93, 8, 0,	LFROM | LPCREL, 4 },
   236  	{ AMOVHU,	C_LAUTO,C_NONE, C_REG,		73, 8, REGSP,	LFROM },
   237  	{ AMOVHU,	C_LOREG,C_NONE,	C_REG,		73, 8, 0,	LFROM },
   238  	{ AMOVHU,	C_ADDR,	C_NONE,	C_REG,		93, 8, 0,	LFROM | LPCREL, 4 },
   239  
   240  	{ ALDREX,	C_SOREG,C_NONE,	C_REG,		77, 4, 0 },
   241  	{ ASTREX,	C_SOREG,C_REG,	C_REG,		78, 4, 0 },
   242  
   243  	{ AMOVF,	C_ZFCON,C_NONE,	C_FREG,		80, 8, 0 },
   244  	{ AMOVF,	C_SFCON,C_NONE,	C_FREG,		81, 4, 0 },
   245  
   246  	{ ACMPF,	C_FREG,	C_REG,	C_NONE,		82, 8, 0 },
   247  	{ ACMPF,	C_FREG, C_NONE,	C_NONE,		83, 8, 0 },
   248  
   249  	{ AMOVFW,	C_FREG,	C_NONE,	C_FREG,		84, 4, 0 },
   250  	{ AMOVWF,	C_FREG,	C_NONE,	C_FREG,		85, 4, 0 },
   251  
   252  	{ AMOVFW,	C_FREG,	C_NONE,	C_REG,		86, 8, 0 },
   253  	{ AMOVWF,	C_REG,	C_NONE,	C_FREG,		87, 8, 0 },
   254  
   255  	{ AMOVW,	C_REG,	C_NONE,	C_FREG,		88, 4, 0 },
   256  	{ AMOVW,	C_FREG,	C_NONE,	C_REG,		89, 4, 0 },
   257  
   258  	{ ATST,		C_REG,	C_NONE,	C_NONE,		90, 4, 0 },
   259  
   260  	{ ALDREXD,	C_SOREG,C_NONE,	C_REG,		91, 4, 0 },
   261  	{ ASTREXD,	C_SOREG,C_REG,	C_REG,		92, 4, 0 },
   262  
   263  	{ APLD,		C_SOREG,C_NONE,	C_NONE,		95, 4, 0 },
   264  	
   265  	{ AUNDEF,		C_NONE,	C_NONE,	C_NONE,		96, 4, 0 },
   266  
   267  	{ ACLZ,		C_REG,	C_NONE,	C_REG,		97, 4, 0 },
   268  
   269  	{ AMULWT,	C_REG,	C_REG,	C_REG,		98, 4, 0 },
   270  	{ AMULAWT,	C_REG,	C_REG,	C_REGREG2,		99, 4, 0 },
   271  
   272  	{ AUSEFIELD,	C_ADDR,	C_NONE,	C_NONE, 	 0, 0, 0 },
   273  	{ APCDATA,	C_LCON,	C_NONE,	C_LCON,		0, 0, 0 },
   274  	{ AFUNCDATA,	C_LCON,	C_NONE,	C_ADDR,	0, 0, 0 },
   275  
   276  	{ AXXX,		C_NONE,	C_NONE,	C_NONE,		 0, 4, 0 },
   277  };