1*795d594fSAndroid Build Coastguard Worker /* 2*795d594fSAndroid Build Coastguard Worker * Copyright (C) 2012 The Android Open Source Project 3*795d594fSAndroid Build Coastguard Worker * 4*795d594fSAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License"); 5*795d594fSAndroid Build Coastguard Worker * you may not use this file except in compliance with the License. 6*795d594fSAndroid Build Coastguard Worker * You may obtain a copy of the License at 7*795d594fSAndroid Build Coastguard Worker * 8*795d594fSAndroid Build Coastguard Worker * http://www.apache.org/licenses/LICENSE-2.0 9*795d594fSAndroid Build Coastguard Worker * 10*795d594fSAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software 11*795d594fSAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS, 12*795d594fSAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13*795d594fSAndroid Build Coastguard Worker * See the License for the specific language governing permissions and 14*795d594fSAndroid Build Coastguard Worker * limitations under the License. 15*795d594fSAndroid Build Coastguard Worker */ 16*795d594fSAndroid Build Coastguard Worker 17*795d594fSAndroid Build Coastguard Worker #ifndef ART_DISASSEMBLER_DISASSEMBLER_X86_H_ 18*795d594fSAndroid Build Coastguard Worker #define ART_DISASSEMBLER_DISASSEMBLER_X86_H_ 19*795d594fSAndroid Build Coastguard Worker 20*795d594fSAndroid Build Coastguard Worker #include "disassembler.h" 21*795d594fSAndroid Build Coastguard Worker 22*795d594fSAndroid Build Coastguard Worker namespace art { 23*795d594fSAndroid Build Coastguard Worker namespace x86 { 24*795d594fSAndroid Build Coastguard Worker 25*795d594fSAndroid Build Coastguard Worker enum RegFile { GPR, MMX, SSE }; 26*795d594fSAndroid Build Coastguard Worker 27*795d594fSAndroid Build Coastguard Worker class DisassemblerX86 final : public Disassembler { 28*795d594fSAndroid Build Coastguard Worker public: DisassemblerX86(DisassemblerOptions * options,bool supports_rex)29*795d594fSAndroid Build Coastguard Worker DisassemblerX86(DisassemblerOptions* options, bool supports_rex) 30*795d594fSAndroid Build Coastguard Worker : Disassembler(options), supports_rex_(supports_rex) {} 31*795d594fSAndroid Build Coastguard Worker 32*795d594fSAndroid Build Coastguard Worker size_t Dump(std::ostream& os, const uint8_t* begin) override; 33*795d594fSAndroid Build Coastguard Worker void Dump(std::ostream& os, const uint8_t* begin, const uint8_t* end) override; 34*795d594fSAndroid Build Coastguard Worker 35*795d594fSAndroid Build Coastguard Worker private: 36*795d594fSAndroid Build Coastguard Worker size_t DumpNops(std::ostream& os, const uint8_t* instr); 37*795d594fSAndroid Build Coastguard Worker size_t DumpInstruction(std::ostream& os, const uint8_t* instr); 38*795d594fSAndroid Build Coastguard Worker 39*795d594fSAndroid Build Coastguard Worker std::string DumpAddress(uint8_t mod, uint8_t rm, uint8_t rex64, uint8_t rex_w, bool no_ops, 40*795d594fSAndroid Build Coastguard Worker bool byte_operand, bool byte_second_operand, uint8_t* prefix, bool load, 41*795d594fSAndroid Build Coastguard Worker RegFile src_reg_file, RegFile dst_reg_file, const uint8_t** instr, 42*795d594fSAndroid Build Coastguard Worker uint32_t* address_bits); 43*795d594fSAndroid Build Coastguard Worker 44*795d594fSAndroid Build Coastguard Worker const bool supports_rex_; 45*795d594fSAndroid Build Coastguard Worker 46*795d594fSAndroid Build Coastguard Worker DISALLOW_COPY_AND_ASSIGN(DisassemblerX86); 47*795d594fSAndroid Build Coastguard Worker }; 48*795d594fSAndroid Build Coastguard Worker 49*795d594fSAndroid Build Coastguard Worker } // namespace x86 50*795d594fSAndroid Build Coastguard Worker } // namespace art 51*795d594fSAndroid Build Coastguard Worker 52*795d594fSAndroid Build Coastguard Worker #endif // ART_DISASSEMBLER_DISASSEMBLER_X86_H_ 53