mostang.com!davidm | 7fbfe0a | 2002-02-15 23:22:05 +0000 | [diff] [blame] | 1 | /* libunwind - a platform-independent unwind library |
| 2 | Copyright (C) 2001-2002 Hewlett-Packard Co |
| 3 | Contributed by David Mosberger-Tang <davidm@hpl.hp.com> |
| 4 | |
| 5 | This file is part of libunwind. |
| 6 | |
mostang.com!davidm | aca3843 | 2002-11-16 03:25:36 +0000 | [diff] [blame^] | 7 | Permission is hereby granted, free of charge, to any person obtaining |
| 8 | a copy of this software and associated documentation files (the |
| 9 | "Software"), to deal in the Software without restriction, including |
| 10 | without limitation the rights to use, copy, modify, merge, publish, |
| 11 | distribute, sublicense, and/or sell copies of the Software, and to |
| 12 | permit persons to whom the Software is furnished to do so, subject to |
| 13 | the following conditions: |
mostang.com!davidm | 7fbfe0a | 2002-02-15 23:22:05 +0000 | [diff] [blame] | 14 | |
mostang.com!davidm | aca3843 | 2002-11-16 03:25:36 +0000 | [diff] [blame^] | 15 | The above copyright notice and this permission notice shall be |
| 16 | included in all copies or substantial portions of the Software. |
mostang.com!davidm | 7fbfe0a | 2002-02-15 23:22:05 +0000 | [diff] [blame] | 17 | |
mostang.com!davidm | aca3843 | 2002-11-16 03:25:36 +0000 | [diff] [blame^] | 18 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, |
| 19 | EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF |
| 20 | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND |
| 21 | NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE |
| 22 | LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION |
| 23 | OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION |
| 24 | WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ |
mostang.com!davidm | 7fbfe0a | 2002-02-15 23:22:05 +0000 | [diff] [blame] | 25 | |
hp.com!davidm | 1f3b87a | 2002-04-05 23:37:55 +0000 | [diff] [blame] | 26 | #ifndef LIBUNWIND_H |
| 27 | #define LIBUNWIND_H |
| 28 | |
| 29 | #include <stdint.h> |
mostang.com!davidm | 7fbfe0a | 2002-02-15 23:22:05 +0000 | [diff] [blame] | 30 | #include <ucontext.h> |
| 31 | |
hp.com!davidm | 1f3b87a | 2002-04-05 23:37:55 +0000 | [diff] [blame] | 32 | #define UNW_TARGET ia64 |
| 33 | |
(none)!davidm | cd66944 | 2002-02-22 21:58:53 +0000 | [diff] [blame] | 34 | typedef uint64_t unw_tdep_word_t; |
| 35 | |
mostang.com!davidm | 7fbfe0a | 2002-02-15 23:22:05 +0000 | [diff] [blame] | 36 | typedef enum |
| 37 | { |
| 38 | /* Note: general registers are excepted to start with index 0. |
| 39 | This convention facilitates architecture-independent |
| 40 | implementation of the C++ exception handling ABI. See |
| 41 | _Unwind_SetGR() and _Unwind_GetGR() for details. */ |
| 42 | UNW_IA64_GR = 0, /* general registers (r0..r127) */ |
| 43 | UNW_IA64_GP = UNW_IA64_GR + 1, |
mostang.com!davidm | 7fbfe0a | 2002-02-15 23:22:05 +0000 | [diff] [blame] | 44 | UNW_IA64_TP = UNW_IA64_GR + 13, |
| 45 | |
| 46 | UNW_IA64_NAT = UNW_IA64_GR + 128, /* NaT registers (nat0..nat127) */ |
| 47 | |
| 48 | UNW_IA64_FR = UNW_IA64_NAT + 128, /* fp registers (f0..f127) */ |
| 49 | |
| 50 | UNW_IA64_AR = UNW_IA64_FR + 128, /* application registers (ar0..r127) */ |
| 51 | UNW_IA64_AR_RSC = UNW_IA64_AR + 16, |
| 52 | UNW_IA64_AR_BSP = UNW_IA64_AR + 17, |
| 53 | UNW_IA64_AR_BSPSTORE = UNW_IA64_AR + 18, |
| 54 | UNW_IA64_AR_RNAT = UNW_IA64_AR + 19, |
| 55 | UNW_IA64_AR_25 = UNW_IA64_AR + 25, /* reserved (scratch) */ |
| 56 | UNW_IA64_AR_26 = UNW_IA64_AR + 26, /* reserved (scratch) */ |
| 57 | UNW_IA64_AR_CCV = UNW_IA64_AR + 32, |
| 58 | UNW_IA64_AR_UNAT = UNW_IA64_AR + 36, |
| 59 | UNW_IA64_AR_FPSR = UNW_IA64_AR + 40, |
| 60 | UNW_IA64_AR_PFS = UNW_IA64_AR + 64, |
| 61 | UNW_IA64_AR_LC = UNW_IA64_AR + 65, |
| 62 | UNW_IA64_AR_EC = UNW_IA64_AR + 66, |
| 63 | |
| 64 | UNW_IA64_BR = UNW_IA64_AR + 128, /* branch registers (b0..p7) */ |
| 65 | UNW_IA64_PR = UNW_IA64_BR + 8, /* predicate registers (p0..p63) */ |
| 66 | UNW_IA64_CFM, |
| 67 | |
| 68 | /* frame info (read-only): */ |
mostang.com!davidm | 99639fb | 2002-04-01 23:01:22 +0000 | [diff] [blame] | 69 | UNW_IA64_BSP, |
(none)!davidm | cd66944 | 2002-02-22 21:58:53 +0000 | [diff] [blame] | 70 | UNW_IA64_IP, |
| 71 | UNW_IA64_SP, |
| 72 | UNW_IA64_PROC_START, |
| 73 | UNW_IA64_HANDLER, |
| 74 | UNW_IA64_LSDA, |
mostang.com!davidm | 7fbfe0a | 2002-02-15 23:22:05 +0000 | [diff] [blame] | 75 | |
(none)!davidm | cd66944 | 2002-02-22 21:58:53 +0000 | [diff] [blame] | 76 | UNW_TDEP_LAST_REG = UNW_IA64_LSDA, |
| 77 | |
| 78 | UNW_TDEP_IP = UNW_IA64_IP, |
| 79 | UNW_TDEP_SP = UNW_IA64_SP, |
| 80 | UNW_TDEP_PROC_START = UNW_IA64_PROC_START, |
| 81 | UNW_TDEP_HANDLER = UNW_IA64_HANDLER, |
| 82 | UNW_TDEP_LSDA = UNW_IA64_LSDA, |
mostang.com!davidm | 7fbfe0a | 2002-02-15 23:22:05 +0000 | [diff] [blame] | 83 | } |
| 84 | ia64_regnum_t; |
| 85 | |
| 86 | /* Info needed for a single IA-64 unwind. A pointer to this structure |
| 87 | is expected in the acquire/release callbacks of the unwind |
| 88 | accessors. */ |
| 89 | typedef struct unw_ia64_table |
| 90 | { |
| 91 | const char *name; /* table name (or NULL if none) */ |
(none)!davidm | cd66944 | 2002-02-22 21:58:53 +0000 | [diff] [blame] | 92 | unw_tdep_word_t segbase; /* base for offsets in the unwind table */ |
| 93 | unw_tdep_word_t start; /* starting IP covered by table */ |
| 94 | unw_tdep_word_t end; /* first IP _not_ covered table */ |
| 95 | unw_tdep_word_t gp; /* global pointer for this load-module */ |
| 96 | unw_tdep_word_t length; /* number of entries in unwind table array */ |
mostang.com!davidm | 7fbfe0a | 2002-02-15 23:22:05 +0000 | [diff] [blame] | 97 | |
(none)!davidm | cd66944 | 2002-02-22 21:58:53 +0000 | [diff] [blame] | 98 | /* Pointer to local copy of the unwind descriptor table: */ |
| 99 | void *array; |
mostang.com!davidm | 7fbfe0a | 2002-02-15 23:22:05 +0000 | [diff] [blame] | 100 | |
| 101 | /* Local copy of the unwind descriptor information. This is |
| 102 | initialized such that adding the unwind entry's info_offset |
| 103 | yields the address at which the corresponding descriptors can |
| 104 | be found. */ |
| 105 | const unsigned char *unwind_info_base; |
| 106 | } |
| 107 | unw_ia64_table_t; |
| 108 | |
hp.com!davidm | f1d10c0 | 2002-04-03 06:51:34 +0000 | [diff] [blame] | 109 | typedef struct unw_tdep_save_loc |
| 110 | { |
| 111 | /* Additional target-dependent info on a save location. On IA-64, |
| 112 | we could use this to specify the bit number in which a NaT bit |
| 113 | gets saved. For now, nobody wants to know this, so it's not |
| 114 | currently implemented. */ |
| 115 | } |
| 116 | unw_tdep_save_loc_t; |
| 117 | |
mostang.com!davidm | 7fbfe0a | 2002-02-15 23:22:05 +0000 | [diff] [blame] | 118 | /* On IA-64, we can directly use ucontext_t as the unwind context. */ |
| 119 | typedef ucontext_t unw_tdep_context_t; |
| 120 | |
| 121 | /* XXX this is not ideal: an application should not be prevented from |
| 122 | using the "getcontext" name just because it's using libunwind. We |
| 123 | can't just use __getcontext() either, because that isn't exported |
| 124 | by glibc... */ |
mostang.com!davidm | 74775e3 | 2002-04-12 05:02:40 +0000 | [diff] [blame] | 125 | #define unw_tdep_getcontext(uc) (getcontext (uc), 0) |
mostang.com!davidm | 5c6360b | 2002-04-04 19:04:09 +0000 | [diff] [blame] | 126 | |
| 127 | #define unw_tdep_is_fpreg(r) ((unsigned) ((r) - UNW_IA64_FR) < 128) |
hp.com!davidm | 1f3b87a | 2002-04-05 23:37:55 +0000 | [diff] [blame] | 128 | |
| 129 | #include "libunwind-common.h" |
| 130 | |
| 131 | #endif /* LIBUNWIND_H */ |