arch.h revision 693dfad9c1b121cf079a3082866daa2225df1797
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;
59d95733284377c0b186ba0c81a1158edc2b913e45Petr Machata};
60d95733284377c0b186ba0c81a1158edc2b913e45Petr Machata
61d95733284377c0b186ba0c81a1158edc2b913e45Petr Machata#define ARCH_HAVE_LIBRARY_DATA
62d95733284377c0b186ba0c81a1158edc2b913e45Petr Machatastruct arch_library_data {
637e26bd32a1a2269c193a6ef100ed8cd3127f3dc2Petr Machata	GElf_Addr pltgot_addr;
64d95733284377c0b186ba0c81a1158edc2b913e45Petr Machata	int bss_plt_prelinked;
65e67635d6dcecb0f44448a5329d69fd0de74ebabaPetr Machata};
6650b96039ebfc60825bb7afb8ab8f56bb87aeb67bPetr Machata
67b64b5c7b6f4a368ccaf60507090192845221a3bePetr Machataenum ppc64_plt_type {
68fbd9742d03154ca842eeae8f6a32e35c1e3c8326Petr Machata	/* Either a non-PLT symbol, or PPC32 symbol.  */
69fbd9742d03154ca842eeae8f6a32e35c1e3c8326Petr Machata	PPC_DEFAULT = 0,
70fbd9742d03154ca842eeae8f6a32e35c1e3c8326Petr Machata
71585f60f7b171a391fbd5149f3d397d192168a67cPetr Machata	/* PPC64 STUB, never resolved.  */
72585f60f7b171a391fbd5149f3d397d192168a67cPetr Machata	PPC64_PLT_STUB,
73b64b5c7b6f4a368ccaf60507090192845221a3bePetr Machata
74b64b5c7b6f4a368ccaf60507090192845221a3bePetr Machata	/* Unresolved PLT symbol (.plt contains PLT address).  */
75585f60f7b171a391fbd5149f3d397d192168a67cPetr Machata	PPC_PLT_UNRESOLVED,
76b64b5c7b6f4a368ccaf60507090192845221a3bePetr Machata
77b64b5c7b6f4a368ccaf60507090192845221a3bePetr Machata	/* Resolved PLT symbol.  The corresponding .plt slot contained
78b64b5c7b6f4a368ccaf60507090192845221a3bePetr Machata	 * target address, which was changed to the address of
79b64b5c7b6f4a368ccaf60507090192845221a3bePetr Machata	 * corresponding PLT entry.  The original is now saved in
801b4c76e739f36a01ca4cc07a1df5aa5e970279e6Petr Machata	 * RESOLVED_VALUE.  */
81585f60f7b171a391fbd5149f3d397d192168a67cPetr Machata	PPC_PLT_RESOLVED,
82b64b5c7b6f4a368ccaf60507090192845221a3bePetr Machata};
83b64b5c7b6f4a368ccaf60507090192845221a3bePetr Machata
8424c6e9daa8d89e13c19fc3f9a475ba7913d7d9c8Petr Machata#define ARCH_HAVE_LIBRARY_SYMBOL_DATA
85b64b5c7b6f4a368ccaf60507090192845221a3bePetr Machatastruct arch_library_symbol_data {
86b64b5c7b6f4a368ccaf60507090192845221a3bePetr Machata	enum ppc64_plt_type type;
8758b2d0fd5deed5f33fbd47a6b6e5c109f43908b5Petr Machata	GElf_Addr resolved_value;
8858b2d0fd5deed5f33fbd47a6b6e5c109f43908b5Petr Machata
8958b2d0fd5deed5f33fbd47a6b6e5c109f43908b5Petr Machata	/* Address of corresponding slot in .plt.  */
9058b2d0fd5deed5f33fbd47a6b6e5c109f43908b5Petr Machata	GElf_Addr plt_slot_addr;
91b64b5c7b6f4a368ccaf60507090192845221a3bePetr Machata};
92b64b5c7b6f4a368ccaf60507090192845221a3bePetr Machata
93abfe118271cd45581f33f71b0cf0fddc3a2e1b05Petr Machata#define ARCH_HAVE_BREAKPOINT_DATA
94b64b5c7b6f4a368ccaf60507090192845221a3bePetr Machatastruct arch_breakpoint_data {
95abfe118271cd45581f33f71b0cf0fddc3a2e1b05Petr Machata	/* We need this just for arch_breakpoint_init.  */
96b64b5c7b6f4a368ccaf60507090192845221a3bePetr Machata};
97b64b5c7b6f4a368ccaf60507090192845221a3bePetr Machata
986b314183200b1462ef4aad6e04fda72f3f6b0d87Petr Machata#define ARCH_HAVE_PROCESS_DATA
996b314183200b1462ef4aad6e04fda72f3f6b0d87Petr Machatastruct arch_process_data {
1006b314183200b1462ef4aad6e04fda72f3f6b0d87Petr Machata	/* Breakpoint that hits when the dynamic linker is about to
1016b314183200b1462ef4aad6e04fda72f3f6b0d87Petr Machata	 * update a .plt slot.  NULL before that address is known.  */
1026b314183200b1462ef4aad6e04fda72f3f6b0d87Petr Machata	struct breakpoint *dl_plt_update_bp;
1036b314183200b1462ef4aad6e04fda72f3f6b0d87Petr Machata
1046b314183200b1462ef4aad6e04fda72f3f6b0d87Petr Machata	/* PLT update breakpoint looks here for the handler.  */
1056b314183200b1462ef4aad6e04fda72f3f6b0d87Petr Machata	struct process_stopping_handler *handler;
1066b314183200b1462ef4aad6e04fda72f3f6b0d87Petr Machata};
1076b314183200b1462ef4aad6e04fda72f3f6b0d87Petr Machata
10850b96039ebfc60825bb7afb8ab8f56bb87aeb67bPetr Machata#endif /* LTRACE_PPC_ARCH_H */
109