📄 cbc.c
字号:
/* * Copyright (C) 1998,1999,2000,2001 Nikos Mavroyanopoulos * * This library is free software; you can redistribute it and/or modify it * under the terms of the GNU Library General Public License as published * by the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Library General Public License for more details. * * You should have received a copy of the GNU Library General Public * License along with this library; if not, write to the * Free Software Foundation, Inc., 59 Temple Place - Suite 330, * Boston, MA 02111-1307, USA. */#include <gpac/internal/crypt_dev.h>#ifndef GPAC_CRYPT_ISMA_ONLYtypedef struct cbc_buf { u32 *previous_ciphertext; u32 *previous_cipher; int blocksize;} CBC_BUFFER;/* CBC MODE */static GF_Err _init_mcrypt( CBC_BUFFER* buf,void *key, int lenofkey, void *IV, int size){/* For cbc */ buf->previous_ciphertext = buf->previous_cipher = NULL; buf->blocksize = size; buf->previous_ciphertext = malloc( size); buf->previous_cipher = malloc( size); if (buf->previous_ciphertext==NULL || buf->previous_cipher==NULL) goto freeall; if (IV!=NULL) { memcpy(buf->previous_ciphertext, IV, size); } else { memset(buf->previous_ciphertext, 0, size); } return GF_OK; freeall: if (buf->previous_ciphertext) free(buf->previous_ciphertext); if (buf->previous_cipher) free(buf->previous_cipher); return GF_OUT_OF_MEM;}static GF_Err _mcrypt_set_state( CBC_BUFFER* buf, void *IV, int size){/* For cbc */ memcpy(buf->previous_ciphertext, IV, size); memcpy(buf->previous_cipher, IV, size); return GF_OK;}static GF_Err _mcrypt_get_state( CBC_BUFFER* buf, void *IV, int *size){ if (*size < buf->blocksize) { *size = buf->blocksize; return GF_BAD_PARAM; } *size = buf->blocksize; memcpy( IV, buf->previous_ciphertext, buf->blocksize); return GF_OK;}static void _end_mcrypt( CBC_BUFFER* buf) { free(buf->previous_ciphertext); free(buf->previous_cipher);}static GF_Err _mcrypt( CBC_BUFFER* buf, void *plaintext, int len, int blocksize, void* akey, void (*func)(void*,void*), void (*func2)(void*,void*)){ u32 *fplain = plaintext; u32 *plain; int dblock, dlen, i, j; void (*_mcrypt_block_encrypt) (void *, void *); _mcrypt_block_encrypt = func; dblock = blocksize / sizeof(u32); dlen = len / blocksize; for (j = 0; j < dlen ; j++) { plain = &fplain[j * dblock]; for (i = 0; i < dblock; i++) { plain[i] ^= buf->previous_ciphertext[i]; } _mcrypt_block_encrypt(akey, plain); /* Copy the ciphertext to prev_ciphertext */ memcpy(buf->previous_ciphertext, plain, blocksize); } if (j==0 && len!=0) return GF_BAD_PARAM; return GF_OK;}static GF_Err _mdecrypt( CBC_BUFFER* buf, void *ciphertext, int len, int blocksize,void* akey, void (*func)(void*,void*), void (*func2)(void*,void*)){ u32 *cipher; u32 *fcipher = ciphertext; int i, j, dlen, dblock; void (*_mcrypt_block_decrypt) (void *, void *); _mcrypt_block_decrypt = func2; dblock = blocksize / sizeof(u32); dlen = len / blocksize; for (j = 0; j < dlen; j++) { cipher = &fcipher[j * dblock]; memcpy(buf->previous_cipher, cipher, blocksize); _mcrypt_block_decrypt(akey, cipher); for (i = 0; i < dblock; i++) { cipher[i] ^= buf->previous_ciphertext[i]; } /* Copy the ciphertext to prev_cipher */ memcpy(buf->previous_ciphertext, buf->previous_cipher, blocksize); } if (j==0 && len!=0) return GF_BAD_PARAM; return GF_OK;}void gf_crypt_register_cbc(GF_Crypt *td){ td->mode_name = "CBC"; td->_init_mcrypt = _init_mcrypt; td->_end_mcrypt = _end_mcrypt; td->_mcrypt = _mcrypt; td->_mdecrypt = _mdecrypt; td->_mcrypt_get_state = _mcrypt_get_state; td->_mcrypt_set_state = _mcrypt_set_state; td->has_IV = 1; td->is_block_mode = 1; td->is_block_algo_mode = 1; td->mode_size = sizeof(CBC_BUFFER); td->mode_version = 20010801;}#endif
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -