mbx_sm2_ecpublic_key

Computes a public key.

Syntax

mbx_status mbx_sm2_ecpublic_key_mb8(int64u* pa_pubx[8], int64u* pa_puby[8], int64u* pa_pubz[8], const int64u* const pa_skey[8], int8u* pBuffer);

mbx_status mbx_sm2_ecpublic_key_ssl_mb8(BIGNUM* pa_pubx[8], BIGNUM* pa_puby[8], BIGNUM* pa_pubz[8], const BIGNUM* const pa_skey[8], int8u* pBuffer);

Include Files

crypto_mb/ec_sm2.h

Parameters

pa_pubx

Array of pointers to the vectors of computed public key x-coordinates.

pa_puby

Array of pointers to the vectors of computed public key y-coordinates.

pa_pubz

Array of pointers to the vectors of computed public key z-coordinates.

pa_skey

Array of pointers to the vectors of private keys.

pBuffer

Pointer to the work buffer.

Description

The function computes public keys using private keys specified by the pa_skey parameter. If z-coordinate of computed public is required (pa_pubz is not NULL), then computed public keys are stored using projective coordinates. If pa_pubz is NULL, then computed public keys are stored using affine coordinates.

The work buffer specified by the pBuffer parameteris not currently used and can be NULL.

Note

The function above has own “twin” with “_ssl” in the name. The only difference in comparison with mbx_sm2_ecpublic_key() is representation of the parameters. mbx_sm2_ecpublic_key_ssl() functions use BIGNUM datatype instead of vector.

Return Values

The mbx_sm2_ecpublic_key() function returns the status that indicates whether the operation completed successfully or not. The status value of 0 indicates that all operations completed successfully. The error condition can be analyzed by the MBX_GET_STS() call.