public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
From: Willy Tarreau <w@1wt.eu>
To: "Gabor Z. Papp" <gzp@papp.hu>
Cc: linux-kernel@vger.kernel.org, stable@vger.kernel.org
Subject: Re: Linux 2.6.32.xx build breaks with gcc 4.7
Date: Tue, 16 Oct 2012 14:43:00 +0200	[thread overview]
Message-ID: <20121016124300.GD31152@1wt.eu> (raw)
In-Reply-To: <x6r4oyzxbm@gzp>

On Tue, Oct 16, 2012 at 09:32:29AM +0200, Gabor Z. Papp wrote:
> lo lo,
> 
> I'm trying to compile 2.6.32.60 with gcc 4.7.2, and getting the
> following error:
> 
>   CC      arch/x86/kernel/ptrace.o
> arch/x86/kernel/ptrace.c:1472:17: error: conflicting types for 'syscall_trace_enter'
> In file included from /usr/src/linux-2.6.32.60-gzpLinux/arch/x86/include/asm/vm86.h:130:0,
>                  from /usr/src/linux-2.6.32.60-gzpLinux/arch/x86/include/asm/processor.h:10,
>                  from /usr/src/linux-2.6.32.60-gzpLinux/arch/x86/include/asm/thread_info.h:22,
>                  from include/linux/thread_info.h:56,
>                  from include/linux/preempt.h:9,
>                  from include/linux/spinlock.h:50,
>                  from include/linux/seqlock.h:29,
>                  from include/linux/time.h:8,
>                  from include/linux/timex.h:56,
>                  from include/linux/sched.h:56,
>                  from arch/x86/kernel/ptrace.c:11:
> /usr/src/linux-2.6.32.60-gzpLinux/arch/x86/include/asm/ptrace.h:145:13: note: previous declaration of 'syscall_trace_enter' was here
> arch/x86/kernel/ptrace.c:1517:17: error: conflicting types for 'syscall_trace_leave'
> In file included from /usr/src/linux-2.6.32.60-gzpLinux/arch/x86/include/asm/vm86.h:130:0,
>                  from /usr/src/linux-2.6.32.60-gzpLinux/arch/x86/include/asm/processor.h:10,
>                  from /usr/src/linux-2.6.32.60-gzpLinux/arch/x86/include/asm/thread_info.h:22,
>                  from include/linux/thread_info.h:56,
>                  from include/linux/preempt.h:9,
>                  from include/linux/spinlock.h:50,
>                  from include/linux/seqlock.h:29,
>                  from include/linux/time.h:8,
>                  from include/linux/timex.h:56,
>                  from include/linux/sched.h:56,
>                  from arch/x86/kernel/ptrace.c:11:
> /usr/src/linux-2.6.32.60-gzpLinux/arch/x86/include/asm/ptrace.h:146:13: note: previous declaration of 'syscall_trace_leave' was here
> make[2]: *** [arch/x86/kernel/ptrace.o] Error 1
> make[1]: *** [arch/x86/kernel] Error 2
> make: *** [arch/x86] Error 2
> 
> My environment looks like:
> 
> Linux 3.2.30, glibc 2.16, gcc 4.7.2
> 
> If I comment out the ancient line, kernel compiles fine.
> 
> Willy says:
> 
> | The affected entry is only used there :
> 
> | arch/x86/include/asm/ptrace.h:extern void syscall_trace_leave(struct pt_regs *);
> | arch/x86/include/asm/thread_info.h:/* work to do in syscall_trace_leave() */
> | arch/x86/kernel/entry_32.S:     ENABLE_INTERRUPTS(CLBR_ANY)     # could let syscall_trace_leave() call
> | arch/x86/kernel/entry_32.S:     call syscall_trace_leave
> | arch/x86/kernel/entry_64.S:     call syscall_trace_leave
> | arch/x86/kernel/ptrace.c:asmregparm void syscall_trace_leave(struct pt_regs *regs)
> 
> | So if the two calls above don't need the include then maybe we can
> | safely remove it.

If someone knows this area well enough to judge whether we can 
  - either remove the asmregparm (I don't think so judging by recent commits
    saying it was possible to remove it after other main changes)
  - or remove the declaration because noone else needs it,

Then I'd happily apply the fix. From what I understood, Paul would probably
need the same fix for 2.6.34.

Thanks,
Willy


      reply	other threads:[~2012-10-16 12:43 UTC|newest]

Thread overview: 2+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
     [not found] <20121012114302.GB14734@1wt.eu>
     [not found] ` <x6lifb3o0t@gzp>
     [not found]   ` <20121012120829.GD14734@1wt.eu>
     [not found]     ` <x6vcecp44c@gzp>
     [not found]       ` <20121015102505.GE24159@1wt.eu>
     [not found]         ` <x6a9voowqv@gzp>
     [not found]           ` <20121015105710.GF24159@1wt.eu>
     [not found]             ` <x61uh0oun5@gzp>
     [not found]               ` <20121015114528.GJ24159@1wt.eu>
     [not found]                 ` <x6y5j7392k@gzp>
     [not found]                   ` <20121015191705.GO24159@1wt.eu>
2012-10-16  7:32                     ` Linux 2.6.32.xx build breaks with gcc 4.7 Gabor Z. Papp
2012-10-16 12:43                       ` Willy Tarreau [this message]

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20121016124300.GD31152@1wt.eu \
    --to=w@1wt.eu \
    --cc=gzp@papp.hu \
    --cc=linux-kernel@vger.kernel.org \
    --cc=stable@vger.kernel.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox