[x264-devel] Fix XAVC slice pattern
Anton Mitrofanov
git at videolan.org
Mon Mar 11 20:24:04 CET 2019
x264 | branch: master | Anton Mitrofanov <BugMaster at narod.ru> | Fri Dec 21 18:54:56 2018 +0300| [c7ec24cfbdf720dbf0806046cb5fb9302b941ec9] | committer: Henrik Gramner
Fix XAVC slice pattern
> http://git.videolan.org/gitweb.cgi/x264.git/?a=commit;h=c7ec24cfbdf720dbf0806046cb5fb9302b941ec9
---
encoder/encoder.c | 9 ++++++---
1 file changed, 6 insertions(+), 3 deletions(-)
diff --git a/encoder/encoder.c b/encoder/encoder.c
index 785d6ed2..758defc4 100644
--- a/encoder/encoder.c
+++ b/encoder/encoder.c
@@ -3076,6 +3076,7 @@ static void *slices_write( x264_t *h )
{
int i_slice_num = 0;
int last_thread_mb = h->sh.i_last_mb;
+ int round_bias = h->param.i_avcintra_class ? 0 : h->param.i_slice_count/2;
/* init stats */
memset( &h->stat.frame, 0, sizeof(h->stat.frame) );
@@ -3110,7 +3111,7 @@ static void *slices_write( x264_t *h )
int height = h->mb.i_mb_height >> PARAM_INTERLACED;
int width = h->mb.i_mb_width << PARAM_INTERLACED;
i_slice_num++;
- h->sh.i_last_mb = (height * i_slice_num + h->param.i_slice_count/2) / h->param.i_slice_count * width - 1;
+ h->sh.i_last_mb = (height * i_slice_num + round_bias) / h->param.i_slice_count * width - 1;
}
}
h->sh.i_last_mb = X264_MIN( h->sh.i_last_mb, last_thread_mb );
@@ -3133,6 +3134,8 @@ fail:
static int threaded_slices_write( x264_t *h )
{
+ int round_bias = h->param.i_avcintra_class ? 0 : h->param.i_slice_count/2;
+
/* set first/last mb and sync contexts */
for( int i = 0; i < h->param.i_threads; i++ )
{
@@ -3143,8 +3146,8 @@ static int threaded_slices_write( x264_t *h )
memcpy( &t->i_frame, &h->i_frame, offsetof(x264_t, rc) - offsetof(x264_t, i_frame) );
}
int height = h->mb.i_mb_height >> PARAM_INTERLACED;
- t->i_threadslice_start = ((height * i + h->param.i_slice_count/2) / h->param.i_threads) << PARAM_INTERLACED;
- t->i_threadslice_end = ((height * (i+1) + h->param.i_slice_count/2) / h->param.i_threads) << PARAM_INTERLACED;
+ t->i_threadslice_start = ((height * i + round_bias) / h->param.i_threads) << PARAM_INTERLACED;
+ t->i_threadslice_end = ((height * (i+1) + round_bias) / h->param.i_threads) << PARAM_INTERLACED;
t->sh.i_first_mb = t->i_threadslice_start * h->mb.i_mb_width;
t->sh.i_last_mb = t->i_threadslice_end * h->mb.i_mb_width - 1;
}
More information about the x264-devel
mailing list