X-Git-Url: http://git.sourceforge.jp/view?a=blobdiff_plain;f=gcc%2Funwind-pe.h;h=9c56af0848618972a3747a91faac3f76bd316db7;hb=263049e491b6367ffc92051fd24d55cab154caf2;hp=74c4e2778b244df44f0f053ad0a694f9119661a5;hpb=a6398abe39206cc17ae1a67d3374c1482e15d07b;p=pf3gnuchains%2Fgcc-fork.git diff --git a/gcc/unwind-pe.h b/gcc/unwind-pe.h index 74c4e2778b2..9c56af08486 100644 --- a/gcc/unwind-pe.h +++ b/gcc/unwind-pe.h @@ -1,5 +1,5 @@ /* Exception handling and frame unwind runtime interface routines. - Copyright (C) 2001 Free Software Foundation, Inc. + Copyright (C) 2001, 2002, 2003, 2004 Free Software Foundation, Inc. This file is part of GCC. @@ -8,6 +8,15 @@ the Free Software Foundation; either version 2, or (at your option) any later version. + In addition to the permissions in the GNU General Public License, the + Free Software Foundation gives you unlimited permission to link the + compiled version of this file into combinations with other programs, + and to distribute those combinations without any restriction coming + from the use of this file. (The General Public License restrictions + do apply in other respects; for example, they cover modification of + the file, and distribution when not linked into a combined + executable.) + GCC is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public @@ -15,14 +24,17 @@ You should have received a copy of the GNU General Public License along with GCC; see the file COPYING. If not, write to the Free - Software Foundation, 59 Temple Place - Suite 330, Boston, MA - 02111-1307, USA. */ + Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA + 02110-1301, USA. */ /* @@@ Really this should be out of line, but this also causes link compatibility problems with the base ABI. This is slightly better than duplicating code, however. */ -/* If using C++, references to abort have to be qualified with std::. */ +#ifndef GCC_UNWIND_PE_H +#define GCC_UNWIND_PE_H + +/* If using C++, references to abort have to be qualified with std::. */ #if __cplusplus #define __gxx_abort std::abort #else @@ -52,6 +64,8 @@ #define DW_EH_PE_indirect 0x80 +#ifndef NO_SIZE_OF_ENCODED_VALUE + /* Given an encoding, return the number of bytes the format occupies. This is only defined for fixed-size encodings, and so does not include leb128. */ @@ -76,6 +90,8 @@ size_of_encoded_value (unsigned char encoding) __gxx_abort (); } +#endif + #ifndef NO_BASE_OF_ENCODED_VALUE /* Given an encoding and an _Unwind_Context, return the base to which @@ -114,17 +130,17 @@ base_of_encoded_value (unsigned char encoding, struct _Unwind_Context *context) pointers should not be leb128 encoded on that target. */ static const unsigned char * -read_uleb128 (const unsigned char *p, _Unwind_Word *val) +read_uleb128 (const unsigned char *p, _uleb128_t *val) { unsigned int shift = 0; unsigned char byte; - _Unwind_Word result; + _uleb128_t result; result = 0; do { byte = *p++; - result |= (byte & 0x7f) << shift; + result |= ((_uleb128_t)byte & 0x7f) << shift; shift += 7; } while (byte & 0x80); @@ -136,26 +152,26 @@ read_uleb128 (const unsigned char *p, _Unwind_Word *val) /* Similar, but read a signed leb128 value. */ static const unsigned char * -read_sleb128 (const unsigned char *p, _Unwind_Sword *val) +read_sleb128 (const unsigned char *p, _sleb128_t *val) { unsigned int shift = 0; unsigned char byte; - _Unwind_Word result; + _uleb128_t result; result = 0; do { byte = *p++; - result |= (byte & 0x7f) << shift; + result |= ((_uleb128_t)byte & 0x7f) << shift; shift += 7; } while (byte & 0x80); /* Sign-extend a negative value. */ if (shift < 8 * sizeof(result) && (byte & 0x40) != 0) - result |= -(1L << shift); + result |= -(((_uleb128_t)1L) << shift); - *val = (_Unwind_Sword) result; + *val = (_sleb128_t) result; return p; } @@ -178,38 +194,38 @@ read_encoded_value_with_base (unsigned char encoding, _Unwind_Ptr base, signed s8 __attribute__ ((mode (DI))); } __attribute__((__packed__)); - union unaligned *u = (union unaligned *) p; - _Unwind_Ptr result; + const union unaligned *u = (const union unaligned *) p; + _Unwind_Internal_Ptr result; if (encoding == DW_EH_PE_aligned) { - _Unwind_Ptr a = (_Unwind_Ptr)p; + _Unwind_Internal_Ptr a = (_Unwind_Internal_Ptr) p; a = (a + sizeof (void *) - 1) & - sizeof(void *); - result = *(_Unwind_Ptr *) a; - p = (const unsigned char *)(a + sizeof (void *)); + result = *(_Unwind_Internal_Ptr *) a; + p = (const unsigned char *) (_Unwind_Internal_Ptr) (a + sizeof (void *)); } else { switch (encoding & 0x0f) { case DW_EH_PE_absptr: - result = (_Unwind_Ptr) u->ptr; + result = (_Unwind_Internal_Ptr) u->ptr; p += sizeof (void *); break; case DW_EH_PE_uleb128: { - _Unwind_Word tmp; + _uleb128_t tmp; p = read_uleb128 (p, &tmp); - result = (_Unwind_Ptr)tmp; + result = (_Unwind_Internal_Ptr) tmp; } break; case DW_EH_PE_sleb128: { - _Unwind_Sword tmp; + _sleb128_t tmp; p = read_sleb128 (p, &tmp); - result = (_Unwind_Ptr)tmp; + result = (_Unwind_Internal_Ptr) tmp; } break; @@ -246,9 +262,9 @@ read_encoded_value_with_base (unsigned char encoding, _Unwind_Ptr base, if (result != 0) { result += ((encoding & 0x70) == DW_EH_PE_pcrel - ? (_Unwind_Ptr)u : base); + ? (_Unwind_Internal_Ptr) u : base); if (encoding & DW_EH_PE_indirect) - result = *(_Unwind_Ptr *)result; + result = *(_Unwind_Internal_Ptr *) result; } } @@ -271,3 +287,5 @@ read_encoded_value (struct _Unwind_Context *context, unsigned char encoding, } #endif + +#endif /* unwind-pe.h */