Index: third_party/mach_override/libudis86/udis86.c |
diff --git a/third_party/mach_override/libudis86/udis86.c b/third_party/mach_override/libudis86/udis86.c |
new file mode 100644 |
index 0000000000000000000000000000000000000000..4c7bf1f439242ad174130f621a349e3fda6b6db1 |
--- /dev/null |
+++ b/third_party/mach_override/libudis86/udis86.c |
@@ -0,0 +1,304 @@ |
+/* udis86 - libudis86/udis86.c |
+ * |
+ * Copyright (c) 2002-2013 Vivek Thampi |
+ * All rights reserved. |
+ * |
+ * Redistribution and use in source and binary forms, with or without modification, |
+ * are permitted provided that the following conditions are met: |
+ * |
+ * * Redistributions of source code must retain the above copyright notice, |
+ * this list of conditions and the following disclaimer. |
+ * * Redistributions in binary form must reproduce the above copyright notice, |
+ * this list of conditions and the following disclaimer in the documentation |
+ * and/or other materials provided with the distribution. |
+ * |
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND |
+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED |
+ * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE |
+ * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR |
+ * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES |
+ * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; |
+ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON |
+ * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS |
+ * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
+ */ |
+ |
+#include "input.h" |
+#include "extern.h" |
+#include "decode.h" |
+ |
+#if !defined(__UD_STANDALONE__) |
+# if HAVE_STRING_H |
+# include <string.h> |
+# endif |
+#endif /* !__UD_STANDALONE__ */ |
+ |
+/* ============================================================================= |
+ * ud_init() - Initializes ud_t object. |
+ * ============================================================================= |
+ */ |
+extern void |
+ud_init(struct ud* u) |
+{ |
+ memset((void*)u, 0, sizeof(struct ud)); |
+ ud_set_mode(u, 16); |
+ u->mnemonic = UD_Iinvalid; |
+ ud_set_pc(u, 0); |
+#ifndef __UD_STANDALONE__ |
+ ud_set_input_file(u, stdin); |
+#endif /* __UD_STANDALONE__ */ |
+ |
+ ud_set_asm_buffer(u, u->asm_buf_int, sizeof(u->asm_buf_int)); |
+} |
+ |
+/* ============================================================================= |
+ * ud_disassemble() - disassembles one instruction and returns the number of |
+ * bytes disassembled. A zero means end of disassembly. |
+ * ============================================================================= |
+ */ |
+extern unsigned int |
+ud_disassemble(struct ud* u) |
+{ |
+ if (ud_input_end(u)) |
+ return 0; |
+ |
+ u->asm_buf[0] = 0; |
+ |
+ if (ud_decode(u) == 0) |
+ return 0; |
+ if (u->translator) |
+ u->translator(u); |
+ return ud_insn_len(u); |
+} |
+ |
+/* ============================================================================= |
+ * ud_set_mode() - Set Disassemly Mode. |
+ * ============================================================================= |
+ */ |
+extern void |
+ud_set_mode(struct ud* u, uint8_t m) |
+{ |
+ switch(m) { |
+ case 16: |
+ case 32: |
+ case 64: u->dis_mode = m ; return; |
+ default: u->dis_mode = 16; return; |
+ } |
+} |
+ |
+/* ============================================================================= |
+ * ud_set_vendor() - Set vendor. |
+ * ============================================================================= |
+ */ |
+extern void |
+ud_set_vendor(struct ud* u, unsigned v) |
+{ |
+ switch(v) { |
+ case UD_VENDOR_INTEL: |
+ u->vendor = v; |
+ break; |
+ case UD_VENDOR_ANY: |
+ u->vendor = v; |
+ break; |
+ default: |
+ u->vendor = UD_VENDOR_AMD; |
+ } |
+} |
+ |
+/* ============================================================================= |
+ * ud_set_pc() - Sets code origin. |
+ * ============================================================================= |
+ */ |
+extern void |
+ud_set_pc(struct ud* u, uint64_t o) |
+{ |
+ u->pc = o; |
+} |
+ |
+/* ============================================================================= |
+ * ud_set_syntax() - Sets the output syntax. |
+ * ============================================================================= |
+ */ |
+extern void |
+ud_set_syntax(struct ud* u, void (*t)(struct ud*)) |
+{ |
+ u->translator = t; |
+} |
+ |
+/* ============================================================================= |
+ * ud_insn() - returns the disassembled instruction |
+ * ============================================================================= |
+ */ |
+const char* |
+ud_insn_asm(const struct ud* u) |
+{ |
+ return u->asm_buf; |
+} |
+ |
+/* ============================================================================= |
+ * ud_insn_offset() - Returns the offset. |
+ * ============================================================================= |
+ */ |
+uint64_t |
+ud_insn_off(const struct ud* u) |
+{ |
+ return u->insn_offset; |
+} |
+ |
+ |
+/* ============================================================================= |
+ * ud_insn_hex() - Returns hex form of disassembled instruction. |
+ * ============================================================================= |
+ */ |
+const char* |
+ud_insn_hex(struct ud* u) |
+{ |
+ u->insn_hexcode[0] = 0; |
+ if (!u->error) { |
+ unsigned int i; |
+ unsigned char *src_ptr = inp_sess(u); |
+ char* src_hex; |
+ src_hex = (char*) u->insn_hexcode; |
+ /* for each byte used to decode instruction */ |
+ for (i = 0; i < u->inp_ctr && i < sizeof(u->insn_hexcode) / 2; |
+ ++i, ++src_ptr) { |
+ sprintf(src_hex, "%02x", *src_ptr & 0xFF); |
+ src_hex += 2; |
+ } |
+ } |
+ return u->insn_hexcode; |
+} |
+ |
+ |
+/* ============================================================================= |
+ * ud_insn_ptr() - Returns code disassembled. |
+ * ============================================================================= |
+ */ |
+extern const uint8_t* |
+ud_insn_ptr(const struct ud* u) |
+{ |
+ return u->inp_sess; |
+} |
+ |
+/* ============================================================================= |
+ * ud_insn_len() - Returns the count of bytes disassembled. |
+ * ============================================================================= |
+ */ |
+extern unsigned int |
+ud_insn_len(const struct ud* u) |
+{ |
+ return u->inp_ctr; |
+} |
+ |
+ |
+/* ============================================================================= |
+ * ud_insn_get_opr |
+ * Return the operand struct representing the nth operand of |
+ * the currently disassembled instruction. Returns NULL if |
+ * there's no such operand. |
+ * ============================================================================= |
+ */ |
+const struct ud_operand* |
+ud_insn_opr(const struct ud *u, unsigned int n) |
+{ |
+ if (n > 2 || u->operand[n].type == UD_NONE) { |
+ return NULL; |
+ } else { |
+ return &u->operand[n]; |
+ } |
+} |
+ |
+ |
+/* ============================================================================= |
+ * ud_opr_is_sreg |
+ * Returns non-zero if the given operand is of a segment register type. |
+ * ============================================================================= |
+ */ |
+int |
+ud_opr_is_sreg(const struct ud_operand *opr) |
+{ |
+ return opr->type == UD_OP_REG && |
+ opr->base >= UD_R_ES && |
+ opr->base <= UD_R_GS; |
+} |
+ |
+ |
+/* ============================================================================= |
+ * ud_opr_is_sreg |
+ * Returns non-zero if the given operand is of a general purpose |
+ * register type. |
+ * ============================================================================= |
+ */ |
+int |
+ud_opr_is_gpr(const struct ud_operand *opr) |
+{ |
+ return opr->type == UD_OP_REG && |
+ opr->base >= UD_R_AL && |
+ opr->base <= UD_R_R15; |
+} |
+ |
+ |
+/* ============================================================================= |
+ * ud_set_user_opaque_data |
+ * ud_get_user_opaque_data |
+ * Get/set user opaqute data pointer |
+ * ============================================================================= |
+ */ |
+void |
+ud_set_user_opaque_data(struct ud * u, void* opaque) |
+{ |
+ u->user_opaque_data = opaque; |
+} |
+ |
+void* |
+ud_get_user_opaque_data(const struct ud *u) |
+{ |
+ return u->user_opaque_data; |
+} |
+ |
+ |
+/* ============================================================================= |
+ * ud_set_asm_buffer |
+ * Allow the user to set an assembler output buffer. If `buf` is NULL, |
+ * we switch back to the internal buffer. |
+ * ============================================================================= |
+ */ |
+void |
+ud_set_asm_buffer(struct ud *u, char *buf, size_t size) |
+{ |
+ if (buf == NULL) { |
+ ud_set_asm_buffer(u, u->asm_buf_int, sizeof(u->asm_buf_int)); |
+ } else { |
+ u->asm_buf = buf; |
+ u->asm_buf_size = size; |
+ } |
+} |
+ |
+ |
+/* ============================================================================= |
+ * ud_set_sym_resolver |
+ * Set symbol resolver for relative targets used in the translation |
+ * phase. |
+ * |
+ * The resolver is a function that takes a uint64_t address and returns a |
+ * symbolic name for the that address. The function also takes a second |
+ * argument pointing to an integer that the client can optionally set to a |
+ * non-zero value for offsetted targets. (symbol+offset) The function may |
+ * also return NULL, in which case the translator only prints the target |
+ * address. |
+ * |
+ * The function pointer maybe NULL which resets symbol resolution. |
+ * ============================================================================= |
+ */ |
+void |
+ud_set_sym_resolver(struct ud *u, const char* (*resolver)(struct ud*, |
+ uint64_t addr, |
+ int64_t *offset)) |
+{ |
+ u->sym_resolver = resolver; |
+} |
+ |
+/* |
+vim:set ts=2 sw=2 expandtab |
+*/ |