arch.h revision 73b85aadbf377541ac336914e5ff8ec521226a97
1d5285b23e7e515ccb6afdb82fae32a608bb28a2fPetr Machata/* 2d5285b23e7e515ccb6afdb82fae32a608bb28a2fPetr Machata * This file is part of ltrace. 3693dfad9c1b121cf079a3082866daa2225df1797Petr Machata * Copyright (C) 2012,2013 Petr Machata 4d5285b23e7e515ccb6afdb82fae32a608bb28a2fPetr Machata * Copyright (C) 2006 Paul Gilliam 5d5285b23e7e515ccb6afdb82fae32a608bb28a2fPetr Machata * Copyright (C) 2002,2004 Juan Cespedes 6d5285b23e7e515ccb6afdb82fae32a608bb28a2fPetr Machata * 7d5285b23e7e515ccb6afdb82fae32a608bb28a2fPetr Machata * This program is free software; you can redistribute it and/or 8d5285b23e7e515ccb6afdb82fae32a608bb28a2fPetr Machata * modify it under the terms of the GNU General Public License as 9d5285b23e7e515ccb6afdb82fae32a608bb28a2fPetr Machata * published by the Free Software Foundation; either version 2 of the 10d5285b23e7e515ccb6afdb82fae32a608bb28a2fPetr Machata * License, or (at your option) any later version. 11d5285b23e7e515ccb6afdb82fae32a608bb28a2fPetr Machata * 12d5285b23e7e515ccb6afdb82fae32a608bb28a2fPetr Machata * This program is distributed in the hope that it will be useful, but 13d5285b23e7e515ccb6afdb82fae32a608bb28a2fPetr Machata * WITHOUT ANY WARRANTY; without even the implied warranty of 14d5285b23e7e515ccb6afdb82fae32a608bb28a2fPetr Machata * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 15d5285b23e7e515ccb6afdb82fae32a608bb28a2fPetr Machata * General Public License for more details. 16d5285b23e7e515ccb6afdb82fae32a608bb28a2fPetr Machata * 17d5285b23e7e515ccb6afdb82fae32a608bb28a2fPetr Machata * You should have received a copy of the GNU General Public License 18d5285b23e7e515ccb6afdb82fae32a608bb28a2fPetr Machata * along with this program; if not, write to the Free Software 19d5285b23e7e515ccb6afdb82fae32a608bb28a2fPetr Machata * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 20d5285b23e7e515ccb6afdb82fae32a608bb28a2fPetr Machata * 02110-1301 USA 21d5285b23e7e515ccb6afdb82fae32a608bb28a2fPetr Machata */ 2250b96039ebfc60825bb7afb8ab8f56bb87aeb67bPetr Machata#ifndef LTRACE_PPC_ARCH_H 2350b96039ebfc60825bb7afb8ab8f56bb87aeb67bPetr Machata#define LTRACE_PPC_ARCH_H 2450b96039ebfc60825bb7afb8ab8f56bb87aeb67bPetr Machata 2550b96039ebfc60825bb7afb8ab8f56bb87aeb67bPetr Machata#include <gelf.h> 2650b96039ebfc60825bb7afb8ab8f56bb87aeb67bPetr Machata 275bfb061c4c7cfac6e1882a586cf36c849d95fceaJuan Cespedes#define BREAKPOINT_VALUE { 0x7f, 0xe0, 0x00, 0x08 } 28f1bfe203f5f1c0e11a614f9d593a68406f5cb47eJuan Cespedes#define BREAKPOINT_LENGTH 4 29f1bfe203f5f1c0e11a614f9d593a68406f5cb47eJuan Cespedes#define DECR_PC_AFTER_BREAK 0 30d914a206a11cc1011a45f00674b1e16988fae77fJuan Cespedes 31d914a206a11cc1011a45f00674b1e16988fae77fJuan Cespedes#define LT_ELFCLASS ELFCLASS32 32d914a206a11cc1011a45f00674b1e16988fae77fJuan Cespedes#define LT_ELF_MACHINE EM_PPC 33b3f8fef12fccb0914b7b28725f42192c279d31c9Petr Machata 3476c61f15d7989bf7adffed2e46a44c34a80bd927Paul Gilliam#ifdef __powerpc64__ // Says 'ltrace' is 64 bits, says nothing about target. 359a2ad351a1c3215dc596ff3e2e3fd4bc24445a6bIan Wienand#define LT_ELFCLASS2 ELFCLASS64 369a2ad351a1c3215dc596ff3e2e3fd4bc24445a6bIan Wienand#define LT_ELF_MACHINE2 EM_PPC64 37b3f8fef12fccb0914b7b28725f42192c279d31c9Petr Machata#define ARCH_SUPPORTS_OPD 387003feea8035a3c4ee661dc2556d158e9ba41d39Petr Machata#endif 399a2ad351a1c3215dc596ff3e2e3fd4bc24445a6bIan Wienand 40693dfad9c1b121cf079a3082866daa2225df1797Petr Machata#define ARCH_HAVE_SW_SINGLESTEP 4150b96039ebfc60825bb7afb8ab8f56bb87aeb67bPetr Machata#define ARCH_HAVE_ADD_PLT_ENTRY 42c67a6e62bc7e95f7f181a51c5b314ef10a6e231ePetr Machata#define ARCH_HAVE_TRANSLATE_ADDRESS 43d95733284377c0b186ba0c81a1158edc2b913e45Petr Machata#define ARCH_HAVE_DYNLINK_DONE 4454737daf1c51ec826fcabc8189a7ff891f29d59bPetr Machata#define ARCH_HAVE_FETCH_ARG 45d5285b23e7e515ccb6afdb82fae32a608bb28a2fPetr Machata#define ARCH_ENDIAN_BIG 46af9e30ec852a24f52a36775154ff79cc4be0193dPetr Machata#define ARCH_HAVE_SIZEOF 47af9e30ec852a24f52a36775154ff79cc4be0193dPetr Machata#define ARCH_HAVE_ALIGNOF 4850b96039ebfc60825bb7afb8ab8f56bb87aeb67bPetr Machata 4950b96039ebfc60825bb7afb8ab8f56bb87aeb67bPetr Machatastruct library_symbol; 50abfe118271cd45581f33f71b0cf0fddc3a2e1b05Petr Machata 51abfe118271cd45581f33f71b0cf0fddc3a2e1b05Petr Machata#define ARCH_HAVE_LTELF_DATA 52e67635d6dcecb0f44448a5329d69fd0de74ebabaPetr Machatastruct arch_ltelf_data { 53e67635d6dcecb0f44448a5329d69fd0de74ebabaPetr Machata GElf_Addr plt_stub_vma; 5450b96039ebfc60825bb7afb8ab8f56bb87aeb67bPetr Machata struct library_symbol *stubs; 55b1492dfaca6882fa0798b549e0557c7dec6b7e9cPetr Machata Elf_Data *opd_data; 56b1492dfaca6882fa0798b549e0557c7dec6b7e9cPetr Machata GElf_Addr opd_base; 57b1492dfaca6882fa0798b549e0557c7dec6b7e9cPetr Machata GElf_Xword opd_size; 58d95733284377c0b186ba0c81a1158edc2b913e45Petr Machata int secure_plt; 5973b85aadbf377541ac336914e5ff8ec521226a97Petr Machata 6073b85aadbf377541ac336914e5ff8ec521226a97Petr Machata Elf_Data *reladyn; 6173b85aadbf377541ac336914e5ff8ec521226a97Petr Machata size_t reladyn_count; 62d95733284377c0b186ba0c81a1158edc2b913e45Petr Machata}; 63d95733284377c0b186ba0c81a1158edc2b913e45Petr Machata 64d95733284377c0b186ba0c81a1158edc2b913e45Petr Machata#define ARCH_HAVE_LIBRARY_DATA 65d95733284377c0b186ba0c81a1158edc2b913e45Petr Machatastruct arch_library_data { 667e26bd32a1a2269c193a6ef100ed8cd3127f3dc2Petr Machata GElf_Addr pltgot_addr; 67d95733284377c0b186ba0c81a1158edc2b913e45Petr Machata int bss_plt_prelinked; 68e67635d6dcecb0f44448a5329d69fd0de74ebabaPetr Machata}; 6950b96039ebfc60825bb7afb8ab8f56bb87aeb67bPetr Machata 70b64b5c7b6f4a368ccaf60507090192845221a3bePetr Machataenum ppc64_plt_type { 71fbd9742d03154ca842eeae8f6a32e35c1e3c8326Petr Machata /* Either a non-PLT symbol, or PPC32 symbol. */ 72fbd9742d03154ca842eeae8f6a32e35c1e3c8326Petr Machata PPC_DEFAULT = 0, 73fbd9742d03154ca842eeae8f6a32e35c1e3c8326Petr Machata 74585f60f7b171a391fbd5149f3d397d192168a67cPetr Machata /* PPC64 STUB, never resolved. */ 75585f60f7b171a391fbd5149f3d397d192168a67cPetr Machata PPC64_PLT_STUB, 76b64b5c7b6f4a368ccaf60507090192845221a3bePetr Machata 77b64b5c7b6f4a368ccaf60507090192845221a3bePetr Machata /* Unresolved PLT symbol (.plt contains PLT address). */ 78585f60f7b171a391fbd5149f3d397d192168a67cPetr Machata PPC_PLT_UNRESOLVED, 79b64b5c7b6f4a368ccaf60507090192845221a3bePetr Machata 80b64b5c7b6f4a368ccaf60507090192845221a3bePetr Machata /* Resolved PLT symbol. The corresponding .plt slot contained 81b64b5c7b6f4a368ccaf60507090192845221a3bePetr Machata * target address, which was changed to the address of 82b64b5c7b6f4a368ccaf60507090192845221a3bePetr Machata * corresponding PLT entry. The original is now saved in 831b4c76e739f36a01ca4cc07a1df5aa5e970279e6Petr Machata * RESOLVED_VALUE. */ 84585f60f7b171a391fbd5149f3d397d192168a67cPetr Machata PPC_PLT_RESOLVED, 8573b85aadbf377541ac336914e5ff8ec521226a97Petr Machata 8673b85aadbf377541ac336914e5ff8ec521226a97Petr Machata /* Very similar to PPC_PLT_UNRESOLVED, but for JMP_IREL 8773b85aadbf377541ac336914e5ff8ec521226a97Petr Machata * slots. */ 8873b85aadbf377541ac336914e5ff8ec521226a97Petr Machata PPC_PLT_IRELATIVE, 89b64b5c7b6f4a368ccaf60507090192845221a3bePetr Machata}; 90b64b5c7b6f4a368ccaf60507090192845221a3bePetr Machata 9124c6e9daa8d89e13c19fc3f9a475ba7913d7d9c8Petr Machata#define ARCH_HAVE_LIBRARY_SYMBOL_DATA 92b64b5c7b6f4a368ccaf60507090192845221a3bePetr Machatastruct arch_library_symbol_data { 93b64b5c7b6f4a368ccaf60507090192845221a3bePetr Machata enum ppc64_plt_type type; 9458b2d0fd5deed5f33fbd47a6b6e5c109f43908b5Petr Machata GElf_Addr resolved_value; 9558b2d0fd5deed5f33fbd47a6b6e5c109f43908b5Petr Machata 9658b2d0fd5deed5f33fbd47a6b6e5c109f43908b5Petr Machata /* Address of corresponding slot in .plt. */ 9758b2d0fd5deed5f33fbd47a6b6e5c109f43908b5Petr Machata GElf_Addr plt_slot_addr; 98b64b5c7b6f4a368ccaf60507090192845221a3bePetr Machata}; 99b64b5c7b6f4a368ccaf60507090192845221a3bePetr Machata 100abfe118271cd45581f33f71b0cf0fddc3a2e1b05Petr Machata#define ARCH_HAVE_BREAKPOINT_DATA 101b64b5c7b6f4a368ccaf60507090192845221a3bePetr Machatastruct arch_breakpoint_data { 10273b85aadbf377541ac336914e5ff8ec521226a97Petr Machata /* This is where we hide symbol for IRELATIVE breakpoint for 10373b85aadbf377541ac336914e5ff8ec521226a97Petr Machata * the first time that it hits. This is NULL for normal 10473b85aadbf377541ac336914e5ff8ec521226a97Petr Machata * breakpoints. */ 10573b85aadbf377541ac336914e5ff8ec521226a97Petr Machata struct library_symbol *irel_libsym; 106b64b5c7b6f4a368ccaf60507090192845221a3bePetr Machata}; 107b64b5c7b6f4a368ccaf60507090192845221a3bePetr Machata 1086b314183200b1462ef4aad6e04fda72f3f6b0d87Petr Machata#define ARCH_HAVE_PROCESS_DATA 1096b314183200b1462ef4aad6e04fda72f3f6b0d87Petr Machatastruct arch_process_data { 1106b314183200b1462ef4aad6e04fda72f3f6b0d87Petr Machata /* Breakpoint that hits when the dynamic linker is about to 1116b314183200b1462ef4aad6e04fda72f3f6b0d87Petr Machata * update a .plt slot. NULL before that address is known. */ 1126b314183200b1462ef4aad6e04fda72f3f6b0d87Petr Machata struct breakpoint *dl_plt_update_bp; 1136b314183200b1462ef4aad6e04fda72f3f6b0d87Petr Machata 1146b314183200b1462ef4aad6e04fda72f3f6b0d87Petr Machata /* PLT update breakpoint looks here for the handler. */ 1156b314183200b1462ef4aad6e04fda72f3f6b0d87Petr Machata struct process_stopping_handler *handler; 1166b314183200b1462ef4aad6e04fda72f3f6b0d87Petr Machata}; 1176b314183200b1462ef4aad6e04fda72f3f6b0d87Petr Machata 11850b96039ebfc60825bb7afb8ab8f56bb87aeb67bPetr Machata#endif /* LTRACE_PPC_ARCH_H */ 119