Commit 078f8eca authored by Felix Beck's avatar Felix Beck Committed by Martin Schwidefsky

[S390] Handling of 4096 bit RSA keys in CRT format.

Also process 4096 bit RSA keys in CRT format. Handle them like the
smaller keys and take care of the zero padding.
Signed-off-by: default avatarFelix Beck <felix.beck@de.ibm.com>
Signed-off-by: default avatarMartin Schwidefsky <schwidefsky@de.ibm.com>
parent c2567f8f
...@@ -396,8 +396,15 @@ static long zcrypt_rsa_crt(struct ica_rsa_modexpo_crt *crt) ...@@ -396,8 +396,15 @@ static long zcrypt_rsa_crt(struct ica_rsa_modexpo_crt *crt)
if (copied == 0) { if (copied == 0) {
unsigned int len; unsigned int len;
spin_unlock_bh(&zcrypt_device_lock); spin_unlock_bh(&zcrypt_device_lock);
/* len is max 256 / 2 - 120 = 8 */ /* len is max 256 / 2 - 120 = 8
len = crt->inputdatalength / 2 - 120; * For bigger device just assume len of leading
* 0s is 8 as stated in the requirements for
* ica_rsa_modexpo_crt struct in zcrypt.h.
*/
if (crt->inputdatalength <= 256)
len = crt->inputdatalength / 2 - 120;
else
len = 8;
if (len > sizeof(z1)) if (len > sizeof(z1))
return -EFAULT; return -EFAULT;
z1 = z2 = z3 = 0; z1 = z2 = z3 = 0;
...@@ -405,6 +412,7 @@ static long zcrypt_rsa_crt(struct ica_rsa_modexpo_crt *crt) ...@@ -405,6 +412,7 @@ static long zcrypt_rsa_crt(struct ica_rsa_modexpo_crt *crt)
copy_from_user(&z2, crt->bp_key, len) || copy_from_user(&z2, crt->bp_key, len) ||
copy_from_user(&z3, crt->u_mult_inv, len)) copy_from_user(&z3, crt->u_mult_inv, len))
return -EFAULT; return -EFAULT;
z1 = z2 = z3 = 0;
copied = 1; copied = 1;
/* /*
* We have to restart device lookup - * We have to restart device lookup -
......
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