blob: 71c3e4161c5778a6752814c6e6c9ace9d1b246a3 [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
Ian Rogers38e12032014-03-14 14:06:14 -070027class 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
Ian Rogers38e12032014-03-14 14:06:14 -070032 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;
34
Ian Rogers706a10e2012-03-23 17:00:55 -070035 private:
36 size_t DumpInstruction(std::ostream& os, const uint8_t* instr);
Ian Rogers38e12032014-03-14 14:06:14 -070037
Andreas Gampee5eb7062014-12-12 18:44:19 -080038 std::string DumpAddress(uint8_t mod, uint8_t rm, uint8_t rex64, uint8_t rex_w, bool no_ops,
39 bool byte_operand, bool byte_second_operand, uint8_t* prefix, bool load,
40 RegFile src_reg_file, RegFile dst_reg_file, const uint8_t** instr,
41 uint32_t* address_bits);
42
Ian Rogers38e12032014-03-14 14:06:14 -070043 const bool supports_rex_;
44
45 DISALLOW_COPY_AND_ASSIGN(DisassemblerX86);
Ian Rogers706a10e2012-03-23 17:00:55 -070046};
47
48} // namespace x86
49} // namespace art
50
Ian Rogers02ed4c02013-09-06 13:10:04 -070051#endif // ART_DISASSEMBLER_DISASSEMBLER_X86_H_