Received: by 2002:ac0:a5a6:0:0:0:0:0 with SMTP id m35-v6csp3038709imm; Fri, 24 Aug 2018 09:27:38 -0700 (PDT) X-Google-Smtp-Source: ANB0VdazaMsC5mAewTrOSMyvqvjOVIGkdee6JEG42wvWZYtcuvjE2gyiDbdlBQteyF/L/VvzWEqE X-Received: by 2002:a17:902:d710:: with SMTP id w16-v6mr2355835ply.93.1535128057994; Fri, 24 Aug 2018 09:27:37 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1535128057; cv=none; d=google.com; s=arc-20160816; b=XaG+fL6AJa/tv1Rd/agLX2gD92PkOEKjOX75dyoEVQNVAIJpqMqrBZxZG908j4cgFy Z4SaOgqit1JbDlUN6GiIp6BOvLBl3hwRgrCJN4bN4rgkyvyuQXNoEH0cBecjfUzG7kF9 YvFPCS3AdDk2kRm4ZnoeYN2Ejd5L2kVXAT9Tqgc+MbowYvlx3ZoZjxYcHi5zLaH3iDmi DGuuWvW9kgMXY8sNSUEF2N6fLCahzypMCKcBW2bKjIXMwYmMg5Q7+VxVLNeF19s8WkZd 6wxukNUBwtuY5ASkVeEg8q+e8QB1MMPfwOXmkMvgeZR6W5j6RhsOyJIQYSFobh8d+Br1 Xexw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:dkim-signature:arc-authentication-results; bh=HJsAFvWQlbocEGZwipV0qy2Gk6KIgIggV67TRx7ZvVc=; b=nTlWVAOSNuGbxB7OnJsdxXV1nCwMII9uOBQ5A+PisNq7QWE9cLYad7bge76lfnypbU eQ335vluJN07Qox7KjwYuFd6nsrAl1RvGsGD0SvLj7E1ZpIIfjgcBn3mREZkvZyXXNEe d7HqG4djLDiZkvat7wtmx+lF9/p+svcmpKIYE7syYpxMFu5GbVMM/cYd9/Mh7LYoJDS0 HJ1SGgsw6/7OM06O7mibiyuPW5ygWlSh3PROQQDtW0QvFY7mv0B8IuTyonGkdGT4eF9L 2ujmgl5ATydQFsEsB1nBGoO5tkUGrVQtQGyuWh7rH5+TfBTs1C6nFwdFwejhAQAjlIrV qN6w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=kOQdVjW3; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id a140-v6si8325293pfa.61.2018.08.24.09.27.23; Fri, 24 Aug 2018 09:27:37 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=kOQdVjW3; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728249AbeHXT7w (ORCPT + 99 others); Fri, 24 Aug 2018 15:59:52 -0400 Received: from mail.kernel.org ([198.145.29.99]:41502 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727618AbeHXT6w (ORCPT ); Fri, 24 Aug 2018 15:58:52 -0400 Received: from sol.localdomain (c-67-185-97-198.hsd1.wa.comcast.net [67.185.97.198]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 3A8592159F; Fri, 24 Aug 2018 16:23:30 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1535127810; bh=xLQOyqOdBZE9OaHvzop6bdy6Jv/N6ypKdUom9H1RQIU=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=kOQdVjW3k5Ry9mPyhdGxppJ8fYzLL8vDlhh4UlyDh8AD0sCQby3usRYS/nxr4wQ3l nXs7m31khQFULtgRbEtZ16CLZSD7En3qNAnkXZqcfwAv3sMl/Tx0m0/skg0iNVDGQC LT8Jfo2e/X0CyD47vCkruE/LUBsmVMNm7X4wdFeM= From: Eric Biggers To: linux-fsdevel@vger.kernel.org, linux-ext4@vger.kernel.org, linux-f2fs-devel@lists.sourceforge.net Cc: linux-integrity@vger.kernel.org, linux-fscrypt@vger.kernel.org, linux-kernel@vger.kernel.org, Mimi Zohar , Dmitry Kasatkin , Michael Halcrow , Victor Hsieh Subject: [RFC PATCH 06/10] fs-verity: add CRC-32C support Date: Fri, 24 Aug 2018 09:16:38 -0700 Message-Id: <20180824161642.1144-7-ebiggers@kernel.org> X-Mailer: git-send-email 2.18.0 In-Reply-To: <20180824161642.1144-1-ebiggers@kernel.org> References: <20180824161642.1144-1-ebiggers@kernel.org> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Eric Biggers Add CRC-32C support to fs-verity, to provide a faster alternative to SHA-256 for users who want integrity-only (not authenticity), i.e. who want to detect only accidental corruption, not malicious changes. CRC-32C is chosen over CRC-32 because the CRC-32C polynomial is believed to provide slightly better error-detection properties; and CRC-32C is just as fast (or can be just as fast) as CRC-32, or even faster e.g. on some x86 processors that have a CRC-32C instruction but not CRC-32. We use "crc32c" from the crypto API, so the polynomial convention is bitwise little-endian, the digest is bytewise little-endian, and the CRC bits are inverted at the beginning and end (which is desirable). Signed-off-by: Eric Biggers --- fs/verity/hash_algs.c | 4 ++++ include/uapi/linux/fsverity.h | 1 + 2 files changed, 5 insertions(+) diff --git a/fs/verity/hash_algs.c b/fs/verity/hash_algs.c index e16d767070fec..3fd4bba7c4aa6 100644 --- a/fs/verity/hash_algs.c +++ b/fs/verity/hash_algs.c @@ -23,6 +23,10 @@ struct fsverity_hash_alg fsverity_hash_algs[] = { .digest_size = 64, .cryptographic = true, }, + [FS_VERITY_ALG_CRC32C] = { + .name = "crc32c", + .digest_size = 4, + }, }; /* diff --git a/include/uapi/linux/fsverity.h b/include/uapi/linux/fsverity.h index 64846763f7aef..b1afd205bbf87 100644 --- a/include/uapi/linux/fsverity.h +++ b/include/uapi/linux/fsverity.h @@ -29,6 +29,7 @@ struct fsverity_digest { /* Supported hash algorithms */ #define FS_VERITY_ALG_SHA256 1 #define FS_VERITY_ALG_SHA512 2 +#define FS_VERITY_ALG_CRC32C 3 /* for integrity only */ /* Metadata stored near the end of verity files, after the Merkle tree */ /* This structure is 64 bytes long */ -- 2.18.0