aes.h

Go to the documentation of this file.
00001 #if 0
00002 /*
00003  * copyright (c) 2007 Michael Niedermayer <michaelni@gmx.at>
00004  *
00005  * This file is part of FFmpeg.
00006  *
00007  * FFmpeg is free software; you can redistribute it and/or
00008  * modify it under the terms of the GNU Lesser General Public
00009  * License as published by the Free Software Foundation; either
00010  * version 2.1 of the License, or (at your option) any later version.
00011  *
00012  * FFmpeg is distributed in the hope that it will be useful,
00013  * but WITHOUT ANY WARRANTY; without even the implied warranty of
00014  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
00015  * Lesser General Public License for more details.
00016  *
00017  * You should have received a copy of the GNU Lesser General Public
00018  * License along with FFmpeg; if not, write to the Free Software
00019  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
00020  */
00021 
00022 #ifndef FFMPEG_AES_H
00023 #define FFMPEG_AES_H
00024 
00025 #include <stdint.h>
00026 
00027 extern const int av_aes_size;
00028 
00029 struct AVAES;
00030 
00031 /**
00032  * Initializes an AVAES context.
00033  * @param key_bits 128, 192 or 256
00034  * @param decrypt 0 for encryption, 1 for decryption
00035  */
00036 int av_aes_init(struct AVAES *a, const uint8_t *key, int key_bits, int decrypt);
00037 
00038 /**
00039  * Encrypts / decrypts.
00040  * @param count number of 16 byte blocks
00041  * @param dst destination array, can be equal to src
00042  * @param src source array, can be equal to dst
00043  * @param iv initialization vector for CBC mode, if NULL then ECB will be used
00044  * @param decrypt 0 for encryption, 1 for decryption
00045  */
00046 void av_aes_crypt(struct AVAES *a, uint8_t *dst, uint8_t *src, int count, uint8_t *iv, int decrypt);
00047 
00048 #endif /* FFMPEG_AES_H */
00049 #endif

Generated on Sat Oct 11 19:44:27 2008 for libextractor by  doxygen 1.5.1