191 lines
		
	
	
		
			7.2 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			191 lines
		
	
	
		
			7.2 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
| From b685411208e0aaa79190d54faf945763514706b8 Mon Sep 17 00:00:00 2001
 | |
| From: jsm28 <jsm28@138bc75d-0d04-0410-961f-82ee72b054a4>
 | |
| Date: Tue, 4 Jul 2017 10:23:57 +0000
 | |
| Subject: [PATCH] Use ucontext_t not struct ucontext in linux-unwind.h files.
 | |
| 
 | |
| Current glibc no longer gives the ucontext_t type the tag struct
 | |
| ucontext, to conform with POSIX namespace rules.  This requires
 | |
| various linux-unwind.h files in libgcc, that were previously using
 | |
| struct ucontext, to be fixed to use ucontext_t instead.  This is
 | |
| similar to the removal of the struct siginfo tag from siginfo_t some
 | |
| years ago.
 | |
| 
 | |
| This patch changes those files to use ucontext_t instead.  As the
 | |
| standard name that should be unconditionally safe, so this is not
 | |
| restricted to architectures supported by glibc, or conditioned on the
 | |
| glibc version.
 | |
| 
 | |
| Tested compilation together with current glibc with glibc's
 | |
| build-many-glibcs.py.
 | |
| 
 | |
| 	* config/aarch64/linux-unwind.h (aarch64_fallback_frame_state),
 | |
| 	config/alpha/linux-unwind.h (alpha_fallback_frame_state),
 | |
| 	config/bfin/linux-unwind.h (bfin_fallback_frame_state),
 | |
| 	config/i386/linux-unwind.h (x86_64_fallback_frame_state,
 | |
| 	x86_fallback_frame_state), config/m68k/linux-unwind.h (struct
 | |
| 	uw_ucontext), config/nios2/linux-unwind.h (struct nios2_ucontext),
 | |
| 	config/pa/linux-unwind.h (pa32_fallback_frame_state),
 | |
| 	config/sh/linux-unwind.h (sh_fallback_frame_state),
 | |
| 	config/tilepro/linux-unwind.h (tile_fallback_frame_state),
 | |
| 	config/xtensa/linux-unwind.h (xtensa_fallback_frame_state): Use
 | |
| 	ucontext_t instead of struct ucontext.
 | |
| 
 | |
| 
 | |
| git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/branches/gcc-6-branch@249957 138bc75d-0d04-0410-961f-82ee72b054a4
 | |
| ---
 | |
|  libgcc/ChangeLog     (REMOVED)       | 14 ++++++++++++++
 | |
|  libgcc/config/aarch64/linux-unwind.h |  2 +-
 | |
|  libgcc/config/alpha/linux-unwind.h   |  2 +-
 | |
|  libgcc/config/bfin/linux-unwind.h    |  2 +-
 | |
|  libgcc/config/i386/linux-unwind.h    |  4 ++--
 | |
|  libgcc/config/m68k/linux-unwind.h    |  2 +-
 | |
|  libgcc/config/nios2/linux-unwind.h   |  2 +-
 | |
|  libgcc/config/pa/linux-unwind.h      |  2 +-
 | |
|  libgcc/config/sh/linux-unwind.h      |  2 +-
 | |
|  libgcc/config/tilepro/linux-unwind.h |  2 +-
 | |
|  libgcc/config/xtensa/linux-unwind.h  |  2 +-
 | |
|  11 files changed, 25 insertions(+), 11 deletions(-)
 | |
| 
 | |
| diff --git a/libgcc/config/aarch64/linux-unwind.h b/libgcc/config/aarch64/linux-unwind.h
 | |
| index 4512efb..06de45a 100644
 | |
| --- a/libgcc/config/aarch64/linux-unwind.h
 | |
| +++ b/libgcc/config/aarch64/linux-unwind.h
 | |
