Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp602234ybz; Fri, 24 Apr 2020 06:12:48 -0700 (PDT) X-Google-Smtp-Source: APiQypJKS/+YnyvAjbokujox67raFJH7r0huBJxY8N/O+5iMnBAuCOC+h+5IIUM1jCYw88KctGtv X-Received: by 2002:a17:907:11de:: with SMTP id va30mr7112593ejb.121.1587733968802; Fri, 24 Apr 2020 06:12:48 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1587733968; cv=none; d=google.com; s=arc-20160816; b=wzw6yaJiudA6KpYVr8AnTxbNurRTErkD5Yeaqxj4OaxltnUKLI2KrHtjroEgVBLxMd bPwXAl7O2BuWf4v4q3gcVQ9Fvl743MPFDNezJjPYroS5QPsZiaU/O+oiWJVOsoryqZjy 07uuH9qGEvrE0oBSfES0rQ+Ci/lVXuxugGberFkN6Z0yis92Xy0qso5I4s+FQRlzqZW1 R86ewbQxplG2tnjHH4ETN8aSG487mtTsEyWo/OKpotxytrmSZSoT8Tn+5hmbxKnAhYt3 MOZwOG3zC1fs7kIRs29OFc6Xd0eUD03okE0es8f0so0vEeDzxUMDshQmQmtCOIzBqOb8 UG6Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:dkim-signature; bh=xINP/8QuphbBDpV9OCD3m5YMGT6cXdpmt1fdm1gdv5k=; b=qLm0vgApD6DN2gktXo2VMCc0aomKnUevWpcHosHhPJ3bFNq8b+Vlonjp3tXi+u6HaA Vjrh14P8Qin/9nWnqO/SxVADPoGJfA7QB/QAXjA44PyywEb8aqWTGq6eZsxcujH6anKi CHWS0ZeKiBCoKC+9dWTbGx009eZU4654sXsSV3i4KqppUbfS5865LlpVzRNMKD5b81LX 5WNaI8KAU9beAqAFOtZ1a8cBCsiSZVHmwkDJ+9hO1NtXP9UEkTeDanYIJaoO1Z2mdK9a aoTT9NvkM99lRzByoQbiwpg1jXsa4/0EO0sd7CwtSOhqPCcolOCMJX0WFxn+MUdQXv31 s8Jw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=cl805xhF; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id k6si2785502edx.457.2020.04.24.06.12.24; Fri, 24 Apr 2020 06:12:48 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=cl805xhF; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728411AbgDXNHs (ORCPT + 99 others); Fri, 24 Apr 2020 09:07:48 -0400 Received: from mail.kernel.org ([198.145.29.99]:57856 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728245AbgDXNHJ (ORCPT ); Fri, 24 Apr 2020 09:07:09 -0400 Received: from e123331-lin.home (amontpellier-657-1-18-247.w109-210.abo.wanadoo.fr [109.210.65.247]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id D709721D7A; Fri, 24 Apr 2020 13:07:06 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1587733628; bh=p+IQwNbfDeLJQR+77NgodSuCuaqd1Jnu5YGcIuDiIUQ=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=cl805xhFzHKUAJmo20ZVqxtpOpmjyxSr8/AbZtPrexCrvqcdOyN3phpQpvhFvr9MW DMJkpSOwmeqFl+fUO+h2y3uGVZ/QvcudwPyjqFbaobSExnfRDkV/wQBcwpTeNc5WLg vUN44RDohp6J49E9u6A2yNLro2YJIndNA2Bb7MkQ= From: Ard Biesheuvel To: linux-efi@vger.kernel.org, Ingo Molnar , Thomas Gleixner Cc: Ard Biesheuvel , linux-kernel@vger.kernel.org, Arvind Sankar , Atish Patra , Palmer Dabbelt , Zou Wei Subject: [PATCH 26/33] efi/arm: Remove __efistub_global annotation Date: Fri, 24 Apr 2020 15:05:24 +0200 Message-Id: <20200424130531.30518-27-ardb@kernel.org> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20200424130531.30518-1-ardb@kernel.org> References: <20200424130531.30518-1-ardb@kernel.org> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Arvind Sankar Instead of using __efistub_global to force variables into the .data section, leave them in the .bss but pull the EFI stub's .bss section into .data in the linker script for the compressed kernel. Signed-off-by: Arvind Sankar Reviewed-by: Ard Biesheuvel Link: https://lore.kernel.org/r/20200416151227.3360778-2-nivedita@alum.mit.edu Signed-off-by: Ard Biesheuvel --- arch/arm/boot/compressed/vmlinux.lds.S | 2 +- drivers/firmware/efi/libstub/Makefile | 7 ++++--- drivers/firmware/efi/libstub/efistub.h | 2 +- 3 files changed, 6 insertions(+), 5 deletions(-) diff --git a/arch/arm/boot/compressed/vmlinux.lds.S b/arch/arm/boot/compressed/vmlinux.lds.S index b247f399de71..b6793c7932a9 100644 --- a/arch/arm/boot/compressed/vmlinux.lds.S +++ b/arch/arm/boot/compressed/vmlinux.lds.S @@ -78,7 +78,7 @@ SECTIONS * The EFI stub always executes from RAM, and runs strictly before the * decompressor, so we can make an exception for its r/w data, and keep it */ - *(.data.efistub) + *(.data.efistub .bss.efistub) __pecoff_data_end = .; /* diff --git a/drivers/firmware/efi/libstub/Makefile b/drivers/firmware/efi/libstub/Makefile index 9a712a6e2f87..aa3ab9a4105e 100644 --- a/drivers/firmware/efi/libstub/Makefile +++ b/drivers/firmware/efi/libstub/Makefile @@ -101,8 +101,9 @@ quiet_cmd_stubcopy = STUBCPY $@ # # ARM discards the .data section because it disallows r/w data in the -# decompressor. So move our .data to .data.efistub, which is preserved -# explicitly by the decompressor linker script. +# decompressor. So move our .data to .data.efistub and .bss to .bss.efistub, +# which are preserved explicitly by the decompressor linker script. # -STUBCOPY_FLAGS-$(CONFIG_ARM) += --rename-section .data=.data.efistub +STUBCOPY_FLAGS-$(CONFIG_ARM) += --rename-section .data=.data.efistub \ + --rename-section .bss=.bss.efistub,load,alloc STUBCOPY_RELOC-$(CONFIG_ARM) := R_ARM_ABS diff --git a/drivers/firmware/efi/libstub/efistub.h b/drivers/firmware/efi/libstub/efistub.h index 2a0698d9dc78..96e25b17c88e 100644 --- a/drivers/firmware/efi/libstub/efistub.h +++ b/drivers/firmware/efi/libstub/efistub.h @@ -25,7 +25,7 @@ #define EFI_ALLOC_ALIGN EFI_PAGE_SIZE #endif -#if defined(CONFIG_ARM) || defined(CONFIG_X86) +#if defined(CONFIG_X86) #define __efistub_global __section(.data) #else #define __efistub_global -- 2.17.1