1/* 2 * Copyright (c) 2009 The Regents of The University of Michigan 3 * All rights reserved. 4 * 5 * Redistribution and use in source and binary forms, with or without 6 * modification, are permitted provided that the following conditions are 7 * met: redistributions of source code must retain the above copyright 8 * notice, this list of conditions and the following disclaimer; --- 39 unchanged lines hidden (view full) --- 48 const RegIndex dest; 49 const uint8_t srcSize; 50 const uint8_t destSize; 51 const uint8_t ext; 52 static const RegIndex foldOBit = 0; 53 54 // Constructor 55 MediaOpBase(ExtMachInst _machInst, |
56 const char *mnem, const char *_instMnem, uint64_t setFlags, |
57 InstRegIndex _src1, InstRegIndex _dest, 58 uint8_t _srcSize, uint8_t _destSize, uint8_t _ext, 59 OpClass __opClass) : |
60 X86MicroopBase(_machInst, mnem, _instMnem, setFlags, |
61 __opClass), 62 src1(_src1.idx), dest(_dest.idx), 63 srcSize(_srcSize), destSize(_destSize), ext(_ext) 64 {} 65 66 bool 67 scalarOp() const 68 { --- 21 unchanged lines hidden (view full) --- 90 91 class MediaOpReg : public MediaOpBase 92 { 93 protected: 94 const RegIndex src2; 95 96 // Constructor 97 MediaOpReg(ExtMachInst _machInst, |
98 const char *mnem, const char *_instMnem, uint64_t setFlags, |
99 InstRegIndex _src1, InstRegIndex _src2, InstRegIndex _dest, 100 uint8_t _srcSize, uint8_t _destSize, uint8_t _ext, 101 OpClass __opClass) : |
102 MediaOpBase(_machInst, mnem, _instMnem, setFlags, |
103 _src1, _dest, _srcSize, _destSize, _ext, 104 __opClass), 105 src2(_src2.idx) 106 {} 107 108 std::string generateDisassembly(Addr pc, 109 const SymbolTable *symtab) const; 110 }; 111 112 class MediaOpImm : public MediaOpBase 113 { 114 protected: 115 uint8_t imm8; 116 117 // Constructor 118 MediaOpImm(ExtMachInst _machInst, |
119 const char *mnem, const char *_instMnem, uint64_t setFlags, |
120 InstRegIndex _src1, uint8_t _imm8, InstRegIndex _dest, 121 uint8_t _srcSize, uint8_t _destSize, uint8_t _ext, 122 OpClass __opClass) : |
123 MediaOpBase(_machInst, mnem, _instMnem, setFlags, |
124 _src1, _dest, _srcSize, _destSize, _ext, 125 __opClass), 126 imm8(_imm8) 127 {} 128 129 std::string generateDisassembly(Addr pc, 130 const SymbolTable *symtab) const; 131 }; 132} 133 134#endif //__ARCH_X86_INSTS_MICROMEDIAOP_HH__ |