Received: by 10.223.185.111 with SMTP id b44csp779069wrg; Fri, 9 Mar 2018 13:36:04 -0800 (PST) X-Google-Smtp-Source: AG47ELuLW4h9aLR5shyT5RpVh6DtMKbZJITejBSw1NpDpISzv//bZ9iXR+uregTekHDpFYJGwgjy X-Received: by 10.98.162.26 with SMTP id m26mr31517103pff.217.1520631364005; Fri, 09 Mar 2018 13:36:04 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1520631363; cv=none; d=google.com; s=arc-20160816; b=Vni+CzNBYsfi29PEitmmaNgWmRS0SxzA6FKaGz+2FUuDYWjD1lNokoMKzELMJ6ssNM oTMHrlpeTfAL4N3jJCASO8ZPxPv5vFPILK+1nSTO/9N+64XLgyizmD61Wo0qxuROgC/T NJuvUq3Qc5kRAbBWgyjPVpoOLHWYUQnX6YUHOZ0bQRSJf1AEiLc4aLsMH57fwnYsc2hv ODXKky4kNQdIUpy8CBbBHV2YqlkcrnoY6P5O/eWRRM1op+jJUbXRKNLKHM/KPYBON/BX /1foOvqdjMJsoH7mIh3chQLTA3vfxq7rKoIpAkdGQRoaBm17ZTsgydEHqtoM8V88EybK NlcA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:references:in-reply-to:date :subject:cc:to:from:arc-authentication-results; bh=DygttBkU14KpNIo5o1WWzr5WhFbmbUY10gBItRyDCYc=; b=HJzdzeUNMkzsIY4kCVUMBFBTxS50SimbrY1smtAS77gQqaJZShaSxwaxjANYKr7Ul1 Tt7RHZjA2AsJrp36uwx+URCkVfFrkcWgeMQAxWMsTlmjM5RCq26iK4+GldXREqjxNImh cD5Dlh62f4rkXszGBlwXhjsC9jZFXHqJm7BdD+9+BzkZxodawJVze1WPuWIAUXnVsoto wmCUY2NZtTAufRSNkZPyoFDPqpYrbtWIYmEIuUQ5IRQOqL1yLSAWZeqFW8pSDe6NE1aa jY2atXlKdSnJaM/kALxOapB5kWasrLXYnYiJ5X50js1MJEjYUBjTcVc+HBFfczp+7xZP 56ZQ== 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=ibm.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id v20-v6si1523504plo.199.2018.03.09.13.35.49; Fri, 09 Mar 2018 13:36:03 -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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=ibm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S932588AbeCIVfB (ORCPT + 99 others); Fri, 9 Mar 2018 16:35:01 -0500 Received: from mx0b-001b2d01.pphosted.com ([148.163.158.5]:56054 "EHLO mx0a-001b2d01.pphosted.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1751211AbeCIVfA (ORCPT ); Fri, 9 Mar 2018 16:35:00 -0500 Received: from pps.filterd (m0098413.ppops.net [127.0.0.1]) by mx0b-001b2d01.pphosted.com (8.16.0.22/8.16.0.22) with SMTP id w29LYkAg108233 for ; Fri, 9 Mar 2018 16:34:59 -0500 Received: from e37.co.us.ibm.com (e37.co.us.ibm.com [32.97.110.158]) by mx0b-001b2d01.pphosted.com with ESMTP id 2gm1xg0qgf-1 (version=TLSv1.2 cipher=AES256-SHA256 bits=256 verify=NOT) for ; Fri, 09 Mar 2018 16:34:59 -0500 Received: from localhost by e37.co.us.ibm.com with IBM ESMTP SMTP Gateway: Authorized Use Only! Violators will be prosecuted for from ; Fri, 9 Mar 2018 14:34:58 -0700 Received: from b03cxnp07028.gho.boulder.ibm.com (9.17.130.15) by e37.co.us.ibm.com (192.168.1.137) with IBM ESMTP SMTP Gateway: Authorized Use Only! Violators will be prosecuted; Fri, 9 Mar 2018 14:34:56 -0700 Received: from b03ledav004.gho.boulder.ibm.com (b03ledav004.gho.boulder.ibm.com [9.17.130.235]) by b03cxnp07028.gho.boulder.ibm.com (8.14.9/8.14.9/NCO v10.0) with ESMTP id w29LYtxM11862438; Fri, 9 Mar 2018 14:34:55 -0700 Received: from b03ledav004.gho.boulder.ibm.com (unknown [127.0.0.1]) by IMSVA (Postfix) with ESMTP id B88737803F; Fri, 9 Mar 2018 14:34:55 -0700 (MST) Received: from t470.localdomain.com (unknown [9.80.193.108]) by b03ledav004.gho.boulder.ibm.com (Postfix) with ESMTP id 1072278038; Fri, 9 Mar 2018 14:34:53 -0700 (MST) From: Mauricio Faria de Oliveira To: linux-kernel@vger.kernel.org, mpe@ellerman.id.au, jeyu@kernel.org Cc: npiggin@gmail.com, linuxppc-dev@lists.ozlabs.org Subject: [PATCH v2] powerpc/64: Fix section mismatch warnings for early boot symbols Date: Fri, 9 Mar 2018 18:34:50 -0300 X-Mailer: git-send-email 1.8.3.1 In-Reply-To: <1520628111-1361-1-git-send-email-mauricfo@linux.vnet.ibm.com> References: <1520628111-1361-1-git-send-email-mauricfo@linux.vnet.ibm.com> X-TM-AS-GCONF: 00 x-cbid: 18030921-0024-0000-0000-0000180EAB2B X-IBM-SpamModules-Scores: X-IBM-SpamModules-Versions: BY=3.00008642; HX=3.00000241; KW=3.00000007; PH=3.00000004; SC=3.00000254; SDB=6.01000693; UDB=6.00509028; IPR=6.00780023; MB=3.00019945; MTD=3.00000008; XFM=3.00000015; UTC=2018-03-09 21:34:57 X-IBM-AV-DETECTION: SAVI=unused REMOTE=unused XFE=unused x-cbparentid: 18030921-0025-0000-0000-00004F0A3E3C Message-Id: <1520631290-5340-1-git-send-email-mauricfo@linux.vnet.ibm.com> X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10432:,, definitions=2018-03-09_11:,, signatures=0 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 priorityscore=1501 malwarescore=0 suspectscore=0 phishscore=0 bulkscore=0 spamscore=0 clxscore=1011 lowpriorityscore=0 impostorscore=0 adultscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.0.1-1709140000 definitions=main-1803090255 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Some of the boot code located at the start of kernel text is "init" class, in that it only runs at boot time, however marking it as normal init code is problematic because that puts it into a different section located at the very end of kernel text. e.g., in case the TOC is not set up, we may not be able to tolerate a branch trampoline to reach the init function. Credits: code and message are based on 2016 patch by Nicholas Piggin, and slightly modified so not to rename the powerpc code/symbol names. Subject: [PATCH] powerpc/64: quieten section mismatch warnings From: Nicholas Piggin Date: Fri Dec 23 00:14:19 AEDT 2016 Signed-off-by: Mauricio Faria de Oliveira --- v2: fix missing close parenthesis in conditional (wrong patch file, sorry) scripts/mod/modpost.c | 22 ++++++++++++++++++++-- 1 file changed, 20 insertions(+), 2 deletions(-) diff --git a/scripts/mod/modpost.c b/scripts/mod/modpost.c index 9917f92..c65d5e2 100644 --- a/scripts/mod/modpost.c +++ b/scripts/mod/modpost.c @@ -1174,8 +1174,15 @@ static const struct sectioncheck *section_mismatch( * fromsec = text section * refsymname = *.constprop.* * + * Pattern 6: + * powerpc64 has boot functions that reference init, but must remain in text. + * This pattern is identified by + * tosec = init section + * fromsym = + * **/ -static int secref_whitelist(const struct sectioncheck *mismatch, +static int secref_whitelist(const struct elf_info *elf, + const struct sectioncheck *mismatch, const char *fromsec, const char *fromsym, const char *tosec, const char *tosym) { @@ -1212,6 +1219,17 @@ static int secref_whitelist(const struct sectioncheck *mismatch, match(fromsym, optim_symbols)) return 0; + /* Check for pattern 6 */ + if (elf->hdr->e_machine == EM_PPC64) + if (match(tosec, init_sections) && + (!strncmp(fromsym, "__boot_from_prom", + strlen("__boot_from_prom")) || + !strncmp(fromsym, "start_here_multiplatform", + strlen("start_here_multiplatform")) || + !strncmp(fromsym, "start_here_common", + strlen("start_here_common")))) + return 0; + return 1; } @@ -1552,7 +1570,7 @@ static void default_mismatch_handler(const char *modname, struct elf_info *elf, tosym = sym_name(elf, to); /* check whitelist - we may ignore it */ - if (secref_whitelist(mismatch, + if (secref_whitelist(elf, mismatch, fromsec, fromsym, tosec, tosym)) { report_sec_mismatch(modname, mismatch, fromsec, r->r_offset, fromsym, -- 1.8.3.1