2017-10-31 13:19:14 +08:00
|
|
|
=pod
|
|
|
|
|
|
|
|
=head1 NAME
|
|
|
|
|
|
|
|
EVP_sm4_cbc,
|
|
|
|
EVP_sm4_ecb,
|
|
|
|
EVP_sm4_cfb,
|
2018-10-02 05:11:57 +08:00
|
|
|
EVP_sm4_cfb128,
|
2017-10-31 13:19:14 +08:00
|
|
|
EVP_sm4_ofb,
|
|
|
|
EVP_sm4_ctr
|
|
|
|
- EVP SM4 cipher
|
|
|
|
|
|
|
|
=head1 SYNOPSIS
|
|
|
|
|
|
|
|
#include <openssl/evp.h>
|
|
|
|
|
2018-08-24 20:38:04 +08:00
|
|
|
const EVP_CIPHER *EVP_sm4_cbc(void);
|
|
|
|
const EVP_CIPHER *EVP_sm4_ecb(void);
|
|
|
|
const EVP_CIPHER *EVP_sm4_cfb(void);
|
2018-10-02 05:11:57 +08:00
|
|
|
const EVP_CIPHER *EVP_sm4_cfb128(void);
|
2018-08-24 20:38:04 +08:00
|
|
|
const EVP_CIPHER *EVP_sm4_ofb(void);
|
|
|
|
const EVP_CIPHER *EVP_sm4_ctr(void);
|
2017-10-31 13:19:14 +08:00
|
|
|
|
|
|
|
=head1 DESCRIPTION
|
|
|
|
|
|
|
|
The SM4 blockcipher (GB/T 32907-2016) for EVP.
|
|
|
|
|
|
|
|
All modes below use a key length of 128 bits and acts on blocks of 128 bits.
|
|
|
|
|
|
|
|
=over 4
|
|
|
|
|
|
|
|
=item EVP_sm4_cbc(),
|
|
|
|
EVP_sm4_ecb(),
|
|
|
|
EVP_sm4_cfb(),
|
2018-10-02 05:11:57 +08:00
|
|
|
EVP_sm4_cfb128(),
|
2017-10-31 13:19:14 +08:00
|
|
|
EVP_sm4_ofb(),
|
|
|
|
EVP_sm4_ctr()
|
|
|
|
|
|
|
|
The SM4 blockcipher with a 128-bit key in CBC, ECB, CFB, OFB and CTR modes
|
|
|
|
respectively.
|
|
|
|
|
|
|
|
=back
|
|
|
|
|
2023-02-22 08:11:33 +08:00
|
|
|
=head1 NOTES
|
|
|
|
|
|
|
|
Developers should be aware of the negative performance implications of
|
|
|
|
calling these functions multiple times and should consider using
|
|
|
|
L<EVP_CIPHER_fetch(3)> instead.
|
|
|
|
See L<crypto(7)/Performance> for further information.
|
|
|
|
|
2017-10-31 13:19:14 +08:00
|
|
|
=head1 RETURN VALUES
|
|
|
|
|
|
|
|
These functions return a B<EVP_CIPHER> structure that contains the
|
|
|
|
implementation of the symmetric cipher. See L<EVP_CIPHER_meth_new(3)> for
|
|
|
|
details of the B<EVP_CIPHER> structure.
|
|
|
|
|
|
|
|
=head1 SEE ALSO
|
|
|
|
|
|
|
|
L<evp(7)>,
|
|
|
|
L<EVP_EncryptInit(3)>,
|
|
|
|
L<EVP_CIPHER_meth_new(3)>
|
|
|
|
|
|
|
|
=head1 COPYRIGHT
|
|
|
|
|
2018-08-24 20:38:04 +08:00
|
|
|
Copyright 2017-2018 The OpenSSL Project Authors. All Rights Reserved.
|
2017-10-31 13:19:14 +08:00
|
|
|
Copyright 2017 Ribose Inc. All Rights Reserved.
|
|
|
|
|
2018-12-06 21:04:44 +08:00
|
|
|
Licensed under the Apache License 2.0 (the "License"). You may not use
|
2017-10-31 13:19:14 +08:00
|
|
|
this file except in compliance with the License. You can obtain a copy
|
|
|
|
in the file LICENSE in the source distribution or at
|
|
|
|
L<https://www.openssl.org/source/license.html>.
|
|
|
|
|
|
|
|
=cut
|
|
|
|
|