[FFmpeg-cvslog] avutil/frame: document alignment and padding requirements

Michael Niedermayer git at videolan.org
Mon Mar 18 04:44:49 CET 2013


ffmpeg | branch: master | Michael Niedermayer <michaelni at gmx.at> | Sun Mar 17 03:20:16 2013 +0100| [3dc25c3ab260571323c363fef09e8422182082c2] | committer: Michael Niedermayer

avutil/frame: document alignment and padding requirements

Signed-off-by: Michael Niedermayer <michaelni at gmx.at>

> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=3dc25c3ab260571323c363fef09e8422182082c2
---

 libavutil/frame.h |   10 ++++++++++
 1 file changed, 10 insertions(+)

diff --git a/libavutil/frame.h b/libavutil/frame.h
index 8fc5814..b5d4694 100644
--- a/libavutil/frame.h
+++ b/libavutil/frame.h
@@ -78,6 +78,11 @@ typedef struct AVFrame {
     /**
      * pointer to the picture/channel planes.
      * This might be different from the first allocated byte
+     *
+     * Some decoders access areas outside 0,0 - width,height, please
+     * see avcodec_align_dimensions2(). Some filters and swscale can read
+     * up to 16 bytes beyond the planes, if these filters are to be used,
+     * then 16 extra bytes must be allocated.
      */
     uint8_t *data[AV_NUM_DATA_POINTERS];
 
@@ -87,6 +92,11 @@ typedef struct AVFrame {
      *
      * For audio, only linesize[0] may be set. For planar audio, each channel
      * plane must be the same size.
+     *
+     * For video the linesizes should be multiplies of the CPUs alignment
+     * preferrance, this is 16 or 32 for modern desktop CPUs.
+     * Some code requires such alignment other code can be slower without
+     * correct alignment, for yet other it makes no difference.
      */
     int linesize[AV_NUM_DATA_POINTERS];
 



More information about the ffmpeg-cvslog mailing list