Path: blob/master/src/hotspot/cpu/arm/disassembler_arm.hpp
40930 views
/*1* Copyright (c) 2008, 2019, Oracle and/or its affiliates. All rights reserved.2* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.3*4* This code is free software; you can redistribute it and/or modify it5* under the terms of the GNU General Public License version 2 only, as6* published by the Free Software Foundation.7*8* This code is distributed in the hope that it will be useful, but WITHOUT9* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or10* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License11* version 2 for more details (a copy is included in the LICENSE file that12* accompanied this code).13*14* You should have received a copy of the GNU General Public License version15* 2 along with this work; if not, write to the Free Software Foundation,16* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.17*18* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA19* or visit www.oracle.com if you need additional information or have any20* questions.21*22*/2324#ifndef CPU_ARM_DISASSEMBLER_ARM_HPP25#define CPU_ARM_DISASSEMBLER_ARM_HPP2627static int pd_instruction_alignment() {28return sizeof(int);29}3031static const char* pd_cpu_opts() {32return "";33}3435// Returns address of n-th instruction preceding addr,36// NULL if no preceding instruction can be found.37// On ARM, we assume a constant instruction length.38// It might be beneficial to check "is_readable" as we do on ppc and s390.39static address find_prev_instr(address addr, int n_instr) {40return addr - Assembler::InstructionSize*n_instr;41}4243// special-case instruction decoding.44// There may be cases where the binutils disassembler doesn't do45// the perfect job. In those cases, decode_instruction0 may kick in46// and do it right.47// If nothing had to be done, just return "here", otherwise return "here + instr_len(here)"48static address decode_instruction0(address here, outputStream* st, address virtual_begin = NULL) {49return here;50}5152// platform-specific instruction annotations (like value of loaded constants)53static void annotate(address pc, outputStream* st) { };5455#endif // CPU_ARM_DISASSEMBLER_ARM_HPP565758