From patchwork Fri Jun 15 12:42:12 2018 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Alexander Graf X-Patchwork-Id: 138690 Delivered-To: patch@linaro.org Received: by 2002:a2e:970d:0:0:0:0:0 with SMTP id r13-v6csp806452lji; Fri, 15 Jun 2018 05:52:03 -0700 (PDT) X-Google-Smtp-Source: ADUXVKKvgDh7dODU9Ngmd/oTq4B7ZX+TI3UA2oWkoldixmr8roUfHhQxakMH1LpV4MIR2L/DT5KY X-Received: by 2002:a50:8fe4:: with SMTP id y91-v6mr1816378edy.295.1529067123634; Fri, 15 Jun 2018 05:52:03 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1529067123; cv=none; d=google.com; s=arc-20160816; b=tqc+2egdIoUMi2AohAAOdCcDbT1JAJv7pD4VeS99YR2JlhM8ctYRFSy07M8WlQBvVi JNCf+he8jRJOEDUWay0P0O0Fd9iX0rUd5gkyH1SznsgUKJaKeJA3YCzJ95b0uW5XkiWy 51KHzgTQJ7W79Hdxbej1WBgmQh0b1Z7sABF1MBo1C8X+zNU3i8Zl6N+drvFMZj3DPBgx Wj4sM6eKk/SPGF6SugjrOW82wkk4Ujrp2G0+ezv+oTcEu8F2eJuYN4zWff0sRfKrhSFq 3e5tczwHi79DZryNzSXGAja0bLxWAMELGL/o7tlcGKFc+YBU/2jBr2sPXA+EE3Qyy4TH obsQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=sender:errors-to:content-transfer-encoding:mime-version :list-subscribe:list-help:list-post:list-archive:list-unsubscribe :list-id:precedence:subject:cc:message-id:date:to:from :arc-authentication-results; bh=k9wQ8FSANTRu3PAMPLuCvg3TVbN/j/0rYIqpSdBCNZQ=; b=BN5Y0d5nRdUQjrlaoOVBssljOuBRPmsFlfSkAd+w7kFVMAny5tq0kSAWLwtdtqoTu4 7J9FzPwzXprBzOBi4tmPjDXImiWTILEjJAo9lsJ2j8NZqgq9BOb9qpmUYJfCnYMLH2cV uJI8e4uZBVIePOfYQYkyawMrda6jmsvb7g6LM2ois1I0QdheUVum2OTK4zyBvlGKKrCr dF2Q8d9/+ojK107YdVJswzdLnJFMbINmTB8JUdjzCHxn8R4XQjVBDABd/OfTEoAu1xIW JI/QsvPeXMps2Bdg7kztCfJNhVQNa8xSu/2LcM1dCJX3pVmJy3pKtksuSZElCiBIWzvX K7uQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of u-boot-bounces@lists.denx.de designates 81.169.180.215 as permitted sender) smtp.mailfrom=u-boot-bounces@lists.denx.de Return-Path: Received: from lists.denx.de (dione.denx.de. [81.169.180.215]) by mx.google.com with ESMTP id k42-v6si3931297ede.149.2018.06.15.05.52.03; Fri, 15 Jun 2018 05:52:03 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of u-boot-bounces@lists.denx.de designates 81.169.180.215 as permitted sender) client-ip=81.169.180.215; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of u-boot-bounces@lists.denx.de designates 81.169.180.215 as permitted sender) smtp.mailfrom=u-boot-bounces@lists.denx.de Received: by lists.denx.de (Postfix, from userid 105) id 3FBEEC21F3D; Fri, 15 Jun 2018 12:48:25 +0000 (UTC) X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on lists.denx.de X-Spam-Level: X-Spam-Status: No, score=0.0 required=5.0 tests=none autolearn=unavailable autolearn_force=no version=3.4.0 Received: from lists.denx.de (localhost [IPv6:::1]) by lists.denx.de (Postfix) with ESMTP id 99C69C21F90; Fri, 15 Jun 2018 12:42:50 +0000 (UTC) Received: by lists.denx.de (Postfix, from userid 105) id 95D06C21EFD; Fri, 15 Jun 2018 12:42:35 +0000 (UTC) Received: from mx2.suse.de (mx2.suse.de [195.135.220.15]) by lists.denx.de (Postfix) with ESMTPS id BF971C21E85 for ; Fri, 15 Jun 2018 12:42:31 +0000 (UTC) X-Virus-Scanned: by amavisd-new at test-mx.suse.de Received: from relay1.suse.de (charybdis-ext-too.suse.de [195.135.220.254]) by mx2.suse.de (Postfix) with ESMTP id DD3C6AF27; Fri, 15 Jun 2018 12:42:30 +0000 (UTC) From: Alexander Graf To: u-boot@lists.denx.de Date: Fri, 15 Jun 2018 14:42:12 +0200 Message-Id: <20180615124229.35310-1-agraf@suse.de> X-Mailer: git-send-email 2.12.3 Cc: Andy Shevchenko , Heinrich Schuchardt Subject: [U-Boot] [PATCH v3 00/17] sandbox: efi_loader support X-BeenThere: u-boot@lists.denx.de X-Mailman-Version: 2.1.18 Precedence: list List-Id: U-Boot discussion List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , MIME-Version: 1.0 Errors-To: u-boot-bounces@lists.denx.de Sender: "U-Boot" This patch set augments Simon's patch set for efi_loader support in sandbox[1], but follows a different memory allocation scheme. Instead of keeping U-Boot addresses in the EFI memory map, this patch set makes the EFI memory map contain host virtual addresses. That way most logic "just works" and all EFI interfaces automatically gain sandbox awareness. We also change the memory map of sandbox to hard code RAM to always live at address 0x80000000. This patch is completely optional. With this patch set in place, I can successfully run the selftest suite as well as an aarch64 grub.efi binary. X86_64 grub.efi doesn't work because that one requires inl instructions to work. Alex [1] https://patchwork.ozlabs.org/project/uboot/list/?series=49832 v1 -> v2: - only compile efi_add_known_memory if efi_loader is enabled - clarify address vs pointer in fs_read patch - include mapmem.h v2 -> v3: - removed: efi_loader: Pass address to fs_read() - new: fs: Convert fs_read/write to take buffer instead of address - new: efi_loader: Introduce ms abi vararg helpers - new: sandbox: Enable 1:1 map - new: distro: Move to compiler based target architecture determination - new: efi_loader: Move to compiler based target architecture determination - new: sandbox: Allow to execute from RAM - new: sandbox: Fix setjmp/longjmp Alexander Graf (13): efi_loader: Use compiler constants for image loader efi_loader: Use map_sysmem() in bootefi command efi.h: Do not use config options efi_loader: Allow SMBIOS tables in highmem sandbox: Map host memory for efi_loader efi_loader: Disable miniapps on sandbox fs: Convert fs_read/write to take buffer instead of address efi_loader: Introduce ms abi vararg helpers sandbox: Enable 1:1 map distro: Move to compiler based target architecture determination efi_loader: Move to compiler based target architecture determination sandbox: Allow to execute from RAM sandbox: Fix setjmp/longjmp Heinrich Schuchardt (1): efi_loader: efi_allocate_pages is too restrictive Simon Glass (3): efi: sandbox: Add distroboot support efi: sandbox: Add relocation constants efi: sandbox: Enable EFI loader for sandbox Makefile | 2 +- arch/sandbox/cpu/cpu.c | 30 ++++++++---------------- arch/sandbox/cpu/os.c | 43 ++++++++++++++++++++--------------- arch/sandbox/cpu/state.c | 4 ++-- arch/sandbox/cpu/u-boot.lds | 9 ++++++++ arch/sandbox/include/asm/io.h | 17 ++++---------- arch/sandbox/include/asm/setjmp.h | 4 +++- board/BuR/common/common.c | 2 +- board/gdsys/p1022/controlcenterd-id.c | 10 ++++---- cmd/bootefi.c | 13 +++++++---- cmd/mvebu/bubt.c | 4 ++-- common/board_f.c | 4 +++- common/splash_source.c | 4 +++- configs/sandbox64_defconfig | 6 ++--- configs/sandbox_defconfig | 6 ++--- configs/sandbox_flattree_defconfig | 4 ++-- configs/sandbox_noblk_defconfig | 4 ++-- configs/sandbox_spl_defconfig | 4 ++-- drivers/bootcount/bootcount_ext.c | 12 +++++----- drivers/fpga/zynqpl.c | 8 ++++--- fs/fs.c | 20 ++++++++-------- include/config_distro_bootcmd.h | 14 +++++++----- include/configs/sandbox.h | 32 +++++++++++++------------- include/efi.h | 25 ++++++++++---------- include/fs.h | 12 +++++----- include/os.h | 19 ++++++++++++++++ lib/efi/Makefile | 4 ++-- lib/efi_loader/Kconfig | 2 +- lib/efi_loader/efi_boottime.c | 36 ++++++++++++++--------------- lib/efi_loader/efi_file.c | 6 ++--- lib/efi_loader/efi_image_loader.c | 12 +++++----- lib/efi_loader/efi_memory.c | 2 +- lib/efi_loader/efi_runtime.c | 14 +++++++----- lib/efi_loader/efi_smbios.c | 11 +++++++-- lib/efi_selftest/Makefile | 2 +- 35 files changed, 219 insertions(+), 182 deletions(-)