2992N/APatch developed in-house. Solaris-specific; not suitable for upstream.
4006N/A if (ctx->cipher->flags & EVP_CIPH_FLAG_CUSTOM_CIPHER) {
4006N/A ret = M_do_cipher(ctx, out, NULL, 0);
4006N/A b = ctx->cipher->block_size;
4006N/A OPENSSL_assert(b <= sizeof ctx->buf);
4006N/A if (ctx->flags & EVP_CIPH_NO_PADDING) {
4006N/A EVPerr(EVP_F_EVP_ENCRYPTFINAL_EX,
4006N/A EVP_R_DATA_NOT_MULTIPLE_OF_BLOCK_LENGTH);
4006N/A+ if (ctx->cipher->cleanup) {
4006N/A+ ctx->cipher->cleanup(ctx);
4006N/A int EVP_DecryptFinal_ex(EVP_CIPHER_CTX *ctx, unsigned char *out, int *outl)
4006N/A if (ctx->cipher->flags & EVP_CIPH_FLAG_CUSTOM_CIPHER) {
4006N/A i = M_do_cipher(ctx, out, NULL, 0);
4006N/A b = ctx->cipher->block_size;
4006N/A EVPerr(EVP_F_EVP_DECRYPTFINAL_EX,
4006N/A EVP_R_DATA_NOT_MULTIPLE_OF_BLOCK_LENGTH);
4006N/A if (ctx->buf_len || !ctx->final_used) {
4006N/A if (ctx->buf_len || !ctx->final_used) {
4006N/A EVPerr(EVP_F_EVP_DECRYPTFINAL_EX, EVP_R_WRONG_FINAL_BLOCK_LENGTH);
4006N/A OPENSSL_assert(b <= sizeof ctx->final);
4006N/A if (n == 0 || n > (int)b) {
4006N/A EVPerr(EVP_F_EVP_DECRYPTFINAL_EX, EVP_R_BAD_DECRYPT);
4006N/A if (ctx->final[--b] != n) {
4006N/A if (ctx->final[--b] != n) {
4006N/A EVPerr(EVP_F_EVP_DECRYPTFINAL_EX, EVP_R_BAD_DECRYPT);
4006N/A n = ctx->cipher->block_size - n;
4006N/A+ if (ctx->cipher->cleanup) {
4006N/A+ ctx->cipher->cleanup(ctx);
2992N/A void EVP_CIPHER_CTX_free(EVP_CIPHER_CTX *ctx)