diff options
author | aj <aj@138bc75d-0d04-0410-961f-82ee72b054a4> | 2003-11-01 09:59:50 +0000 |
---|---|---|
committer | aj <aj@138bc75d-0d04-0410-961f-82ee72b054a4> | 2003-11-01 09:59:50 +0000 |
commit | 358738f405897b9048582d9b32a7178895e1c274 (patch) | |
tree | 979d73e2cbba427d30603801daf43b6ff3a25bd1 /gcc/unwind-dw2-fde-darwin.c | |
parent | 4044e7e8a165e082ec6fc43fca8531a162b698f0 (diff) | |
download | gcc-358738f405897b9048582d9b32a7178895e1c274.tar.gz |
* unwind-dw2.c (_Unwind_FindEnclosingFunction): Constify variable.
(uw_frame_state_for): Constify variables.
(extract_cie_info): Constify first argument.
* unwind-dw2-fde-darwin.c: Adjust prototype of
_Unwind_Find_registered_FDE for recent changes.
(examine_objects): Constify return value and local variable result.
(_Unwind_Find_FDE): Constify return value and local variable ret.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@73172 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/unwind-dw2-fde-darwin.c')
-rw-r--r-- | gcc/unwind-dw2-fde-darwin.c | 50 |
1 files changed, 25 insertions, 25 deletions
diff --git a/gcc/unwind-dw2-fde-darwin.c b/gcc/unwind-dw2-fde-darwin.c index 26706d33705..24cf3bca7e9 100644 --- a/gcc/unwind-dw2-fde-darwin.c +++ b/gcc/unwind-dw2-fde-darwin.c @@ -41,8 +41,8 @@ typedef int __gthread_mutex_t; #define __gthread_mutex_lock(x) (void)(x) #define __gthread_mutex_unlock(x) (void)(x) -static fde * _Unwind_Find_registered_FDE (void *pc, - struct dwarf_eh_bases *bases); +static const fde * _Unwind_Find_registered_FDE (void *pc, + struct dwarf_eh_bases *bases); #define _Unwind_Find_FDE _Unwind_Find_registered_FDE #include "unwind-dw2-fde.c" @@ -99,7 +99,7 @@ enum { because this object might be about to be unloaded. Called by KeyMgr. */ -static void +static void live_image_destructor (struct live_images *image) { if (image->object_info) @@ -136,11 +136,11 @@ live_image_destructor (struct live_images *image) give each unseen image a new `struct object'. Even if we can't, check whether the PC is inside the FDE of each unseen image. */ - -static inline fde * + +static inline const fde * examine_objects (void *pc, struct dwarf_eh_bases *bases, int dont_alloc) { - fde *result = NULL; + const fde *result = NULL; struct live_images *image; image = _keymgr_get_and_lock_processwide_ptr (KEYMGR_GCC3_LIVE_IMAGE_LIST); @@ -150,7 +150,7 @@ examine_objects (void *pc, struct dwarf_eh_bases *bases, int dont_alloc) { char *fde; unsigned long sz; - + fde = getsectdatafromheader (image->mh, "__DATA", "__eh_frame", &sz); if (fde == NULL) { @@ -159,20 +159,20 @@ examine_objects (void *pc, struct dwarf_eh_bases *bases, int dont_alloc) if (fde != NULL) image->examined_p |= IMAGE_IS_TEXT_MASK; } - + /* If .eh_frame is empty, don't register at all. */ if (fde != NULL && sz > 0) { char *real_fde = (fde + image->vm_slide); struct object *ob = NULL; struct object panicob; - + if (! dont_alloc) ob = calloc (1, sizeof (struct object)); dont_alloc |= ob == NULL; if (dont_alloc) ob = &panicob; - + ob->pc_begin = (void *)-1; ob->tbase = 0; ob->dbase = 0; @@ -180,19 +180,19 @@ examine_objects (void *pc, struct dwarf_eh_bases *bases, int dont_alloc) ob->s.i = 0; ob->s.b.encoding = DW_EH_PE_omit; ob->fde_end = real_fde + sz; - + image->fde = real_fde; - + result = search_object (ob, pc); - + if (! dont_alloc) { struct object **p; image->destructor = live_image_destructor; image->object_info = ob; - - image->examined_p |= (EXAMINED_IMAGE_MASK + + image->examined_p |= (EXAMINED_IMAGE_MASK | DESTRUCTOR_MAY_BE_CALLED_LIVE); /* Insert the object into the classified list. */ @@ -206,16 +206,16 @@ examine_objects (void *pc, struct dwarf_eh_bases *bases, int dont_alloc) if (result) { int encoding; - + bases->tbase = ob->tbase; bases->dbase = ob->dbase; - + encoding = ob->s.b.encoding; if (ob->s.b.mixed_encoding) encoding = get_fde_encoding (result); - read_encoded_value_with_base (encoding, + read_encoded_value_with_base (encoding, base_from_object (encoding, ob), - result->pc_begin, + result->pc_begin, (_Unwind_Ptr *)&bases->func); break; } @@ -229,25 +229,25 @@ examine_objects (void *pc, struct dwarf_eh_bases *bases, int dont_alloc) return result; } -fde * +const fde * _Unwind_Find_FDE (void *pc, struct dwarf_eh_bases *bases) { struct km_object_info *the_obj_info; - fde *ret = NULL; + const fde *ret = NULL; - the_obj_info = + the_obj_info = _keymgr_get_and_lock_processwide_ptr (KEYMGR_GCC3_DW2_OBJ_LIST); if (! the_obj_info) the_obj_info = calloc (1, sizeof (*the_obj_info)); - + if (the_obj_info != NULL) { seen_objects = the_obj_info->seen_objects; unseen_objects = the_obj_info->unseen_objects; - + ret = _Unwind_Find_registered_FDE (pc, bases); } - + /* OK, didn't find it in the list of FDEs we've seen before, so go through and look at the new ones. */ if (ret == NULL) |