Received: by 2002:a25:d7c1:0:0:0:0:0 with SMTP id o184csp918219ybg; Fri, 18 Oct 2019 09:15:04 -0700 (PDT) X-Google-Smtp-Source: APXvYqzeFELAYF4yxUyBlqY6atmTbqUJ0QA+Lp0feXiYKLsF9D4UDf2yb807WBHwgeAKk25j1Z+Q X-Received: by 2002:aa7:c303:: with SMTP id l3mr10530535edq.234.1571415304703; Fri, 18 Oct 2019 09:15:04 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1571415304; cv=none; d=google.com; s=arc-20160816; b=0lh9MADO8cFs6FSnWTUcVcCHgenqphjn9SbsaNqEhd5mF/29zswud0ae6z8e22fIlo IO7YmQh8oATI5ZNbER9MrL4Ue3M3miW5KMXlZP7M79dUNN4+QY/8Hliexqu/D0KixfpG SDccuWMspIc4HcW6ESgHG67Ic1oTc9SIq/H3fdzNSPPsszHIJNFmJyz3cFnhPWePRxNj kQJfnaHaMDlWZf/4BYRweLlqMeNOiz1Gsl5FmnZ4QIcXlr5YHwLNQfkLWCgGV2nLjvak qeicAPnsXRhCUw1kcAf+8NgCoE51UsIdFgxSmluM8V3n+a1D1bd+2ktQ8n0HvRLmgq8G dExg== 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 :content-language:in-reply-to:mime-version:user-agent:date :message-id:references:cc:to:from:subject; bh=RTdEc0n6jec6rG/97am3XN/gcyIpN0qU+AxRprvhSFY=; b=uxLd5ij/MAQvvI/9mTmF8+Nj8BfueDBO10AGZ6/PkOgGaOIskituBOHL4losGMWQlf t1psua8BReXBru+W0jsR6nx5ij6FcDlwZ5+JmHJ8+3Eq/XzKOaNBVqgKAAG83i76KbhN 14/ZPHf5IOpLIbh/WyVSzPP+86spyNCCrdl8gqzAyabFai02Al86i+VeRuhmrb4wLurF DD/xu1wmmQ1TlFxpC1bv7olMHnt0vSj7CRsLIjP69Z1OfWFG72kcEJsTmRDFtHyc3LOr lCrV1DCvIuPu35a7zRCNFmGPlb2LiDz3/F1SzlidvRFCtmAvorVrTTHLc1Ks1quY5ETe 7Eaw== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=siemens.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id i40si4097818eda.225.2019.10.18.09.14.41; Fri, 18 Oct 2019 09:15:04 -0700 (PDT) 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=siemens.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2439863AbfJQOMb (ORCPT + 99 others); Thu, 17 Oct 2019 10:12:31 -0400 Received: from thoth.sbs.de ([192.35.17.2]:46843 "EHLO thoth.sbs.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727429AbfJQOMb (ORCPT ); Thu, 17 Oct 2019 10:12:31 -0400 Received: from mail2.sbs.de (mail2.sbs.de [192.129.41.66]) by thoth.sbs.de (8.15.2/8.15.2) with ESMTPS id x9HECJuL004263 (version=TLSv1.2 cipher=DHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Thu, 17 Oct 2019 16:12:19 +0200 Received: from [139.25.68.37] ([139.25.68.37]) by mail2.sbs.de (8.15.2/8.15.2) with ESMTP id x9HECJNG019630; Thu, 17 Oct 2019 16:12:19 +0200 Subject: Re: [PATCH v2] scripts/gdb: fix debugging modules on s390 From: Jan Kiszka To: Ilya Leoshkevich , Kieran Bingham , linux-kernel@vger.kernel.org, linux-s390@vger.kernel.org, Andrew Morton Cc: Heiko Carstens , Vasily Gorbik References: <20191017085917.81791-1-iii@linux.ibm.com> Message-ID: Date: Thu, 17 Oct 2019 16:12:18 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.1.1 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 17.10.19 16:11, Jan Kiszka wrote: > On 17.10.19 10:59, Ilya Leoshkevich wrote: >> Currently lx-symbols assumes that module text is always located at >> module->core_layout->base, but s390 uses the following layout: >> >> +------+ <- module->core_layout->base >> | GOT | >> +------+ <- module->core_layout->base + module->arch->plt_offset >> | PLT | >> +------+ <- module->core_layout->base + module->arch->plt_offset + >> | TEXT | module->arch->plt_size >> +------+ >> >> Therefore, when trying to debug modules on s390, all the symbol >> addresses are skewed by plt_offset + plt_size. >> >> Fix by adding plt_offset + plt_size to module_addr in >> load_module_symbols(). >> >> Signed-off-by: Ilya Leoshkevich >> --- >> >> v1 -> v2: print the adjusted address. >> >> scripts/gdb/linux/symbols.py | 8 +++++++- >> 1 file changed, 7 insertions(+), 1 deletion(-) >> >> diff --git a/scripts/gdb/linux/symbols.py b/scripts/gdb/linux/symbols.py >> index f0d8f2ecfde7..df4c810de663 100644 >> --- a/scripts/gdb/linux/symbols.py >> +++ b/scripts/gdb/linux/symbols.py >> @@ -15,7 +15,7 @@ import gdb >> import os >> import re >> >> -from linux import modules >> +from linux import modules, utils >> >> >> if hasattr(gdb, 'Breakpoint'): >> @@ -111,6 +111,12 @@ lx-symbols command.""" >> module_file = self._get_module_file(module_name) >> >> if module_file: >> + if utils.is_target_arch('s390'): >> + # Module text is preceded by PLT stubs on s390. >> + module_arch = module['arch'] >> + plt_offset = int(module_arch['plt_offset']) >> + plt_size = int(module_arch['plt_size']) >> + module_addr = hex(int(module_addr, 0) + plt_offset + plt_size) >> gdb.write("loading @{addr}: {filename}\n".format( >> addr=module_addr, filename=module_file)) >> cmdline = "add-symbol-file {filename} {addr}{sections}".format( >> > > Reviewed-by: Jan Kiszka > > Thanks, > Jan > Sorry, forgot to CC Andrew for pickup. Jan -- Siemens AG, Corporate Technology, CT RDA IOT SES-DE Corporate Competence Center Embedded Linux