Commit 0f2d4fee authored by Harald Freudenberger's avatar Harald Freudenberger Committed by Vasily Gorbik

s390/zcrypt: simplify prep of CCA key token

The preparation of the key data struct for a CCA RSA ME
operation had some improvement to skip leading zeros
in the key's exponent. However, all supported CCA cards
nowadays support leading zeros in key tokens.

So for simplifying the CCA key preparing code, this
patch simply removes this optimization code.
Signed-off-by: default avatarHarald Freudenberger <freude@linux.ibm.com>
Reviewed-by: default avatarJuergen Christ <jchrist@linux.ibm.com>
Reviewed-by: default avatarHolger Dengler <dengler@linux.ibm.com>
Signed-off-by: default avatarVasily Gorbik <gor@linux.ibm.com>
parent bd922f33
...@@ -89,10 +89,7 @@ struct cca_pvt_ext_crt_sec { ...@@ -89,10 +89,7 @@ struct cca_pvt_ext_crt_sec {
#define CCA_PVT_EXT_CRT_SEC_FMT_CL 0x40 #define CCA_PVT_EXT_CRT_SEC_FMT_CL 0x40
/** /**
* Set up private key fields of a type6 MEX message. The _pad variant * Set up private key fields of a type6 MEX message.
* strips leading zeroes from the b_key.
* Note that all numerics in the key token are big-endian,
* while the entries in the key block header are little-endian.
* *
* @mex: pointer to user input data * @mex: pointer to user input data
* @p: pointer to memory area for the key * @p: pointer to memory area for the key
...@@ -111,10 +108,9 @@ static inline int zcrypt_type6_mex_key_en(struct ica_rsa_modexpo *mex, void *p) ...@@ -111,10 +108,9 @@ static inline int zcrypt_type6_mex_key_en(struct ica_rsa_modexpo *mex, void *p)
struct t6_keyblock_hdr t6_hdr; struct t6_keyblock_hdr t6_hdr;
struct cca_token_hdr pubhdr; struct cca_token_hdr pubhdr;
struct cca_public_sec pubsec; struct cca_public_sec pubsec;
char exponent[0]; char exponent[];
} __packed *key = p; } __packed *key = p;
unsigned char *temp; unsigned char *ptr;
int i;
/* /*
* The inputdatalength was a selection criteria in the dispatching * The inputdatalength was a selection criteria in the dispatching
...@@ -131,37 +127,29 @@ static inline int zcrypt_type6_mex_key_en(struct ica_rsa_modexpo *mex, void *p) ...@@ -131,37 +127,29 @@ static inline int zcrypt_type6_mex_key_en(struct ica_rsa_modexpo *mex, void *p)
key->pubsec = static_pub_sec; key->pubsec = static_pub_sec;
/* key parameter block */ /* key parameter block */
temp = key->exponent; ptr = key->exponent;
if (copy_from_user(temp, mex->b_key, mex->inputdatalength)) if (copy_from_user(ptr, mex->b_key, mex->inputdatalength))
return -EFAULT; return -EFAULT;
/* Strip leading zeroes from b_key. */ ptr += mex->inputdatalength;
for (i = 0; i < mex->inputdatalength; i++)
if (temp[i])
break;
if (i >= mex->inputdatalength)
return -EINVAL;
memmove(temp, temp + i, mex->inputdatalength - i);
temp += mex->inputdatalength - i;
/* modulus */ /* modulus */
if (copy_from_user(temp, mex->n_modulus, mex->inputdatalength)) if (copy_from_user(ptr, mex->n_modulus, mex->inputdatalength))
return -EFAULT; return -EFAULT;
key->pubsec.modulus_bit_len = 8 * mex->inputdatalength; key->pubsec.modulus_bit_len = 8 * mex->inputdatalength;
key->pubsec.modulus_byte_len = mex->inputdatalength; key->pubsec.modulus_byte_len = mex->inputdatalength;
key->pubsec.exponent_len = mex->inputdatalength - i; key->pubsec.exponent_len = mex->inputdatalength;
key->pubsec.section_length = sizeof(key->pubsec) + key->pubsec.section_length = sizeof(key->pubsec) +
2 * mex->inputdatalength - i; 2 * mex->inputdatalength;
key->pubhdr.token_length = key->pubhdr.token_length =
key->pubsec.section_length + sizeof(key->pubhdr); key->pubsec.section_length + sizeof(key->pubhdr);
key->t6_hdr.ulen = key->pubhdr.token_length + 4; key->t6_hdr.ulen = key->pubhdr.token_length + 4;
key->t6_hdr.blen = key->pubhdr.token_length + 6; key->t6_hdr.blen = key->pubhdr.token_length + 6;
return sizeof(*key) + 2 * mex->inputdatalength - i;
return sizeof(*key) + 2 * mex->inputdatalength;
} }
/** /**
* Set up private key fields of a type6 CRT message. * Set up private key fields of a type6 CRT message.
* Note that all numerics in the key token are big-endian,
* while the entries in the key block header are little-endian.
* *
* @mex: pointer to user input data * @mex: pointer to user input data
* @p: pointer to memory area for the key * @p: pointer to memory area for the key
...@@ -242,6 +230,7 @@ static inline int zcrypt_type6_crt_key(struct ica_rsa_modexpo_crt *crt, void *p) ...@@ -242,6 +230,7 @@ static inline int zcrypt_type6_crt_key(struct ica_rsa_modexpo_crt *crt, void *p)
* used. * used.
*/ */
memcpy((char *)(pub + 1), pk_exponent, 3); memcpy((char *)(pub + 1), pk_exponent, 3);
return size; return size;
} }
......
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