mirror of
https://github.com/shadps4-emu/ext-ffmpeg-core.git
synced 2024-11-26 20:30:21 +00:00
e30b7d7fe2
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>
78 lines
1.7 KiB
C
Executable File
78 lines
1.7 KiB
C
Executable File
/*
|
|
* Copyright (c) 2011 Mans Rullgard
|
|
*
|
|
* 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_INTFLOAT_H
|
|
#define AVUTIL_INTFLOAT_H
|
|
|
|
#include <stdint.h>
|
|
#include "attributes.h"
|
|
|
|
union av_intfloat32 {
|
|
uint32_t i;
|
|
float f;
|
|
};
|
|
|
|
union av_intfloat64 {
|
|
uint64_t i;
|
|
double f;
|
|
};
|
|
|
|
/**
|
|
* Reinterpret a 32-bit integer as a float.
|
|
*/
|
|
static av_always_inline float av_int2float(uint32_t i)
|
|
{
|
|
union av_intfloat32 v;
|
|
v.i = i;
|
|
return v.f;
|
|
}
|
|
|
|
/**
|
|
* Reinterpret a float as a 32-bit integer.
|
|
*/
|
|
static av_always_inline uint32_t av_float2int(float f)
|
|
{
|
|
union av_intfloat32 v;
|
|
v.f = f;
|
|
return v.i;
|
|
}
|
|
|
|
/**
|
|
* Reinterpret a 64-bit integer as a double.
|
|
*/
|
|
static av_always_inline double av_int2double(uint64_t i)
|
|
{
|
|
union av_intfloat64 v;
|
|
v.i = i;
|
|
return v.f;
|
|
}
|
|
|
|
/**
|
|
* Reinterpret a double as a 64-bit integer.
|
|
*/
|
|
static av_always_inline uint64_t av_double2int(double f)
|
|
{
|
|
union av_intfloat64 v;
|
|
v.f = f;
|
|
return v.i;
|
|
}
|
|
|
|
#endif /* AVUTIL_INTFLOAT_H */
|