Commit 9bbd1bfb authored by Finn Callies's avatar Finn Callies Committed by Vasily Gorbik

s390/crypto: Add Support for Query Authentication Information

Introduce functions __cpacf_qai() and wrapper cpacf_qai() to the
respective existing functions __cpacf_query() and cpacf_query() are
introduced to support the Query Authentication Information feature of
MSA 13.
Suggested-by: default avatarHarald Freudenberger <freude@linux.ibm.com>
Reviewed-by: default avatarHarald Freudenberger <freude@linux.ibm.com>
Acked-by: default avatarHeiko Carstens <hca@linux.ibm.com>
Signed-off-by: default avatarFinn Callies <fcallies@linux.ibm.com>
Signed-off-by: default avatarVasily Gorbik <gor@linux.ibm.com>
parent 27aad7f7
...@@ -205,8 +205,10 @@ ...@@ -205,8 +205,10 @@
#define CPACF_KDSA_ENC_EDDSA_SIGN_ED448 0x34 #define CPACF_KDSA_ENC_EDDSA_SIGN_ED448 0x34
#define CPACF_FC_QUERY 0x00 #define CPACF_FC_QUERY 0x00
#define CPACF_FC_QUERY_AUTH_INFO 0x7F
typedef struct { unsigned char bytes[16]; } cpacf_mask_t; typedef struct { unsigned char bytes[16]; } cpacf_mask_t;
typedef struct { unsigned char bytes[256]; } cpacf_qai_t;
/* /*
* Prototype for a not existing function to produce a link * Prototype for a not existing function to produce a link
...@@ -349,7 +351,8 @@ static inline int cpacf_test_func(cpacf_mask_t *mask, unsigned int func) ...@@ -349,7 +351,8 @@ static inline int cpacf_test_func(cpacf_mask_t *mask, unsigned int func)
return (mask->bytes[func >> 3] & (0x80 >> (func & 7))) != 0; return (mask->bytes[func >> 3] & (0x80 >> (func & 7))) != 0;
} }
static __always_inline int cpacf_query_func(unsigned int opcode, unsigned int func) static __always_inline int cpacf_query_func(unsigned int opcode,
unsigned int func)
{ {
cpacf_mask_t mask; cpacf_mask_t mask;
...@@ -358,6 +361,32 @@ static __always_inline int cpacf_query_func(unsigned int opcode, unsigned int fu ...@@ -358,6 +361,32 @@ static __always_inline int cpacf_query_func(unsigned int opcode, unsigned int fu
return 0; return 0;
} }
static __always_inline void __cpacf_qai(unsigned int opcode, cpacf_qai_t *qai)
{
__cpacf_query_insn(opcode, qai, CPACF_FC_QUERY_AUTH_INFO);
}
/**
* cpacf_qai() - Get the query authentication information for a CPACF opcode
* @opcode: the opcode of the crypto instruction
* @mask: ptr to struct cpacf_qai_t
*
* Executes the query authentication information function for the given crypto
* instruction @opcode and checks if @func is available
*
* On success 1 is returned and the mask is filled with the query authentication
* information for this CPACF opcode, otherwise 0 is returned.
*/
static __always_inline int cpacf_qai(unsigned int opcode, cpacf_qai_t *qai)
{
if (cpacf_query_func(opcode, CPACF_FC_QUERY_AUTH_INFO)) {
__cpacf_qai(opcode, qai);
return 1;
}
memset(qai, 0, sizeof(*qai));
return 0;
}
/** /**
* cpacf_km() - executes the KM (CIPHER MESSAGE) instruction * cpacf_km() - executes the KM (CIPHER MESSAGE) instruction
* @func: the function code passed to KM; see CPACF_KM_xxx defines * @func: the function code passed to KM; see CPACF_KM_xxx defines
......
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