mbx_sm2_ecdsa_verify¶
Verifies the SM2 ECDSA signature.
Syntax¶
mbx_status mbx_sm2_ecdsa_verify_mb8(const int8u* constpa_sign_r[8], const int8u* constpa_sign_s[8], const int8u* constpa_user_id[8], const int user_id_len[8], const int8u* constpa_msg[8], const int msg_len[8], const int64u* constpa_pubx[8], const int64u* constpa_puby[8], const int64u* const pa_pubz[8], int8u*pBuffer);
mbx_status mbx_sm2_ecdsa_verify_ssl_mb8(const ECDSA_SIG* constpa_sig[8], const int8u* constpa_user_id[8], const int user_id_len[8], const int8u* constpa_msg[8], const int msg_len[8], const BIGNUM* constpa_pubx[8], const BIGNUM* constpa_puby[8], const BIGNUM* const pa_pubz[8], int8u*pBuffer);
Include Files¶
crypto_mb/ec_sm2.h
Parameters¶
pa_sign_r |
Array of pointers to the r-components of the signature. |
pa_sign_s |
Array of pointers to the s-components of the signature. |
pa_user_id |
Array of pointers to the users ID. |
user_id_len |
Array of users ID length. |
pa_msg |
Array of pointers to the messages are being signed. |
msg_len |
Array of messages length. |
pa_pubx |
Array of pointers to the vectors of signer’s public key x-coordinates. |
pa_puby |
Array of pointers to the vectors of signer’s public key y-coordinates. |
pa_pubz |
Array of pointers to the vectors of signer’s public key z-coordinates.. |
pBuffer |
Pointer to the work buffer. |
Description¶
The function computes user ids, messages, and signer public keys
representative using SM2 hash algorithm. User ids are specified by
pa_user_id parameter and its length are specified by user_id_len
parameter. Messages are specified by pa_msg parameter and its length are
specified by msg_len parameter. Public keys are specified by pa_pubx,
pa_puby, and pa_pubz parameters. If the pa_pubz parameter is not
NULL
, then it is assumed that signer’s public keys are represented
in projective coordinates. If the pa_pubz parameter is NULL
, then
signer’s public keys are considered in affine coordinates.
Then function verifies digital signatures of the computed input data representative. Signatures are represented as big endian byte strings and r- and s- components are stored separately in pa_sign_r and pa_sign_s parameters.
The work buffer specified by pBuffer parameter is not currently used and
can be NULL
.
Note
The function above has own “twin” with “_ssl” in the name. The differences in comparison with mbx_sm2_ecdsa_verify() are the following:
Representation of the key stuff. mbx_sm2_ecdsa_verify_ssl() functions use BIGNUM datatype instead of vector.
Representation of the signatures. mbx_sm2_ecdsa_verify_ssl() functions use ECDSA_SIG structure instead of vectors of
r-
ands-
components of the signature.
Return Values¶
The mbx_sm2_ecdsa_verify() functions return the status that indicates whether the operation completed successfully or not. The status value of 0 indicates that all digital signatures were successfully verified. The error condition can be analyzed by the MBX_GET_STS() call.