[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