1/* 2 * Ported by the State University of New York at Buffalo by the Distributed 3 * Computer Systems Lab, Department of Computer Science, 1991. 4 */ 5 6#ifndef tahoe_opcodeT 7#define tahoe_opcodeT int 8#endif /* no tahoe_opcodeT */ 9 10struct vot_wot /* tahoe opcode table: wot to do with this */ 11 /* particular opcode */ 12{ 13 char * args; /* how to compile said opcode */ 14 tahoe_opcodeT code; /* op-code (may be > 8 bits!) */ 15}; 16 17struct vot /* tahoe opcode text */ 18{ 19 char * name; /* opcode name: lowercase string [key] */ 20 struct vot_wot detail; /* rest of opcode table [datum] */ 21}; 22 23#define vot_how args 24#define vot_code code 25#define vot_detail detail 26#define vot_name name 27 28static struct vot 29votstrs[] = 30{ 31{ "halt", {"", 0x00 } }, 32{ "sinf", {"", 0x05 } }, 33{ "ldf", {"rl", 0x06 } }, 34{ "ldd", {"rq", 0x07 } }, 35{ "addb2", {"rbmb", 0x08 } }, 36{ "movb", {"rbwb", 0x09 } }, 37{ "addw2", {"rwmw", 0x0a } }, 38{ "movw", {"rwww", 0x0b } }, 39{ "addl2", {"rlml", 0x0c } }, 40{ "movl", {"rlwl", 0x0d } }, 41{ "bbs", {"rlvlbw", 0x0e } }, 42{ "nop", {"", 0x10 } }, 43{ "brb", {"bb", 0x11 } }, 44{ "brw", {"bw", 0x13 } }, 45{ "cosf", {"", 0x15 } }, 46{ "lnf", {"rl", 0x16 } }, 47{ "lnd", {"rq", 0x17 } }, 48{ "addb3", {"rbrbwb", 0x18 } }, 49{ "cmpb", {"rbwb", 0x19 } }, 50{ "addw3", {"rwrwww", 0x1a } }, 51{ "cmpw", {"rwww", 0x1b } }, 52{ "addl3", {"rlrlwl", 0x1c } }, 53{ "cmpl", {"rlwl", 0x1d } }, 54{ "bbc", {"rlvlbw", 0x1e } }, 55{ "rei", {"", 0x20 } }, 56{ "bneq", {"bb", 0x21 } }, 57{ "bnequ", {"bb", 0x21 } }, 58{ "cvtwl", {"rwwl", 0x23 } }, 59{ "stf", {"wl", 0x26 } }, 60{ "std", {"wq", 0x27 } }, 61{ "subb2", {"rbmb", 0x28 } }, 62{ "mcomb", {"rbwb", 0x29 } }, 63{ "subw2", {"rwmw", 0x2a } }, 64{ "mcomw", {"rwww", 0x2b } }, 65{ "subl2", {"rlml", 0x2c } }, 66{ "mcoml", {"rlwl", 0x2d } }, 67{ "emul", {"rlrlrlwq", 0x2e } }, 68{ "aoblss", {"rlmlbw", 0x2f } }, 69{ "bpt", {"", 0x30 } }, 70{ "beql", {"bb", 0x31 } }, 71{ "beqlu", {"bb", 0x31 } }, 72{ "cvtwb", {"rwwb", 0x33 } }, 73{ "logf", {"", 0x35 } }, 74{ "cmpf", {"rl", 0x36 } }, 75{ "cmpd", {"rq", 0x37 } }, 76{ "subb3", {"rbrbwb", 0x38 } }, 77{ "bitb", {"rbrb", 0x39 } }, 78{ "subw3", {"rwrwww", 0x3a } }, 79{ "bitw", {"rwrw", 0x3b } }, 80{ "subl3", {"rlrlwl", 0x3c } }, 81{ "bitl", {"rlrl", 0x3d } }, 82{ "ediv", {"rlrqwlwl", 0x3e } }, 83{ "aobleq", {"rlmlbw", 0x3f } }, 84{ "ret", {"", 0x40 } }, 85{ "bgtr", {"bb", 0x41 } }, 86{ "sqrtf", {"", 0x45 } }, 87{ "cmpf2", {"rl", 0x46 } }, 88{ "cmpd2", {"rqrq", 0x47 } }, 89{ "shll", {"rbrlwl", 0x48 } }, 90{ "clrb", {"wb", 0x49 } }, 91{ "shlq", {"rbrqwq", 0x4a } }, 92{ "clrw", {"ww", 0x4b } }, 93{ "mull2", {"rlml", 0x4c } }, 94{ "clrl", {"wl", 0x4d } }, 95{ "shal", {"rbrlwl", 0x4e } }, 96{ "bleq", {"bb", 0x51 } }, 97{ "expf", {"", 0x55 } }, 98{ "tstf", {"", 0x56 } }, 99{ "tstd", {"", 0x57 } }, 100{ "shrl", {"rbrlwl", 0x58 } }, 101{ "tstb", {"rb", 0x59 } }, 102{ "shrq", {"rbrqwq", 0x5a } }, 103{ "tstw", {"rw", 0x5b } }, 104{ "mull3", {"rlrlwl", 0x5c } }, 105{ "tstl", {"rl", 0x5d } }, 106{ "shar", {"rbrlwl", 0x5e } }, 107{ "bbssi", {"rlmlbw", 0x5f } }, 108{ "ldpctx", {"", 0x60 } }, 109{ "pushd", {"", 0x67 } }, 110{ "incb", {"mb", 0x69 } }, 111{ "incw", {"mw", 0x6b } }, 112{ "divl2", {"rlml", 0x6c } }, 113{ "incl", {"ml", 0x6d } }, 114{ "cvtlb", {"rlwb", 0x6f } }, 115{ "svpctx", {"", 0x70 } }, 116{ "jmp", {"ab", 0x71 } }, 117{ "cvlf", {"rl", 0x76 } }, 118{ "cvld", {"rl", 0x77 } }, 119{ "decb", {"mb", 0x79 } }, 120{ "decw", {"mw", 0x7b } }, 121{ "divl3", {"rlrlwl", 0x7c } }, 122{ "decl", {"ml", 0x7d } }, 123{ "cvtlw", {"rlww", 0x7f } }, 124{ "bgeq", {"bb", 0x81 } }, 125{ "movs2", {"abab", 0x82 } }, 126{ "cvfl", {"wl", 0x86 } }, 127{ "cvdl", {"wl", 0x87 } }, 128{ "orb2", {"rbmb", 0x88 } }, 129{ "cvtbl", {"rbwl", 0x89 } }, 130{ "orw2", {"rwmw", 0x8a } }, 131{ "bispsw", {"rw", 0x8b } }, 132{ "orl2", {"rlml", 0x8c } }, 133{ "adwc", {"rlml", 0x8d } }, 134{ "adda", {"rlml", 0x8e } }, 135{ "blss", {"bb", 0x91 } }, 136{ "cmps2", {"abab", 0x92 } }, 137{ "ldfd", {"rl", 0x97 } }, 138{ "orb3", {"rbrbwb", 0x98 } }, 139{ "cvtbw", {"rbww", 0x99 } }, 140{ "orw3", {"rwrwww", 0x9a } }, 141{ "bicpsw", {"rw", 0x9b } }, 142{ "orl3", {"rlrlwl", 0x9c } }, 143{ "sbwc", {"rlml", 0x9d } }, 144{ "suba", {"rlml", 0x9e } }, 145{ "bgtru", {"bb", 0xa1 } }, 146{ "cvdf", {"", 0xa6 } }, 147{ "andb2", {"rbmb", 0xa8 } }, 148{ "movzbl", {"rbwl", 0xa9 } }, 149{ "andw2", {"rwmw", 0xaa } }, 150{ "loadr", {"rwal", 0xab } }, 151{ "andl2", {"rlml", 0xac } }, 152{ "mtpr", {"rlrl", 0xad } }, 153{ "ffs", {"rlwl", 0xae } }, 154{ "blequ", {"bb", 0xb1 } }, 155{ "negf", {"", 0xb6 } }, 156{ "negd", {"", 0xb7 } }, 157{ "andb3", {"rbrbwb", 0xb8 } }, 158{ "movzbw", {"rbww", 0xb9 } }, 159{ "andw3", {"rwrwww", 0xba } }, 160{ "storer", {"rwal", 0xbb } }, 161{ "andl3", {"rlrlwl", 0xbc } }, 162{ "mfpr", {"rlwl", 0xbd } }, 163{ "ffc", {"rlwl", 0xbe } }, 164{ "calls", {"rbab", 0xbf } }, 165{ "prober", {"rbabrl", 0xc0 } }, 166{ "bvc", {"bb", 0xc1 } }, 167{ "movs3", {"ababrw", 0xc2 } }, 168{ "movzwl", {"rwwl", 0xc3 } }, 169{ "addf", {"rl", 0xc6 } }, 170{ "addd", {"rq", 0xc7 } }, 171{ "xorb2", {"rbmb", 0xc8 } }, 172{ "movob", {"rbwb", 0xc9 } }, 173{ "xorw2", {"rwmw", 0xca } }, 174{ "movow", {"rwww", 0xcb } }, 175{ "xorl2", {"rlml", 0xcc } }, 176{ "movpsl", {"wl", 0xcd } }, 177{ "kcall", {"rw", 0xcf } }, 178{ "probew", {"rbabrl", 0xd0 } }, 179{ "bvs", {"bb", 0xd1 } }, 180{ "cmps3", {"ababrw", 0xd2 } }, 181{ "subf", {"rq", 0xd6 } }, 182{ "subd", {"rq", 0xd7 } }, 183{ "xorb3", {"rbrbwb", 0xd8 } }, 184{ "pushb", {"rb", 0xd9 } }, 185{ "xorw3", {"rwrwww", 0xda } }, 186{ "pushw", {"rw", 0xdb } }, 187{ "xorl3", {"rlrlwl", 0xdc } }, 188{ "pushl", {"rl", 0xdd } }, 189{ "insque", {"abab", 0xe0 } }, 190{ "bcs", {"bb", 0xe1 } }, 191{ "bgequ", {"bb", 0xe1 } }, 192{ "mulf", {"rq", 0xe6 } }, 193{ "muld", {"rq", 0xe7 } }, 194{ "mnegb", {"rbwb", 0xe8 } }, 195{ "movab", {"abwl", 0xe9 } }, 196{ "mnegw", {"rwww", 0xea } }, 197{ "movaw", {"awwl", 0xeb } }, 198{ "mnegl", {"rlwl", 0xec } }, 199{ "moval", {"alwl", 0xed } }, 200{ "remque", {"ab", 0xf0 } }, 201{ "bcc", {"bb", 0xf1 } }, 202{ "blssu", {"bb", 0xf1 } }, 203{ "divf", {"rq", 0xf6 } }, 204{ "divd", {"rq", 0xf7 } }, 205{ "movblk", {"alalrw", 0xf8 } }, 206{ "pushab", {"ab", 0xf9 } }, 207{ "pushaw", {"aw", 0xfb } }, 208{ "casel", {"rlrlrl", 0xfc } }, 209{ "pushal", {"al", 0xfd } }, 210{ "callf", {"rbab", 0xfe } }, 211{ "" , "" } /* empty is end sentinel */ 212 213}; 214