Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp2562955imu; Sun, 13 Jan 2019 05:07:48 -0800 (PST) X-Google-Smtp-Source: ALg8bN485zehyBWSwIF8d9U1WGokbu21yjADabqUqzuhyGbyZNP9HPOt1cGoZFzXsYZj7d5ZZgpS X-Received: by 2002:a17:902:aa0a:: with SMTP id be10mr21422171plb.266.1547384868750; Sun, 13 Jan 2019 05:07:48 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1547384868; cv=none; d=google.com; s=arc-20160816; b=zXieZn2VJZBb6i7lEVhobSwGmeWR4LoXLQWhaLlKnpBepv+n6udVvT1JhoJikHWx99 RMSIUcmHnwFwF8f0jwZUJmIfOrks36CA7p77Aswm7LC8r3YLG3q45fu314EMjFQNFgtu mtLPnQ7VALtzZZdC3+sNv1BmDR5MkuXlf1zKfxSk61c/9hIfGSYado42fQvlwcX+akH4 2OR0FClPSr5ifoWr8SBU1fXKrkIH8/kB/U88s2I7JcizlBddaZjG5XOvB57yfP2MxyFk bFp2f9MyfUAXbUyV+iSwATBrPquaz6QLoi49ViCgWM4mBC3kfXR3B2PusTlZ/rUoiqjf Adpg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :organization:references:in-reply-to:message-id:subject:cc:to:from :date; bh=6ZGKvgUc07bv9pE9i07F0nzSHOZMuVFpkZvMzv+iKzs=; b=ESOL2QGn4Z3vVFCg5VEvHBKOOOJu8svTEkhI0UG91UF5KdMtDUr0/LnHgTwvppxBEV ODLfCRyXMcznJ/788Wg4Y/qX0LcEO71IeTl2H9tWG6KUBiA6//nH+G1FFDt7HIQYDuBj WP0SYT9hTvil0EDS3K2EyaCvMaJd/ze0UeUFOiT58k9KkZGhBeBO08y/jRkDkmi+/wxL E7HXmazWFHBt3iBVZ+twTcIHnSB5IuyaIvONuoXGuavHTrnNIxiO0/NZpc3MMZ/WntFT EWVjyF7yqSfZ7mGU8a4QBOQteVnICcieed0M7Ep8maWCJxxn7wfCx+80yN7/bN+mYOxS hA2Q== ARC-Authentication-Results: i=1; mx.google.com; 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 b8si20942256pge.384.2019.01.13.05.07.18; Sun, 13 Jan 2019 05:07:48 -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; 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 S1726546AbfAMNFu (ORCPT + 99 others); Sun, 13 Jan 2019 08:05:50 -0500 Received: from verein.lst.de ([213.95.11.211]:39960 "EHLO newverein.lst.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726221AbfAMNFu (ORCPT ); Sun, 13 Jan 2019 08:05:50 -0500 Received: by newverein.lst.de (Postfix, from userid 107) id 29BC468DD2; Sun, 13 Jan 2019 14:05:48 +0100 (CET) X-Spam-Checker-Version: SpamAssassin 3.3.1 (2010-03-16) on newverein.lst.de X-Spam-Level: X-Spam-Status: No, score=-0.2 required=5.0 tests=ALL_TRUSTED,BAYES_50 autolearn=disabled version=3.3.1 Received: from blackhole (p5B0D8EE3.dip0.t-ipconnect.de [91.13.142.227]) by newverein.lst.de (Postfix) with ESMTPSA id A9EE067329; Sun, 13 Jan 2019 14:05:44 +0100 (CET) Date: Sun, 13 Jan 2019 14:05:38 +0100 From: Torsten Duwe To: Balbir Singh Cc: Segher Boessenkool , Joe Lawrence , Jiri Kosina , linux-kernel@vger.kernel.org, live-patching@vger.kernel.org, linuxppc-dev@lists.ozlabs.org Subject: Re: ppc64le reliable stack unwinder and scheduled tasks Message-ID: <20190113140512.44eac0e0@blackhole> In-Reply-To: <20190113123356.GA26056@350D> References: <7f468285-b149-37e2-e782-c9e538b997a9@redhat.com> <20190112010914.GB10427@350D> <20190112084541.GK14180@gate.crashing.org> <20190113123356.GA26056@350D> Organization: LST e.V. X-Mailer: Claws Mail 3.16.0 (GTK+ 2.24.32; x86_64-suse-linux-gnu) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Sun, 13 Jan 2019 23:33:56 +1100 Balbir Singh wrote: > On Sat, Jan 12, 2019 at 02:45:41AM -0600, Segher Boessenkool wrote: > > On Sat, Jan 12, 2019 at 12:09:14PM +1100, Balbir Singh wrote: > > > Could you please define interesting frame on top a bit more? > > > Usually the topmost return address is in LR > > > > There is no reliable way (other than DWARF unwind info) to find out > > where the value of LR at function entry currently lives (if > > anywhere). It may or may not be still available in LR, it may or > > may not be saved to the return stack slot. It can also live in > > some GPR, or in some other stack slot. > > > > (The same is true for all other registers). > > > > The only thing the ABI guarantees you is that you can find all > > stack frames via the back chain. If you want more you can use some > > heuristics and do some heroics (like GDB does), but this is not > > fully reliable. Using DWARF unwind info is, but that requires big > > tables. > > > > Thanks, so are you suggesting that a reliable stack is not possible on > ppc64le? Even with the restricted scope of the kernel? The LR value location is _always_ hard to determine for the topmost frame. This is not a problem for voluntarily sleeping tasks, because the topmost function will always be well known. It is a problem for tasks preempted by an interrupt, or those handling an exception, that's why these need to report "unreliable". Note that this is a very general problem, across _all_ RISC-like architectures. It should thus be handled as generically as possible. Torsten