mirror of
https://github.com/RPCS3/ffmpeg-core.git
synced 2025-04-10 02:21:20 +00:00

Contains the following squashed commits from the old branch: Initial commit Fix link order Add option to link against system ffmpeg, disable precompiled binaries for mingw Update macOS files for XCode 12 Update ffmpeg to 5.1.2 Add mjpeg encoder (#7) Add mjpeg2jpeg bitstream filter Add macOS-arm64 builds Add macOS arm64 to CMakeLists Add arm64-osx-release to build.yml dummy commit to trigger workflow Properly split macOS builds in build.yml Try to fix actions uploads Rename the builds Fix build.yml Fix typo in build.yml Amend CMakeLists using the correct check ci: change upload path to directly upload libraries ci: build and use universal binary on macOS ci: set macOS deployment target to macOS 11.0 ci: build FFMPEG prebuilt for each OS/architecture Add linux arm64 prebuilt. Add both x86_64 and arm64 prebuilts for macOS. ci: create release for pre-built FFMPEG cmake: download and use only necessary prebuilt FFMPEG Add arm64 windows prebuilt Co-authored-by: Seungyun Lee <khora.lee.0@gmail.com> Co-authored-by: shinra-electric <50119606+shinra-electric@users.noreply.github.com> Co-authored-by: SaturnSky <ikadro@gmail.com>
95 lines
2.8 KiB
C
Executable File
95 lines
2.8 KiB
C
Executable File
/*
|
|
* A 32-bit implementation of the XTEA algorithm
|
|
* Copyright (c) 2012 Samuel Pitoiset
|
|
*
|
|
* This file is part of FFmpeg.
|
|
*
|
|
* FFmpeg is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
* License as published by the Free Software Foundation; either
|
|
* version 2.1 of the License, or (at your option) any later version.
|
|
*
|
|
* FFmpeg 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
|
|
* Lesser General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
* License along with FFmpeg; if not, write to the Free Software
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
|
*/
|
|
|
|
#ifndef AVUTIL_XTEA_H
|
|
#define AVUTIL_XTEA_H
|
|
|
|
#include <stdint.h>
|
|
|
|
/**
|
|
* @file
|
|
* @brief Public header for libavutil XTEA algorithm
|
|
* @defgroup lavu_xtea XTEA
|
|
* @ingroup lavu_crypto
|
|
* @{
|
|
*/
|
|
|
|
typedef struct AVXTEA {
|
|
uint32_t key[16];
|
|
} AVXTEA;
|
|
|
|
/**
|
|
* Allocate an AVXTEA context.
|
|
*/
|
|
AVXTEA *av_xtea_alloc(void);
|
|
|
|
/**
|
|
* Initialize an AVXTEA context.
|
|
*
|
|
* @param ctx an AVXTEA context
|
|
* @param key a key of 16 bytes used for encryption/decryption,
|
|
* interpreted as big endian 32 bit numbers
|
|
*/
|
|
void av_xtea_init(struct AVXTEA *ctx, const uint8_t key[16]);
|
|
|
|
/**
|
|
* Initialize an AVXTEA context.
|
|
*
|
|
* @param ctx an AVXTEA context
|
|
* @param key a key of 16 bytes used for encryption/decryption,
|
|
* interpreted as little endian 32 bit numbers
|
|
*/
|
|
void av_xtea_le_init(struct AVXTEA *ctx, const uint8_t key[16]);
|
|
|
|
/**
|
|
* Encrypt or decrypt a buffer using a previously initialized context,
|
|
* in big endian format.
|
|
*
|
|
* @param ctx an AVXTEA context
|
|
* @param dst destination array, can be equal to src
|
|
* @param src source array, can be equal to dst
|
|
* @param count number of 8 byte blocks
|
|
* @param iv initialization vector for CBC mode, if NULL then ECB will be used
|
|
* @param decrypt 0 for encryption, 1 for decryption
|
|
*/
|
|
void av_xtea_crypt(struct AVXTEA *ctx, uint8_t *dst, const uint8_t *src,
|
|
int count, uint8_t *iv, int decrypt);
|
|
|
|
/**
|
|
* Encrypt or decrypt a buffer using a previously initialized context,
|
|
* in little endian format.
|
|
*
|
|
* @param ctx an AVXTEA context
|
|
* @param dst destination array, can be equal to src
|
|
* @param src source array, can be equal to dst
|
|
* @param count number of 8 byte blocks
|
|
* @param iv initialization vector for CBC mode, if NULL then ECB will be used
|
|
* @param decrypt 0 for encryption, 1 for decryption
|
|
*/
|
|
void av_xtea_le_crypt(struct AVXTEA *ctx, uint8_t *dst, const uint8_t *src,
|
|
int count, uint8_t *iv, int decrypt);
|
|
|
|
/**
|
|
* @}
|
|
*/
|
|
|
|
#endif /* AVUTIL_XTEA_H */
|