| @@ -52,7 +52,7 @@ aarch64_fallback_frame_state (struct _Unwind_Context *context,
 | |
|    struct rt_sigframe
 | |
|    {
 | |
|      siginfo_t info;
 | |
| -    struct ucontext uc;
 | |
| +    ucontext_t uc;
 | |
|    };
 | |
|  
 | |
|    struct rt_sigframe *rt_;
 | |
| diff --git a/libgcc/config/alpha/linux-unwind.h b/libgcc/config/alpha/linux-unwind.h
 | |
| index bdbba4a..e84812e 100644
 | |
| --- a/libgcc/config/alpha/linux-unwind.h
 | |
| +++ b/libgcc/config/alpha/linux-unwind.h
 | |
| @@ -51,7 +51,7 @@ alpha_fallback_frame_state (struct _Unwind_Context *context,
 | |
|      {
 | |
|        struct rt_sigframe {
 | |
|  	siginfo_t info;
 | |
| -	struct ucontext uc;
 | |
| +	ucontext_t uc;
 | |
|        } *rt_ = context->cfa;
 | |
|        sc = &rt_->uc.uc_mcontext;
 | |
|      }
 | |
| diff --git a/libgcc/config/bfin/linux-unwind.h b/libgcc/config/bfin/linux-unwind.h
 | |
| index 77b7c23..8bf5e82 100644
 | |
| --- a/libgcc/config/bfin/linux-unwind.h
 | |
| +++ b/libgcc/config/bfin/linux-unwind.h
 | |
| @@ -52,7 +52,7 @@ bfin_fallback_frame_state (struct _Unwind_Context *context,
 | |
|  	void *puc;
 | |
|  	char retcode[8];
 | |
|  	siginfo_t info;
 | |
| -	struct ucontext uc;
 | |
| +	ucontext_t uc;
 | |
|        } *rt_ = context->cfa;
 | |
|  
 | |
|        /* The void * cast is necessary to avoid an aliasing warning.
 | |
| diff --git a/libgcc/config/i386/linux-unwind.h b/libgcc/config/i386/linux-unwind.h
 | |
| index 540a0a2..29efbe3 100644
 | |
| --- a/libgcc/config/i386/linux-unwind.h
 | |
| +++ b/libgcc/config/i386/linux-unwind.h
 | |
| @@ -58,7 +58,7 @@ x86_64_fallback_frame_state (struct _Unwind_Context *context,
 | |
|    if (*(unsigned char *)(pc+0) == 0x48
 | |
|        && *(unsigned long long *)(pc+1) == RT_SIGRETURN_SYSCALL)
 | |
|      {
 | |
| -      struct ucontext *uc_ = context->cfa;
 | |
| +      ucontext_t *uc_ = context->cfa;
 | |
|        /* The void * cast is necessary to avoid an aliasing warning.
 | |
|           The aliasing warning is correct, but should not be a problem
 | |
|           because it does not alias anything.  */
 | |
| @@ -138,7 +138,7 @@ x86_fallback_frame_state (struct _Unwind_Context *context,
 | |
|  	siginfo_t *pinfo;
 | |
|  	void *puc;
 | |
|  	siginfo_t info;
 | |
| -	struct ucontext uc;
 | |
| +	ucontext_t uc;
 | |
|        } *rt_ = context->cfa;
 | |
|        /* The void * cast is necessary to avoid an aliasing warning.
 | |
|           The aliasing warning is correct, but should not be a problem
 | |
| diff --git a/libgcc/config/m68k/linux-unwind.h b/libgcc/config/m68k/linux-unwind.h
 | |
| index 75b7cf7..f964e24 100644
 | |
| --- a/libgcc/config/m68k/linux-unwind.h
 | |
| +++ b/libgcc/config/m68k/linux-unwind.h
 | |
| @@ -33,7 +33,7 @@ see the files COPYING3 and COPYING.RUNTIME respectively.  If not, see
 | |
|  /* <sys/ucontext.h> is unfortunately broken right now.  */
 | |
|  struct uw_ucontext {
 | |
|  	unsigned long	  uc_flags;
 | |
| -	struct ucontext  *uc_link;
 | |
| +	ucontext_t	 *uc_link;
 | |
|  	stack_t		  uc_stack;
 | |
|  	mcontext_t	  uc_mcontext;
 | |
|  	unsigned long	  uc_filler[80];
 | |
| diff --git a/libgcc/config/nios2/linux-unwind.h b/libgcc/config/nios2/linux-unwind.h
 | |
| index 2304142..30f25ea 100644
 | |
| --- a/libgcc/config/nios2/linux-unwind.h
 | |
| +++ b/libgcc/config/nios2/linux-unwind.h
 | |
| @@ -38,7 +38,7 @@ struct nios2_mcontext {
 | |
|  
 | |
|  struct nios2_ucontext {
 | |
|    unsigned long uc_flags;
 | |
| -  struct ucontext *uc_link;
 | |
| +  ucontext_t *uc_link;
 | |
|    stack_t uc_stack;
 | |
|    struct nios2_mcontext uc_mcontext;
 | |
|    sigset_t uc_sigmask;	/* mask last for extensibility */
 | |
| diff --git a/libgcc/config/pa/linux-unwind.h b/libgcc/config/pa/linux-unwind.h
 | |
| index 9a2657f..e47493d 100644
 | |
| --- a/libgcc/config/pa/linux-unwind.h
 | |
| +++ b/libgcc/config/pa/linux-unwind.h
 | |
| @@ -80,7 +80,7 @@ pa32_fallback_frame_state (struct _Unwind_Context *context,
 | |
|    struct sigcontext *sc;
 | |
|    struct rt_sigframe {
 | |
|      siginfo_t info;
 | |
| -    struct ucontext uc;
 | |
| +    ucontext_t uc;
 | |
|    } *frame;
 | |
|  
 | |
|    /* rt_sigreturn trampoline:
 | |
| diff --git a/libgcc/config/sh/linux-unwind.h b/libgcc/config/sh/linux-unwind.h
 | |
| index e389cac..0bf43ba 100644
 | |
| --- a/libgcc/config/sh/linux-unwind.h
 | |
| +++ b/libgcc/config/sh/linux-unwind.h
 | |
| @@ -180,7 +180,7 @@ sh_fallback_frame_state (struct _Unwind_Context *context,
 | |
|      {
 | |
|        struct rt_sigframe {
 | |
|  	siginfo_t info;
 | |
| -	struct ucontext uc;
 | |
| +	ucontext_t uc;
 | |
|        } *rt_ = context->cfa;
 | |
|        /* The void * cast is necessary to avoid an aliasing warning.
 | |
|           The aliasing warning is correct, but should not be a problem
 | |
| diff --git a/libgcc/config/tilepro/linux-unwind.h b/libgcc/config/tilepro/linux-unwind.h
 | |
| index 796e976..75f8890 100644
 | |
| --- a/libgcc/config/tilepro/linux-unwind.h
 | |
| +++ b/libgcc/config/tilepro/linux-unwind.h
 | |
| @@ -61,7 +61,7 @@ tile_fallback_frame_state (struct _Unwind_Context *context,
 | |
|    struct rt_sigframe {
 | |
|      unsigned char save_area[C_ABI_SAVE_AREA_SIZE];
 | |
|      siginfo_t info;
 | |
| -    struct ucontext uc;
 | |
| +    ucontext_t uc;
 | |
|    } *rt_;
 | |
|  
 | |
|    /* Return if this is not a signal handler.  */
 | |
| diff --git a/libgcc/config/xtensa/linux-unwind.h b/libgcc/config/xtensa/linux-unwind.h
 | |
| index 9872492..586a9d4 100644
 | |
| --- a/libgcc/config/xtensa/linux-unwind.h
 | |
| +++ b/libgcc/config/xtensa/linux-unwind.h
 | |
| @@ -67,7 +67,7 @@ xtensa_fallback_frame_state (struct _Unwind_Context *context,
 | |
|  
 | |
|    struct rt_sigframe {
 | |
|      siginfo_t info;
 | |
| -    struct ucontext uc;
 | |
| +    ucontext_t uc;
 | |
|    } *rt_;
 | |
|  
 | |
|    /* movi a2, __NR_rt_sigreturn; syscall */
 | |
| -- 
 | |
| 2.9.3
 | |
| 
 | 
