diff options
Diffstat (limited to 'drivers/s390/crypto/pkey_api.c')
| -rw-r--r-- | drivers/s390/crypto/pkey_api.c | 15 | 
1 files changed, 15 insertions, 0 deletions
| diff --git a/drivers/s390/crypto/pkey_api.c b/drivers/s390/crypto/pkey_api.c index dd84995049b9..cf23ce1b1146 100644 --- a/drivers/s390/crypto/pkey_api.c +++ b/drivers/s390/crypto/pkey_api.c @@ -150,6 +150,8 @@ static int pkey_skey2pkey(const u8 *key, struct pkey_protkey *pkey)  	u16 cardnr, domain;  	struct keytoken_header *hdr = (struct keytoken_header *)key; +	zcrypt_wait_api_operational(); +  	/*  	 * The cca_xxx2protkey call may fail when a card has been  	 * addressed where the master key was changed after last fetch @@ -197,6 +199,8 @@ static int pkey_clr2ep11key(const u8 *clrkey, size_t clrkeylen,  	u16 card, dom;  	u32 nr_apqns, *apqns = NULL; +	zcrypt_wait_api_operational(); +  	/* build a list of apqns suitable for ep11 keys with cpacf support */  	rc = ep11_findcard2(&apqns, &nr_apqns, 0xFFFF, 0xFFFF,  			    ZCRYPT_CEX7, EP11_API_V, NULL); @@ -230,6 +234,8 @@ static int pkey_ep11key2pkey(const u8 *key, struct pkey_protkey *pkey)  	u32 nr_apqns, *apqns = NULL;  	struct ep11keyblob *kb = (struct ep11keyblob *) key; +	zcrypt_wait_api_operational(); +  	/* build a list of apqns suitable for this key */  	rc = ep11_findcard2(&apqns, &nr_apqns, 0xFFFF, 0xFFFF,  			    ZCRYPT_CEX7, EP11_API_V, kb->wkvp); @@ -436,6 +442,7 @@ static int pkey_nonccatok2pkey(const u8 *key, u32 keylen,  		if (rc == 0)  			break;  		/* PCKMO failed, so try the CCA secure key way */ +		zcrypt_wait_api_operational();  		rc = cca_clr2seckey(0xFFFF, 0xFFFF, t->keytype,  				    ckey.clrkey, tmpbuf);  		if (rc == 0) @@ -625,6 +632,8 @@ static int pkey_clr2seckey2(const struct pkey_apqn *apqns, size_t nr_apqns,  		return -EINVAL;  	} +	zcrypt_wait_api_operational(); +  	/* simple try all apqns from the list */  	for (i = 0, rc = -ENODEV; i < nr_apqns; i++) {  		card = apqns[i].card; @@ -801,6 +810,8 @@ static int pkey_keyblob2pkey2(const struct pkey_apqn *apqns, size_t nr_apqns,  		return -EINVAL;  	} +	zcrypt_wait_api_operational(); +  	/* simple try all apqns from the list */  	for (i = 0, rc = -ENODEV; i < nr_apqns; i++) {  		card = apqns[i].card; @@ -838,6 +849,8 @@ static int pkey_apqns4key(const u8 *key, size_t keylen, u32 flags,  	if (keylen < sizeof(struct keytoken_header) || flags == 0)  		return -EINVAL; +	zcrypt_wait_api_operational(); +  	if (hdr->type == TOKTYPE_NON_CCA  	    && (hdr->version == TOKVER_EP11_AES_WITH_HEADER  		|| hdr->version == TOKVER_EP11_ECC_WITH_HEADER) @@ -941,6 +954,8 @@ static int pkey_apqns4keytype(enum pkey_key_type ktype,  	int rc;  	u32 _nr_apqns, *_apqns = NULL; +	zcrypt_wait_api_operational(); +  	if (ktype == PKEY_TYPE_CCA_DATA || ktype == PKEY_TYPE_CCA_CIPHER) {  		u64 cur_mkvp = 0, old_mkvp = 0;  		int minhwtype = ZCRYPT_CEX3C; | 
