Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp152189pxb; Fri, 15 Jan 2021 09:34:31 -0800 (PST) X-Google-Smtp-Source: ABdhPJzBb+TZhHdR4GkKU/N+PTljNLaEkg1RGUfvvASH4ChWvncCms0DB8BbHoyX48qQAlq55pRv X-Received: by 2002:aa7:d459:: with SMTP id q25mr10472040edr.279.1610732071385; Fri, 15 Jan 2021 09:34:31 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1610732071; cv=none; d=google.com; s=arc-20160816; b=oyOlh/07/vKluvPFoID1USoXYJ6dN2i7lFPt7PIUZEn2tFC+hA8tyOpCGopo2ej61j UTpo59W7KrIFtCvMku3GwP2LXACd3h9MyiFJyC7wSwERzIRnJoO7w+7KO/i8yjZzvxjj bzR0qZryqFkHucuJH/BD1WKxZ0j03uqE4+5Juy7uuRT5YN0/i1+8O9GLPShYi6UQoWvq T5DpjUHjo49gP4+jTbFD4gFi6ANcag3AXMzAAidyyImm+InMpQ68zsqtADN2GyVxK8JK jxrOWVwntnwWxuDzs3uxjWf1F7o2fLOlh4l2CU70tFNSGzKeUMj/dAMCeeqRMZjg7p+V 2BVw== 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=mxartZ0ayF3HrpCzJgjwsHpT/jq4bw00N6tRsCIOmXw=; b=blbxFGm+DLQ8OAVHB14fp9xPmV+nNyqiJ9WkgNSatrGQOQ7Obbp/tA+hZ1HCjhmXyX WmqA/QvojLS4VD3UxpgVzkFCZ7bnsJO/I9sg68tpKokHiHlLmIhosnPSs1xTj/3kQeuz QxBVijz0hW8NAtMAQBsnHrm/Idfk7A26yWtsrrZOH5pewrEmcWPI9eoGUZ9Jvn26CNIo 8tgD+ZmwV9qenJoIr1ObWZvW9gtVrkTDc/AjuVShUD5iDbL9jVXL7+YqJoWgCZ8A1h86 I6e48/hZsBUiWRYxeD7J8gaVcRKWZa1P/ARLv7XvgetYjKr85V/hsWMnL5p6H1HhIpwm bnnQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linux.microsoft.com header.s=default header.b=lMRs4lTf; 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 e19si1032522edc.566.2021.01.15.09.34.06; Fri, 15 Jan 2021 09:34:31 -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=lMRs4lTf; 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 S2387815AbhAORcD (ORCPT + 99 others); Fri, 15 Jan 2021 12:32:03 -0500 Received: from linux.microsoft.com ([13.77.154.182]:56876 "EHLO linux.microsoft.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1732557AbhAORbq (ORCPT ); Fri, 15 Jan 2021 12:31:46 -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 F3A7720B6C46; Fri, 15 Jan 2021 09:30:27 -0800 (PST) DKIM-Filter: OpenDKIM Filter v2.11.0 linux.microsoft.com F3A7720B6C46 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linux.microsoft.com; s=default; t=1610731828; bh=mxartZ0ayF3HrpCzJgjwsHpT/jq4bw00N6tRsCIOmXw=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=lMRs4lTfaPXobfqCsuOTlkr/T8ZcHETFR/6qSfFBGCXbT2Fe4XAQHVRqJ1YMYGN/N VTAeVoSOzFbQmbi+enwJFqg6BeF2QROyuAiGCvnz4YCNlXbzQnw4ERnEu2Jx797yaH ZSxkruBY+jCyVv3HaDMt81MOOXWPNb3n7O8BFlWo= 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, linuxppc-dev@lists.ozlabs.org Subject: [PATCH v15 07/10] kexec: Use fdt_appendprop_addrrange() to add ima buffer to FDT Date: Fri, 15 Jan 2021 09:30:14 -0800 Message-Id: <20210115173017.30617-8-nramas@linux.microsoft.com> X-Mailer: git-send-email 2.30.0 In-Reply-To: <20210115173017.30617-1-nramas@linux.microsoft.com> References: <20210115173017.30617-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 Reviewed-by: Thiago Jung Bauermann --- 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 450fa6128001..49183da2fc34 100644 --- a/drivers/of/kexec.c +++ b/drivers/of/kexec.c @@ -210,36 +210,6 @@ int ima_free_kexec_buffer(void) } #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. @@ -251,32 +221,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.30.0