fs-verity: rename fsverity_signed_digest to fsverity_formatted_digest
authorEric Biggers <ebiggers@google.com>
Fri, 13 Nov 2020 21:19:16 +0000 (13:19 -0800)
committerEric Biggers <ebiggers@google.com>
Mon, 16 Nov 2020 19:40:11 +0000 (11:40 -0800)
The name "struct fsverity_signed_digest" is causing confusion because it
isn't actually a signed digest, but rather it's the way that the digest
is formatted in order to be signed.  Rename it to
"struct fsverity_formatted_digest" to prevent this confusion.

Also update the struct's comment to clarify that it's specific to the
built-in signature verification support and isn't a requirement for all
fs-verity users.

I'll be renaming this struct in fsverity-utils too.

Acked-by: Luca Boccassi <luca.boccassi@microsoft.com>
Link: https://lore.kernel.org/r/20201113211918.71883-3-ebiggers@kernel.org
Signed-off-by: Eric Biggers <ebiggers@google.com>
Documentation/filesystems/fsverity.rst
fs/verity/fsverity_private.h
fs/verity/signature.c

index 895e9711ed8815faa71c37e5a1cc6f8ae002f575..421b75498d49b26dd4e92c3e53cab10a46681f13 100644 (file)
@@ -372,7 +372,7 @@ kernel.  Specifically, it adds support for:
 File measurements must be signed in the following format, which is
 similar to the structure used by `FS_IOC_MEASURE_VERITY`_::
 
-    struct fsverity_signed_digest {
+    struct fsverity_formatted_digest {
             char magic[8];                  /* must be "FSVerity" */
             __le16 digest_algorithm;
             __le16 digest_size;
index e96d99d5145e1da25fe07f9e26650d57df28b2b6..75f8e18b44a5b6c02aa0a3381027611b12dbde20 100644 (file)
@@ -101,12 +101,19 @@ struct fsverity_descriptor {
                                         sizeof(struct fsverity_descriptor))
 
 /*
- * Format in which verity file measurements are signed.  This is the same as
- * 'struct fsverity_digest', except here some magic bytes are prepended to
- * provide some context about what is being signed in case the same key is used
- * for non-fsverity purposes, and here the fields have fixed endianness.
+ * Format in which verity file measurements are signed in built-in signatures.
+ * This is the same as 'struct fsverity_digest', except here some magic bytes
+ * are prepended to provide some context about what is being signed in case the
+ * same key is used for non-fsverity purposes, and here the fields have fixed
+ * endianness.
+ *
+ * This struct is specific to the built-in signature verification support, which
+ * is optional.  fs-verity users may also verify signatures in userspace, in
+ * which case userspace is responsible for deciding on what bytes are signed.
+ * This struct may still be used, but it doesn't have to be.  For example,
+ * userspace could instead use a string like "sha256:$digest_as_hex_string".
  */
-struct fsverity_signed_digest {
+struct fsverity_formatted_digest {
        char magic[8];                  /* must be "FSVerity" */
        __le16 digest_algorithm;
        __le16 digest_size;
index 12794a4dd15852ba43bc794ab53243f312b95be2..74ae10f04d215e631bd12294ccf813b7b748866c 100644 (file)
@@ -44,7 +44,7 @@ int fsverity_verify_signature(const struct fsverity_info *vi,
        const struct inode *inode = vi->inode;
        const struct fsverity_hash_alg *hash_alg = vi->tree_params.hash_alg;
        const u32 sig_size = le32_to_cpu(desc->sig_size);
-       struct fsverity_signed_digest *d;
+       struct fsverity_formatted_digest *d;
        int err;
 
        if (sig_size == 0) {