mirror of
https://github.com/RPCS3/ffmpeg-core.git
synced 2025-04-13 20:10: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>
116 lines
3.8 KiB
C
Executable File
116 lines
3.8 KiB
C
Executable File
/*
|
|
* 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_THREADMESSAGE_H
|
|
#define AVUTIL_THREADMESSAGE_H
|
|
|
|
typedef struct AVThreadMessageQueue AVThreadMessageQueue;
|
|
|
|
typedef enum AVThreadMessageFlags {
|
|
|
|
/**
|
|
* Perform non-blocking operation.
|
|
* If this flag is set, send and recv operations are non-blocking and
|
|
* return AVERROR(EAGAIN) immediately if they can not proceed.
|
|
*/
|
|
AV_THREAD_MESSAGE_NONBLOCK = 1,
|
|
|
|
} AVThreadMessageFlags;
|
|
|
|
/**
|
|
* Allocate a new message queue.
|
|
*
|
|
* @param mq pointer to the message queue
|
|
* @param nelem maximum number of elements in the queue
|
|
* @param elsize size of each element in the queue
|
|
* @return >=0 for success; <0 for error, in particular AVERROR(ENOSYS) if
|
|
* lavu was built without thread support
|
|
*/
|
|
int av_thread_message_queue_alloc(AVThreadMessageQueue **mq,
|
|
unsigned nelem,
|
|
unsigned elsize);
|
|
|
|
/**
|
|
* Free a message queue.
|
|
*
|
|
* The message queue must no longer be in use by another thread.
|
|
*/
|
|
void av_thread_message_queue_free(AVThreadMessageQueue **mq);
|
|
|
|
/**
|
|
* Send a message on the queue.
|
|
*/
|
|
int av_thread_message_queue_send(AVThreadMessageQueue *mq,
|
|
void *msg,
|
|
unsigned flags);
|
|
|
|
/**
|
|
* Receive a message from the queue.
|
|
*/
|
|
int av_thread_message_queue_recv(AVThreadMessageQueue *mq,
|
|
void *msg,
|
|
unsigned flags);
|
|
|
|
/**
|
|
* Set the sending error code.
|
|
*
|
|
* If the error code is set to non-zero, av_thread_message_queue_send() will
|
|
* return it immediately. Conventional values, such as AVERROR_EOF or
|
|
* AVERROR(EAGAIN), can be used to cause the sending thread to stop or
|
|
* suspend its operation.
|
|
*/
|
|
void av_thread_message_queue_set_err_send(AVThreadMessageQueue *mq,
|
|
int err);
|
|
|
|
/**
|
|
* Set the receiving error code.
|
|
*
|
|
* If the error code is set to non-zero, av_thread_message_queue_recv() will
|
|
* return it immediately when there are no longer available messages.
|
|
* Conventional values, such as AVERROR_EOF or AVERROR(EAGAIN), can be used
|
|
* to cause the receiving thread to stop or suspend its operation.
|
|
*/
|
|
void av_thread_message_queue_set_err_recv(AVThreadMessageQueue *mq,
|
|
int err);
|
|
|
|
/**
|
|
* Set the optional free message callback function which will be called if an
|
|
* operation is removing messages from the queue.
|
|
*/
|
|
void av_thread_message_queue_set_free_func(AVThreadMessageQueue *mq,
|
|
void (*free_func)(void *msg));
|
|
|
|
/**
|
|
* Return the current number of messages in the queue.
|
|
*
|
|
* @return the current number of messages or AVERROR(ENOSYS) if lavu was built
|
|
* without thread support
|
|
*/
|
|
int av_thread_message_queue_nb_elems(AVThreadMessageQueue *mq);
|
|
|
|
/**
|
|
* Flush the message queue
|
|
*
|
|
* This function is mostly equivalent to reading and free-ing every message
|
|
* except that it will be done in a single operation (no lock/unlock between
|
|
* reads).
|
|
*/
|
|
void av_thread_message_flush(AVThreadMessageQueue *mq);
|
|
|
|
#endif /* AVUTIL_THREADMESSAGE_H */
|