Received: by 2002:a05:6a10:16a7:0:0:0:0 with SMTP id gp39csp1392362pxb; Fri, 13 Nov 2020 11:25:37 -0800 (PST) X-Google-Smtp-Source: ABdhPJz2/GDNTJBhCzfcke1d6CeYl93fHYegdO3SPCjtSvAtGZmJVQsCmD5jQM2kffclSP1nztQ6 X-Received: by 2002:a17:906:512:: with SMTP id j18mr3575964eja.370.1605295537329; Fri, 13 Nov 2020 11:25:37 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1605295537; cv=none; d=google.com; s=arc-20160816; b=IeegY8Vkev++lDSXYABNUU4Zx1zILqhM5aCImRyl8gLR0MuJ3nFQ5xMuisApbDeNnh oZUN7S2RbiW1Vqi41smZORHCOK+3ILTKQl5dz//BnbbhMncg2BFuY5YF5HoSjhPzEB0F tLyvult3JAlirLAKCAJt9iVMQ3R3IvfhwWb9p2Miq8tZvpkhpFBGvqR9mi7ezZFFAdJR h9E6WNR3phOMzyPVdvzqYflheDwRwg/qXl3PLwHwp1XTcbTZcTJ9miBTh78A9elx/o4T 9ohHybTkDXHc/H6yA0tgMY8EooJFtQY6JsBGz3S+TDT8yS1srZz1KrYrf8j0gnLyHrCK FyVQ== 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=As5x7eyArPRnO995ZhTECQJT5CoCqQXZIxILVcOXTkY=; b=JnTB6lTNxduxwTnfD69K6fkzaieiLbqGgJyKKCarFzsyTZEfBLcjY+hSZhvWgt3+h1 tRcN9l0F6KX0TlkblLfE/EeRtILHeSwDbzYXbPg88xaUNiKMPmN2VKnItaa5ilXdofFy Ca6+9gbWB18shBE9SPXXZ0qHpr6J2KokbpEFrQqvpoxvkhBgqwC/W67eFBfom0bcN0jk rKzlxT3oJYdT6Ox7Nn88THpnAZHfYSEQELbIzp2YnurhwJv4wK2FiH9rSLstYPL5RZLd jG0FwXdM/No4M/cnnjhsbna+oiT/ULzc6QUFZdGj5/2gEj7ryzqPGKpfeAAptsXYIA+c 4ZGw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linux.microsoft.com header.s=default header.b=X2DAhVJp; 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 f1si6493441eja.366.2020.11.13.11.25.14; Fri, 13 Nov 2020 11:25:37 -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=X2DAhVJp; 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 S1726502AbgKMTXS (ORCPT + 99 others); Fri, 13 Nov 2020 14:23:18 -0500 Received: from linux.microsoft.com ([13.77.154.182]:48918 "EHLO linux.microsoft.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726287AbgKMTWx (ORCPT ); Fri, 13 Nov 2020 14:22:53 -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 E54DF20C28C6; Fri, 13 Nov 2020 11:22:51 -0800 (PST) DKIM-Filter: OpenDKIM Filter v2.11.0 linux.microsoft.com E54DF20C28C6 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linux.microsoft.com; s=default; t=1605295372; bh=As5x7eyArPRnO995ZhTECQJT5CoCqQXZIxILVcOXTkY=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=X2DAhVJph47pTcV4K/YZRke9lGnHnz3J3NHNlSzXP77mlxIZcleA9zX5O1D6oLs7j qQ8x9PJzyZHK2asNcWm3e+3Vpb1kslMw39Tz2TlXVLyMSPMC//UWkXX5lTav5++wS8 vaaCkLbIshfy6l0QP/pJzGz+5qHI/te85HCTYizE= From: Lakshmi Ramasubramanian To: zohar@linux.ibm.com, bauerman@linux.ibm.com, robh@kernel.org, gregkh@linuxfoundation.org, james.morse@arm.com, catalin.marinas@arm.com, sashal@kernel.org, will@kernel.org, mpe@ellerman.id.au, benh@kernel.crashing.org, paulus@samba.org, robh+dt@kernel.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, kstewart@linuxfoundation.org, takahiro.akashi@linaro.org, tglx@linutronix.de, masahiroy@kernel.org, bhsharma@redhat.com, mbrugger@suse.com, hsinyi@chromium.org, tao.li@vivo.com, christophe.leroy@c-s.fr Cc: linux-integrity@vger.kernel.org, linux-kernel@vger.kernel.org, devicetree@vger.kernel.org, prsriva@linux.microsoft.com, balajib@linux.microsoft.com Subject: [PATCH v9 5/8] powerpc: Move remove_ima_buffer() to drivers/of Date: Fri, 13 Nov 2020 11:22:40 -0800 Message-Id: <20201113192243.1993-6-nramas@linux.microsoft.com> X-Mailer: git-send-email 2.29.2 In-Reply-To: <20201113192243.1993-1-nramas@linux.microsoft.com> References: <20201113192243.1993-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 remove_ima_buffer() removes the chosen node, namely "linux,ima-kexec-buffer", from the device tree and frees the memory reserved for carrying forward the IMA measurement logs on kexec. This function does not have architecture specific code, but is currently limited to powerpc. Move remove_ima_buffer() to "drivers/of/ima_kexec.c" so that it is accessible for other architectures as well. Co-developed-by: Prakhar Srivastava Signed-off-by: Prakhar Srivastava Signed-off-by: Lakshmi Ramasubramanian --- arch/powerpc/include/asm/ima.h | 8 ++------ arch/powerpc/kexec/ima.c | 26 -------------------------- drivers/of/ima_kexec.c | 26 ++++++++++++++++++++++++++ include/linux/kexec.h | 2 ++ 4 files changed, 30 insertions(+), 32 deletions(-) diff --git a/arch/powerpc/include/asm/ima.h b/arch/powerpc/include/asm/ima.h index ead488cf3981..a2fc71bc3b23 100644 --- a/arch/powerpc/include/asm/ima.h +++ b/arch/powerpc/include/asm/ima.h @@ -2,17 +2,13 @@ #ifndef _ASM_POWERPC_IMA_H #define _ASM_POWERPC_IMA_H +#include + struct kimage; int ima_get_kexec_buffer(void **addr, size_t *size); int ima_free_kexec_buffer(void); -#ifdef CONFIG_IMA -void remove_ima_buffer(void *fdt, int chosen_node); -#else -static inline void remove_ima_buffer(void *fdt, int chosen_node) {} -#endif - #ifdef CONFIG_IMA_KEXEC int arch_ima_add_kexec_buffer(struct kimage *image, unsigned long load_addr, size_t size); diff --git a/arch/powerpc/kexec/ima.c b/arch/powerpc/kexec/ima.c index df491fab5d4b..baa95d1a8304 100644 --- a/arch/powerpc/kexec/ima.c +++ b/arch/powerpc/kexec/ima.c @@ -61,32 +61,6 @@ int ima_free_kexec_buffer(void) return memblock_free(addr, size); } -/** - * remove_ima_buffer - remove the IMA buffer property and reservation from @fdt - * - * @fdt: Flattened Device Tree to update - * @chosen_node: Offset to the chosen node in the device tree - * - * The IMA measurement buffer is of no use to a subsequent kernel, so we always - * remove it from the device tree. - */ -void remove_ima_buffer(void *fdt, int chosen_node) -{ - int ret; - unsigned long addr; - size_t size; - - ret = get_ima_kexec_buffer(fdt, chosen_node, &addr, &size); - if (ret) - return; - - fdt_delprop(fdt, chosen_node, "linux,ima-kexec-buffer"); - - ret = delete_fdt_mem_rsv(fdt, addr, size); - if (!ret) - pr_debug("Removed old IMA buffer reservation.\n"); -} - #ifdef CONFIG_IMA_KEXEC static int get_addr_size_cells(int *addr_cells, int *size_cells) { diff --git a/drivers/of/ima_kexec.c b/drivers/of/ima_kexec.c index 9c14777404f2..a063a8b4dcb4 100644 --- a/drivers/of/ima_kexec.c +++ b/drivers/of/ima_kexec.c @@ -63,3 +63,29 @@ int get_ima_kexec_buffer(void *fdt, int chosen_node, return 0; } + +/** + * remove_ima_buffer - remove the IMA buffer property and reservation from @fdt + * + * @fdt: Flattened Device Tree to update + * @chosen_node: Offset to the chosen node in the device tree + * + * The IMA measurement buffer is of no use to a subsequent kernel, so we always + * remove it from the device tree. + */ +void remove_ima_buffer(void *fdt, int chosen_node) +{ + int ret; + unsigned long addr; + size_t size; + + ret = get_ima_kexec_buffer(fdt, chosen_node, &addr, &size); + if (ret) + return; + + fdt_delprop(fdt, chosen_node, "linux,ima-kexec-buffer"); + + ret = delete_fdt_mem_rsv(fdt, addr, size); + if (!ret) + pr_debug("Removed old IMA buffer reservation.\n"); +} diff --git a/include/linux/kexec.h b/include/linux/kexec.h index a4f248caa483..152e5a56bb35 100644 --- a/include/linux/kexec.h +++ b/include/linux/kexec.h @@ -410,12 +410,14 @@ static inline int kexec_crash_loaded(void) { return 0; } #if defined(CONFIG_OF_FLATTREE) && defined(CONFIG_HAVE_IMA_KEXEC) extern int get_ima_kexec_buffer(void *fdt, int chosen_node, unsigned long *addr, size_t *size); +extern void remove_ima_buffer(void *fdt, int chosen_node); #else static inline int get_ima_kexec_buffer(void *fdt, int chosen_node, unsigned long *addr, size_t *size) { return -EOPNOTSUPP; } +static inline void remove_ima_buffer(void *fdt, int chosen_node) {} #endif /* CONFIG_OF_FLATTREE && CONFIG_HAVE_IMA_KEXEC */ #if defined(CONFIG_OF_FLATTREE) && defined(CONFIG_KEXEC_FILE) -- 2.29.2