blob: a329280b702c1a60587f13f3dbfd6972b6326465 [file] [log] [blame]
Ian Rogers706a10e2012-03-23 17:00:55 -07001/*
2 * Copyright (C) 2012 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
Ian Rogers02ed4c02013-09-06 13:10:04 -070017#ifndef ART_DISASSEMBLER_DISASSEMBLER_X86_H_
18#define ART_DISASSEMBLER_DISASSEMBLER_X86_H_
Ian Rogers706a10e2012-03-23 17:00:55 -070019
20#include "disassembler.h"
21
22namespace art {
23namespace x86 {
24
Andreas Gampee5eb7062014-12-12 18:44:19 -080025enum RegFile { GPR, MMX, SSE };
26
Roland Levillainbbc6e7e2018-08-24 16:58:47 +010027class DisassemblerX86 final : public Disassembler {
Ian Rogers706a10e2012-03-23 17:00:55 -070028 public:
Brian Carlstrom2cbaccb2014-09-14 20:34:17 -070029 DisassemblerX86(DisassemblerOptions* options, bool supports_rex)
30 : Disassembler(options), supports_rex_(supports_rex) {}
Ian Rogers706a10e2012-03-23 17:00:55 -070031
Roland Levillainbbc6e7e2018-08-24 16:58:47 +010032 size_t Dump(std::ostream& os, const uint8_t* begin) override;
33 void Dump(std::ostream& os, const uint8_t* begin, const uint8_t* end) override;
Ian Rogers38e12032014-03-14 14:06:14 -070034
Ian Rogers706a10e2012-03-23 17:00:55 -070035 private:
Serdjuk, Nikolay Y44148222015-09-14 18:05:33 +060036 size_t DumpNops(std::ostream& os, const uint8_t* instr);
Ian Rogers706a10e2012-03-23 17:00:55 -070037 size_t DumpInstruction(std::ostream& os, const uint8_t* instr);
Ian Rogers38e12032014-03-14 14:06:14 -070038
Andreas Gampee5eb7062014-12-12 18:44:19 -080039 std::string DumpAddress(uint8_t mod, uint8_t rm, uint8_t rex64, uint8_t rex_w, bool no_ops,
40 bool byte_operand, bool byte_second_operand, uint8_t* prefix, bool load,
41 RegFile src_reg_file, RegFile dst_reg_file, const uint8_t** instr,
42 uint32_t* address_bits);
43
Ian Rogers38e12032014-03-14 14:06:14 -070044 const bool supports_rex_;
45
46 DISALLOW_COPY_AND_ASSIGN(DisassemblerX86);
Ian Rogers706a10e2012-03-23 17:00:55 -070047};
48
49} // namespace x86
50} // namespace art
51
Ian Rogers02ed4c02013-09-06 13:10:04 -070052#endif // ART_DISASSEMBLER_DISASSEMBLER_X86_H_