Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp672729imu; Wed, 16 Jan 2019 05:50:07 -0800 (PST) X-Google-Smtp-Source: ALg8bN5ah3M8f9huzF/qn+/UwizslgWX0njtkQTKcesjjFIpZHMnGuBgLMtX6b1EWPWrp3Zcc4PD X-Received: by 2002:a62:7892:: with SMTP id t140mr9848463pfc.237.1547646607072; Wed, 16 Jan 2019 05:50:07 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1547646607; cv=none; d=google.com; s=arc-20160816; b=cHX+1JW9X1QNsJZ5QReeVuOt34/ezQtkjgcYU3/th8oNrst7Y5309pt4ETA0sxUMzX 8W9oac4y8aG84wsEnaGDw4zqczFsMVdazyHPUNEDikpGkh11UIFv4KvMEQPD8BQdqtRN Zgjr8Y7fhWC7GQdqKqt4ngj622O8rWCrxS9/CSTJ69jnQodXmMkj5m5FQYjmm5mlCNSU nWqmW163Vi3cZjmiGDtG9iSDW+gUkBQLHZ1PFP7m7lO3Hkk5YyxXyLJZj76xLgJogG/E n3vIAghCpGB7lkpF2MKSrGvuZSahj0vSQ+gRcKO5BZRi1QoN2vu4IuBcilgotaOqm8tX 8DrA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:message-id:references :in-reply-to:subject:cc:to:from:date:content-transfer-encoding :mime-version:dkim-signature; bh=ueRAERzUH65+Drr7doYhBdpCMWXmWkgznpq2aomP0nY=; b=ZeLjwtYAVzl+jbkSdLGn9SLPG7JZOI3wUetI9ivcl/ELY7E+9vvlv18NHIU9z3Zhe9 Ozpq9ytW+HHB3HIq/1B8/8fD182lvciCCX/CAKCeid0uSHfduottUCzxvNvJPCbaVIFU To5tp6zjSdAY6GkAVVLdg4tBw/gY/l1J84BEKjJF3o20UNt553t9Hnc6ijRgq8SlwxoF XEaz6lA2TdBV5j9RRB3Pij/LkdROH1whITM24oyHrqz0+RW3S1plirP62LMFj8vtgqZ6 o4nXMflK24jDOy13ln8+f3nWfoDEaHutuPs4JuTUkEQVVjNpl2I8quGYyTWroAbd/vLF Vfkg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@agner.ch header.s=dkim header.b=fPgYUVao; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id f63si6591755pfg.136.2019.01.16.05.49.49; Wed, 16 Jan 2019 05:50:07 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@agner.ch header.s=dkim header.b=fPgYUVao; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2391127AbfAOWh7 (ORCPT + 99 others); Tue, 15 Jan 2019 17:37:59 -0500 Received: from mail.kmu-office.ch ([178.209.48.109]:58324 "EHLO mail.kmu-office.ch" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730777AbfAOWh7 (ORCPT ); Tue, 15 Jan 2019 17:37:59 -0500 Received: from webmail.kmu-office.ch (unknown [IPv6:2a02:418:6a02::a3]) by mail.kmu-office.ch (Postfix) with ESMTPSA id 522515C0DDF; Tue, 15 Jan 2019 23:37:57 +0100 (CET) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=agner.ch; s=dkim; t=1547591877; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=ueRAERzUH65+Drr7doYhBdpCMWXmWkgznpq2aomP0nY=; b=fPgYUVaoTfrth3LHyPvCnx8D0jXJoNbgx9xREzlTJFk2uVYe4Vj64WDtcVxVFA3CdzFToH +gUl3laEVurFmtrE5YLe/jdyCgo7MRPvF+XEB+0zCCsdVOW6CcTtw7/ZAJ3J6W/mFs7bQB dj9SIvP3FRkEOM+FbFw9K/GgulPWK5Q= MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Date: Tue, 15 Jan 2019 23:37:57 +0100 From: Stefan Agner To: Stefan Agner Cc: Jeremy Fertic , Arnd Bergmann , rostedt@goodmis.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, Russell King - ARM Linux Subject: Re: ARM: config issue with ftrace function graph tracer In-Reply-To: <20190113161420.GE2392@n2100.armlinux.org.uk> References: <20190112010139.GA5288@r2700x.localdomain> <20190113161420.GE2392@n2100.armlinux.org.uk> Message-ID: <78d9aedb4b23dcc929ca9330cc5f0090@agner.ch> X-Sender: stefan@agner.ch User-Agent: Roundcube Webmail/1.3.7 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 13.01.2019 17:14, Russell King - ARM Linux wrote: > On Sun, Jan 13, 2019 at 04:41:52PM +0100, Stefan Agner wrote: >> Hi, >> >> On 12.01.2019 02:01, Jeremy Fertic wrote: >> > I'm having a problem with the ftrace function graph tracer on a 32 bit arm >> > board (orangepi pc). A bisect points to the following commit: >> > >> > f9b58e8c7d03 ("ARM: 8800/1: use choice for kernel unwinders") >> > >> > Before this commit, if I use sunxi_defconfig and then menuconfig to enable >> > FTRACE and FUNCTION_TRACER then the function graph tracer works. With this >> > commit, and as of v5.0-rc1, doing the same as above results in a broken >> > function graph tracer and often an oops as well. The commit introduces a >> > choice group and it looks like it should default to UNWINDER_FRAME_POINTER >> > if FUNCTION_GRAPH_TRACER is enabled. FUNCTION_GRAPH_TRACER is enabled by >> > default when I enable FUNCTION_TRACER but this has no effect on the choice. >> > The choice always defaults to the other option which is UNWINDER_ARM. If I >> > manually choose UNWINDER_FRAME_POINTER then the function graph tracer works >> > fine. >> >> The default selection is there, but this is made at "make >> sunxi_defconfig" time. At this point FUNCTION_GRAPH_TRACER is not >> enabled, hence Kconfig uses UNWIDER_ARM. However, when enabling the >> FUNCTION_GRAPH_TRACER Kconfig will _not_ reconsider and switch enable >> UNWINDER_FRAME_POINTER. >> >> Before that commit, when enabling FUNCTION_GRAPH_TRACER, we simply also >> enabled FRAME_POINTER... >> >> I guess we need to make sure that FUNCTION_GRAPH_TRACER depends on the >> UNWINDER_FRAME_POINTER choice. There is already a similar dependency >> with THUMB2_KERNEL. We can cleanup that dependency since >> UNWINDER_FRAME_POINTER already depends on !THUMB2_KERNEL. >> >> diff --git a/arch/arm/Kconfig b/arch/arm/Kconfig >> index 664e918e2624..a2ac65a8b2cc 100644 >> --- a/arch/arm/Kconfig >> +++ b/arch/arm/Kconfig >> @@ -69,7 +69,7 @@ config ARM >> select HAVE_EFFICIENT_UNALIGNED_ACCESS if (CPU_V6 || CPU_V6K || >> CPU_V7) && MMU >> select HAVE_EXIT_THREAD >> select HAVE_FTRACE_MCOUNT_RECORD if !XIP_KERNEL >> - select HAVE_FUNCTION_GRAPH_TRACER if !THUMB2_KERNEL >> + select HAVE_FUNCTION_GRAPH_TRACER if UNWINDER_FRAME_POINTER >> select HAVE_FUNCTION_TRACER if !XIP_KERNEL >> select HAVE_GCC_PLUGINS >> select HAVE_GENERIC_DMA_COHERENT >> diff --git a/arch/arm/Kconfig.debug b/arch/arm/Kconfig.debug >> index 6d6e0330930b..8341649fa71d 100644 >> --- a/arch/arm/Kconfig.debug >> +++ b/arch/arm/Kconfig.debug >> @@ -47,8 +47,8 @@ config DEBUG_WX >> >> choice >> prompt "Choose kernel unwinder" >> - default UNWINDER_ARM if AEABI && !FUNCTION_GRAPH_TRACER >> - default UNWINDER_FRAME_POINTER if !AEABI || >> FUNCTION_GRAPH_TRACER >> + default UNWINDER_ARM if AEABI >> + default UNWINDER_FRAME_POINTER if !AEABI >> help >> This determines which method will be used for unwinding kernel >> stack >> traces for panics, oopses, bugs, warnings, perf, >> /proc//stack, > > This looks rather horrid - the upshot of this means that the function > tracer becomes unavailable on EABI unless you know that you must change > the unwinder from its default. > > Before the change to the choice statement, people could select the > function graph tracer, and the correct unwinder would be selected > for them. That's knowledge that people never required before, and > I think it's really quite unfair to require them to know this to use > the function graph tracer. It is not ideal I agree. Searching for the symbol FUNCTION_GRAPH_TRACER in menuconfig immediately shows what dependency are missing. Also, we used to have the same situation with THUMB2_KERNEL already: You had to know that you need to disable Thumb2 Kernel in order to see FUNCTION_GRAPH_TRACER. > > Maybe someone can put some effort into getting the function graph > tracer working with non-framepointer kernels... but as the above > currently stands, I really don't like the patch and I'd much rather > revert the original change to fix this regression. I am all for that effort. Using Thumb2 on Arm32 is also getting more popular. Is known what is exactly missing/what effort would be required? -- Stefan