Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp2170149ybl; Sun, 19 Jan 2020 20:52:32 -0800 (PST) X-Google-Smtp-Source: APXvYqxBG9dEkkSjUz/pDUqNzDxSt80aag3LiIf51srJZ8h3crvTsSnWE5cvQmbyHCw+VgcKojXa X-Received: by 2002:aca:cdca:: with SMTP id d193mr11756128oig.152.1579495952475; Sun, 19 Jan 2020 20:52:32 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1579495952; cv=none; d=google.com; s=arc-20160816; b=WM3Yxc3HJghdc9LSMlTF5nJ7AjnU5t4NUJchmF9gZju7t0SSOJyD/Mo+1Nu0BqFm9Z eowRjg6KBvmNcGbDy6PeNoUktWKwNuqLWkxrism4n3Lyq+P905ADuX0ywZ0XaSuZv1zk 0w7BUUtUUGXUJrNxjaCIHwSpEHpu5DoSXUzW7e6dW5J0yPcChyjjuHhB+Q+ccn9mv9+J rb3PSJpZEBIf5aAxAILdtTXo2L6ntfUm5v/Xr1b3t1xvdiIJp7yrEI7Q4JVANflX1KHa f0QCT8DBKm+96/jc5Ktzw90sP2lYbqiZJa0cIOjDuLfMk5U5ZvxV5XJ1Bb9bfTm3sl2A fZAA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:in-reply-to:content-disposition :mime-version:references:message-id:subject:cc:to:from:date :dkim-signature; bh=aOK2Wv34Jv2uKr8eXhPqjKsozzUn53pkOKxNgF8Ad7g=; b=d8JGXpF7ySWd1+VFPn6NNJDuP6H7BL3QrDjG8QdiZoicQM8TO8MtGvkxJfEdptUlb4 sOie2FGOKTVqInT+c0W0klEr1SFDmlNvraJcH9CwHbSHUs0eJyJ5+Rdputbn/H9FgX6g ETdYHidivCFlnN0XyVf4M9v/fKulQFRGqufihrYsBWnlwtia+/BTynfJth7HvLKbUbZV cLMepoL7copCsOwURo2F2GiW+4biwTdiaLIOs0YXMJadPAtQhmsOoy0coQjZPBiPwx42 rsrL6ynLTZN1hozYqAkxiWrcf+r1ApXL6qIWkuGjvd57v2bamc3wsUz9lT+HDT8GVj+Q gtwQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=j0tf43nq; spf=pass (google.com: best guess record for domain of linux-ext4-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-ext4-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 65si6160433oif.14.2020.01.19.20.52.21; Sun, 19 Jan 2020 20:52:32 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-ext4-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=j0tf43nq; spf=pass (google.com: best guess record for domain of linux-ext4-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-ext4-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 S1729083AbgATEwT (ORCPT + 99 others); Sun, 19 Jan 2020 23:52:19 -0500 Received: from mail.kernel.org ([198.145.29.99]:41128 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729043AbgATEwT (ORCPT ); Sun, 19 Jan 2020 23:52:19 -0500 Received: from sol.localdomain (c-107-3-166-239.hsd1.ca.comcast.net [107.3.166.239]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id EE82A2073A; Mon, 20 Jan 2020 04:52:17 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1579495938; bh=DAtdwoWn08bxGri1PxDJ/LULe8Ktr8pcYIS21k28EN4=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=j0tf43nqBaHRTk8KvCSppcB0LKW557pYqYNlt49K3zTMGOJWI1C55cXqV6Sa+upBN fe1G0uKWFmL5LwUIKfbU9zbeAHfL4x+4mO/ID01faHvm3joFX5AL1Kn8Zsh+bQ3+NM w1eqcV5s+H8nFfeVbQ2zUJHWkDdHVGMQVksgVduE= Date: Sun, 19 Jan 2020 20:52:16 -0800 From: Eric Biggers To: Daniel Rosenberg Cc: Theodore Ts'o , linux-ext4@vger.kernel.org, Jaegeuk Kim , Chao Yu , linux-f2fs-devel@lists.sourceforge.net, linux-fscrypt@vger.kernel.org, Alexander Viro , Andreas Dilger , Jonathan Corbet , linux-doc@vger.kernel.org, linux-kernel@vger.kernel.org, linux-fsdevel@vger.kernel.org, Gabriel Krisman Bertazi , kernel-team@android.com Subject: Re: [PATCH v3 0/9] Support for Casefolding and Encryption Message-ID: <20200120045216.GB913@sol.localdomain> References: <20200117214246.235591-1-drosen@google.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20200117214246.235591-1-drosen@google.com> Sender: linux-ext4-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-ext4@vger.kernel.org On Fri, Jan 17, 2020 at 01:42:37PM -0800, Daniel Rosenberg wrote: > These patches are all on top of fscrypt's developement branch > > Ext4 and F2FS currently both support casefolding and encryption, but not at > the same time. These patches aim to rectify that. > > Since directory names are stored case preserved, we cannot just take the hash > of the ciphertext. Instead we use the siphash of the casefolded name. With this > we no longer have a direct path from an encrypted name to the hash without the > key. To deal with this, fscrypt now always includes the hash in the name it > presents when the key is not present. There is a pre-existing bug where you can > change parts of the hash and still match the name so long as the disruption to > the hash does not happen to affect lookup on that filesystem. I'm not sure how > to fix that without making ext4 lookups slower in the more common case. > > I moved the identical dcache operations for ext4 and f2fs into the VFS, as any > filesystem that uses casefolding will need the same code. This will also allow > further optimizations to that path, although my current changes don't take > advantage of that yet. > > For Ext4, this also means that we need to store the hash on disk. We only do so > for encrypted and casefolded directories to avoid on disk format changes. > Previously encryption and casefolding could not live on the same filesystem, > and we're relaxing that requirement. F2fs is a bit more straightforward since > it already stores hashes on disk. > > I've updated the related tools with just enough to enable the feature. I still > need to adjust ext4's fsck's, although without access to the keys, > neither fsck will be able to verify the hashes of casefolded and encrypted names. > > v3 changes: > fscrypt patch only creates hash key if it will be needed. > Rebased on top of fscrypt branch, reconstified match functions in ext4/f2fs > > v2 changes: > fscrypt moved to separate thread to rebase on fscrypt dev branch > addressed feedback, plus some minor fixes > > > Daniel Rosenberg (9): > fscrypt: Add siphash and hash key for policy v2 > fscrypt: Don't allow v1 policies with casefolding > fscrypt: Change format of no-key token > fscrypt: Only create hash key when needed > vfs: Fold casefolding into vfs > f2fs: Handle casefolding with Encryption > ext4: Use struct super_blocks' casefold data > ext4: Hande casefolding with encryption > ext4: Optimize match for casefolded encrypted dirs Thanks for the new version of this patchset, Daniel! I'd like to apply the first four patches (the fs/crypto/ part, to prepare for the new dirhash method) for 5.6, to get ready for the actual encrypted+casefolded support in filesystems later. But we don't have much time left before the merge window, the more I look at the patches I'm still not very happy with them. E.g., some comments I made haven't been addressed, it's missing updates to the documentation, and some of the code comments and commit messages are still confusing. For one, there's still some ambiguity between the dirhash and the SHA-256 hash, and it's not really explained why the patch introduces the SHA-256 stuff, which actually has nothing to do with encrypted+casefold (other than it was a good opportunity to do it as the nokey name format had to be changed for encrypted+casefold anyway). I also found a bug where the return value of base64_decode() isn't being checked properly. We should also keep fscrypt_match_name() simpler by setting disk_name for short names, like we were before. There are also some places that count the padding in struct fscrypt_nokey_name and some that don't, which is confusing. We also no longer need to call fscrypt_get_policy() during setflags, as we call fscrypt_require_key() now anyway. And there's now some ambiguity about what's meant by a "per-file key", since now there will be 2 types of per-file keys. So I hope you don't mind, but to move things along I've had a go at cleaning up the fscrypt patches, and I've sent out an updated version of them. Can you please take a look when you have a chance?: https://lkml.kernel.org/linux-fscrypt/20200120044401.325453-1-ebiggers@kernel.org/T/#u Thanks! - Eric