Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp1272011pxb; Thu, 4 Feb 2021 08:51:20 -0800 (PST) X-Google-Smtp-Source: ABdhPJxkBazKBcI61mkX9r+oTuv4Lp/iumS8lYuslZwVoPVWJzaUpcNM76sJV+9htdkb/7J0Kdmo X-Received: by 2002:a17:907:1b06:: with SMTP id mp6mr11013ejc.408.1612457476208; Thu, 04 Feb 2021 08:51:16 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1612457475; cv=none; d=google.com; s=arc-20160816; b=U2lleX7X8pxPUAnV93HoiBbjVOoelKE0/8i6J48V8RG3QDksp6+Bb/XiRCmQ/zr0Bz EWxgW8xorkEVG7Y3eOM2gCn64NllpXfALWEe/Cecim+IuNAsmo9Z8J/CHfvxOPMTHyns qcaPCyCHKlYrrag/TUs9XANpOtSXbeoBuRaupJnBrojqYufQuvon76Ur4rtmJTLN47l6 ATHrfzGSzbysMnkT8Yu8GYpL5IURLMKLcMUB8v43Sy6PBzHSCZpQ9wWBJPiJ1ZrC5PpC zEj+XCv604EkTCRit6JvvNB3c1L+WsDtCJag8zEbSaQYlmRbS/cKg1KI8fAap3oZISxU WBqA== 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=QBFOOxdcjIUDjpLpw6mCgqllaPEa7vgx5gY87SXorjY=; b=TDiKuiWLsHXVk2DUmN18uTerZEoK/GoAwrjeniOIzkivfe0U70fq9HwOzg+25RljnN dUdvEIBD3vjPNkwQmMNO2QvRcNVwh9EqPYesB/o6qrMwphhkYIXmm1fKg7ThbbeKO121 4PCFntkiAsvCImShD27UoS3cgOi3zFb7cjcCcnTRV7c4ea7n1g6ircCjTOh2w+vsPOpq N6x7JhWpheYxynabbnaYQNoYWXbePVrmQiW4mqMtJY+BhO4RqWTxleiwpLoIX+e0l1Oj 1/avL3QXk6azgDpbQ2axwt1SfDUlUqvRGDZNXppU6K0JMnqzITmjwr6EZWdoBcXJ1hS/ azSg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linux.microsoft.com header.s=default header.b=JTggXmiW; 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 r12si2516842edd.539.2021.02.04.08.50.46; Thu, 04 Feb 2021 08:51:15 -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=JTggXmiW; 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 S238087AbhBDQqV (ORCPT + 99 others); Thu, 4 Feb 2021 11:46:21 -0500 Received: from linux.microsoft.com ([13.77.154.182]:52918 "EHLO linux.microsoft.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S238059AbhBDQnf (ORCPT ); Thu, 4 Feb 2021 11:43:35 -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 A876220B6C47; Thu, 4 Feb 2021 08:42:03 -0800 (PST) DKIM-Filter: OpenDKIM Filter v2.11.0 linux.microsoft.com A876220B6C47 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linux.microsoft.com; s=default; t=1612456924; bh=QBFOOxdcjIUDjpLpw6mCgqllaPEa7vgx5gY87SXorjY=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=JTggXmiW/mdeqiJ7Vw9Lxk52v+WbWtyU2/uTpAUDOAlAyt468XFZkMNt0m1HsN7aJ TPm4vd5RyCeJ67I6cXL79TUsdYFMHgX915i946bH3fLIKAh9KMBnlhgM5PqNFFfCOn 9wfUEmEk1Tdu86A3bM9yUYnujEFg6AYT6ir8Wl8U= 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, joe@perches.com, 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 v16 07/12] kexec: Use fdt_appendprop_addrrange() to add ima buffer to FDT Date: Thu, 4 Feb 2021 08:41:30 -0800 Message-Id: <20210204164135.29856-8-nramas@linux.microsoft.com> X-Mailer: git-send-email 2.30.0 In-Reply-To: <20210204164135.29856-1-nramas@linux.microsoft.com> References: <20210204164135.29856-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 7ee4f498ca19..5ae0e5d90f55 100644 --- a/drivers/of/kexec.c +++ b/drivers/of/kexec.c @@ -232,36 +232,6 @@ int of_ima_add_kexec_buffer(struct kimage *image, return 0; } -/** - * 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. @@ -273,32 +243,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->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->ima_buffer_addr, addr_cells); - if (ret) - return ret; - - ret = write_number(value + 4 * addr_cells, image->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->ima_buffer_addr, + image->ima_buffer_size); if (ret < 0) return -EINVAL; -- 2.30.0