Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp1059343pxb; Sun, 21 Feb 2021 09:53:28 -0800 (PST) X-Google-Smtp-Source: ABdhPJxqsMOjSScpdDgQptnKYaqAZJD3z4MKlei32E5YBEThffrIFWBHFV+KIIQsQmW3qKdF1G4b X-Received: by 2002:a05:6402:4312:: with SMTP id m18mr18871259edc.99.1613930008390; Sun, 21 Feb 2021 09:53:28 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1613930008; cv=none; d=google.com; s=arc-20160816; b=Qq0oCfNbVqoUOrL1xK02ZxTZ1xsGckAQKou41kklPIXkrnZO7Zp041fh0qwQX5uTGm JpkeaRyyh1aXV7JBU2tzFSt5bj6+rkyMuZ40r0YyWU3YCyINEjuIla0zOI3no6nd7q0X /WpGAR6N/JEu99tFF2Yf3MEpoG/rBG7+BWTtAV08xbC1Ic/uh6pSs7t1Jn6XkJdu34tI /tAgH/Q0FUoVHU6tDT1yhSCAZVnrWmW1/8GSvPekvloFE1Tf2DJV4RXLGg6AOx9Ix0Ub WH2fyFdMJaKdZ64n6+XbBm00bHAGOJZ9x7KSEn0p1mHJKsnqFCkkO+pOV+x1xx97pek6 ksCQ== 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=5tVdVRRrroArIcB3wic0bOUaFnm0puk45+VCxameqFY=; b=t5lQFPiRplvwTAD+TjdqHlbYbrrWqUQgSEI7+heiNty7DR0O/oIkhU9MD4v3E80bH+ tpymTQFErwMXXGzd175IMn/vIU44HReQVBZ2z9yWuWxlgAf0TsO08uygOei41QC4GbIV G7aIasX2LVy0lnS7sLWVjjpSjaXl80gk+1wFq6ETBe3Rhjx51R9RBjfpv5UsYm47F5bF Ad1HXhFA9FVEaS4lAtTCa65uI6nvlA9vR7oaBBXCeF4xeUG8ONDKMwY06ySroLZOBDH8 weZIVtDKlIJebboYIJWmHPfiDalod3wc2Rja8Y/vf+KMEbUYZHzULQhuKxjwY5jDe+UY J/vg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linux.microsoft.com header.s=default header.b=VO+GRuSK; 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 j23si10718911ejd.156.2021.02.21.09.53.05; Sun, 21 Feb 2021 09:53:28 -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=VO+GRuSK; 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 S230164AbhBURvl (ORCPT + 99 others); Sun, 21 Feb 2021 12:51:41 -0500 Received: from linux.microsoft.com ([13.77.154.182]:45662 "EHLO linux.microsoft.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230198AbhBURu7 (ORCPT ); Sun, 21 Feb 2021 12:50:59 -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 5B44D20B57A9; Sun, 21 Feb 2021 09:49:43 -0800 (PST) DKIM-Filter: OpenDKIM Filter v2.11.0 linux.microsoft.com 5B44D20B57A9 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linux.microsoft.com; s=default; t=1613929783; bh=5tVdVRRrroArIcB3wic0bOUaFnm0puk45+VCxameqFY=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=VO+GRuSKumk1qZZjgksCFLKGIHvqRBcej/ZJ0gy4ic2simAXDkL+7Xf0FbnQmHx+4 sXgqeBqQayqv+SAv9N1ppkqNdUhtS343Oxgo9+/iHJ52mgotuvGXi4t8lErFteIyos lo6jrbDOjhiiLC//fzIxzpmfXjZt93UzC8ZtVKbU= 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, sfr@canb.auug.org.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, 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 v19 11/13] kexec: Use fdt_appendprop_addrrange() to add ima buffer to FDT Date: Sun, 21 Feb 2021 09:49:28 -0800 Message-Id: <20210221174930.27324-12-nramas@linux.microsoft.com> X-Mailer: git-send-email 2.30.0 In-Reply-To: <20210221174930.27324-1-nramas@linux.microsoft.com> References: <20210221174930.27324-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 6512e25671df..f335d941a716 100644 --- a/drivers/of/kexec.c +++ b/drivers/of/kexec.c @@ -216,36 +216,6 @@ static void remove_ima_buffer(void *fdt, int chosen_node) } #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. @@ -257,32 +227,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