From mboxrd@z Thu Jan 1 00:00:00 1970 From: vladimir.zapolskiy@nokia.com (Vladimir Zapolskiy) Date: Thu, 22 Dec 2011 16:52:32 +0200 Subject: [PATCH] arm: oprofile: fix linkage issue In-Reply-To: <20111222142140.GP16765@erda.amd.com> References: <1324561016-19389-1-git-send-email-vladimir.zapolskiy@nokia.com> <20111222142140.GP16765@erda.amd.com> Message-ID: <4EF34430.6030700@nokia.com> To: linux-arm-kernel@lists.infradead.org List-Id: linux-arm-kernel.lists.infradead.org On 12/22/2011 04:21 PM, ext Robert Richter wrote: > On 22.12.11 15:36:56, Vladimir Zapolskiy wrote: >> This change fixes a linking problem, which happens if oprofile is selected to >> be compiled as built-in: >> >> `oprofile_arch_exit' referenced in section `.init.text' of >> arch/arm/oprofile/built-in.o: defined in discarded section >> `.exit.text' of arch/arm/oprofile/built-in.o >> >> The problem is appeared after commit 87121ca504, which introduced >> oprofile_arch_exit() calls from __init function. Note that the aforementioned >> commit has been backported to stable branches, and the problem is known to be >> reproduced at least with 3.0.13 and 3.1.5 kernels. > > I will fix it upstream, afterwards this goes into stable due to the > stable tag. > What's the expected difference with this change? > Right, commit 87121ca504 went into stable kernels 3.0 and 3.1, need to > fix them too: > > CC: stable at kernel.org # 3.0+ > > Please fix also arch/sh with this patch: > > $ git grep exit.*oprofile_arch_exit arch/*/oprofile drivers/oprofile/ > arch/arm/oprofile/common.c:void __exit oprofile_arch_exit(void) > arch/sh/oprofile/common.c:void __exit oprofile_arch_exit(void) > arch/sh/oprofile/common.c:void __exit oprofile_arch_exit(void) {} I checked the linkage of arch/sh/oprofile/built-in.o on 3.0.13 under the same conditions, and there the original issue is not reproduced, probably because of not tightly optimized vmlinux ld script, so for sh architecture the problem is not so hot as it is for arm. With best wishes, Vladimir > Thanks, > > -Robert > >> >> Signed-off-by: Vladimir Zapolskiy >> Cc: Will Deacon >> Cc: Robert Richter >> Cc: stable at kernel.org >> --- >> arch/arm/oprofile/common.c | 2 +- >> 1 files changed, 1 insertions(+), 1 deletions(-) >> >> diff --git a/arch/arm/oprofile/common.c b/arch/arm/oprofile/common.c >> index c074e66..4e0a371 100644 >> --- a/arch/arm/oprofile/common.c >> +++ b/arch/arm/oprofile/common.c >> @@ -116,7 +116,7 @@ int __init oprofile_arch_init(struct oprofile_operations *ops) >> return oprofile_perf_init(ops); >> } >> >> -void __exit oprofile_arch_exit(void) >> +void oprofile_arch_exit(void) >> { >> oprofile_perf_exit(); >> } >> -- >> 1.7.2.3 >> >> >