From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S933406AbbLTPne (ORCPT ); Sun, 20 Dec 2015 10:43:34 -0500 Received: from v094114.home.net.pl ([79.96.170.134]:41768 "HELO v094114.home.net.pl" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with SMTP id S933112AbbLTPnd (ORCPT ); Sun, 20 Dec 2015 10:43:33 -0500 From: "Rafael J. Wysocki" To: Josh Poimboeuf Cc: Thomas Gleixner , Ingo Molnar , "H. Peter Anvin" , x86@kernel.org, linux-kernel@vger.kernel.org, live-patching@vger.kernel.org, Michal Marek , Peter Zijlstra , Andy Lutomirski , Borislav Petkov , Linus Torvalds , Andi Kleen , Pedro Alves , Namhyung Kim , Bernd Petrovitsch , Chris J Arges , Andrew Morton , Jiri Slaby , Arnaldo Carvalho de Melo , Pavel Machek , Len Brown Subject: Re: [PATCH v15 20/25] x86/asm/acpi: Create a stack frame in do_suspend_lowlevel() Date: Sun, 20 Dec 2015 17:13:48 +0100 Message-ID: <2897805.ggaLPyNUGa@vostro.rjw.lan> User-Agent: KMail/4.11.5 (Linux/4.1.0-rc5+; KDE/4.11.5; x86_64; ; ) In-Reply-To: <334211c7c2848b9080f4bc4a7fc8140979cbda07.1450442274.git.jpoimboe@redhat.com> References: <334211c7c2848b9080f4bc4a7fc8140979cbda07.1450442274.git.jpoimboe@redhat.com> MIME-Version: 1.0 Content-Transfer-Encoding: 7Bit Content-Type: text/plain; charset="utf-8" Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Friday, December 18, 2015 06:39:34 AM Josh Poimboeuf wrote: > do_suspend_lowlevel() is a callable non-leaf function which doesn't > honor CONFIG_FRAME_POINTER, which can result in bad stack traces. > > Create a stack frame for it when CONFIG_FRAME_POINTER is enabled. > > Signed-off-by: Josh Poimboeuf > Acked-by: Pavel Machek > Cc: Rafael J. Wysocki > Cc: Len Brown Acked-by: Rafael J. Wysocki > --- > arch/x86/kernel/acpi/wakeup_64.S | 3 +++ > 1 file changed, 3 insertions(+) > > diff --git a/arch/x86/kernel/acpi/wakeup_64.S b/arch/x86/kernel/acpi/wakeup_64.S > index 8c35df4..169963f 100644 > --- a/arch/x86/kernel/acpi/wakeup_64.S > +++ b/arch/x86/kernel/acpi/wakeup_64.S > @@ -5,6 +5,7 @@ > #include > #include > #include > +#include > > # Copyright 2003 Pavel Machek , distribute under GPLv2 > > @@ -39,6 +40,7 @@ bogus_64_magic: > jmp bogus_64_magic > > ENTRY(do_suspend_lowlevel) > + FRAME_BEGIN > subq $8, %rsp > xorl %eax, %eax > call save_processor_state > @@ -109,6 +111,7 @@ ENTRY(do_suspend_lowlevel) > > xorl %eax, %eax > addq $8, %rsp > + FRAME_END > jmp restore_processor_state > ENDPROC(do_suspend_lowlevel) > > -- I speak only for myself. Rafael J. Wysocki, Intel Open Source Technology Center.