Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753405AbdIFVtr (ORCPT ); Wed, 6 Sep 2017 17:49:47 -0400 Received: from mx1.redhat.com ([209.132.183.28]:39988 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752513AbdIFVtq (ORCPT ); Wed, 6 Sep 2017 17:49:46 -0400 DMARC-Filter: OpenDMARC Filter v1.3.2 mx1.redhat.com 56752883A0 Authentication-Results: ext-mx02.extmail.prod.ext.phx2.redhat.com; dmarc=none (p=none dis=none) header.from=redhat.com Authentication-Results: ext-mx02.extmail.prod.ext.phx2.redhat.com; spf=fail smtp.mailfrom=jpoimboe@redhat.com Date: Wed, 6 Sep 2017 16:49:45 -0500 From: Josh Poimboeuf To: Dave Jones Cc: Linux Kernel Mailing List Subject: Re: x86/kconfig: Consolidate unwinders into multiple choice selection Message-ID: <20170906214945.5xcxv3t7z3lrz7se@treble> References: <20170905170953.gqqrnmeahoojrdwz@codemonkey.org.uk> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline In-Reply-To: <20170905170953.gqqrnmeahoojrdwz@codemonkey.org.uk> User-Agent: Mutt/1.6.0.1 (2016-04-01) X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.5.110.26]); Wed, 06 Sep 2017 21:49:46 +0000 (UTC) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 3327 Lines: 96 On Tue, Sep 05, 2017 at 01:09:53PM -0400, Dave Jones wrote: > On Mon, Sep 04, 2017 at 08:05:13PM +0000, Linux Kernel wrote: > > Web: https://git.kernel.org/torvalds/c/81d387190039c14edac8de2b3ec789beb899afd9 > > Commit: 81d387190039c14edac8de2b3ec789beb899afd9 > > Parent: a34a766ff96d9e88572e35a45066279e40a85d84 > > Refname: refs/heads/master > > Author: Josh Poimboeuf > > AuthorDate: Tue Jul 25 08:54:24 2017 -0500 > > Committer: Ingo Molnar > > CommitDate: Wed Jul 26 14:05:36 2017 +0200 > > > > x86/kconfig: Consolidate unwinders into multiple choice selection > > > > There are three mutually exclusive unwinders. Make that more obvious by > > combining them into a multiple-choice selection: > > > > CONFIG_FRAME_POINTER_UNWINDER > > CONFIG_ORC_UNWINDER > > CONFIG_GUESS_UNWINDER (if CONFIG_EXPERT=y) > > The help texts for the various unwinders are now attached to the wrong > kconfig item. > > > +choice > > + prompt "Choose kernel unwinder" > > + default FRAME_POINTER_UNWINDER > > + ---help--- > > + This determines which method will be used for unwinding kernel stack > > + traces for panics, oopses, bugs, warnings, perf, /proc//stack, > > + livepatch, lockdep, and more. > > This is what gets displayed, but tells me nothing about what the > benefits/downsides are of each (or even what they are; I had to read the > Kconfig file to figure out what 'GUESS' meant) > > > an oldconfig run .. > > > Choose kernel unwinder > > 1. Frame pointer unwinder (FRAME_POINTER_UNWINDER) (NEW) > 2. ORC unwinder (ORC_UNWINDER) (NEW) > 3. Guess unwinder (GUESS_UNWINDER) (NEW) > choice[1-3?]: ? > > This determines which method will be used for unwinding kernel stack > traces for panics, oopses, bugs, warnings, perf, /proc//stack, > livepatch, lockdep, and more. > > Prompt: Choose kernel unwinder > Location: > -> Kernel hacking > Defined at arch/x86/Kconfig.debug:359 > Selected by: m > > > > Choose kernel unwinder > > 1. Frame pointer unwinder (FRAME_POINTER_UNWINDER) (NEW) > 2. ORC unwinder (ORC_UNWINDER) (NEW) > 3. Guess unwinder (GUESS_UNWINDER) (NEW) > choice[1-3?]: This is a quirk of the config tool. It's not very intuitive, but to see the help for a given option you have to type the number appended with a '?', like: > 1. Frame pointer unwinder (FRAME_POINTER_UNWINDER) (NEW) 2. ORC unwinder (ORC_UNWINDER) (NEW) choice[1-2?]: 1? CONFIG_FRAME_POINTER_UNWINDER: This option enables the frame pointer unwinder for unwinding kernel stack traces. The unwinder itself is fast and it uses less RAM than the ORC unwinder, but the kernel text size will grow by ~3% and the kernel's overall performance will degrade by roughly 5-10%. This option is recommended if you want to use the livepatch consistency model, as this is currently the only way to get a reliable stack trace (CONFIG_HAVE_RELIABLE_STACKTRACE). Symbol: FRAME_POINTER_UNWINDER [=y] Type : boolean Prompt: Frame pointer unwinder Location: -> Kernel hacking -> Choose kernel unwinder ( [=y]) Defined at arch/x86/Kconfig.debug:367 Depends on: Selects: FRAME_POINTER [=y] -- Josh