mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/herbert/cryptodev-2.6.git
synced 2026-04-18 19:43:43 -04:00
s390/ap/zcrypt: debug feature improvements
This patch adds some debug feature improvements related to some failures happened in the past. With CEX8 the max request and response sizes have been extended but the user space applications did not rework their code and thus ran into receive buffer issues. This ffdc patch here helps with additional checks and debug feature messages in debugging and pointing to the root cause of some failures related to wrong buffer sizes. Signed-off-by: Harald Freudenberger <freude@linux.ibm.com> Reviewed-by: Jürgen Christ <jchrist@linux.ibm.com> Signed-off-by: Vasily Gorbik <gor@linux.ibm.com>
This commit is contained in:
committed by
Vasily Gorbik
parent
966ffbd861
commit
d64e5e9120
@@ -714,6 +714,8 @@ static long zcrypt_rsa_modexpo(struct ap_perms *perms,
|
||||
spin_unlock(&zcrypt_list_lock);
|
||||
|
||||
if (!pref_zq) {
|
||||
ZCRYPT_DBF_DBG("%s no matching queue found => ENODEV\n",
|
||||
__func__);
|
||||
rc = -ENODEV;
|
||||
goto out;
|
||||
}
|
||||
@@ -822,6 +824,8 @@ static long zcrypt_rsa_crt(struct ap_perms *perms,
|
||||
spin_unlock(&zcrypt_list_lock);
|
||||
|
||||
if (!pref_zq) {
|
||||
ZCRYPT_DBF_DBG("%s no matching queue found => ENODEV\n",
|
||||
__func__);
|
||||
rc = -ENODEV;
|
||||
goto out;
|
||||
}
|
||||
@@ -940,6 +944,8 @@ static long _zcrypt_send_cprb(bool userspace, struct ap_perms *perms,
|
||||
spin_unlock(&zcrypt_list_lock);
|
||||
|
||||
if (!pref_zq) {
|
||||
ZCRYPT_DBF_DBG("%s no match for address %02x.%04x => ENODEV\n",
|
||||
__func__, xcRB->user_defined, *domain);
|
||||
rc = -ENODEV;
|
||||
goto out;
|
||||
}
|
||||
@@ -1112,6 +1118,17 @@ static long _zcrypt_send_ep11_cprb(bool userspace, struct ap_perms *perms,
|
||||
spin_unlock(&zcrypt_list_lock);
|
||||
|
||||
if (!pref_zq) {
|
||||
if (targets && target_num == 1) {
|
||||
ZCRYPT_DBF_DBG("%s no match for address %02x.%04x => ENODEV\n",
|
||||
__func__, (int) targets->ap_id,
|
||||
(int) targets->dom_id);
|
||||
} else if (targets) {
|
||||
ZCRYPT_DBF_DBG("%s no match for %d target addrs => ENODEV\n",
|
||||
__func__, (int) target_num);
|
||||
} else {
|
||||
ZCRYPT_DBF_DBG("%s no match for address ff.ffff => ENODEV\n",
|
||||
__func__);
|
||||
}
|
||||
rc = -ENODEV;
|
||||
goto out_free;
|
||||
}
|
||||
@@ -1188,6 +1205,8 @@ static long zcrypt_rng(char *buffer)
|
||||
spin_unlock(&zcrypt_list_lock);
|
||||
|
||||
if (!pref_zq) {
|
||||
ZCRYPT_DBF_DBG("%s no matching queue found => ENODEV\n",
|
||||
__func__);
|
||||
rc = -ENODEV;
|
||||
goto out;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user