Commit 9db67581 authored by Dave Jiang's avatar Dave Jiang Committed by Dan Williams

keys-encrypted: add nvdimm key format type to encrypted keys

Adding nvdimm key format type to encrypted keys in order to limit the size
of the key to 32bytes.
Signed-off-by: default avatarDave Jiang <dave.jiang@intel.com>
Acked-by: default avatarMimi Zohar <zohar@linux.ibm.com>
Signed-off-by: default avatarDan Williams <dan.j.williams@intel.com>
parent 76ef5e17
...@@ -76,7 +76,7 @@ Usage:: ...@@ -76,7 +76,7 @@ Usage::
Where:: Where::
format:= 'default | ecryptfs' format:= 'default | ecryptfs | enc32'
key-type:= 'trusted' | 'user' key-type:= 'trusted' | 'user'
...@@ -173,3 +173,7 @@ are anticipated. In particular the new format 'ecryptfs' has been defined in ...@@ -173,3 +173,7 @@ are anticipated. In particular the new format 'ecryptfs' has been defined in
in order to use encrypted keys to mount an eCryptfs filesystem. More details in order to use encrypted keys to mount an eCryptfs filesystem. More details
about the usage can be found in the file about the usage can be found in the file
``Documentation/security/keys/ecryptfs.rst``. ``Documentation/security/keys/ecryptfs.rst``.
Another new format 'enc32' has been defined in order to support encrypted keys
with payload size of 32 bytes. This will initially be used for nvdimm security
but may expand to other usages that require 32 bytes payload.
...@@ -45,6 +45,7 @@ static const char hmac_alg[] = "hmac(sha256)"; ...@@ -45,6 +45,7 @@ static const char hmac_alg[] = "hmac(sha256)";
static const char blkcipher_alg[] = "cbc(aes)"; static const char blkcipher_alg[] = "cbc(aes)";
static const char key_format_default[] = "default"; static const char key_format_default[] = "default";
static const char key_format_ecryptfs[] = "ecryptfs"; static const char key_format_ecryptfs[] = "ecryptfs";
static const char key_format_enc32[] = "enc32";
static unsigned int ivsize; static unsigned int ivsize;
static int blksize; static int blksize;
...@@ -54,6 +55,7 @@ static int blksize; ...@@ -54,6 +55,7 @@ static int blksize;
#define HASH_SIZE SHA256_DIGEST_SIZE #define HASH_SIZE SHA256_DIGEST_SIZE
#define MAX_DATA_SIZE 4096 #define MAX_DATA_SIZE 4096
#define MIN_DATA_SIZE 20 #define MIN_DATA_SIZE 20
#define KEY_ENC32_PAYLOAD_LEN 32
static struct crypto_shash *hash_tfm; static struct crypto_shash *hash_tfm;
...@@ -62,12 +64,13 @@ enum { ...@@ -62,12 +64,13 @@ enum {
}; };
enum { enum {
Opt_error = -1, Opt_default, Opt_ecryptfs Opt_error = -1, Opt_default, Opt_ecryptfs, Opt_enc32
}; };
static const match_table_t key_format_tokens = { static const match_table_t key_format_tokens = {
{Opt_default, "default"}, {Opt_default, "default"},
{Opt_ecryptfs, "ecryptfs"}, {Opt_ecryptfs, "ecryptfs"},
{Opt_enc32, "enc32"},
{Opt_error, NULL} {Opt_error, NULL}
}; };
...@@ -195,6 +198,7 @@ static int datablob_parse(char *datablob, const char **format, ...@@ -195,6 +198,7 @@ static int datablob_parse(char *datablob, const char **format,
key_format = match_token(p, key_format_tokens, args); key_format = match_token(p, key_format_tokens, args);
switch (key_format) { switch (key_format) {
case Opt_ecryptfs: case Opt_ecryptfs:
case Opt_enc32:
case Opt_default: case Opt_default:
*format = p; *format = p;
*master_desc = strsep(&datablob, " \t"); *master_desc = strsep(&datablob, " \t");
...@@ -625,15 +629,22 @@ static struct encrypted_key_payload *encrypted_key_alloc(struct key *key, ...@@ -625,15 +629,22 @@ static struct encrypted_key_payload *encrypted_key_alloc(struct key *key,
format_len = (!format) ? strlen(key_format_default) : strlen(format); format_len = (!format) ? strlen(key_format_default) : strlen(format);
decrypted_datalen = dlen; decrypted_datalen = dlen;
payload_datalen = decrypted_datalen; payload_datalen = decrypted_datalen;
if (format && !strcmp(format, key_format_ecryptfs)) { if (format) {
if (!strcmp(format, key_format_ecryptfs)) {
if (dlen != ECRYPTFS_MAX_KEY_BYTES) { if (dlen != ECRYPTFS_MAX_KEY_BYTES) {
pr_err("encrypted_key: keylen for the ecryptfs format " pr_err("encrypted_key: keylen for the ecryptfs format must be equal to %d bytes\n",
"must be equal to %d bytes\n",
ECRYPTFS_MAX_KEY_BYTES); ECRYPTFS_MAX_KEY_BYTES);
return ERR_PTR(-EINVAL); return ERR_PTR(-EINVAL);
} }
decrypted_datalen = ECRYPTFS_MAX_KEY_BYTES; decrypted_datalen = ECRYPTFS_MAX_KEY_BYTES;
payload_datalen = sizeof(struct ecryptfs_auth_tok); payload_datalen = sizeof(struct ecryptfs_auth_tok);
} else if (!strcmp(format, key_format_enc32)) {
if (decrypted_datalen != KEY_ENC32_PAYLOAD_LEN) {
pr_err("encrypted_key: enc32 key payload incorrect length: %d\n",
decrypted_datalen);
return ERR_PTR(-EINVAL);
}
}
} }
encrypted_datalen = roundup(decrypted_datalen, blksize); encrypted_datalen = roundup(decrypted_datalen, blksize);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment