FFmpeg git repo
Go to file
Andreas Rheinhardt d4b63885a6 avcodec/mpegpicture: Store linesize in ScratchpadContext
The mpegvideo-based codecs currently require the linesize to be
constant (except when the frame dimensions change); one reason
for this is that certain scratch buffers whose size depend on
linesize are only allocated once and are presumed to be correctly
sized if the pointers are != NULL.

This commit changes this by storing the actual linesize these
buffers belong to and reallocating the buffers if it does not
suffice. This is not enough to actually support changing linesizes,
but it is a start. And it is a prerequisite for the next patch.

Also don't emit an error message in case the source ctx's
edge_emu_buffer is unset in ff_mpeg_update_thread_context().
It need not be an error at all; e.g. it is a perfectly normal
state in case a hardware acceleration is used as the scratch
buffers are not allocated in this case (it is easy to run into
this issue with MPEG-4) or if the src context was not initialized
at all (e.g. because the first packet contained garbage).

Signed-off-by: Andreas Rheinhardt <andreas.rheinhardt@outlook.com>
2024-06-12 10:47:44 +02:00
compat
doc lavc: bump minor and add APIchanges entry for new USAC profile 2024-06-08 00:22:36 +02:00
ffbuild
fftools fftools/ffmpeg_mux_init: Fix leak when using non-encoding option 2024-06-11 14:32:25 +02:00
libavcodec avcodec/mpegpicture: Store linesize in ScratchpadContext 2024-06-12 10:47:44 +02:00
libavdevice avdevice/xcbgrab: Check sscanf() return 2024-06-12 00:39:11 +02:00
libavfilter avfilter/vf_rotate: Check ff_draw_init2() return value 2024-06-12 00:39:14 +02:00
libavformat avformat/mov: Use int64_t in intermediate for corrected_dts 2024-06-12 00:39:13 +02:00
libavutil lavu/hwcontext_vulkan: Support write on drm frame 2024-06-12 01:53:18 +02:00
libpostproc
libswresample
libswscale riscv: probe for Zbb extension at load time 2024-06-11 20:12:37 +03:00
presets
tests riscv: probe for Zbb extension at load time 2024-06-11 20:12:37 +03:00
tools tools/decode_simple: Check avcodec_send_packet() for errors on flushing 2024-05-28 03:48:06 +02:00
.gitattributes
.gitignore
.mailmap
Changelog changelog: add entry for xHE-AAC 2024-06-02 18:34:46 +02:00
configure configure: Disable DNN without backend 2024-06-11 19:36:54 +08:00
CONTRIBUTING.md
COPYING.GPLv2
COPYING.GPLv3
COPYING.LGPLv2.1
COPYING.LGPLv3
CREDITS
INSTALL.md
LICENSE.md
MAINTAINERS MAINTAINERS: add myself as *BSD maintainer 2024-05-13 03:40:16 +02:00
Makefile
README.md
RELEASE

FFmpeg README

FFmpeg is a collection of libraries and tools to process multimedia content such as audio, video, subtitles and related metadata.

Libraries

  • libavcodec provides implementation of a wider range of codecs.
  • libavformat implements streaming protocols, container formats and basic I/O access.
  • libavutil includes hashers, decompressors and miscellaneous utility functions.
  • libavfilter provides means to alter decoded audio and video through a directed graph of connected filters.
  • libavdevice provides an abstraction to access capture and playback devices.
  • libswresample implements audio mixing and resampling routines.
  • libswscale implements color conversion and scaling routines.

Tools

  • ffmpeg is a command line toolbox to manipulate, convert and stream multimedia content.
  • ffplay is a minimalistic multimedia player.
  • ffprobe is a simple analysis tool to inspect multimedia content.
  • Additional small tools such as aviocat, ismindex and qt-faststart.

Documentation

The offline documentation is available in the doc/ directory.

The online documentation is available in the main website and in the wiki.

Examples

Coding examples are available in the doc/examples directory.

License

FFmpeg codebase is mainly LGPL-licensed with optional components licensed under GPL. Please refer to the LICENSE file for detailed information.

Contributing

Patches should be submitted to the ffmpeg-devel mailing list using git format-patch or git send-email. Github pull requests should be avoided because they are not part of our review process and will be ignored.