Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S933823AbYBCA1n (ORCPT ); Sat, 2 Feb 2008 19:27:43 -0500 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1753700AbYBCA1e (ORCPT ); Sat, 2 Feb 2008 19:27:34 -0500 Received: from rv-out-0910.google.com ([209.85.198.189]:8075 "EHLO rv-out-0910.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753540AbYBCA1c (ORCPT ); Sat, 2 Feb 2008 19:27:32 -0500 DomainKey-Signature: a=rsa-sha1; c=nofws; d=gmail.com; s=gamma; h=subject:from:to:cc:in-reply-to:references:content-type:date:message-id:mime-version:x-mailer:content-transfer-encoding; b=fnfwhl3Yi7NLkTIb/7wpl1ZizeCfQcl3ThgpnJBF58ZC17SV/zVywbDJMBG0M1C+cWTJlk+SoTOOvSTykS/m3htm29SQWw2/2HkbD+Qmp80fMUFOIbYBLBvBMBJX5bHrHrxaaCZc2+7HPXwiJkjQ5UO3mjYk3siS2Iktbc5SDiQ= Subject: Re: [PATCH] AMD Thermal Interrupt Support From: Harvey Harrison To: Andrew Morton Cc: Russell Leidich , Andi Kleen , Torsten Kaiser , linux-kernel@vger.kernel.org, Thomas Gleixner , Ingo Molnar , valdis.kletnieks@vt.edu, Tim Hockin In-Reply-To: <20080202161057.b240f443.akpm@linux-foundation.org> References: <3f1a065b0801021350x7fd065fbj9680ce1a4f3c6538@mail.gmail.com> <20080104222637.GA19248@one.firstfloor.org> <3f1a065b0801041653y77c27a8cvce703cb7d13e10a0@mail.gmail.com> <20080105132402.GA705@one.firstfloor.org> <3f1a065b0801051208y7e832e8ctda61f28e6328dec3@mail.gmail.com> <3f1a065b0801081542p6cca6249g35e83f7e1f450fbd@mail.gmail.com> <20080108235212.GE2117@one.firstfloor.org> <3f1a065b0801081828y4b084a52g1db9bcb8821cb3da@mail.gmail.com> <20080109023714.GK2117@one.firstfloor.org> <3f1a065b0801101821k71ea7523l5024f12abb50357f@mail.gmail.com> <3f1a065b0801171706o57ae5d6w8a986db508ddcee4@mail.gmail.com> <20080202161057.b240f443.akpm@linux-foundation.org> Content-Type: text/plain Date: Sat, 02 Feb 2008 16:27:40 -0800 Message-Id: <1201998460.1844.32.camel@brick> Mime-Version: 1.0 X-Mailer: Evolution 2.12.1 Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2480 Lines: 53 On Sat, 2008-02-02 at 16:10 -0800, Andrew Morton wrote: > On Thu, 17 Jan 2008 17:06:33 -0800 "Russell Leidich" wrote: > > > > Here's the hopefully-final version of the patch, which I have just > > > tested on Intel and AMD. > > Curious. This just broke. > > i386 allmodconfig: > > arch/x86/kernel/cpu/mcheck/p4.o: In function `smp_thermal_interrupt': > arch/x86/kernel/cpu/mcheck/p4.c:61: multiple definition of `smp_thermal_interrupt' > arch/x86/kernel/cpu/mcheck/mce_thermal.o:arch/x86/kernel/cpu/mcheck/mce_thermal.c:17: first defined here > /opt/crosstool/gcc-4.1.0-glibc-2.3.6/i686-unknown-linux-gnu/bin/i686-unknown-linux-gnu-ld: Warning: size of symbol `smp_thermal_interrupt' changed from 4 in arch/x86/kernel/cpu/mcheck/mce_thermal.o to 43 in arch/x86/kernel/cpu/mcheck/p4.o > /opt/crosstool/gcc-4.1.0-glibc-2.3.6/i686-unknown-linux-gnu/bin/i686-unknown-linux-gnu-ld: Warning: type of symbol `smp_thermal_interrupt' changed from 1 to 2 in arch/x86/kernel/cpu/mcheck/p4.o > > In mainline we just did this: > > --- linux-2.6.24/arch/x86/kernel/cpu/mcheck/p4.c 2008-02-01 14:29:18.000000000 -0800 > +++ devel/arch/x86/kernel/cpu/mcheck/p4.c 2008-02-02 15:38:06.000000000 -0800 > @@ -57,7 +57,7 @@ static void intel_thermal_interrupt(stru > /* Thermal interrupt handler for this CPU setup */ > static void (*vendor_thermal_interrupt)(struct pt_regs *regs) = unexpected_thermal_interrupt; > > -fastcall void smp_thermal_interrupt(struct pt_regs *regs) > +void smp_thermal_interrupt(struct pt_regs *regs) > > which I think was always wrong and has just now tripped up the linker. I > _assume_ that function should be __attribute__((weak)). Then again, maybe > I'm full of it. But hey, it compiles now. > What tree fails to compile? grepping mainline: ./arch/x86/kernel/cpu/mcheck/mce_intel_64.c:asmlinkage void smp_thermal_interrupt(void) ./arch/x86/kernel/cpu/mcheck/p4.c:void smp_thermal_interrupt(struct pt_regs *regs) ./arch/x86/kernel/entry_64.S: apicinterrupt THERMAL_APIC_VECTOR,smp_thermal_interrupt ./arch/x86/kernel/traps_64.c:asmlinkage void __attribute__((weak)) smp_thermal_interrupt(void) Notice the one in p4.c doesn't take void args. I'll look into it. Harvey -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/