Received: by 2002:a25:e74b:0:0:0:0:0 with SMTP id e72csp1840549ybh; Mon, 20 Jul 2020 08:27:20 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyVknlKj4RdOO8c4DGYNrKHwDQw6kdi3SM/yJpFHq1DUPU6E3+0pYry3CGilTDzeqgM6KMm X-Received: by 2002:aa7:c885:: with SMTP id p5mr22765381eds.100.1595258840293; Mon, 20 Jul 2020 08:27:20 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1595258840; cv=none; d=google.com; s=arc-20160816; b=n+XhUVwPgqBVdDSj44yJ+GcGn47039NeFyI4hQNOd7OI2jII65QcafQKWIy9k2gLXw gAoi8PCd7/uNN1mK5Y5jX68oRhZUxTi1L50ChtckaEeY93Wsb4d8VM7sz8/6o23r970f b8zT0xh0fOEbJ4Lmhl29VQhTlwTCuVdHd42t4o0he0D1OE5Y6WOeAB6N1pOnaYP6ZT9N 4m6+B/BNmkJ1DH7jO9szb9iFVfxRDGav+P/s+WwqKyKlZ8GwSTwWw/7jc4A3iPFfB9Y9 QVNBDiagVmTuCpBD2Iz1di/9DuFbafYnitkZ3AI1YkOCN0dXFtlNjagUpVMcaxNvOGdG YfCA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature:dkim-filter; bh=JZzh/EUOcEiLud4aF6UaeKHEzHlG5Ifz8gy91uTi3GI=; b=P95fC4F3DNMESWTSPoGcDnqmyUD1gP71LgzvW2sM8O51uX0ulpZBKv3evy/u5BWHCE PhWk8u9llJShlUP6vUzbTAg0umR/GxDSJSzPb+Xu0f1dg8tK8HxkbuWsU+ejgHqK22u5 FEdKwHQWQe/qBrhZjB7JWmczImRlBcyr7VNjxyarGFdMGpQ3kbEbGzmLXyg6crJQ29dv kRBuh6oJpvaTyT9zF6w2JjdvqHKLv8YqYs0p815Gkd8WFtnxzzAMKJlrB4OGe5F1ZU1A 7HLMTgZkZvpop3/rprHYjZeygRM9M3kF4+i7664/nYkaUveb+vfwiCmNT+0CUlW6Pchg yfKQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linux.microsoft.com header.s=default header.b=ENkdmT1Q; 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 gh11si10820189ejb.442.2020.07.20.08.26.57; Mon, 20 Jul 2020 08:27:20 -0700 (PDT) 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=ENkdmT1Q; 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 S1728351AbgGTPX5 (ORCPT + 99 others); Mon, 20 Jul 2020 11:23:57 -0400 Received: from linux.microsoft.com ([13.77.154.182]:47642 "EHLO linux.microsoft.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726426AbgGTPXz (ORCPT ); Mon, 20 Jul 2020 11:23:55 -0400 Received: from prsriva-linux.hsd1.wa.comcast.net (c-24-19-135-168.hsd1.wa.comcast.net [24.19.135.168]) by linux.microsoft.com (Postfix) with ESMTPSA id B6B7E20B490A; Mon, 20 Jul 2020 08:23:53 -0700 (PDT) DKIM-Filter: OpenDKIM Filter v2.11.0 linux.microsoft.com B6B7E20B490A DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linux.microsoft.com; s=default; t=1595258634; bh=JZzh/EUOcEiLud4aF6UaeKHEzHlG5Ifz8gy91uTi3GI=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=ENkdmT1QrPRYMa/tPVZtY88ZDhOo1A6TSRbg3EM4OnjY3U7AY8yYiCD6VTJ2NWuDA B7yhfDp7fl8XGpfS9l68Ln2TUO/cL8kgv8P+FpK09+Z5f6Ymj/A8/DtFPEft5o2yhx f8ZRAuSZAumI6UKOz15mUPGXy/U7jMvkgb2e3vJE= From: Prakhar Srivastava To: linux-integrity@vger.kernel.org, linux-kernel@vger.kernel.org, devicetree@vger.kernel.org Cc: catalin.marinas@arm.com, will@kernel.org, mpe@ellerman.id.au, benh@kernel.crashing.org, paulus@samba.org, robh+dt@kernel.org, frowand.list@gmail.com, zohar@linux.ibm.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, vincenzo.frascino@arm.com, mark.rutland@arm.com, masahiroy@kernel.org, james.morse@arm.com, bhsharma@redhat.com, mbrugger@suse.com, hsinyi@chromium.org, tao.li@vivo.com, christophe.leroy@c-s.fr, gregkh@linuxfoundation.org, nramas@linux.microsoft.com, prsriva@linux.microsoft.com, tusharsu@linux.microsoft.com, balajib@linux.microsoft.com, bauerman@linux.ibm.com, robh@kernel.org Subject: [PATCH V3 1/6] Refactoring powerpc code to be made available to other architectures Date: Mon, 20 Jul 2020 08:23:37 -0700 Message-Id: <20200720152342.337990-2-prsriva@linux.microsoft.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20200720152342.337990-1-prsriva@linux.microsoft.com> References: <20200720152342.337990-1-prsriva@linux.microsoft.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Existing code in arch/powerpc can be used for carrying forward the IMA measurement logs by other architectures. Moving non architecture specific code to security/intergrity, to be made available to other architectures Signed-off-by: Prakhar Srivastava --- arch/powerpc/include/asm/ima.h | 3 - arch/powerpc/kexec/ima.c | 54 ------------------ security/integrity/ima/ima_kexec.c | 91 ++++++++++++++++++++++++++++++ 3 files changed, 91 insertions(+), 57 deletions(-) diff --git a/arch/powerpc/include/asm/ima.h b/arch/powerpc/include/asm/ima.h index ead488cf3981..bc27fd94de52 100644 --- a/arch/powerpc/include/asm/ima.h +++ b/arch/powerpc/include/asm/ima.h @@ -4,9 +4,6 @@ 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 diff --git a/arch/powerpc/kexec/ima.c b/arch/powerpc/kexec/ima.c index 720e50e490b6..563313703756 100644 --- a/arch/powerpc/kexec/ima.c +++ b/arch/powerpc/kexec/ima.c @@ -46,60 +46,6 @@ static int do_get_kexec_buffer(const void *prop, int len, unsigned long *addr, return 0; } -/** - * ima_get_kexec_buffer - get IMA buffer from the previous kernel - * @addr: On successful return, set to point to the buffer contents. - * @size: On successful return, set to the buffer size. - * - * Return: 0 on success, negative errno on error. - */ -int ima_get_kexec_buffer(void **addr, size_t *size) -{ - int ret, len; - unsigned long tmp_addr; - size_t tmp_size; - const void *prop; - - prop = of_get_property(of_chosen, "linux,ima-kexec-buffer", &len); - if (!prop) - return -ENOENT; - - ret = do_get_kexec_buffer(prop, len, &tmp_addr, &tmp_size); - if (ret) - return ret; - - *addr = __va(tmp_addr); - *size = tmp_size; - - return 0; -} - -/** - * ima_free_kexec_buffer - free memory used by the IMA buffer - */ -int ima_free_kexec_buffer(void) -{ - int ret; - unsigned long addr; - size_t size; - struct property *prop; - - prop = of_find_property(of_chosen, "linux,ima-kexec-buffer", NULL); - if (!prop) - return -ENOENT; - - ret = do_get_kexec_buffer(prop->value, prop->length, &addr, &size); - if (ret) - return ret; - - ret = of_remove_property(of_chosen, prop); - if (ret) - return ret; - - return memblock_free(addr, size); - -} - /** * remove_ima_buffer - remove the IMA buffer property and reservation from @fdt * diff --git a/security/integrity/ima/ima_kexec.c b/security/integrity/ima/ima_kexec.c index 121de3e04af2..2fe2d3bf7bda 100644 --- a/security/integrity/ima/ima_kexec.c +++ b/security/integrity/ima/ima_kexec.c @@ -10,8 +10,99 @@ #include #include #include +#include +#include +#include #include "ima.h" +static int get_addr_size_cells(int *addr_cells, int *size_cells) +{ + struct device_node *root; + + root = of_find_node_by_path("/"); + if (!root) + return -EINVAL; + + *addr_cells = of_n_addr_cells(root); + *size_cells = of_n_size_cells(root); + + of_node_put(root); + + return 0; +} + +static int do_get_kexec_buffer(const void *prop, int len, unsigned long *addr, + size_t *size) +{ + int ret, addr_cells, size_cells; + + ret = get_addr_size_cells(&addr_cells, &size_cells); + if (ret) + return ret; + + if (len < 4 * (addr_cells + size_cells)) + return -ENOENT; + + *addr = of_read_number(prop, addr_cells); + *size = of_read_number(prop + 4 * addr_cells, size_cells); + + return 0; +} + +/** + * ima_get_kexec_buffer - get IMA buffer from the previous kernel + * @addr: On successful return, set to point to the buffer contents. + * @size: On successful return, set to the buffer size. + * + * Return: 0 on success, negative errno on error. + */ +int ima_get_kexec_buffer(void **addr, size_t *size) +{ + int ret, len; + unsigned long tmp_addr; + size_t tmp_size; + const void *prop; + + prop = of_get_property(of_chosen, "linux,ima-kexec-buffer", &len); + if (!prop) + return -ENOENT; + + ret = do_get_kexec_buffer(prop, len, &tmp_addr, &tmp_size); + if (ret) + return ret; + + *addr = __va(tmp_addr); + *size = tmp_size; + + return 0; +} + +/** + * ima_free_kexec_buffer - free memory used by the IMA buffer + */ +int ima_free_kexec_buffer(void) +{ + int ret; + unsigned long addr; + size_t size; + struct property *prop; + + prop = of_find_property(of_chosen, "linux,ima-kexec-buffer", NULL); + if (!prop) + return -ENOENT; + + ret = do_get_kexec_buffer(prop->value, prop->length, &addr, &size); + if (ret) + return ret; + + ret = of_remove_property(of_chosen, prop); + if (ret) + return ret; + + return memblock_free(addr, size); + +} + #ifdef CONFIG_IMA_KEXEC static int ima_dump_measurement_list(unsigned long *buffer_size, void **buffer, unsigned long segment_size) -- 2.25.1