Received: by 2002:a05:6a10:f347:0:0:0:0 with SMTP id d7csp3044742pxu; Sat, 19 Dec 2020 10:00:25 -0800 (PST) X-Google-Smtp-Source: ABdhPJzAg05Qo0ZClcRAznp+e4/RZtgD1nV1+m8p9jb+xHNha6eD4FJTAr6GKqhm5FUmwSLEzJW9 X-Received: by 2002:a17:906:4756:: with SMTP id j22mr9374114ejs.353.1608400825536; Sat, 19 Dec 2020 10:00:25 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1608400825; cv=none; d=google.com; s=arc-20160816; b=ZgbmZa07+3ACInAIc3JG2UDdKdxlC37tLYVfJOpwOv2i+ZZgW8/nw3QcEQ0T1eJfMR ntgGelLJwl9E/NwHoVyNl0APxT1xtRgTsKbx/nKFW+ZU5uKA9cV/rfNFfqvLMmbs7dQU /lkLOHque0p/oegsHC3kk7JMnA8S3JO2ujw/Ilwh/VTTrySYpJAFVfFNlHSmbe//roDA w9l2eeOpnjZPJSQFyOayq4TD3l2habmS1l7WUjBCWoJgwy/enWQYM0AwiGJRz4U+lCCT 6LKMwQ2s54Ahot+epEp/tyCM5GBFkIYf39NA4ggBAr3cJDChsjFBgwqAnqzqx4M0l6w8 JWYw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature:dkim-filter; bh=2sX3DOQNul17WhMPoQraNg57fmG6VY+bxXXYc4MwJTU=; b=WcYck5/I1j+wSActIbaNaJbC5PD1gtnwP0k+A1wjtHLtmp9zOrRrLt0Qc2uZbYHGZV 21Af0+Kt0KYizUMiZn87IrxWmGOtBd3ztI5cwFxwpxiPHYDUE3zyG9t8dic92tlVkBoy L6fH8mRh/uB3WuchQKL9jquxnNlGgudyWbdD/L0BZn0W6rBSSyeLZSTnvQiHcnpntz8L WWJdJ69T94gXdfzoiIZlyZoMejVUf+2i14zQhDaLHx0jR8ukPefCQlYY3fdeBFjO/JW7 ogyH3+YA235b0ivXljF2WzHyD4ifE5Pf4Q6nEJnmidOKZp4cuHqSkUiJQcWFCobkXslB 5kzA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linux.microsoft.com header.s=default header.b=iOVrA1QY; 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=linux.microsoft.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id t10si2978916edt.208.2020.12.19.10.00.03; Sat, 19 Dec 2020 10:00:25 -0800 (PST) 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=@linux.microsoft.com header.s=default header.b=iOVrA1QY; 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=linux.microsoft.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727402AbgLSR6V (ORCPT + 99 others); Sat, 19 Dec 2020 12:58:21 -0500 Received: from linux.microsoft.com ([13.77.154.182]:51144 "EHLO linux.microsoft.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727211AbgLSR6U (ORCPT ); Sat, 19 Dec 2020 12:58:20 -0500 Received: from localhost.localdomain (c-73-42-176-67.hsd1.wa.comcast.net [73.42.176.67]) by linux.microsoft.com (Postfix) with ESMTPSA id E5EB320B83F6; Sat, 19 Dec 2020 09:57:38 -0800 (PST) DKIM-Filter: OpenDKIM Filter v2.11.0 linux.microsoft.com E5EB320B83F6 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linux.microsoft.com; s=default; t=1608400659; bh=2sX3DOQNul17WhMPoQraNg57fmG6VY+bxXXYc4MwJTU=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=iOVrA1QYCMhqVU2uQWKbJd+ZrzStgOgCcQZ3zDz6e08cafn8qT4hGDL9W8ei1SGjO Pilt2kYj+V3UXhMMKlRdZOQP6wjcCpl0ef/HFiCcL17UPep6EOfASrH8cbPiko/pcv t1E82vSwEQ8z7jGBB62eA4hHLuIDYrlswV1GIpPk= From: Lakshmi Ramasubramanian To: zohar@linux.ibm.com, bauerman@linux.ibm.com, robh@kernel.org, takahiro.akashi@linaro.org, gregkh@linuxfoundation.org, will@kernel.org, catalin.marinas@arm.com, mpe@ellerman.id.au Cc: james.morse@arm.com, sashal@kernel.org, benh@kernel.crashing.org, paulus@samba.org, frowand.list@gmail.com, vincenzo.frascino@arm.com, mark.rutland@arm.com, dmitry.kasatkin@gmail.com, jmorris@namei.org, serge@hallyn.com, pasha.tatashin@soleen.com, allison@lohutok.net, masahiroy@kernel.org, bhsharma@redhat.com, mbrugger@suse.com, hsinyi@chromium.org, tao.li@vivo.com, christophe.leroy@c-s.fr, prsriva@linux.microsoft.com, balajib@linux.microsoft.com, linux-integrity@vger.kernel.org, linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, devicetree@vger.kernel.org Subject: [PATCH v13 3/6] kexec: Use fdt_appendprop_addrrange() to add ima buffer to FDT Date: Sat, 19 Dec 2020 09:57:10 -0800 Message-Id: <20201219175713.18888-4-nramas@linux.microsoft.com> X-Mailer: git-send-email 2.29.2 In-Reply-To: <20201219175713.18888-1-nramas@linux.microsoft.com> References: <20201219175713.18888-1-nramas@linux.microsoft.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org fdt_appendprop_addrrange() function adds a property, with the given name, to the device tree at the given node offset, and also sets the address and size of the property. This function should be used to add "linux,ima-kexec-buffer" property to the device tree and set the address and size of the IMA measurement buffer, instead of using custom function. Use fdt_appendprop_addrrange() to add "linux,ima-kexec-buffer" property to the device tree. This property holds the address and size of the IMA measurement buffer that needs to be passed from the current kernel to the next kernel across kexec system call. Remove custom code that is used in setup_ima_buffer() to add "linux,ima-kexec-buffer" property to the device tree. Co-developed-by: Prakhar Srivastava Signed-off-by: Prakhar Srivastava Signed-off-by: Lakshmi Ramasubramanian --- drivers/of/kexec.c | 57 ++++------------------------------------------ 1 file changed, 5 insertions(+), 52 deletions(-) diff --git a/drivers/of/kexec.c b/drivers/of/kexec.c index 33d97106f176..0031491d9aeb 100644 --- a/drivers/of/kexec.c +++ b/drivers/of/kexec.c @@ -147,36 +147,6 @@ static inline void remove_ima_buffer(void *fdt, int chosen_node) {} #endif /* CONFIG_HAVE_IMA_KEXEC */ #ifdef CONFIG_IMA_KEXEC -/** - * write_number - Convert number to big-endian format - * - * @p: Buffer to write the number to - * @value: Number to convert - * @cells: Number of cells - * - * Return: 0 on success, or negative errno on error. - */ -static int write_number(void *p, u64 value, int cells) -{ - if (cells == 1) { - u32 tmp; - - if (value > U32_MAX) - return -EINVAL; - - tmp = cpu_to_be32(value); - memcpy(p, &tmp, sizeof(tmp)); - } else if (cells == 2) { - u64 tmp; - - tmp = cpu_to_be64(value); - memcpy(p, &tmp, sizeof(tmp)); - } else - return -EINVAL; - - return 0; -} - /** * setup_ima_buffer - add IMA buffer information to the fdt * @image: kexec image being loaded. @@ -188,32 +158,15 @@ static int write_number(void *p, u64 value, int cells) static int setup_ima_buffer(const struct kimage *image, void *fdt, int chosen_node) { - int ret, addr_cells, size_cells, entry_size; - u8 value[16]; + int ret; if (!image->arch.ima_buffer_size) return 0; - ret = get_addr_size_cells(&addr_cells, &size_cells); - if (ret) - return ret; - - entry_size = 4 * (addr_cells + size_cells); - - if (entry_size > sizeof(value)) - return -EINVAL; - - ret = write_number(value, image->arch.ima_buffer_addr, addr_cells); - if (ret) - return ret; - - ret = write_number(value + 4 * addr_cells, image->arch.ima_buffer_size, - size_cells); - if (ret) - return ret; - - ret = fdt_setprop(fdt, chosen_node, "linux,ima-kexec-buffer", value, - entry_size); + ret = fdt_appendprop_addrrange(fdt, 0, chosen_node, + "linux,ima-kexec-buffer", + image->arch.ima_buffer_addr, + image->arch.ima_buffer_size); if (ret < 0) return -EINVAL; -- 2.29.2