aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorReimar Döffinger <Reimar.Doeffinger@gmx.de>2009-04-08 20:19:12 +0000
committerReimar Döffinger <Reimar.Doeffinger@gmx.de>2009-04-08 20:19:12 +0000
commitfeb993e5794b3dacb51085a9b77013495eb6dd1c (patch)
tree417d93a8a94c57b00b3552393d9355a320c32501
parentc81604f862a550bef5261680cfdc48deb6fce046 (diff)
downloadffmpeg-feb993e5794b3dacb51085a9b77013495eb6dd1c.tar.gz
Add av_shrink_packet function for use in av_get_packet that reduces pkt->size
and ensures the following padding is correctly initialized to 0. Originally committed as revision 18378 to svn://svn.ffmpeg.org/ffmpeg/trunk
-rw-r--r--libavcodec/avcodec.h8
-rw-r--r--libavcodec/avpacket.c7
-rw-r--r--libavformat/utils.c2
3 files changed, 16 insertions, 1 deletions
diff --git a/libavcodec/avcodec.h b/libavcodec/avcodec.h
index 218e236e9b..f500151e85 100644
--- a/libavcodec/avcodec.h
+++ b/libavcodec/avcodec.h
@@ -2655,6 +2655,14 @@ void av_init_packet(AVPacket *pkt);
int av_new_packet(AVPacket *pkt, int size);
/**
+ * Reduce packet size, correctly zeroing padding
+ *
+ * @param pkt packet
+ * @param size new size
+ */
+void av_shrink_packet(AVPacket *pkt, int size);
+
+/**
* @warning This is a hack - the packet memory allocation stuff is broken. The
* packet is allocated if it was not really allocated.
*/
diff --git a/libavcodec/avpacket.c b/libavcodec/avpacket.c
index 107afb3817..d91ee3a10d 100644
--- a/libavcodec/avpacket.c
+++ b/libavcodec/avpacket.c
@@ -62,6 +62,13 @@ int av_new_packet(AVPacket *pkt, int size)
return 0;
}
+void av_shrink_packet(AVPacket *pkt, int size)
+{
+ if (pkt->size <= size) return;
+ pkt->size = size;
+ memset(pkt->data + size, 0, FF_INPUT_BUFFER_PADDING_SIZE);
+}
+
int av_dup_packet(AVPacket *pkt)
{
if (((pkt->destruct == av_destruct_packet_nofree) || (pkt->destruct == NULL)) && pkt->data) {
diff --git a/libavformat/utils.c b/libavformat/utils.c
index 54c92028a9..d3b9c090eb 100644
--- a/libavformat/utils.c
+++ b/libavformat/utils.c
@@ -272,7 +272,7 @@ int av_get_packet(ByteIOContext *s, AVPacket *pkt, int size)
if(ret<=0)
av_free_packet(pkt);
else
- pkt->size= ret;
+ av_shrink_packet(pkt, ret);
return ret;
}