Sean Callanan | 04cc307 | 2009-12-19 02:59:52 +0000 | [diff] [blame] | 1 | //===- X86DisassemblerShared.h - Emitter shared header ----------*- C++ -*-===// |
| 2 | // |
| 3 | // The LLVM Compiler Infrastructure |
| 4 | // |
| 5 | // This file is distributed under the University of Illinois Open Source |
| 6 | // License. See LICENSE.TXT for details. |
| 7 | // |
| 8 | //===----------------------------------------------------------------------===// |
| 9 | |
| 10 | #ifndef X86DISASSEMBLERSHARED_H |
| 11 | #define X86DISASSEMBLERSHARED_H |
| 12 | |
Nuno Lopes | 91b866a | 2009-12-19 11:52:18 +0000 | [diff] [blame] | 13 | #include <string.h> |
Chandler Carruth | 91d19d8 | 2012-12-04 10:37:14 +0000 | [diff] [blame] | 14 | #include <string> |
Sean Callanan | 04cc307 | 2009-12-19 02:59:52 +0000 | [diff] [blame] | 15 | |
Daniel Dunbar | 3a821f7 | 2009-12-19 04:16:57 +0000 | [diff] [blame] | 16 | #define INSTRUCTION_SPECIFIER_FIELDS \ |
Craig Topper | b8aec08 | 2012-08-01 07:39:18 +0000 | [diff] [blame] | 17 | struct OperandSpecifier operands[X86_MAX_OPERANDS]; \ |
Daniel Dunbar | 3a821f7 | 2009-12-19 04:16:57 +0000 | [diff] [blame] | 18 | InstructionContext insnContext; \ |
| 19 | std::string name; \ |
| 20 | \ |
| 21 | InstructionSpecifier() { \ |
Daniel Dunbar | 3a821f7 | 2009-12-19 04:16:57 +0000 | [diff] [blame] | 22 | insnContext = IC; \ |
| 23 | name = ""; \ |
Daniel Dunbar | 3a821f7 | 2009-12-19 04:16:57 +0000 | [diff] [blame] | 24 | memset(operands, 0, sizeof(operands)); \ |
Sean Callanan | 04cc307 | 2009-12-19 02:59:52 +0000 | [diff] [blame] | 25 | } |
| 26 | |
| 27 | #define INSTRUCTION_IDS \ |
| 28 | InstrUID instructionIDs[256]; |
| 29 | |
| 30 | #include "../../lib/Target/X86/Disassembler/X86DisassemblerDecoderCommon.h" |
| 31 | |
| 32 | #undef INSTRUCTION_SPECIFIER_FIELDS |
| 33 | #undef INSTRUCTION_IDS |
| 34 | |
| 35 | #endif |