Received: by 2002:a05:6a10:f347:0:0:0:0 with SMTP id d7csp14051187pxu; Mon, 4 Jan 2021 11:29:00 -0800 (PST) X-Google-Smtp-Source: ABdhPJz8RXP9C322mMwxnJ6m0FbDf2Z7Sk/XOw9GpdUPcmHlP9Likmeyse0fCTuAk4W+xbtO/vc6 X-Received: by 2002:a17:906:85cf:: with SMTP id i15mr70987374ejy.373.1609788540622; Mon, 04 Jan 2021 11:29:00 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1609788540; cv=none; d=google.com; s=arc-20160816; b=G1O3JOQ7TeynWTU7YpTAlthub//4ZnvL/S9csQHNVUG9TLOkV+uBJ8VTXZ9Qpt6yB8 c7xvURuXI/JWtjIxWNzwvXWUGJnbv1SH5nfjGWFz6WRxe7vyyBSkiyD9YfP3smDJphfX CrZCUhVRKQ89y9a4L4x3Df+xQ6GMcIG4zEfbWYGVWFyGZlCROpZ1AXMVtA7k5k6QJm1M ZsA+dH2ccjoVmFmEoGijHkO73l/oKUT3+cSInuR6Q9CVwmK+IbhgyLTNo3OG+vueAQsQ 0+mP/vRIXtDDcOBSVIvEadnlyimZiZAC2fpZ3slqgCODQYteenj9IQ3vqJ9zVvK0lsVU WKdA== 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=HL6to3zIpD157+Axm2zUZyuM6pBas6XN9X7BttUpCNI=; b=STzV/+qgYT6/usUdJAJBizYUmC2iZBx8UXUGgJeWmKvR2b0pmaWWgapXLY+Vue+FwA 3O63K+ODsx6FcD62L1ngwn39B3ORnXlKuL5quzrYEWvjXdsLAcLgAKUxRUhL7IenkaIN L395gT2eqeh3EZT+YFgPa7P+WyN/1waotxjOr1EZaHT5X6RZ5/efOYd/E/pkKvmMeOZp salMxpj3M4j+PLDxCfgtslVQg73irQrvEzu8tIqc8U/druA79YEi9FYnJyjeoJAXxaPk LS/U+JB0DM7tCEb7idnlSRzbm3i/HU9Tx2vOMlPG3AWSgv0jD16uE4/8TO9Wzs9LLMXj BdIQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linux.microsoft.com header.s=default header.b=NXIeWc1x; 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 hs23si29665961ejc.239.2021.01.04.11.28.37; Mon, 04 Jan 2021 11:29:00 -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=NXIeWc1x; 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 S1728009AbhADT1O (ORCPT + 99 others); Mon, 4 Jan 2021 14:27:14 -0500 Received: from linux.microsoft.com ([13.77.154.182]:36580 "EHLO linux.microsoft.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727520AbhADT0y (ORCPT ); Mon, 4 Jan 2021 14:26:54 -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 C7C4820B6C42; Mon, 4 Jan 2021 11:26:12 -0800 (PST) DKIM-Filter: OpenDKIM Filter v2.11.0 linux.microsoft.com C7C4820B6C42 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linux.microsoft.com; s=default; t=1609788373; bh=HL6to3zIpD157+Axm2zUZyuM6pBas6XN9X7BttUpCNI=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=NXIeWc1xUTnh4uqLuBt7IPa2n3zeaf8TGFHCpV13zEjRBaLSUlNsR60qNIXSbYbgc p+Gdlacjprsr8SNBVmwDqQORJcCmNnizur6JS/UA90UlkywYC7ce4sWPwFx+29Duet YRn7l20Q3ZzWyloklikps4k8kXpwH6heHtG8h1GQ= 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@vger.kernel.org Subject: [PATCH v14 3/6] kexec: Use fdt_appendprop_addrrange() to add ima buffer to FDT Date: Mon, 4 Jan 2021 11:25:59 -0800 Message-Id: <20210104192602.10131-4-nramas@linux.microsoft.com> X-Mailer: git-send-email 2.29.2 In-Reply-To: <20210104192602.10131-1-nramas@linux.microsoft.com> References: <20210104192602.10131-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 9b1650b5c036..d06556dba03b 100644 --- a/drivers/of/kexec.c +++ b/drivers/of/kexec.c @@ -206,36 +206,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. @@ -247,32 +217,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