aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMichael Niedermayer <michaelni@gmx.at>2011-03-30 02:58:38 +0200
committerMichael Niedermayer <michaelni@gmx.at>2011-03-30 02:58:38 +0200
commit55ce3c67bb25cd44889f2143ce9fd7dac3ab4a9d (patch)
tree20f16981174b1d3469daf22217b98e24e311e62f
parentcd39549e2c386edfa5f4d4bdc0cda78f882a4fe4 (diff)
downloadffmpeg-55ce3c67bb25cd44889f2143ce9fd7dac3ab4a9d.tar.gz
Merge remote-tracking branch 'ffmpeg-mt/master'
* ffmpeg-mt/master: Update todo. More items appeared... Fix mdec Duplicate: id3v1: change filesize to int64_t. Duplicate: id3v1: Seek back to old position after reading. Conflicts: libavcodec/mpegvideo.c libavcodec/snow.c libavformat/id3v1.c Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
-rw-r--r--libavcodec/mdec.c2
-rw-r--r--libavformat/id3v1.c2
-rw-r--r--mt-work/todo.txt10
3 files changed, 9 insertions, 5 deletions
diff --git a/libavcodec/mdec.c b/libavcodec/mdec.c
index b28ac26913..ba06641ab0 100644
--- a/libavcodec/mdec.c
+++ b/libavcodec/mdec.c
@@ -246,7 +246,7 @@ static av_cold int decode_init_thread_copy(AVCodecContext *avctx){
avctx->coded_frame= p;
a->avctx= avctx;
- p->qscale_table= av_mallocz( p->qstride * a->mb_height);
+ p->qscale_table= av_mallocz(a->mb_width);
return 0;
}
diff --git a/libavformat/id3v1.c b/libavformat/id3v1.c
index 4f9b5840ec..365c3e0fab 100644
--- a/libavformat/id3v1.c
+++ b/libavformat/id3v1.c
@@ -227,7 +227,7 @@ void ff_id3v1_read(AVFormatContext *s)
{
int ret;
uint8_t buf[ID3v1_TAG_SIZE];
- int64_t filesize, position = url_ftell(s->pb);
+ int64_t filesize, position = avio_tell(s->pb);
if (!url_is_streamed(s->pb)) {
/* XXX: change that */
diff --git a/mt-work/todo.txt b/mt-work/todo.txt
index a27f181759..013853e3ae 100644
--- a/mt-work/todo.txt
+++ b/mt-work/todo.txt
@@ -2,7 +2,7 @@ Todo
-- For other people
- Multithread vp8 or vc1.
-- Multithread an intra codec like mjpeg.
+- Multithread an intra codec like mjpeg (trivial).
- Fix mpeg1 (see below).
- Try the first three items under Optimization.
- Fix h264 (see below).
@@ -14,6 +14,8 @@ General critical:
- Error resilience has to run before ff_report_frame_progress()
is called. Otherwise there will be race conditions. (This might already
work.) In general testing error paths should be done more.
+- 'make fate THREADS=2' doesn't pass. Most failures are due to
+bugs in vsync in ffmpeg.c, which are currently obscuring real failures.
h264:
- Files split at the wrong NAL unit don't (and can't)
@@ -39,7 +41,7 @@ with threads on. Currently disabled for this reason.
-- Prove correct
- decode_update_progress() in h264.c
-h264_race_checking branch has some work on h264,
+race_checking branch has some work on h264,
but not that function. It might be worth putting
the branch under #ifdef DEBUG in mainline, but
the code would have to be cleaner.
@@ -48,9 +50,11 @@ the code would have to be cleaner.
-- Optimization
+- Merge h264 decode_update_progress() with loop_filter().
+Add CODEC_CAP_DRAW_HORIZ_BAND as a side effect.
- EMU_EDGE is always set for h264 PAFF+MT
because draw_edges() writes into the other field's
-thread's pixels.
+thread's pixels. Needs an option to skip T/B fields.
- Check update_thread_context() functions and make
sure they only copy what they need to.
- Try some more optimization of the "ref < 48; ref++"