Fix palette mode in multi-thread encoding setting
Fix a couple of memory related errors. Also fix thread test failures. Change-Id: I0103995f832cecf1dd2380000321ac7204f0cfc0
This commit is contained in:
@@ -1933,7 +1933,7 @@ static size_t read_uncompressed_header(VP10Decoder *pbi,
|
||||
memset(&cm->ref_frame_map, -1, sizeof(cm->ref_frame_map));
|
||||
pbi->need_resync = 0;
|
||||
}
|
||||
if (cm->current_video_frame == 0)
|
||||
if (frame_is_intra_only(cm))
|
||||
cm->allow_screen_content_tools = vpx_rb_read_bit(rb);
|
||||
} else {
|
||||
cm->intra_only = cm->show_frame ? 0 : vpx_rb_read_bit(rb);
|
||||
|
||||
@@ -1217,7 +1217,7 @@ static void write_uncompressed_header(VP10_COMP *cpi,
|
||||
write_sync_code(wb);
|
||||
write_bitdepth_colorspace_sampling(cm, wb);
|
||||
write_frame_size(cm, wb);
|
||||
if (cm->current_video_frame == 0)
|
||||
if (frame_is_intra_only(cm))
|
||||
vpx_wb_write_bit(wb, cm->allow_screen_content_tools);
|
||||
} else {
|
||||
if (!cm->show_frame)
|
||||
|
||||
@@ -1945,11 +1945,11 @@ void vp10_remove_compressor(VP10_COMP *cpi) {
|
||||
|
||||
// Deallocate allocated thread data.
|
||||
if (t < cpi->num_workers - 1) {
|
||||
if (cpi->common.allow_screen_content_tools)
|
||||
vpx_free(thread_data->td->mb.palette_buffer);
|
||||
vpx_free(thread_data->td->counts);
|
||||
vp10_free_pc_tree(thread_data->td);
|
||||
vpx_free(thread_data->td);
|
||||
if (cpi->common.allow_screen_content_tools)
|
||||
vpx_free(thread_data->td->mb.palette_buffer);
|
||||
}
|
||||
}
|
||||
vpx_free(cpi->tile_thr_data);
|
||||
|
||||
@@ -96,13 +96,6 @@ void vp10_encode_tiles_mt(VP10_COMP *cpi) {
|
||||
CHECK_MEM_ERROR(cm, thread_data->td->counts,
|
||||
vpx_calloc(1, sizeof(*thread_data->td->counts)));
|
||||
|
||||
// Allocate buffers used by palette coding mode.
|
||||
if (cpi->common.allow_screen_content_tools) {
|
||||
MACROBLOCK *x = &thread_data->td->mb;
|
||||
CHECK_MEM_ERROR(cm, x->palette_buffer,
|
||||
vpx_memalign(16, sizeof(*x->palette_buffer)));
|
||||
}
|
||||
|
||||
// Create threads
|
||||
if (!winterface->reset(worker))
|
||||
vpx_internal_error(&cm->error, VPX_CODEC_ERROR,
|
||||
@@ -135,6 +128,13 @@ void vp10_encode_tiles_mt(VP10_COMP *cpi) {
|
||||
memcpy(thread_data->td->counts, &cpi->common.counts,
|
||||
sizeof(cpi->common.counts));
|
||||
}
|
||||
|
||||
// Allocate buffers used by palette coding mode.
|
||||
if (cpi->common.allow_screen_content_tools && i < num_workers - 1) {
|
||||
MACROBLOCK *x = &thread_data->td->mb;
|
||||
CHECK_MEM_ERROR(cm, x->palette_buffer,
|
||||
vpx_memalign(16, sizeof(*x->palette_buffer)));
|
||||
}
|
||||
}
|
||||
|
||||
// Encode a frame
|
||||
|
||||
Reference in New Issue
Block a user