mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2024-12-23 12:43:46 +02:00
Merge remote-tracking branch 'qatar/master'
* qatar/master: id3v2: fix doxy comment - 'machine byte order' makes no sense on char arrays VC1: restore mistakenly removed code twinvq: check output buffer size before decoding twinvq: return an error when the packet size is too small lavf: export some forgotten symbols with non-av prefixes. swscale: update altivec yuv2planeX asm to new per-plane API. swscale: make yuv2yuvX_10_sse2/avx 8/9/16-bits aware. yuv2planeX10 SIMD swscale: decide whether to use yuv2plane1/X on a per-plane basis. swscale: reintroduce full precision in 16-bit output. Split up yuv2yuvX functions Split out yuv2yuv1 luma and chroma in order to make them generic DSP functions lavc: replace references to deprecated AVCodecContext.error_recognition to use AVCodecContext.err_recognition lavc: translate non-flag-based er options into flag-based ef options at codec open add -err_filter AVOptions to access flag-based error recognition h264_weight: initialize "height" function argument properly. presets: spelling error in libvpx 1080p50_60 avplay: fix fullscreen behaviour with SDL 1.2.14 on Mac OS X Conflicts: ffplay.c libavformat/libavformat.v libswscale/swscale.c libswscale/x86/swscale_template.c tests/ref/lavfi/pixfmts_scale Merged-by: Michael Niedermayer <michaelni@gmx.at>
This commit is contained in:
commit
f97faf6751
@ -596,7 +596,7 @@ static av_cold int aac_decode_init(AVCodecContext *avctx)
|
||||
int ret = set_default_channel_config(avctx, new_che_pos, ac->m4ac.chan_config);
|
||||
if (!ret)
|
||||
output_configure(ac, ac->che_pos, new_che_pos, ac->m4ac.chan_config, OC_GLOBAL_HDR);
|
||||
else if (avctx->error_recognition >= FF_ER_EXPLODE)
|
||||
else if (avctx->err_recognition & AV_EF_EXPLODE)
|
||||
return AVERROR_INVALIDDATA;
|
||||
}
|
||||
}
|
||||
|
@ -1359,7 +1359,7 @@ static int ac3_decode_frame(AVCodecContext * avctx, void *data, int *data_size,
|
||||
if (s->frame_size > buf_size) {
|
||||
av_log(avctx, AV_LOG_ERROR, "incomplete frame\n");
|
||||
err = AAC_AC3_PARSE_ERROR_FRAME_SIZE;
|
||||
} else if (avctx->error_recognition >= FF_ER_CAREFUL) {
|
||||
} else if (avctx->err_recognition & AV_EF_CRCCHECK) {
|
||||
/* check for crc mismatch */
|
||||
if (av_crc(av_crc_get_table(AV_CRC_16_ANSI), 0, &buf[2], s->frame_size-2)) {
|
||||
av_log(avctx, AV_LOG_ERROR, "frame CRC mismatch\n");
|
||||
|
@ -393,7 +393,7 @@ static av_cold int read_specific_config(ALSDecContext *ctx)
|
||||
if (get_bits_left(&gb) < 32)
|
||||
return -1;
|
||||
|
||||
if (avctx->error_recognition >= FF_ER_CAREFUL) {
|
||||
if (avctx->err_recognition & AV_EF_CRCCHECK) {
|
||||
ctx->crc_table = av_crc_get_table(AV_CRC_32_IEEE_LE);
|
||||
ctx->crc = 0xFFFFFFFF;
|
||||
ctx->crc_org = ~get_bits_long(&gb, 32);
|
||||
@ -1476,7 +1476,7 @@ static int decode_frame(AVCodecContext *avctx,
|
||||
}
|
||||
|
||||
// update CRC
|
||||
if (sconf->crc_enabled && avctx->error_recognition >= FF_ER_CAREFUL) {
|
||||
if (sconf->crc_enabled && (avctx->err_recognition & AV_EF_CRCCHECK)) {
|
||||
int swap = HAVE_BIGENDIAN != sconf->msb_first;
|
||||
|
||||
if (ctx->avctx->bits_per_raw_sample == 24) {
|
||||
@ -1710,7 +1710,7 @@ static av_cold int decode_init(AVCodecContext *avctx)
|
||||
|
||||
// allocate crc buffer
|
||||
if (HAVE_BIGENDIAN != sconf->msb_first && sconf->crc_enabled &&
|
||||
avctx->error_recognition >= FF_ER_CAREFUL) {
|
||||
(avctx->err_recognition & AV_EF_CRCCHECK)) {
|
||||
ctx->crc_buffer = av_malloc(sizeof(*ctx->crc_buffer) *
|
||||
ctx->cur_frame_length *
|
||||
avctx->channels *
|
||||
|
@ -136,7 +136,7 @@ static int h261_decode_gob_header(H261Context *h){
|
||||
|
||||
if(s->qscale==0) {
|
||||
av_log(s->avctx, AV_LOG_ERROR, "qscale has forbidden 0 value\n");
|
||||
if (s->avctx->error_recognition >= FF_ER_COMPLIANT)
|
||||
if (s->avctx->err_recognition & AV_EF_BITSTREAM)
|
||||
return -1;
|
||||
}
|
||||
|
||||
|
@ -732,7 +732,7 @@ intrax8_decoded:
|
||||
av_log(avctx, AV_LOG_DEBUG, "%"PRId64"\n", rdtsc()-time);
|
||||
#endif
|
||||
|
||||
return (ret && avctx->error_recognition >= FF_ER_EXPLODE)?ret:get_consumed_bytes(s, buf_size);
|
||||
return (ret && (avctx->err_recognition & AV_EF_EXPLODE))?ret:get_consumed_bytes(s, buf_size);
|
||||
}
|
||||
|
||||
AVCodec ff_h263_decoder = {
|
||||
|
@ -2893,7 +2893,7 @@ static int decode_slice_header(H264Context *h, H264Context *h0){
|
||||
ff_thread_report_progress((AVFrame*)s->current_picture_ptr, INT_MAX, 1);
|
||||
ff_generate_sliding_window_mmcos(h);
|
||||
if (ff_h264_execute_ref_pic_marking(h, h->mmco, h->mmco_index) < 0 &&
|
||||
s->avctx->error_recognition >= FF_ER_EXPLODE)
|
||||
(s->avctx->err_recognition & AV_EF_EXPLODE))
|
||||
return AVERROR_INVALIDDATA;
|
||||
/* Error concealment: if a ref is missing, copy the previous ref in its place.
|
||||
* FIXME: avoiding a memcpy would be nice, but ref handling makes many assumptions
|
||||
@ -3072,7 +3072,7 @@ static int decode_slice_header(H264Context *h, H264Context *h0){
|
||||
}
|
||||
|
||||
if(h->nal_ref_idc && ff_h264_decode_ref_pic_marking(h0, &s->gb) < 0 &&
|
||||
s->avctx->error_recognition >= FF_ER_EXPLODE)
|
||||
(s->avctx->err_recognition & AV_EF_EXPLODE))
|
||||
return AVERROR_INVALIDDATA;
|
||||
|
||||
if(FRAME_MBAFF){
|
||||
|
@ -654,7 +654,7 @@ int ff_h264_execute_ref_pic_marking(H264Context *h, MMCO *mmco, int mmco_count){
|
||||
|
||||
print_short_term(h);
|
||||
print_long_term(h);
|
||||
return h->s.avctx->error_recognition >= FF_ER_EXPLODE ? err : 0;
|
||||
return (h->s.avctx->err_recognition & AV_EF_EXPLODE) ? err : 0;
|
||||
}
|
||||
|
||||
int ff_h264_decode_ref_pic_marking(H264Context *h, GetBitContext *gb){
|
||||
|
@ -82,7 +82,7 @@ read_header:
|
||||
init_get_bits(&s->gb, buf_ptr+dqt_offs, (buf_end - (buf_ptr+dqt_offs))*8);
|
||||
s->start_code = DQT;
|
||||
if (ff_mjpeg_decode_dqt(s) < 0 &&
|
||||
avctx->error_recognition >= FF_ER_EXPLODE)
|
||||
(avctx->err_recognition & AV_EF_EXPLODE))
|
||||
return AVERROR_INVALIDDATA;
|
||||
}
|
||||
|
||||
@ -116,7 +116,7 @@ read_header:
|
||||
s->mjpb_skiptosod = (sod_offs - sos_offs - show_bits(&s->gb, 16));
|
||||
s->start_code = SOS;
|
||||
if (ff_mjpeg_decode_sos(s, NULL, NULL) < 0 &&
|
||||
avctx->error_recognition >= FF_ER_EXPLODE)
|
||||
(avctx->err_recognition & AV_EF_EXPLODE))
|
||||
return AVERROR_INVALIDDATA;
|
||||
}
|
||||
|
||||
|
@ -1522,7 +1522,7 @@ eoi_parser:
|
||||
break;
|
||||
}
|
||||
if (ff_mjpeg_decode_sos(s, NULL, NULL) < 0 &&
|
||||
avctx->error_recognition >= FF_ER_EXPLODE)
|
||||
(avctx->err_recognition & AV_EF_EXPLODE))
|
||||
return AVERROR_INVALIDDATA;
|
||||
break;
|
||||
case DRI:
|
||||
|
@ -1378,7 +1378,7 @@ static int mpeg1_decode_picture(AVCodecContext *avctx,
|
||||
if (s->pict_type == AV_PICTURE_TYPE_P || s->pict_type == AV_PICTURE_TYPE_B) {
|
||||
s->full_pel[0] = get_bits1(&s->gb);
|
||||
f_code = get_bits(&s->gb, 3);
|
||||
if (f_code == 0 && avctx->error_recognition >= FF_ER_COMPLIANT)
|
||||
if (f_code == 0 && (avctx->err_recognition & AV_EF_BITSTREAM))
|
||||
return -1;
|
||||
s->mpeg_f_code[0][0] = f_code;
|
||||
s->mpeg_f_code[0][1] = f_code;
|
||||
@ -1386,7 +1386,7 @@ static int mpeg1_decode_picture(AVCodecContext *avctx,
|
||||
if (s->pict_type == AV_PICTURE_TYPE_B) {
|
||||
s->full_pel[1] = get_bits1(&s->gb);
|
||||
f_code = get_bits(&s->gb, 3);
|
||||
if (f_code == 0 && avctx->error_recognition >= FF_ER_COMPLIANT)
|
||||
if (f_code == 0 && (avctx->err_recognition & AV_EF_BITSTREAM))
|
||||
return -1;
|
||||
s->mpeg_f_code[1][0] = f_code;
|
||||
s->mpeg_f_code[1][1] = f_code;
|
||||
@ -1819,7 +1819,7 @@ static int mpeg_decode_slice(Mpeg1Context *s1, int mb_y,
|
||||
&& s->progressive_frame == 0 /* vbv_delay == 0xBBB || 0xE10*/;
|
||||
|
||||
if (left < 0 || (left && show_bits(&s->gb, FFMIN(left, 23)) && !is_d10)
|
||||
|| (avctx->error_recognition >= FF_ER_AGGRESSIVE && left > 8)) {
|
||||
|| ((avctx->err_recognition & AV_EF_BUFFER) && left > 8)) {
|
||||
av_log(avctx, AV_LOG_ERROR, "end mismatch left=%d %0X\n", left, show_bits(&s->gb, FFMIN(left, 23)));
|
||||
return -1;
|
||||
} else
|
||||
@ -1911,7 +1911,7 @@ static int slice_decode_thread(AVCodecContext *c, void *arg)
|
||||
//av_log(c, AV_LOG_DEBUG, "ret:%d resync:%d/%d mb:%d/%d ts:%d/%d ec:%d\n",
|
||||
//ret, s->resync_mb_x, s->resync_mb_y, s->mb_x, s->mb_y, s->start_mb_y, s->end_mb_y, s->error_count);
|
||||
if (ret < 0) {
|
||||
if (c->error_recognition >= FF_ER_EXPLODE)
|
||||
if (c->err_recognition & AV_EF_EXPLODE)
|
||||
return ret;
|
||||
if (s->resync_mb_x >= 0 && s->resync_mb_y >= 0)
|
||||
ff_er_add_slice(s, s->resync_mb_x, s->resync_mb_y, s->mb_x, s->mb_y, AC_ERROR | DC_ERROR | MV_ERROR);
|
||||
@ -1999,7 +1999,7 @@ static int mpeg1_decode_sequence(AVCodecContext *avctx,
|
||||
s->aspect_ratio_info = get_bits(&s->gb, 4);
|
||||
if (s->aspect_ratio_info == 0) {
|
||||
av_log(avctx, AV_LOG_ERROR, "aspect ratio has forbidden 0 value\n");
|
||||
if (avctx->error_recognition >= FF_ER_COMPLIANT)
|
||||
if (avctx->err_recognition & AV_EF_BITSTREAM)
|
||||
return -1;
|
||||
}
|
||||
s->frame_rate_index = get_bits(&s->gb, 4);
|
||||
@ -2287,7 +2287,7 @@ static int mpeg_decode_frame(AVCodecContext *avctx,
|
||||
|
||||
if (avctx->extradata && !avctx->frame_number) {
|
||||
int ret = decode_chunks(avctx, picture, data_size, avctx->extradata, avctx->extradata_size);
|
||||
if (ret < 0 && avctx->error_recognition >= FF_ER_EXPLODE)
|
||||
if (ret < 0 && (avctx->err_recognition & AV_EF_EXPLODE))
|
||||
return ret;
|
||||
}
|
||||
|
||||
@ -2347,7 +2347,7 @@ static int decode_chunks(AVCodecContext *avctx,
|
||||
s->sync=1;
|
||||
} else {
|
||||
av_log(avctx, AV_LOG_ERROR, "ignoring SEQ_START_CODE after %X\n", last_code);
|
||||
if (avctx->error_recognition >= FF_ER_EXPLODE)
|
||||
if (avctx->err_recognition & AV_EF_EXPLODE)
|
||||
return AVERROR_INVALIDDATA;
|
||||
}
|
||||
break;
|
||||
@ -2381,7 +2381,7 @@ static int decode_chunks(AVCodecContext *avctx,
|
||||
last_code = PICTURE_START_CODE;
|
||||
} else {
|
||||
av_log(avctx, AV_LOG_ERROR, "ignoring pic after %X\n", last_code);
|
||||
if (avctx->error_recognition >= FF_ER_EXPLODE)
|
||||
if (avctx->err_recognition & AV_EF_EXPLODE)
|
||||
return AVERROR_INVALIDDATA;
|
||||
}
|
||||
break;
|
||||
@ -2394,7 +2394,7 @@ static int decode_chunks(AVCodecContext *avctx,
|
||||
mpeg_decode_sequence_extension(s);
|
||||
} else {
|
||||
av_log(avctx, AV_LOG_ERROR, "ignoring seq ext after %X\n", last_code);
|
||||
if (avctx->error_recognition >= FF_ER_EXPLODE)
|
||||
if (avctx->err_recognition & AV_EF_EXPLODE)
|
||||
return AVERROR_INVALIDDATA;
|
||||
}
|
||||
break;
|
||||
@ -2412,7 +2412,7 @@ static int decode_chunks(AVCodecContext *avctx,
|
||||
mpeg_decode_picture_coding_extension(s);
|
||||
} else {
|
||||
av_log(avctx, AV_LOG_ERROR, "ignoring pic cod ext after %X\n", last_code);
|
||||
if (avctx->error_recognition >= FF_ER_EXPLODE)
|
||||
if (avctx->err_recognition & AV_EF_EXPLODE)
|
||||
return AVERROR_INVALIDDATA;
|
||||
}
|
||||
break;
|
||||
@ -2428,7 +2428,7 @@ static int decode_chunks(AVCodecContext *avctx,
|
||||
s->sync=1;
|
||||
} else {
|
||||
av_log(avctx, AV_LOG_ERROR, "ignoring GOP_START_CODE after %X\n", last_code);
|
||||
if (avctx->error_recognition >= FF_ER_EXPLODE)
|
||||
if (avctx->err_recognition & AV_EF_EXPLODE)
|
||||
return AVERROR_INVALIDDATA;
|
||||
}
|
||||
break;
|
||||
@ -2475,7 +2475,7 @@ static int decode_chunks(AVCodecContext *avctx,
|
||||
|
||||
if (!s2->pict_type) {
|
||||
av_log(avctx, AV_LOG_ERROR, "Missing picture start code\n");
|
||||
if (avctx->error_recognition >= FF_ER_EXPLODE)
|
||||
if (avctx->err_recognition & AV_EF_EXPLODE)
|
||||
return AVERROR_INVALIDDATA;
|
||||
break;
|
||||
}
|
||||
@ -2516,7 +2516,7 @@ static int decode_chunks(AVCodecContext *avctx,
|
||||
emms_c();
|
||||
|
||||
if (ret < 0) {
|
||||
if (avctx->error_recognition >= FF_ER_EXPLODE)
|
||||
if (avctx->err_recognition & AV_EF_EXPLODE)
|
||||
return ret;
|
||||
if (s2->resync_mb_x >= 0 && s2->resync_mb_y >= 0)
|
||||
ff_er_add_slice(s2, s2->resync_mb_x, s2->resync_mb_y, s2->mb_x, s2->mb_y, AC_ERROR | DC_ERROR | MV_ERROR);
|
||||
|
@ -79,7 +79,7 @@ typedef struct MPADecodeContext {
|
||||
#endif
|
||||
int adu_mode; ///< 0 for standard mp3, 1 for adu formatted mp3
|
||||
int dither_state;
|
||||
int error_recognition;
|
||||
int err_recognition;
|
||||
AVCodecContext* avctx;
|
||||
MPADSPContext mpadsp;
|
||||
} MPADecodeContext;
|
||||
@ -280,7 +280,7 @@ static av_cold int decode_init(AVCodecContext * avctx)
|
||||
ff_mpadsp_init(&s->mpadsp);
|
||||
|
||||
avctx->sample_fmt= OUT_FMT;
|
||||
s->error_recognition= avctx->error_recognition;
|
||||
s->err_recognition = avctx->err_recognition;
|
||||
|
||||
if (!init && !avctx->parse_only) {
|
||||
int offset;
|
||||
@ -1104,7 +1104,7 @@ static int huffman_decode(MPADecodeContext *s, GranuleDef *g,
|
||||
s_index -= 4;
|
||||
skip_bits_long(&s->gb, last_pos - pos);
|
||||
av_log(s->avctx, AV_LOG_INFO, "overread, skip %d enddists: %d %d\n", last_pos - pos, end_pos-pos, end_pos2-pos);
|
||||
if(s->error_recognition >= FF_ER_COMPLIANT)
|
||||
if(s->err_recognition & AV_EF_BITSTREAM)
|
||||
s_index=0;
|
||||
break;
|
||||
}
|
||||
@ -1134,10 +1134,10 @@ static int huffman_decode(MPADecodeContext *s, GranuleDef *g,
|
||||
/* skip extension bits */
|
||||
bits_left = end_pos2 - get_bits_count(&s->gb);
|
||||
//av_log(NULL, AV_LOG_ERROR, "left:%d buf:%p\n", bits_left, s->in_gb.buffer);
|
||||
if (bits_left < 0 && s->error_recognition >= FF_ER_COMPLIANT) {
|
||||
if (bits_left < 0 && (s->err_recognition & AV_EF_BITSTREAM)) {
|
||||
av_log(s->avctx, AV_LOG_ERROR, "bits_left=%d\n", bits_left);
|
||||
s_index=0;
|
||||
}else if(bits_left > 0 && s->error_recognition >= FF_ER_AGGRESSIVE){
|
||||
}else if(bits_left > 0 && (s->err_recognition & AV_EF_BUFFER)){
|
||||
av_log(s->avctx, AV_LOG_ERROR, "bits_left=%d\n", bits_left);
|
||||
s_index=0;
|
||||
}
|
||||
|
@ -275,11 +275,11 @@ static int mxpeg_decode_frame(AVCodecContext *avctx,
|
||||
}
|
||||
|
||||
ret = ff_mjpeg_decode_sos(jpg, s->mxm_bitmask, reference_ptr);
|
||||
if (ret < 0 && avctx->error_recognition >= FF_ER_EXPLODE)
|
||||
if (ret < 0 && (avctx->err_recognition & AV_EF_EXPLODE))
|
||||
return ret;
|
||||
} else {
|
||||
ret = ff_mjpeg_decode_sos(jpg, NULL, NULL);
|
||||
if (ret < 0 && avctx->error_recognition >= FF_ER_EXPLODE)
|
||||
if (ret < 0 && (avctx->err_recognition & AV_EF_EXPLODE))
|
||||
return ret;
|
||||
}
|
||||
|
||||
|
@ -201,14 +201,19 @@ static const AVOption options[]={
|
||||
{"unofficial", "allow unofficial extensions", 0, AV_OPT_TYPE_CONST, {.dbl = FF_COMPLIANCE_UNOFFICIAL }, INT_MIN, INT_MAX, V|D|E, "strict"},
|
||||
{"experimental", "allow non standardized experimental things", 0, AV_OPT_TYPE_CONST, {.dbl = FF_COMPLIANCE_EXPERIMENTAL }, INT_MIN, INT_MAX, V|D|E, "strict"},
|
||||
{"b_qoffset", "qp offset between P and B frames", OFFSET(b_quant_offset), AV_OPT_TYPE_FLOAT, {.dbl = 1.25 }, -FLT_MAX, FLT_MAX, V|E},
|
||||
#if FF_API_ER
|
||||
{"er", "set error detection aggressivity", OFFSET(error_recognition), AV_OPT_TYPE_INT, {.dbl = FF_ER_CAREFUL }, INT_MIN, INT_MAX, A|V|D, "er"},
|
||||
{"careful", NULL, 0, AV_OPT_TYPE_CONST, {.dbl = FF_ER_CAREFUL }, INT_MIN, INT_MAX, V|D, "er"},
|
||||
{"compliant", NULL, 0, AV_OPT_TYPE_CONST, {.dbl = FF_ER_COMPLIANT }, INT_MIN, INT_MAX, V|D, "er"},
|
||||
{"aggressive", NULL, 0, AV_OPT_TYPE_CONST, {.dbl = FF_ER_AGGRESSIVE }, INT_MIN, INT_MAX, V|D, "er"},
|
||||
#if FF_API_ER
|
||||
{"very_aggressive", NULL, 0, AV_OPT_TYPE_CONST, {.dbl = FF_ER_VERY_AGGRESSIVE }, INT_MIN, INT_MAX, V|D, "er"},
|
||||
#endif /* FF_API_ER */
|
||||
{"explode", "abort decoding on error recognition", 0, AV_OPT_TYPE_CONST, {.dbl = FF_ER_EXPLODE }, INT_MIN, INT_MAX, V|D, "er"},
|
||||
#endif /* FF_API_ER */
|
||||
{"err_filter", "set error detection filter flags", OFFSET(err_recognition), AV_OPT_TYPE_FLAGS, {.dbl = AV_EF_CRCCHECK }, INT_MIN, INT_MAX, A|V|D, "err_filter"},
|
||||
{"crccheck", NULL, 0, AV_OPT_TYPE_CONST, {.dbl = AV_EF_CRCCHECK }, INT_MIN, INT_MAX, V|D, "err_filter"},
|
||||
{"bitstream", NULL, 0, AV_OPT_TYPE_CONST, {.dbl = AV_EF_BITSTREAM }, INT_MIN, INT_MAX, V|D, "err_filter"},
|
||||
{"buffer", NULL, 0, AV_OPT_TYPE_CONST, {.dbl = AV_EF_BUFFER }, INT_MIN, INT_MAX, V|D, "err_filter"},
|
||||
{"explode", "abort decoding on minor error recognition", 0, AV_OPT_TYPE_CONST, {.dbl = AV_EF_EXPLODE }, INT_MIN, INT_MAX, V|D, "err_filter"},
|
||||
{"has_b_frames", NULL, OFFSET(has_b_frames), AV_OPT_TYPE_INT, {.dbl = DEFAULT }, INT_MIN, INT_MAX},
|
||||
{"block_align", NULL, OFFSET(block_align), AV_OPT_TYPE_INT, {.dbl = DEFAULT }, INT_MIN, INT_MAX},
|
||||
{"parse_only", NULL, OFFSET(parse_only), AV_OPT_TYPE_INT, {.dbl = DEFAULT }, INT_MIN, INT_MAX},
|
||||
|
@ -822,7 +822,7 @@ static int twin_decode_frame(AVCodecContext * avctx, void *data,
|
||||
const ModeTab *mtab = tctx->mtab;
|
||||
float *out = data;
|
||||
enum FrameType ftype;
|
||||
int window_type;
|
||||
int window_type, out_size;
|
||||
static const enum FrameType wtype_to_ftype_table[] = {
|
||||
FT_LONG, FT_LONG, FT_SHORT, FT_LONG,
|
||||
FT_MEDIUM, FT_LONG, FT_LONG, FT_MEDIUM, FT_MEDIUM
|
||||
@ -831,8 +831,14 @@ static int twin_decode_frame(AVCodecContext * avctx, void *data,
|
||||
if (buf_size*8 < avctx->bit_rate*mtab->size/avctx->sample_rate + 8) {
|
||||
av_log(avctx, AV_LOG_ERROR,
|
||||
"Frame too small (%d bytes). Truncated file?\n", buf_size);
|
||||
*data_size = 0;
|
||||
return buf_size;
|
||||
return AVERROR(EINVAL);
|
||||
}
|
||||
|
||||
out_size = mtab->size * avctx->channels *
|
||||
av_get_bytes_per_sample(avctx->sample_fmt);
|
||||
if (*data_size < out_size) {
|
||||
av_log(avctx, AV_LOG_ERROR, "output buffer is too small\n");
|
||||
return AVERROR(EINVAL);
|
||||
}
|
||||
|
||||
init_get_bits(&gb, buf, buf_size * 8);
|
||||
@ -857,7 +863,7 @@ static int twin_decode_frame(AVCodecContext * avctx, void *data,
|
||||
return buf_size;
|
||||
}
|
||||
|
||||
*data_size = mtab->size*avctx->channels*4;
|
||||
*data_size = out_size;
|
||||
|
||||
return buf_size;
|
||||
}
|
||||
|
@ -610,6 +610,16 @@ int attribute_align_arg avcodec_open2(AVCodecContext *avctx, AVCodec *codec, AVD
|
||||
goto free_and_end;
|
||||
}
|
||||
avctx->frame_number = 0;
|
||||
#if FF_API_ER
|
||||
|
||||
av_log(avctx, AV_LOG_DEBUG, "err{or,}_recognition separate: %d; %d\n",
|
||||
avctx->error_recognition, avctx->err_recognition);
|
||||
/* FF_ER_CAREFUL (==1) implies AV_EF_CRCCHECK (== 1<<1 - 1),
|
||||
FF_ER_COMPLIANT (==2) implies AV_EF_{CRCCHECK,BITSTREAM} (== 1<<2 - 1), et cetera} */
|
||||
avctx->err_recognition |= (1<<(avctx->error_recognition-(avctx->error_recognition>=FF_ER_VERY_AGGRESSIVE))) - 1;
|
||||
av_log(avctx, AV_LOG_DEBUG, "err{or,}_recognition combined: %d; %d\n",
|
||||
avctx->error_recognition, avctx->err_recognition);
|
||||
#endif
|
||||
|
||||
if (!HAVE_THREADS)
|
||||
av_log(avctx, AV_LOG_WARNING, "Warning: not compiled with thread support, using thread emulation\n");
|
||||
|
@ -930,6 +930,8 @@ static void vc1_mc_4mv_chroma(VC1Context *v, int dir)
|
||||
if (!v->field_mode || (v->field_mode && !v->numref)) {
|
||||
valid_count = get_chroma_mv(mvx, mvy, intra, 0, &tx, &ty);
|
||||
if (!valid_count) {
|
||||
s->current_picture.f.motion_val[1][s->block_index[0]][0] = 0;
|
||||
s->current_picture.f.motion_val[1][s->block_index[0]][1] = 0;
|
||||
v->luma_mv[s->mb_x][0] = v->luma_mv[s->mb_x][1] = 0;
|
||||
return; //no need to do MC for intra blocks
|
||||
}
|
||||
@ -941,6 +943,8 @@ static void vc1_mc_4mv_chroma(VC1Context *v, int dir)
|
||||
if (dominant)
|
||||
chroma_ref_type = !v->cur_field_type;
|
||||
}
|
||||
s->current_picture.f.motion_val[1][s->block_index[0]][0] = tx;
|
||||
s->current_picture.f.motion_val[1][s->block_index[0]][1] = ty;
|
||||
uvmx = (tx + ((tx & 3) == 3)) >> 1;
|
||||
uvmy = (ty + ((ty & 3) == 3)) >> 1;
|
||||
|
||||
|
@ -44,6 +44,7 @@ SECTION .text
|
||||
PROLOGUE 0,6,8
|
||||
movifnidn r0, r0mp
|
||||
movifnidn r1d, r1m
|
||||
movifnidn r2d, r2m
|
||||
movifnidn r4d, r4m
|
||||
movifnidn r5d, r5m
|
||||
%endmacro
|
||||
|
@ -62,7 +62,7 @@ typedef struct ID3v2ExtraMetaGEOB {
|
||||
/**
|
||||
* Detect ID3v2 Header.
|
||||
* @param buf must be ID3v2_HEADER_SIZE byte long
|
||||
* @param magic magic bytes to identify the header, machine byte order.
|
||||
* @param magic magic bytes to identify the header.
|
||||
* If in doubt, use ID3v2_DEFAULT_MAGIC.
|
||||
*/
|
||||
int ff_id3v2_match(const uint8_t *buf, const char *magic);
|
||||
|
@ -23,5 +23,10 @@ LIBAVFORMAT_$MAJOR {
|
||||
ff_timefilter_new;
|
||||
ff_timefilter_update;
|
||||
ff_timefilter_reset;
|
||||
get_*;
|
||||
put_*;
|
||||
udp_set_remote_url;
|
||||
udp_get_local_port;
|
||||
init_checksum;
|
||||
local: *;
|
||||
};
|
||||
|
@ -94,34 +94,29 @@ altivec_packIntArrayToCharArray(int *val, uint8_t* dest, int dstW)
|
||||
|
||||
//FIXME remove the usage of scratch buffers.
|
||||
static void
|
||||
yuv2yuvX_altivec_real(SwsContext *c,
|
||||
const int16_t *lumFilter, const int16_t **lumSrc,
|
||||
int lumFilterSize, const int16_t *chrFilter,
|
||||
const int16_t **chrUSrc, const int16_t **chrVSrc,
|
||||
int chrFilterSize, const int16_t **alpSrc,
|
||||
uint8_t *dest[4], int dstW, int chrDstW)
|
||||
yuv2planeX_altivec(const int16_t *filter, int filterSize,
|
||||
const int16_t **src, uint8_t *dest, int dstW,
|
||||
const uint8_t *dither, int offset)
|
||||
{
|
||||
uint8_t *yDest = dest[0], *uDest = dest[1], *vDest = dest[2];
|
||||
const uint8_t *lumDither = c->lumDither8, *chrDither = c->chrDither8;
|
||||
register int i, j;
|
||||
{
|
||||
DECLARE_ALIGNED(16, int, val)[dstW];
|
||||
|
||||
for (i=0; i<dstW; i++)
|
||||
val[i] = lumDither[i & 7] << 12;
|
||||
val[i] = dither[(i + offset) & 7] << 12;
|
||||
|
||||
for (j = 0; j < lumFilterSize; j++) {
|
||||
vector signed short l1, vLumFilter = vec_ld(j << 1, lumFilter);
|
||||
vector unsigned char perm, perm0 = vec_lvsl(j << 1, lumFilter);
|
||||
for (j = 0; j < filterSize; j++) {
|
||||
vector signed short l1, vLumFilter = vec_ld(j << 1, filter);
|
||||
vector unsigned char perm, perm0 = vec_lvsl(j << 1, filter);
|
||||
vLumFilter = vec_perm(vLumFilter, vLumFilter, perm0);
|
||||
vLumFilter = vec_splat(vLumFilter, 0); // lumFilter[j] is loaded 8 times in vLumFilter
|
||||
|
||||
perm = vec_lvsl(0, lumSrc[j]);
|
||||
l1 = vec_ld(0, lumSrc[j]);
|
||||
perm = vec_lvsl(0, src[j]);
|
||||
l1 = vec_ld(0, src[j]);
|
||||
|
||||
for (i = 0; i < (dstW - 7); i+=8) {
|
||||
int offset = i << 2;
|
||||
vector signed short l2 = vec_ld((i << 1) + 16, lumSrc[j]);
|
||||
vector signed short l2 = vec_ld((i << 1) + 16, src[j]);
|
||||
|
||||
vector signed int v1 = vec_ld(offset, val);
|
||||
vector signed int v2 = vec_ld(offset + 16, val);
|
||||
@ -143,73 +138,10 @@ yuv2yuvX_altivec_real(SwsContext *c,
|
||||
l1 = l2;
|
||||
}
|
||||
for ( ; i < dstW; i++) {
|
||||
val[i] += lumSrc[j][i] * lumFilter[j];
|
||||
val[i] += src[j][i] * filter[j];
|
||||
}
|
||||
}
|
||||
altivec_packIntArrayToCharArray(val, yDest, dstW);
|
||||
}
|
||||
if (uDest != 0) {
|
||||
DECLARE_ALIGNED(16, int, u)[chrDstW];
|
||||
DECLARE_ALIGNED(16, int, v)[chrDstW];
|
||||
|
||||
for (i=0; i<chrDstW; i++) {
|
||||
u[i] = chrDither[i & 7] << 12;
|
||||
v[i] = chrDither[(i + 3) & 7] << 12;
|
||||
}
|
||||
|
||||
for (j = 0; j < chrFilterSize; j++) {
|
||||
vector signed short l1, l1_V, vChrFilter = vec_ld(j << 1, chrFilter);
|
||||
vector unsigned char perm, perm0 = vec_lvsl(j << 1, chrFilter);
|
||||
vChrFilter = vec_perm(vChrFilter, vChrFilter, perm0);
|
||||
vChrFilter = vec_splat(vChrFilter, 0); // chrFilter[j] is loaded 8 times in vChrFilter
|
||||
|
||||
perm = vec_lvsl(0, chrUSrc[j]);
|
||||
l1 = vec_ld(0, chrUSrc[j]);
|
||||
l1_V = vec_ld(0, chrVSrc[j]);
|
||||
|
||||
for (i = 0; i < (chrDstW - 7); i+=8) {
|
||||
int offset = i << 2;
|
||||
vector signed short l2 = vec_ld((i << 1) + 16, chrUSrc[j]);
|
||||
vector signed short l2_V = vec_ld((i << 1) + 16, chrVSrc[j]);
|
||||
|
||||
vector signed int v1 = vec_ld(offset, u);
|
||||
vector signed int v2 = vec_ld(offset + 16, u);
|
||||
vector signed int v1_V = vec_ld(offset, v);
|
||||
vector signed int v2_V = vec_ld(offset + 16, v);
|
||||
|
||||
vector signed short ls = vec_perm(l1, l2, perm); // chrUSrc[j][i] ... chrUSrc[j][i+7]
|
||||
vector signed short ls_V = vec_perm(l1_V, l2_V, perm); // chrVSrc[j][i] ... chrVSrc[j][i]
|
||||
|
||||
vector signed int i1 = vec_mule(vChrFilter, ls);
|
||||
vector signed int i2 = vec_mulo(vChrFilter, ls);
|
||||
vector signed int i1_V = vec_mule(vChrFilter, ls_V);
|
||||
vector signed int i2_V = vec_mulo(vChrFilter, ls_V);
|
||||
|
||||
vector signed int vf1 = vec_mergeh(i1, i2);
|
||||
vector signed int vf2 = vec_mergel(i1, i2); // chrUSrc[j][i] * chrFilter[j] ... chrUSrc[j][i+7] * chrFilter[j]
|
||||
vector signed int vf1_V = vec_mergeh(i1_V, i2_V);
|
||||
vector signed int vf2_V = vec_mergel(i1_V, i2_V); // chrVSrc[j][i] * chrFilter[j] ... chrVSrc[j][i+7] * chrFilter[j]
|
||||
|
||||
vector signed int vo1 = vec_add(v1, vf1);
|
||||
vector signed int vo2 = vec_add(v2, vf2);
|
||||
vector signed int vo1_V = vec_add(v1_V, vf1_V);
|
||||
vector signed int vo2_V = vec_add(v2_V, vf2_V);
|
||||
|
||||
vec_st(vo1, offset, u);
|
||||
vec_st(vo2, offset + 16, u);
|
||||
vec_st(vo1_V, offset, v);
|
||||
vec_st(vo2_V, offset + 16, v);
|
||||
|
||||
l1 = l2;
|
||||
l1_V = l2_V;
|
||||
}
|
||||
for ( ; i < chrDstW; i++) {
|
||||
u[i] += chrUSrc[j][i] * chrFilter[j];
|
||||
v[i] += chrVSrc[j][i] * chrFilter[j];
|
||||
}
|
||||
}
|
||||
altivec_packIntArrayToCharArray(u, uDest, chrDstW);
|
||||
altivec_packIntArrayToCharArray(v, vDest, chrDstW);
|
||||
altivec_packIntArrayToCharArray(val, dest, dstW);
|
||||
}
|
||||
}
|
||||
|
||||
@ -405,7 +337,7 @@ void ff_sws_init_swScale_altivec(SwsContext *c)
|
||||
if (!is16BPS(dstFormat) && !is9_OR_10BPS(dstFormat) &&
|
||||
dstFormat != PIX_FMT_NV12 && dstFormat != PIX_FMT_NV21 &&
|
||||
!c->alpPixBuf) {
|
||||
c->yuv2yuvX = yuv2yuvX_altivec_real;
|
||||
c->yuv2planeX = yuv2planeX_altivec;
|
||||
}
|
||||
|
||||
/* The following list of supported dstFormat values should
|
||||
|
@ -290,80 +290,53 @@ const uint16_t dither_scale[15][16]={
|
||||
{ 3, 5, 7, 9, 11, 12, 14, 15, 15, 15, 15, 15, 15, 15, 16,65535,},
|
||||
};
|
||||
|
||||
#define output_pixel(pos, val, bias, signedness) \
|
||||
if (big_endian) { \
|
||||
AV_WB16(pos, bias + av_clip_ ## signedness ## 16(val >> shift)); \
|
||||
} else { \
|
||||
AV_WL16(pos, bias + av_clip_ ## signedness ## 16(val >> shift)); \
|
||||
}
|
||||
|
||||
static av_always_inline void
|
||||
yuv2yuvX16_c_template(const int16_t *lumFilter, const int32_t **lumSrc,
|
||||
int lumFilterSize, const int16_t *chrFilter,
|
||||
const int32_t **chrUSrc, const int32_t **chrVSrc,
|
||||
int chrFilterSize, const int32_t **alpSrc,
|
||||
uint16_t *dest[4], int dstW, int chrDstW,
|
||||
yuv2plane1_16_c_template(const int32_t *src, uint16_t *dest, int dstW,
|
||||
int big_endian, int output_bits)
|
||||
{
|
||||
int i;
|
||||
int shift = 19 - output_bits;
|
||||
|
||||
for (i = 0; i < dstW; i++) {
|
||||
int val = src[i] + (1 << (shift - 1));
|
||||
output_pixel(&dest[i], val, 0, uint);
|
||||
}
|
||||
}
|
||||
|
||||
static av_always_inline void
|
||||
yuv2planeX_16_c_template(const int16_t *filter, int filterSize,
|
||||
const int32_t **src, uint16_t *dest, int dstW,
|
||||
int big_endian, int output_bits)
|
||||
{
|
||||
//FIXME Optimize (just quickly written not optimized..)
|
||||
int i;
|
||||
int dword= output_bits == 16;
|
||||
uint16_t *yDest = dest[0], *uDest = dest[1], *vDest = dest[2],
|
||||
*aDest = CONFIG_SWSCALE_ALPHA ? dest[3] : NULL;
|
||||
int shift = 11 + 4*dword + 16 - output_bits - 1;
|
||||
int shift = 15 + 16 - output_bits;
|
||||
|
||||
#define output_pixel(pos, val) \
|
||||
if (big_endian) { \
|
||||
AV_WB16(pos, av_clip_uint16(val >> shift)); \
|
||||
} else { \
|
||||
AV_WL16(pos, av_clip_uint16(val >> shift)); \
|
||||
}
|
||||
for (i = 0; i < dstW; i++) {
|
||||
int val = 1 << (26-output_bits + 4*dword - 1);
|
||||
int val = 1 << (26-output_bits + 4*dword);
|
||||
int j;
|
||||
|
||||
for (j = 0; j < lumFilterSize; j++)
|
||||
val += ((dword ? lumSrc[j][i] : ((int16_t**)lumSrc)[j][i]) * lumFilter[j])>>1;
|
||||
/* range of val is [0,0x7FFFFFFF], so 31 bits, but with lanczos/spline
|
||||
* filters (or anything with negative coeffs, the range can be slightly
|
||||
* wider in both directions. To account for this overflow, we subtract
|
||||
* a constant so it always fits in the signed range (assuming a
|
||||
* reasonable filterSize), and re-add that at the end. */
|
||||
val -= 0x40000000;
|
||||
for (j = 0; j < filterSize; j++)
|
||||
val += src[j][i] * filter[j];
|
||||
|
||||
output_pixel(&yDest[i], val);
|
||||
}
|
||||
|
||||
if (uDest) {
|
||||
for (i = 0; i < chrDstW; i++) {
|
||||
int u = 1 << (26-output_bits + 4*dword - 1);
|
||||
int v = 1 << (26-output_bits + 4*dword - 1);
|
||||
int j;
|
||||
|
||||
for (j = 0; j < chrFilterSize; j++) {
|
||||
u += ((dword ? chrUSrc[j][i] : ((int16_t**)chrUSrc)[j][i]) * chrFilter[j]) >> 1;
|
||||
v += ((dword ? chrVSrc[j][i] : ((int16_t**)chrVSrc)[j][i]) * chrFilter[j]) >> 1;
|
||||
}
|
||||
|
||||
output_pixel(&uDest[i], u);
|
||||
output_pixel(&vDest[i], v);
|
||||
output_pixel(&dest[i], val, 0x8000, int);
|
||||
}
|
||||
}
|
||||
|
||||
if (CONFIG_SWSCALE_ALPHA && aDest) {
|
||||
for (i = 0; i < dstW; i++) {
|
||||
int val = 1 << (26-output_bits + 4*dword - 1);
|
||||
int j;
|
||||
|
||||
for (j = 0; j < lumFilterSize; j++)
|
||||
val += ((dword ? alpSrc[j][i] : ((int16_t**)alpSrc)[j][i]) * lumFilter[j]) >> 1;
|
||||
|
||||
output_pixel(&aDest[i], val);
|
||||
}
|
||||
}
|
||||
#undef output_pixel
|
||||
}
|
||||
|
||||
static av_always_inline void
|
||||
yuv2yuvX10_c_template(const int16_t *lumFilter, const int16_t **lumSrc,
|
||||
int lumFilterSize, const int16_t *chrFilter,
|
||||
const int16_t **chrUSrc, const int16_t **chrVSrc,
|
||||
int chrFilterSize, const int16_t **alpSrc,
|
||||
uint16_t *dest[4], int dstW, int chrDstW,
|
||||
int big_endian, int output_bits)
|
||||
{
|
||||
//FIXME Optimize (just quickly written not optimized..)
|
||||
int i;
|
||||
uint16_t *yDest = dest[0], *uDest = dest[1], *vDest = dest[2],
|
||||
*aDest = CONFIG_SWSCALE_ALPHA ? dest[3] : NULL;
|
||||
int shift = 11 + 16 - output_bits;
|
||||
|
||||
#define output_pixel(pos, val) \
|
||||
if (big_endian) { \
|
||||
@ -371,171 +344,96 @@ yuv2yuvX10_c_template(const int16_t *lumFilter, const int16_t **lumSrc,
|
||||
} else { \
|
||||
AV_WL16(pos, av_clip_uintp2(val >> shift, output_bits)); \
|
||||
}
|
||||
|
||||
static av_always_inline void
|
||||
yuv2plane1_10_c_template(const int16_t *src, uint16_t *dest, int dstW,
|
||||
int big_endian, int output_bits)
|
||||
{
|
||||
int i;
|
||||
int shift = 15 - output_bits;
|
||||
|
||||
for (i = 0; i < dstW; i++) {
|
||||
int val = src[i] + (1 << (shift - 1));
|
||||
output_pixel(&dest[i], val);
|
||||
}
|
||||
}
|
||||
|
||||
static av_always_inline void
|
||||
yuv2planeX_10_c_template(const int16_t *filter, int filterSize,
|
||||
const int16_t **src, uint16_t *dest, int dstW,
|
||||
int big_endian, int output_bits)
|
||||
{
|
||||
int i;
|
||||
int shift = 11 + 16 - output_bits;
|
||||
|
||||
for (i = 0; i < dstW; i++) {
|
||||
int val = 1 << (26-output_bits);
|
||||
int j;
|
||||
|
||||
for (j = 0; j < lumFilterSize; j++)
|
||||
val += lumSrc[j][i] * lumFilter[j];
|
||||
for (j = 0; j < filterSize; j++)
|
||||
val += src[j][i] * filter[j];
|
||||
|
||||
output_pixel(&yDest[i], val);
|
||||
}
|
||||
|
||||
if (uDest) {
|
||||
for (i = 0; i < chrDstW; i++) {
|
||||
int u = 1 << (26-output_bits);
|
||||
int v = 1 << (26-output_bits);
|
||||
int j;
|
||||
|
||||
for (j = 0; j < chrFilterSize; j++) {
|
||||
u += chrUSrc[j][i] * chrFilter[j];
|
||||
v += chrVSrc[j][i] * chrFilter[j];
|
||||
}
|
||||
|
||||
output_pixel(&uDest[i], u);
|
||||
output_pixel(&vDest[i], v);
|
||||
output_pixel(&dest[i], val);
|
||||
}
|
||||
}
|
||||
|
||||
if (CONFIG_SWSCALE_ALPHA && aDest) {
|
||||
for (i = 0; i < dstW; i++) {
|
||||
int val = 1 << (26-output_bits);
|
||||
int j;
|
||||
|
||||
for (j = 0; j < lumFilterSize; j++)
|
||||
val += alpSrc[j][i] * lumFilter[j];
|
||||
|
||||
output_pixel(&aDest[i], val);
|
||||
}
|
||||
}
|
||||
#undef output_pixel
|
||||
}
|
||||
|
||||
#define yuv2NBPS(bits, BE_LE, is_be, yuv2yuvX_template_fn, typeX_t) \
|
||||
static void yuv2yuvX ## bits ## BE_LE ## _c(SwsContext *c, const int16_t *lumFilter, \
|
||||
const int16_t **_lumSrc, int lumFilterSize, \
|
||||
const int16_t *chrFilter, const int16_t **_chrUSrc, \
|
||||
const int16_t **_chrVSrc, \
|
||||
int chrFilterSize, const int16_t **_alpSrc, \
|
||||
uint8_t *_dest[4], int dstW, int chrDstW) \
|
||||
#define yuv2NBPS(bits, BE_LE, is_be, template_size, typeX_t) \
|
||||
static void yuv2plane1_ ## bits ## BE_LE ## _c(const int16_t *src, \
|
||||
uint8_t *dest, int dstW, \
|
||||
const uint8_t *dither, int offset)\
|
||||
{ \
|
||||
const typeX_t **lumSrc = (const typeX_t **) _lumSrc, \
|
||||
**chrUSrc = (const typeX_t **) _chrUSrc, \
|
||||
**chrVSrc = (const typeX_t **) _chrVSrc, \
|
||||
**alpSrc = (const typeX_t **) _alpSrc; \
|
||||
yuv2yuvX_template_fn(lumFilter, lumSrc, lumFilterSize, \
|
||||
chrFilter, chrUSrc, chrVSrc, chrFilterSize, \
|
||||
alpSrc, (uint16_t **) _dest, \
|
||||
dstW, chrDstW, is_be, bits); \
|
||||
yuv2plane1_ ## template_size ## _c_template((const typeX_t *) src, \
|
||||
(uint16_t *) dest, dstW, is_be, bits); \
|
||||
}\
|
||||
static void yuv2planeX_ ## bits ## BE_LE ## _c(const int16_t *filter, int filterSize, \
|
||||
const int16_t **src, uint8_t *dest, int dstW, \
|
||||
const uint8_t *dither, int offset)\
|
||||
{ \
|
||||
yuv2planeX_## template_size ## _c_template(filter, \
|
||||
filterSize, (const typeX_t **) src, \
|
||||
(uint16_t *) dest, dstW, is_be, bits); \
|
||||
}
|
||||
yuv2NBPS( 9, BE, 1, yuv2yuvX10_c_template, int16_t);
|
||||
yuv2NBPS( 9, LE, 0, yuv2yuvX10_c_template, int16_t);
|
||||
yuv2NBPS(10, BE, 1, yuv2yuvX10_c_template, int16_t);
|
||||
yuv2NBPS(10, LE, 0, yuv2yuvX10_c_template, int16_t);
|
||||
yuv2NBPS(16, BE, 1, yuv2yuvX16_c_template, int32_t);
|
||||
yuv2NBPS(16, LE, 0, yuv2yuvX16_c_template, int32_t);
|
||||
yuv2NBPS( 9, BE, 1, 10, int16_t);
|
||||
yuv2NBPS( 9, LE, 0, 10, int16_t);
|
||||
yuv2NBPS(10, BE, 1, 10, int16_t);
|
||||
yuv2NBPS(10, LE, 0, 10, int16_t);
|
||||
yuv2NBPS(16, BE, 1, 16, int32_t);
|
||||
yuv2NBPS(16, LE, 0, 16, int32_t);
|
||||
|
||||
static void yuv2yuvX_c(SwsContext *c, const int16_t *lumFilter,
|
||||
const int16_t **lumSrc, int lumFilterSize,
|
||||
const int16_t *chrFilter, const int16_t **chrUSrc,
|
||||
const int16_t **chrVSrc,
|
||||
int chrFilterSize, const int16_t **alpSrc,
|
||||
uint8_t *dest[4], int dstW, int chrDstW)
|
||||
static void yuv2planeX_8_c(const int16_t *filter, int filterSize,
|
||||
const int16_t **src, uint8_t *dest, int dstW,
|
||||
const uint8_t *dither, int offset)
|
||||
{
|
||||
uint8_t *yDest = dest[0], *uDest = dest[1], *vDest = dest[2],
|
||||
*aDest = CONFIG_SWSCALE_ALPHA ? dest[3] : NULL;
|
||||
int i;
|
||||
const uint8_t *lumDither = c->lumDither8, *chrDither = c->chrDither8;
|
||||
|
||||
//FIXME Optimize (just quickly written not optimized..)
|
||||
for (i=0; i<dstW; i++) {
|
||||
int val = lumDither[i & 7] << 12;
|
||||
int val = dither[(i + offset) & 7] << 12;
|
||||
int j;
|
||||
for (j=0; j<lumFilterSize; j++)
|
||||
val += lumSrc[j][i] * lumFilter[j];
|
||||
for (j=0; j<filterSize; j++)
|
||||
val += src[j][i] * filter[j];
|
||||
|
||||
yDest[i]= av_clip_uint8(val>>19);
|
||||
}
|
||||
|
||||
if (uDest)
|
||||
for (i=0; i<chrDstW; i++) {
|
||||
int u = chrDither[i & 7] << 12;
|
||||
int v = chrDither[(i + 3) & 7] << 12;
|
||||
int j;
|
||||
for (j=0; j<chrFilterSize; j++) {
|
||||
u += chrUSrc[j][i] * chrFilter[j];
|
||||
v += chrVSrc[j][i] * chrFilter[j];
|
||||
}
|
||||
|
||||
uDest[i]= av_clip_uint8(u>>19);
|
||||
vDest[i]= av_clip_uint8(v>>19);
|
||||
}
|
||||
|
||||
if (CONFIG_SWSCALE_ALPHA && aDest)
|
||||
for (i=0; i<dstW; i++) {
|
||||
int val = lumDither[i & 7] << 12;
|
||||
int j;
|
||||
for (j=0; j<lumFilterSize; j++)
|
||||
val += alpSrc[j][i] * lumFilter[j];
|
||||
|
||||
aDest[i]= av_clip_uint8(val>>19);
|
||||
dest[i]= av_clip_uint8(val>>19);
|
||||
}
|
||||
}
|
||||
|
||||
static void yuv2yuv1_c(SwsContext *c, const int16_t *lumSrc,
|
||||
const int16_t *chrUSrc, const int16_t *chrVSrc,
|
||||
const int16_t *alpSrc,
|
||||
uint8_t *dest[4], int dstW, int chrDstW)
|
||||
static void yuv2plane1_8_c(const int16_t *src, uint8_t *dest, int dstW,
|
||||
const uint8_t *dither, int offset)
|
||||
{
|
||||
uint8_t *yDest = dest[0], *uDest = dest[1], *vDest = dest[2],
|
||||
*aDest = CONFIG_SWSCALE_ALPHA ? dest[3] : NULL;
|
||||
int i;
|
||||
const uint8_t *lumDither = c->lumDither8, *chrDither = c->chrDither8;
|
||||
|
||||
for (i=0; i<dstW; i++) {
|
||||
int val = (lumSrc[i]+ lumDither[i & 7]) >> 7;
|
||||
yDest[i]= av_clip_uint8(val);
|
||||
}
|
||||
|
||||
if (uDest)
|
||||
for (i=0; i<chrDstW; i++) {
|
||||
int u = (chrUSrc[i] + chrDither[i & 7]) >> 7;
|
||||
int v = (chrVSrc[i] + chrDither[(i + 3) & 7]) >> 7;
|
||||
uDest[i]= av_clip_uint8(u);
|
||||
vDest[i]= av_clip_uint8(v);
|
||||
}
|
||||
|
||||
if (CONFIG_SWSCALE_ALPHA && aDest)
|
||||
for (i=0; i<dstW; i++) {
|
||||
int val = (alpSrc[i] + lumDither[i & 7]) >> 7;
|
||||
aDest[i]= av_clip_uint8(val);
|
||||
int val = (src[i] + dither[(i + offset) & 7]) >> 7;
|
||||
dest[i]= av_clip_uint8(val);
|
||||
}
|
||||
}
|
||||
|
||||
static void yuv2nv12X_c(SwsContext *c, const int16_t *lumFilter,
|
||||
const int16_t **lumSrc, int lumFilterSize,
|
||||
const int16_t *chrFilter, const int16_t **chrUSrc,
|
||||
const int16_t **chrVSrc, int chrFilterSize,
|
||||
const int16_t **alpSrc, uint8_t *dest[4],
|
||||
int dstW, int chrDstW)
|
||||
static void yuv2nv12cX_c(SwsContext *c, const int16_t *chrFilter, int chrFilterSize,
|
||||
const int16_t **chrUSrc, const int16_t **chrVSrc,
|
||||
uint8_t *dest, int chrDstW)
|
||||
{
|
||||
uint8_t *yDest = dest[0], *uDest = dest[1];
|
||||
enum PixelFormat dstFormat = c->dstFormat;
|
||||
const uint8_t *lumDither = c->lumDither8, *chrDither = c->chrDither8;
|
||||
|
||||
//FIXME Optimize (just quickly written not optimized..)
|
||||
const uint8_t *chrDither = c->chrDither8;
|
||||
int i;
|
||||
for (i=0; i<dstW; i++) {
|
||||
int val = lumDither[i & 7] << 12;
|
||||
int j;
|
||||
for (j=0; j<lumFilterSize; j++)
|
||||
val += lumSrc[j][i] * lumFilter[j];
|
||||
|
||||
yDest[i]= av_clip_uint8(val>>19);
|
||||
}
|
||||
|
||||
if (!uDest)
|
||||
return;
|
||||
|
||||
if (dstFormat == PIX_FMT_NV12)
|
||||
for (i=0; i<chrDstW; i++) {
|
||||
@ -547,8 +445,8 @@ static void yuv2nv12X_c(SwsContext *c, const int16_t *lumFilter,
|
||||
v += chrVSrc[j][i] * chrFilter[j];
|
||||
}
|
||||
|
||||
uDest[2*i]= av_clip_uint8(u>>19);
|
||||
uDest[2*i+1]= av_clip_uint8(v>>19);
|
||||
dest[2*i]= av_clip_uint8(u>>19);
|
||||
dest[2*i+1]= av_clip_uint8(v>>19);
|
||||
}
|
||||
else
|
||||
for (i=0; i<chrDstW; i++) {
|
||||
@ -560,8 +458,8 @@ static void yuv2nv12X_c(SwsContext *c, const int16_t *lumFilter,
|
||||
v += chrVSrc[j][i] * chrFilter[j];
|
||||
}
|
||||
|
||||
uDest[2*i]= av_clip_uint8(v>>19);
|
||||
uDest[2*i+1]= av_clip_uint8(u>>19);
|
||||
dest[2*i]= av_clip_uint8(v>>19);
|
||||
dest[2*i+1]= av_clip_uint8(u>>19);
|
||||
}
|
||||
}
|
||||
|
||||
@ -2310,26 +2208,31 @@ static av_always_inline void hcscale(SwsContext *c, int16_t *dst1, int16_t *dst2
|
||||
|
||||
static av_always_inline void
|
||||
find_c_packed_planar_out_funcs(SwsContext *c,
|
||||
yuv2planar1_fn *yuv2yuv1, yuv2planarX_fn *yuv2yuvX,
|
||||
yuv2planar1_fn *yuv2plane1, yuv2planarX_fn *yuv2planeX,
|
||||
yuv2interleavedX_fn *yuv2nv12cX,
|
||||
yuv2packed1_fn *yuv2packed1, yuv2packed2_fn *yuv2packed2,
|
||||
yuv2packedX_fn *yuv2packedX)
|
||||
{
|
||||
enum PixelFormat dstFormat = c->dstFormat;
|
||||
|
||||
if (dstFormat == PIX_FMT_NV12 || dstFormat == PIX_FMT_NV21) {
|
||||
*yuv2yuvX = yuv2nv12X_c;
|
||||
} else if (is16BPS(dstFormat)) {
|
||||
*yuv2yuvX = isBE(dstFormat) ? yuv2yuvX16BE_c : yuv2yuvX16LE_c;
|
||||
if (is16BPS(dstFormat)) {
|
||||
*yuv2planeX = isBE(dstFormat) ? yuv2planeX_16BE_c : yuv2planeX_16LE_c;
|
||||
*yuv2plane1 = isBE(dstFormat) ? yuv2plane1_16BE_c : yuv2plane1_16LE_c;
|
||||
} else if (is9_OR_10BPS(dstFormat)) {
|
||||
if (av_pix_fmt_descriptors[dstFormat].comp[0].depth_minus1 == 8) {
|
||||
*yuv2yuvX = isBE(dstFormat) ? yuv2yuvX9BE_c : yuv2yuvX9LE_c;
|
||||
*yuv2planeX = isBE(dstFormat) ? yuv2planeX_9BE_c : yuv2planeX_9LE_c;
|
||||
*yuv2plane1 = isBE(dstFormat) ? yuv2plane1_9BE_c : yuv2plane1_9LE_c;
|
||||
} else {
|
||||
*yuv2yuvX = isBE(dstFormat) ? yuv2yuvX10BE_c : yuv2yuvX10LE_c;
|
||||
*yuv2planeX = isBE(dstFormat) ? yuv2planeX_10BE_c : yuv2planeX_10LE_c;
|
||||
*yuv2plane1 = isBE(dstFormat) ? yuv2plane1_10BE_c : yuv2plane1_10LE_c;
|
||||
}
|
||||
} else {
|
||||
*yuv2yuv1 = yuv2yuv1_c;
|
||||
*yuv2yuvX = yuv2yuvX_c;
|
||||
*yuv2plane1 = yuv2plane1_8_c;
|
||||
*yuv2planeX = yuv2planeX_8_c;
|
||||
if (dstFormat == PIX_FMT_NV12 || dstFormat == PIX_FMT_NV21)
|
||||
*yuv2nv12cX = yuv2nv12cX_c;
|
||||
}
|
||||
|
||||
if(c->flags & SWS_FULL_CHR_H_INT) {
|
||||
switch (dstFormat) {
|
||||
case PIX_FMT_RGBA:
|
||||
@ -2591,10 +2494,11 @@ static int swScale(SwsContext *c, const uint8_t* src[],
|
||||
const int chrSrcSliceH= -((-srcSliceH) >> c->chrSrcVSubSample);
|
||||
int lastDstY;
|
||||
uint32_t *pal=c->pal_yuv;
|
||||
|
||||
int should_dither= isNBPS(c->srcFormat) || is16BPS(c->srcFormat);
|
||||
yuv2planar1_fn yuv2yuv1 = c->yuv2yuv1;
|
||||
yuv2planarX_fn yuv2yuvX = c->yuv2yuvX;
|
||||
|
||||
yuv2planar1_fn yuv2plane1 = c->yuv2plane1;
|
||||
yuv2planarX_fn yuv2planeX = c->yuv2planeX;
|
||||
yuv2interleavedX_fn yuv2nv12cX = c->yuv2nv12cX;
|
||||
yuv2packed1_fn yuv2packed1 = c->yuv2packed1;
|
||||
yuv2packed2_fn yuv2packed2 = c->yuv2packed2;
|
||||
yuv2packedX_fn yuv2packedX = c->yuv2packedX;
|
||||
@ -2748,9 +2652,8 @@ static int swScale(SwsContext *c, const uint8_t* src[],
|
||||
}
|
||||
if (dstY >= dstH-2) {
|
||||
// hmm looks like we can't use MMX here without overwriting this array's tail
|
||||
find_c_packed_planar_out_funcs(c, &yuv2yuv1, &yuv2yuvX,
|
||||
&yuv2packed1, &yuv2packed2,
|
||||
&yuv2packedX);
|
||||
find_c_packed_planar_out_funcs(c, &yuv2plane1, &yuv2planeX, &yuv2nv12cX,
|
||||
&yuv2packed1, &yuv2packed2, &yuv2packedX);
|
||||
}
|
||||
|
||||
{
|
||||
@ -2761,18 +2664,35 @@ static int swScale(SwsContext *c, const uint8_t* src[],
|
||||
|
||||
if (isPlanarYUV(dstFormat) || dstFormat==PIX_FMT_GRAY8) { //YV12 like
|
||||
const int chrSkipMask= (1<<c->chrDstVSubSample)-1;
|
||||
if ((dstY&chrSkipMask) || isGray(dstFormat))
|
||||
dest[1] = dest[2] = NULL; //FIXME split functions in lumi / chromi
|
||||
if (c->yuv2yuv1 && vLumFilterSize == 1 && vChrFilterSize == 1) { // unscaled YV12
|
||||
const int16_t *alpBuf= (CONFIG_SWSCALE_ALPHA && alpPixBuf) ? alpSrcPtr[0] : NULL;
|
||||
yuv2yuv1(c, lumSrcPtr[0], chrUSrcPtr[0], chrVSrcPtr[0], alpBuf,
|
||||
dest, dstW, chrDstW);
|
||||
} else { //General YV12
|
||||
yuv2yuvX(c, vLumFilter + dstY * vLumFilterSize,
|
||||
lumSrcPtr, vLumFilterSize,
|
||||
vChrFilter + chrDstY * vChrFilterSize,
|
||||
chrUSrcPtr, chrVSrcPtr, vChrFilterSize,
|
||||
alpSrcPtr, dest, dstW, chrDstW);
|
||||
|
||||
if (vLumFilterSize == 1) {
|
||||
yuv2plane1(lumSrcPtr[0], dest[0], dstW, c->lumDither8, 0);
|
||||
} else {
|
||||
yuv2planeX(vLumFilter + dstY * vLumFilterSize, vLumFilterSize,
|
||||
lumSrcPtr, dest[0], dstW, c->lumDither8, 0);
|
||||
}
|
||||
|
||||
if (!((dstY&chrSkipMask) || isGray(dstFormat))) {
|
||||
if (yuv2nv12cX) {
|
||||
yuv2nv12cX(c, vChrFilter + chrDstY * vChrFilterSize, vChrFilterSize, chrUSrcPtr, chrVSrcPtr, dest[1], chrDstW);
|
||||
} else if (vChrFilterSize == 1) {
|
||||
yuv2plane1(chrUSrcPtr[0], dest[1], chrDstW, c->chrDither8, 0);
|
||||
yuv2plane1(chrVSrcPtr[0], dest[2], chrDstW, c->chrDither8, 3);
|
||||
} else {
|
||||
yuv2planeX(vChrFilter + chrDstY * vChrFilterSize, vChrFilterSize,
|
||||
chrUSrcPtr, dest[1], chrDstW, c->chrDither8, 0);
|
||||
yuv2planeX(vChrFilter + chrDstY * vChrFilterSize, vChrFilterSize,
|
||||
chrVSrcPtr, dest[2], chrDstW, c->chrDither8, 3);
|
||||
}
|
||||
}
|
||||
|
||||
if (CONFIG_SWSCALE_ALPHA && alpPixBuf){
|
||||
if (vLumFilterSize == 1) {
|
||||
yuv2plane1(alpSrcPtr[0], dest[3], dstW, c->lumDither8, 0);
|
||||
} else {
|
||||
yuv2planeX(vLumFilter + dstY * vLumFilterSize, vLumFilterSize,
|
||||
alpSrcPtr, dest[3], dstW, c->lumDither8, 0);
|
||||
}
|
||||
}
|
||||
} else {
|
||||
assert(lumSrcPtr + vLumFilterSize - 1 < lumPixBuf + vLumBufSize*2);
|
||||
@ -2826,8 +2746,8 @@ static av_cold void sws_init_swScale_c(SwsContext *c)
|
||||
{
|
||||
enum PixelFormat srcFormat = c->srcFormat;
|
||||
|
||||
find_c_packed_planar_out_funcs(c, &c->yuv2yuv1, &c->yuv2yuvX,
|
||||
&c->yuv2packed1, &c->yuv2packed2,
|
||||
find_c_packed_planar_out_funcs(c, &c->yuv2plane1, &c->yuv2planeX,
|
||||
&c->yuv2nv12cX, &c->yuv2packed1, &c->yuv2packed2,
|
||||
&c->yuv2packedX);
|
||||
|
||||
c->chrToYV12 = NULL;
|
||||
|
@ -61,56 +61,58 @@ typedef int (*SwsFunc)(struct SwsContext *context, const uint8_t* src[],
|
||||
int srcStride[], int srcSliceY, int srcSliceH,
|
||||
uint8_t* dst[], int dstStride[]);
|
||||
|
||||
|
||||
/**
|
||||
* Write one line of horizontally scaled Y/U/V/A to planar output
|
||||
* Write one line of horizontally scaled data to planar output
|
||||
* without any additional vertical scaling (or point-scaling).
|
||||
*
|
||||
* @param c SWS scaling context
|
||||
* @param lumSrc scaled luma (Y) source data, 15bit for 8-10bit output,
|
||||
* @param src scaled source data, 15bit for 8-10bit output,
|
||||
* 19-bit for 16bit output (in int32_t)
|
||||
* @param chrUSrc scaled chroma (U) source data, 15bit for 8-10bit output,
|
||||
* 19-bit for 16bit output (in int32_t)
|
||||
* @param chrVSrc scaled chroma (V) source data, 15bit for 8-10bit output,
|
||||
* 19-bit for 16bit output (in int32_t)
|
||||
* @param alpSrc scaled alpha (A) source data, 15bit for 8-10bit output,
|
||||
* 19-bit for 16bit output (in int32_t)
|
||||
* @param dest pointer to the 4 output planes (Y/U/V/A). For >8bit
|
||||
* @param dest pointer to the output plane. For >8bit
|
||||
* output, this is in uint16_t
|
||||
* @param dstW width of dest[0], dest[3], lumSrc and alpSrc in pixels
|
||||
* @param chrDstW width of dest[1], dest[2], chrUSrc and chrVSrc
|
||||
* @param dstW width of destination in pixels
|
||||
* @param dither ordered dither array of type int16_t and size 8
|
||||
* @param offset Dither offset
|
||||
*/
|
||||
typedef void (*yuv2planar1_fn) (struct SwsContext *c,
|
||||
const int16_t *lumSrc, const int16_t *chrUSrc,
|
||||
const int16_t *chrVSrc, const int16_t *alpSrc,
|
||||
uint8_t *dest[4], int dstW, int chrDstW);
|
||||
typedef void (*yuv2planar1_fn) (const int16_t *src, uint8_t *dest, int dstW,
|
||||
const uint8_t *dither, int offset);
|
||||
|
||||
/**
|
||||
* Write one line of horizontally scaled Y/U/V/A to planar output
|
||||
* Write one line of horizontally scaled data to planar output
|
||||
* with multi-point vertical scaling between input pixels.
|
||||
*
|
||||
* @param filter vertical luma/alpha scaling coefficients, 12bit [0,4096]
|
||||
* @param src scaled luma (Y) or alpha (A) source data, 15bit for 8-10bit output,
|
||||
* 19-bit for 16bit output (in int32_t)
|
||||
* @param filterSize number of vertical input lines to scale
|
||||
* @param dest pointer to output plane. For >8bit
|
||||
* output, this is in uint16_t
|
||||
* @param dstW width of destination pixels
|
||||
* @param offset Dither offset
|
||||
*/
|
||||
typedef void (*yuv2planarX_fn) (const int16_t *filter, int filterSize,
|
||||
const int16_t **src, uint8_t *dest, int dstW,
|
||||
const uint8_t *dither, int offset);
|
||||
|
||||
/**
|
||||
* Write one line of horizontally scaled chroma to interleaved output
|
||||
* with multi-point vertical scaling between input pixels.
|
||||
*
|
||||
* @param c SWS scaling context
|
||||
* @param lumFilter vertical luma/alpha scaling coefficients, 12bit [0,4096]
|
||||
* @param lumSrc scaled luma (Y) source data, 15bit for 8-10bit output,
|
||||
* 19-bit for 16bit output (in int32_t)
|
||||
* @param lumFilterSize number of vertical luma/alpha input lines to scale
|
||||
* @param chrFilter vertical chroma scaling coefficients, 12bit [0,4096]
|
||||
* @param chrUSrc scaled chroma (U) source data, 15bit for 8-10bit output,
|
||||
* 19-bit for 16bit output (in int32_t)
|
||||
* @param chrVSrc scaled chroma (V) source data, 15bit for 8-10bit output,
|
||||
* 19-bit for 16bit output (in int32_t)
|
||||
* @param chrFilterSize number of vertical chroma input lines to scale
|
||||
* @param alpSrc scaled alpha (A) source data, 15bit for 8-10bit output,
|
||||
* 19-bit for 16bit output (in int32_t)
|
||||
* @param dest pointer to the 4 output planes (Y/U/V/A). For >8bit
|
||||
* @param dest pointer to the output plane. For >8bit
|
||||
* output, this is in uint16_t
|
||||
* @param dstW width of dest[0], dest[3], lumSrc and alpSrc in pixels
|
||||
* @param chrDstW width of dest[1], dest[2], chrUSrc and chrVSrc
|
||||
* @param dstW width of chroma planes
|
||||
*/
|
||||
typedef void (*yuv2planarX_fn) (struct SwsContext *c, const int16_t *lumFilter,
|
||||
const int16_t **lumSrc, int lumFilterSize,
|
||||
const int16_t *chrFilter, const int16_t **chrUSrc,
|
||||
const int16_t **chrVSrc, int chrFilterSize,
|
||||
const int16_t **alpSrc, uint8_t *dest[4],
|
||||
int dstW, int chrDstW);
|
||||
typedef void (*yuv2interleavedX_fn) (struct SwsContext *c, const int16_t *chrFilter, int chrFilterSize,
|
||||
const int16_t **chrUSrc, const int16_t **chrVSrc,
|
||||
uint8_t *dest, int dstW);
|
||||
|
||||
/**
|
||||
* Write one line of horizontally scaled Y/U/V/A to packed-pixel YUV/RGB
|
||||
* output without any additional vertical scaling (or point-scaling). Note
|
||||
@ -412,8 +414,9 @@ typedef struct SwsContext {
|
||||
#endif
|
||||
|
||||
/* function pointers for swScale() */
|
||||
yuv2planar1_fn yuv2yuv1;
|
||||
yuv2planarX_fn yuv2yuvX;
|
||||
yuv2planar1_fn yuv2plane1;
|
||||
yuv2planarX_fn yuv2planeX;
|
||||
yuv2interleavedX_fn yuv2nv12cX;
|
||||
yuv2packed1_fn yuv2packed1;
|
||||
yuv2packed2_fn yuv2packed2;
|
||||
yuv2packedX_fn yuv2packedX;
|
||||
|
@ -1,6 +1,7 @@
|
||||
;******************************************************************************
|
||||
;* x86-optimized horizontal line scaling functions
|
||||
;* x86-optimized horizontal/vertical line scaling functions
|
||||
;* Copyright (c) 2011 Ronald S. Bultje <rsbultje@gmail.com>
|
||||
;* Kieran Kunhya <kieran@kunhya.com>
|
||||
;*
|
||||
;* This file is part of Libav.
|
||||
;*
|
||||
@ -28,6 +29,11 @@ max_19bit_int: times 4 dd 0x7ffff
|
||||
max_19bit_flt: times 4 dd 524287.0
|
||||
minshort: times 8 dw 0x8000
|
||||
unicoeff: times 4 dd 0x20000000
|
||||
yuv2yuvX_16_start: times 4 dd 0x4000 - 0x40000000
|
||||
yuv2yuvX_10_start: times 4 dd 0x10000
|
||||
yuv2yuvX_9_start: times 4 dd 0x20000
|
||||
yuv2yuvX_10_upper: times 8 dw 0x3ff
|
||||
yuv2yuvX_9_upper: times 8 dw 0x1ff
|
||||
|
||||
SECTION .text
|
||||
|
||||
@ -429,3 +435,233 @@ INIT_XMM
|
||||
SCALE_FUNCS2 sse2, 6, 7, 8
|
||||
SCALE_FUNCS2 ssse3, 6, 6, 8
|
||||
SCALE_FUNCS2 sse4, 6, 6, 8
|
||||
|
||||
;-----------------------------------------------------------------------------
|
||||
; vertical line scaling
|
||||
;
|
||||
; void yuv2plane1_<output_size>_<opt>(const int16_t *src, uint8_t *dst, int dstW,
|
||||
; const uint8_t *dither, int offset)
|
||||
; and
|
||||
; void yuv2planeX_<output_size>_<opt>(const int16_t *filter, int filterSize,
|
||||
; const int16_t **src, uint8_t *dst, int dstW,
|
||||
; const uint8_t *dither, int offset)
|
||||
;
|
||||
; Scale one or $filterSize lines of source data to generate one line of output
|
||||
; data. The input is 15-bit in int16_t if $output_size is [8,10] and 19-bit in
|
||||
; int32_t if $output_size is 16. $filter is 12-bits. $filterSize is a multiple
|
||||
; of 2. $offset is either 0 or 3. $dither holds 8 values.
|
||||
;-----------------------------------------------------------------------------
|
||||
|
||||
%macro yuv2planeX_fn 4
|
||||
|
||||
%ifdef ARCH_X86_32
|
||||
%define cntr_reg r1
|
||||
%define movsx mov
|
||||
%else
|
||||
%define cntr_reg r11
|
||||
%define movsx movsxd
|
||||
%endif
|
||||
|
||||
cglobal yuv2planeX_%2_%1, %4, 7, %3
|
||||
%if %2 == 8 || %2 == 9 || %2 == 10
|
||||
pxor m6, m6
|
||||
%endif ; %2 == 8/9/10
|
||||
|
||||
%if %2 == 8
|
||||
%ifdef ARCH_X86_32
|
||||
%assign pad 0x2c - (stack_offset & 15)
|
||||
SUB rsp, pad
|
||||
%define m_dith m7
|
||||
%else ; x86-64
|
||||
%define m_dith m9
|
||||
%endif ; x86-32
|
||||
|
||||
; create registers holding dither
|
||||
movq m_dith, [r5] ; dither
|
||||
test r6d, r6d
|
||||
jz .no_rot
|
||||
%if mmsize == 16
|
||||
punpcklqdq m_dith, m_dith
|
||||
%endif ; mmsize == 16
|
||||
PALIGNR m_dith, m_dith, 3, m0
|
||||
.no_rot:
|
||||
%if mmsize == 16
|
||||
punpcklbw m_dith, m6
|
||||
%ifdef ARCH_X86_64
|
||||
punpcklwd m8, m_dith, m6
|
||||
pslld m8, 12
|
||||
%else ; x86-32
|
||||
punpcklwd m5, m_dith, m6
|
||||
pslld m5, 12
|
||||
%endif ; x86-32/64
|
||||
punpckhwd m_dith, m6
|
||||
pslld m_dith, 12
|
||||
%ifdef ARCH_X86_32
|
||||
mova [rsp+ 0], m5
|
||||
mova [rsp+16], m_dith
|
||||
%endif
|
||||
%else ; mmsize == 8
|
||||
punpcklbw m5, m_dith, m6
|
||||
punpckhbw m_dith, m6
|
||||
punpcklwd m4, m5, m6
|
||||
punpckhwd m5, m6
|
||||
punpcklwd m3, m_dith, m6
|
||||
punpckhwd m_dith, m6
|
||||
pslld m4, 12
|
||||
pslld m5, 12
|
||||
pslld m3, 12
|
||||
pslld m_dith, 12
|
||||
mova [rsp+ 0], m4
|
||||
mova [rsp+ 8], m5
|
||||
mova [rsp+16], m3
|
||||
mova [rsp+24], m_dith
|
||||
%endif ; mmsize == 8/16
|
||||
%endif ; %2 == 8
|
||||
|
||||
xor r5, r5
|
||||
|
||||
.pixelloop
|
||||
%assign %%i 0
|
||||
; the rep here is for the 8bit output mmx case, where dither covers
|
||||
; 8 pixels but we can only handle 2 pixels per register, and thus 4
|
||||
; pixels per iteration. In order to not have to keep track of where
|
||||
; we are w.r.t. dithering, we unroll the mmx/8bit loop x2.
|
||||
%if %2 == 8
|
||||
%rep 16/mmsize
|
||||
%endif ; %2 == 8
|
||||
|
||||
%if %2 == 8
|
||||
%ifdef ARCH_X86_32
|
||||
mova m2, [rsp+mmsize*(0+%%i)]
|
||||
mova m1, [rsp+mmsize*(1+%%i)]
|
||||
%else ; x86-64
|
||||
mova m2, m8
|
||||
mova m1, m_dith
|
||||
%endif ; x86-32/64
|
||||
%else ; %2 == 9/10/16
|
||||
mova m1, [yuv2yuvX_%2_start]
|
||||
mova m2, m1
|
||||
%endif ; %2 == 8/9/10/16
|
||||
movsx cntr_reg, r1m
|
||||
.filterloop_ %+ %%i
|
||||
; input pixels
|
||||
mov r6, [r2+gprsize*cntr_reg-2*gprsize]
|
||||
%if %2 == 16
|
||||
mova m3, [r6+r5*4]
|
||||
mova m5, [r6+r5*4+mmsize]
|
||||
%else ; %2 == 8/9/10
|
||||
mova m3, [r6+r5*2]
|
||||
%endif ; %2 == 8/9/10/16
|
||||
mov r6, [r2+gprsize*cntr_reg-gprsize]
|
||||
%if %2 == 16
|
||||
mova m4, [r6+r5*4]
|
||||
mova m6, [r6+r5*4+mmsize]
|
||||
%else ; %2 == 8/9/10
|
||||
mova m4, [r6+r5*2]
|
||||
%endif ; %2 == 8/9/10/16
|
||||
|
||||
; coefficients
|
||||
movd m0, [r0+2*cntr_reg-4]; coeff[0], coeff[1]
|
||||
%if %2 == 16
|
||||
pshuflw m7, m0, 0 ; coeff[0]
|
||||
pshuflw m0, m0, 0x55 ; coeff[1]
|
||||
pmovsxwd m7, m7 ; word -> dword
|
||||
pmovsxwd m0, m0 ; word -> dword
|
||||
|
||||
pmulld m3, m7
|
||||
pmulld m5, m7
|
||||
pmulld m4, m0
|
||||
pmulld m6, m0
|
||||
|
||||
paddd m2, m3
|
||||
paddd m1, m5
|
||||
paddd m2, m4
|
||||
paddd m1, m6
|
||||
%else ; %2 == 10/9/8
|
||||
punpcklwd m5, m3, m4
|
||||
punpckhwd m3, m4
|
||||
SPLATD m0, m0
|
||||
|
||||
pmaddwd m5, m0
|
||||
pmaddwd m3, m0
|
||||
|
||||
paddd m2, m5
|
||||
paddd m1, m3
|
||||
%endif ; %2 == 8/9/10/16
|
||||
|
||||
sub cntr_reg, 2
|
||||
jg .filterloop_ %+ %%i
|
||||
|
||||
%if %2 == 16
|
||||
psrad m2, 31 - %2
|
||||
psrad m1, 31 - %2
|
||||
%else ; %2 == 10/9/8
|
||||
psrad m2, 27 - %2
|
||||
psrad m1, 27 - %2
|
||||
%endif ; %2 == 8/9/10/16
|
||||
|
||||
%if %2 == 8
|
||||
packssdw m2, m1
|
||||
packuswb m2, m2
|
||||
movh [r3+r5*1], m2
|
||||
%else ; %2 == 9/10/16
|
||||
%if %2 == 16
|
||||
packssdw m2, m1
|
||||
paddw m2, [minshort]
|
||||
%else ; %2 == 9/10
|
||||
%ifidn %1, sse4
|
||||
packusdw m2, m1
|
||||
%elifidn %1, avx
|
||||
packusdw m2, m1
|
||||
%else ; mmx2/sse2
|
||||
packssdw m2, m1
|
||||
pmaxsw m2, m6
|
||||
%endif ; mmx2/sse2/sse4/avx
|
||||
pminsw m2, [yuv2yuvX_%2_upper]
|
||||
%endif ; %2 == 9/10/16
|
||||
mova [r3+r5*2], m2
|
||||
%endif ; %2 == 8/9/10/16
|
||||
|
||||
add r5, mmsize/2
|
||||
sub r4d, mmsize/2
|
||||
%if %2 == 8
|
||||
%assign %%i %%i+2
|
||||
%endrep
|
||||
%endif ; %2 == 8
|
||||
jg .pixelloop
|
||||
|
||||
%if %2 == 8
|
||||
%ifdef ARCH_X86_32
|
||||
ADD rsp, pad
|
||||
RET
|
||||
%else ; x86-64
|
||||
REP_RET
|
||||
%endif ; x86-32/64
|
||||
%else ; %2 == 9/10/16
|
||||
REP_RET
|
||||
%endif ; %2 == 8/9/10/16
|
||||
%endmacro
|
||||
|
||||
%define PALIGNR PALIGNR_MMX
|
||||
%ifdef ARCH_X86_32
|
||||
INIT_MMX
|
||||
yuv2planeX_fn mmx, 8, 0, 7
|
||||
yuv2planeX_fn mmx2, 9, 0, 5
|
||||
yuv2planeX_fn mmx2, 10, 0, 5
|
||||
%endif
|
||||
|
||||
INIT_XMM
|
||||
yuv2planeX_fn sse2, 8, 10, 7
|
||||
yuv2planeX_fn sse2, 9, 7, 5
|
||||
yuv2planeX_fn sse2, 10, 7, 5
|
||||
|
||||
%define PALIGNR PALIGNR_SSSE3
|
||||
yuv2planeX_fn sse4, 8, 10, 7
|
||||
yuv2planeX_fn sse4, 9, 7, 5
|
||||
yuv2planeX_fn sse4, 10, 7, 5
|
||||
yuv2planeX_fn sse4, 16, 8, 5
|
||||
|
||||
INIT_AVX
|
||||
yuv2planeX_fn avx, 8, 10, 7
|
||||
yuv2planeX_fn avx, 9, 7, 5
|
||||
yuv2planeX_fn avx, 10, 7, 5
|
||||
|
@ -213,6 +213,23 @@ SCALE_FUNCS_SSE(sse2);
|
||||
SCALE_FUNCS_SSE(ssse3);
|
||||
SCALE_FUNCS_SSE(sse4);
|
||||
|
||||
#define VSCALEX_FUNC(size, opt) \
|
||||
extern void ff_yuv2planeX_ ## size ## _ ## opt(const int16_t *filter, int filterSize, \
|
||||
const int16_t **src, uint8_t *dest, int dstW, \
|
||||
const uint8_t *dither, int offset)
|
||||
#define VSCALEX_FUNCS(opt1, opt2) \
|
||||
VSCALEX_FUNC(8, opt1); \
|
||||
VSCALEX_FUNC(9, opt2); \
|
||||
VSCALEX_FUNC(10, opt2)
|
||||
|
||||
#if ARCH_X86_32
|
||||
VSCALEX_FUNCS(mmx, mmx2);
|
||||
#endif
|
||||
VSCALEX_FUNCS(sse2, sse2);
|
||||
VSCALEX_FUNCS(sse4, sse4);
|
||||
VSCALEX_FUNC(16, sse4);
|
||||
VSCALEX_FUNCS(avx, avx);
|
||||
|
||||
void ff_sws_init_swScale_mmx(SwsContext *c)
|
||||
{
|
||||
int cpu_flags = av_get_cpu_flags();
|
||||
@ -249,10 +266,18 @@ void ff_sws_init_swScale_mmx(SwsContext *c)
|
||||
case 8: ASSIGN_SCALE_FUNC2(hscalefn, 8, opt1, opt2); break; \
|
||||
default: ASSIGN_SCALE_FUNC2(hscalefn, X, opt1, opt2); break; \
|
||||
}
|
||||
#define ASSIGN_VSCALEX_FUNC(vscalefn, opt1, opt2, opt2chk, do_16_case) \
|
||||
switch(c->dstBpc){ \
|
||||
case 16: do_16_case; break; \
|
||||
case 10: if (!isBE(c->dstFormat) && opt2chk) vscalefn = ff_yuv2planeX_10_ ## opt2; break; \
|
||||
case 9: if (!isBE(c->dstFormat) && opt2chk) vscalefn = ff_yuv2planeX_9_ ## opt2; break; \
|
||||
default: vscalefn = ff_yuv2planeX_8_ ## opt1; break; \
|
||||
}
|
||||
#if ARCH_X86_32
|
||||
if (cpu_flags & AV_CPU_FLAG_MMX) {
|
||||
ASSIGN_MMX_SCALE_FUNC(c->hyScale, c->hLumFilterSize, mmx, mmx);
|
||||
ASSIGN_MMX_SCALE_FUNC(c->hcScale, c->hChrFilterSize, mmx, mmx);
|
||||
ASSIGN_VSCALEX_FUNC(c->yuv2planeX, mmx, mmx2, cpu_flags & AV_CPU_FLAG_MMX2,);
|
||||
}
|
||||
#endif
|
||||
#define ASSIGN_SSE_SCALE_FUNC(hscalefn, filtersize, opt1, opt2) \
|
||||
@ -266,6 +291,7 @@ void ff_sws_init_swScale_mmx(SwsContext *c)
|
||||
if (cpu_flags & AV_CPU_FLAG_SSE2) {
|
||||
ASSIGN_SSE_SCALE_FUNC(c->hyScale, c->hLumFilterSize, sse2, sse2);
|
||||
ASSIGN_SSE_SCALE_FUNC(c->hcScale, c->hChrFilterSize, sse2, sse2);
|
||||
ASSIGN_VSCALEX_FUNC(c->yuv2planeX, sse2, sse2, 1,);
|
||||
}
|
||||
if (cpu_flags & AV_CPU_FLAG_SSSE3) {
|
||||
ASSIGN_SSE_SCALE_FUNC(c->hyScale, c->hLumFilterSize, ssse3, ssse3);
|
||||
@ -275,6 +301,12 @@ void ff_sws_init_swScale_mmx(SwsContext *c)
|
||||
/* Xto15 don't need special sse4 functions */
|
||||
ASSIGN_SSE_SCALE_FUNC(c->hyScale, c->hLumFilterSize, sse4, ssse3);
|
||||
ASSIGN_SSE_SCALE_FUNC(c->hcScale, c->hChrFilterSize, sse4, ssse3);
|
||||
ASSIGN_VSCALEX_FUNC(c->yuv2planeX, sse4, sse4, 1,
|
||||
if (!isBE(c->dstFormat)) c->yuv2planeX = ff_yuv2planeX_16_sse4);
|
||||
}
|
||||
|
||||
if (cpu_flags & AV_CPU_FLAG_AVX) {
|
||||
ASSIGN_VSCALEX_FUNC(c->yuv2planeX, avx, avx, 1,);
|
||||
}
|
||||
#endif
|
||||
}
|
||||
|
@ -35,41 +35,6 @@
|
||||
#endif
|
||||
#define MOVNTQ(a,b) REAL_MOVNTQ(a,b)
|
||||
|
||||
#define YSCALEYUV2YV12X(offset, dest, end, pos) \
|
||||
__asm__ volatile(\
|
||||
"movq "DITHER16"+0(%0), %%mm3 \n\t"\
|
||||
"movq "DITHER16"+8(%0), %%mm4 \n\t"\
|
||||
"lea " offset "(%0), %%"REG_d" \n\t"\
|
||||
"mov (%%"REG_d"), %%"REG_S" \n\t"\
|
||||
".p2align 4 \n\t" /* FIXME Unroll? */\
|
||||
"1: \n\t"\
|
||||
"movq 8(%%"REG_d"), %%mm0 \n\t" /* filterCoeff */\
|
||||
"movq (%%"REG_S", %3, 2), %%mm2 \n\t" /* srcData */\
|
||||
"movq 8(%%"REG_S", %3, 2), %%mm5 \n\t" /* srcData */\
|
||||
"add $16, %%"REG_d" \n\t"\
|
||||
"mov (%%"REG_d"), %%"REG_S" \n\t"\
|
||||
"test %%"REG_S", %%"REG_S" \n\t"\
|
||||
"pmulhw %%mm0, %%mm2 \n\t"\
|
||||
"pmulhw %%mm0, %%mm5 \n\t"\
|
||||
"paddw %%mm2, %%mm3 \n\t"\
|
||||
"paddw %%mm5, %%mm4 \n\t"\
|
||||
" jnz 1b \n\t"\
|
||||
"psraw $3, %%mm3 \n\t"\
|
||||
"psraw $3, %%mm4 \n\t"\
|
||||
"packuswb %%mm4, %%mm3 \n\t"\
|
||||
MOVNTQ(%%mm3, (%1, %3))\
|
||||
"add $8, %3 \n\t"\
|
||||
"cmp %2, %3 \n\t"\
|
||||
"movq "DITHER16"+0(%0), %%mm3 \n\t"\
|
||||
"movq "DITHER16"+8(%0), %%mm4 \n\t"\
|
||||
"lea " offset "(%0), %%"REG_d" \n\t"\
|
||||
"mov (%%"REG_d"), %%"REG_S" \n\t"\
|
||||
"jb 1b \n\t"\
|
||||
:: "r" (&c->redDither),\
|
||||
"r" (dest), "g" ((x86_reg)(end)), "r"((x86_reg)(pos))\
|
||||
: "%"REG_d, "%"REG_S\
|
||||
);
|
||||
|
||||
#if !COMPILE_TEMPLATE_MMX2
|
||||
static av_always_inline void
|
||||
dither_8to16(SwsContext *c, const uint8_t *srcDither, int rot)
|
||||
@ -106,170 +71,6 @@ dither_8to16(SwsContext *c, const uint8_t *srcDither, int rot)
|
||||
}
|
||||
#endif
|
||||
|
||||
static void RENAME(yuv2yuvX)(SwsContext *c, const int16_t *lumFilter,
|
||||
const int16_t **lumSrc, int lumFilterSize,
|
||||
const int16_t *chrFilter, const int16_t **chrUSrc,
|
||||
const int16_t **chrVSrc,
|
||||
int chrFilterSize, const int16_t **alpSrc,
|
||||
uint8_t *dest[4], int dstW, int chrDstW)
|
||||
{
|
||||
uint8_t *yDest = dest[0], *uDest = dest[1], *vDest = dest[2],
|
||||
*aDest = CONFIG_SWSCALE_ALPHA ? dest[3] : NULL;
|
||||
const uint8_t *lumDither = c->lumDither8, *chrDither = c->chrDither8;
|
||||
|
||||
if (uDest) {
|
||||
x86_reg uv_off = c->uv_offx2 >> 1;
|
||||
dither_8to16(c, chrDither, 0);
|
||||
YSCALEYUV2YV12X(CHR_MMX_FILTER_OFFSET, uDest, chrDstW, 0)
|
||||
dither_8to16(c, chrDither, 1);
|
||||
YSCALEYUV2YV12X(CHR_MMX_FILTER_OFFSET, vDest - uv_off, chrDstW + uv_off, uv_off)
|
||||
}
|
||||
dither_8to16(c, lumDither, 0);
|
||||
if (CONFIG_SWSCALE_ALPHA && aDest) {
|
||||
YSCALEYUV2YV12X(ALP_MMX_FILTER_OFFSET, aDest, dstW, 0)
|
||||
}
|
||||
|
||||
YSCALEYUV2YV12X(LUM_MMX_FILTER_OFFSET, yDest, dstW, 0)
|
||||
}
|
||||
|
||||
#define YSCALEYUV2YV12X_ACCURATE(offset, dest, end, pos) \
|
||||
__asm__ volatile(\
|
||||
"lea " offset "(%0), %%"REG_d" \n\t"\
|
||||
"movq "DITHER32"+0(%0), %%mm4 \n\t"\
|
||||
"movq "DITHER32"+8(%0), %%mm5 \n\t"\
|
||||
"movq "DITHER32"+16(%0), %%mm6 \n\t"\
|
||||
"movq "DITHER32"+24(%0), %%mm7 \n\t"\
|
||||
"mov (%%"REG_d"), %%"REG_S" \n\t"\
|
||||
".p2align 4 \n\t"\
|
||||
"1: \n\t"\
|
||||
"movq (%%"REG_S", %3, 2), %%mm0 \n\t" /* srcData */\
|
||||
"movq 8(%%"REG_S", %3, 2), %%mm2 \n\t" /* srcData */\
|
||||
"mov "STR(APCK_PTR2)"(%%"REG_d"), %%"REG_S" \n\t"\
|
||||
"movq (%%"REG_S", %3, 2), %%mm1 \n\t" /* srcData */\
|
||||
"movq %%mm0, %%mm3 \n\t"\
|
||||
"punpcklwd %%mm1, %%mm0 \n\t"\
|
||||
"punpckhwd %%mm1, %%mm3 \n\t"\
|
||||
"movq "STR(APCK_COEF)"(%%"REG_d"), %%mm1 \n\t" /* filterCoeff */\
|
||||
"pmaddwd %%mm1, %%mm0 \n\t"\
|
||||
"pmaddwd %%mm1, %%mm3 \n\t"\
|
||||
"paddd %%mm0, %%mm4 \n\t"\
|
||||
"paddd %%mm3, %%mm5 \n\t"\
|
||||
"movq 8(%%"REG_S", %3, 2), %%mm3 \n\t" /* srcData */\
|
||||
"mov "STR(APCK_SIZE)"(%%"REG_d"), %%"REG_S" \n\t"\
|
||||
"add $"STR(APCK_SIZE)", %%"REG_d" \n\t"\
|
||||
"test %%"REG_S", %%"REG_S" \n\t"\
|
||||
"movq %%mm2, %%mm0 \n\t"\
|
||||
"punpcklwd %%mm3, %%mm2 \n\t"\
|
||||
"punpckhwd %%mm3, %%mm0 \n\t"\
|
||||
"pmaddwd %%mm1, %%mm2 \n\t"\
|
||||
"pmaddwd %%mm1, %%mm0 \n\t"\
|
||||
"paddd %%mm2, %%mm6 \n\t"\
|
||||
"paddd %%mm0, %%mm7 \n\t"\
|
||||
" jnz 1b \n\t"\
|
||||
"psrad $19, %%mm4 \n\t"\
|
||||
"psrad $19, %%mm5 \n\t"\
|
||||
"psrad $19, %%mm6 \n\t"\
|
||||
"psrad $19, %%mm7 \n\t"\
|
||||
"packssdw %%mm5, %%mm4 \n\t"\
|
||||
"packssdw %%mm7, %%mm6 \n\t"\
|
||||
"packuswb %%mm6, %%mm4 \n\t"\
|
||||
MOVNTQ(%%mm4, (%1, %3))\
|
||||
"add $8, %3 \n\t"\
|
||||
"cmp %2, %3 \n\t"\
|
||||
"lea " offset "(%0), %%"REG_d" \n\t"\
|
||||
"movq "DITHER32"+0(%0), %%mm4 \n\t"\
|
||||
"movq "DITHER32"+8(%0), %%mm5 \n\t"\
|
||||
"movq "DITHER32"+16(%0), %%mm6 \n\t"\
|
||||
"movq "DITHER32"+24(%0), %%mm7 \n\t"\
|
||||
"mov (%%"REG_d"), %%"REG_S" \n\t"\
|
||||
"jb 1b \n\t"\
|
||||
:: "r" (&c->redDither),\
|
||||
"r" (dest), "g" ((x86_reg)(end)), "r"((x86_reg)(pos))\
|
||||
: "%"REG_a, "%"REG_d, "%"REG_S\
|
||||
);
|
||||
|
||||
#if !COMPILE_TEMPLATE_MMX2
|
||||
static av_always_inline void
|
||||
dither_8to32(SwsContext *c, const uint8_t *srcDither, int rot)
|
||||
{
|
||||
if (rot) {
|
||||
__asm__ volatile("pxor %%mm0, %%mm0\n\t"
|
||||
"movq (%0), %%mm4\n\t"
|
||||
"movq %%mm4, %%mm5\n\t"
|
||||
"psrlq $24, %%mm4\n\t"
|
||||
"psllq $40, %%mm5\n\t"
|
||||
"por %%mm5, %%mm4\n\t"
|
||||
"movq %%mm4, %%mm6\n\t"
|
||||
"punpcklbw %%mm0, %%mm4\n\t"
|
||||
"punpckhbw %%mm0, %%mm6\n\t"
|
||||
"movq %%mm4, %%mm5\n\t"
|
||||
"movq %%mm6, %%mm7\n\t"
|
||||
"punpcklwd %%mm0, %%mm4\n\t"
|
||||
"punpckhwd %%mm0, %%mm5\n\t"
|
||||
"punpcklwd %%mm0, %%mm6\n\t"
|
||||
"punpckhwd %%mm0, %%mm7\n\t"
|
||||
"pslld $12, %%mm4\n\t"
|
||||
"pslld $12, %%mm5\n\t"
|
||||
"pslld $12, %%mm6\n\t"
|
||||
"pslld $12, %%mm7\n\t"
|
||||
"movq %%mm4, "DITHER32"+0(%1)\n\t"
|
||||
"movq %%mm5, "DITHER32"+8(%1)\n\t"
|
||||
"movq %%mm6, "DITHER32"+16(%1)\n\t"
|
||||
"movq %%mm7, "DITHER32"+24(%1)\n\t"
|
||||
:: "r"(srcDither), "r"(&c->redDither)
|
||||
);
|
||||
} else {
|
||||
__asm__ volatile("pxor %%mm0, %%mm0\n\t"
|
||||
"movq (%0), %%mm4\n\t"
|
||||
"movq %%mm4, %%mm6\n\t"
|
||||
"punpcklbw %%mm0, %%mm4\n\t"
|
||||
"punpckhbw %%mm0, %%mm6\n\t"
|
||||
"movq %%mm4, %%mm5\n\t"
|
||||
"movq %%mm6, %%mm7\n\t"
|
||||
"punpcklwd %%mm0, %%mm4\n\t"
|
||||
"punpckhwd %%mm0, %%mm5\n\t"
|
||||
"punpcklwd %%mm0, %%mm6\n\t"
|
||||
"punpckhwd %%mm0, %%mm7\n\t"
|
||||
"pslld $12, %%mm4\n\t"
|
||||
"pslld $12, %%mm5\n\t"
|
||||
"pslld $12, %%mm6\n\t"
|
||||
"pslld $12, %%mm7\n\t"
|
||||
"movq %%mm4, "DITHER32"+0(%1)\n\t"
|
||||
"movq %%mm5, "DITHER32"+8(%1)\n\t"
|
||||
"movq %%mm6, "DITHER32"+16(%1)\n\t"
|
||||
"movq %%mm7, "DITHER32"+24(%1)\n\t"
|
||||
:: "r"(srcDither), "r"(&c->redDither)
|
||||
);
|
||||
}
|
||||
}
|
||||
#endif
|
||||
|
||||
static void RENAME(yuv2yuvX_ar)(SwsContext *c, const int16_t *lumFilter,
|
||||
const int16_t **lumSrc, int lumFilterSize,
|
||||
const int16_t *chrFilter, const int16_t **chrUSrc,
|
||||
const int16_t **chrVSrc,
|
||||
int chrFilterSize, const int16_t **alpSrc,
|
||||
uint8_t *dest[4], int dstW, int chrDstW)
|
||||
{
|
||||
uint8_t *yDest = dest[0], *uDest = dest[1], *vDest = dest[2],
|
||||
*aDest = CONFIG_SWSCALE_ALPHA ? dest[3] : NULL;
|
||||
const uint8_t *lumDither = c->lumDither8, *chrDither = c->chrDither8;
|
||||
|
||||
if (uDest) {
|
||||
x86_reg uv_off = c->uv_offx2 >> 1;
|
||||
dither_8to32(c, chrDither, 0);
|
||||
YSCALEYUV2YV12X_ACCURATE(CHR_MMX_FILTER_OFFSET, uDest, chrDstW, 0)
|
||||
dither_8to32(c, chrDither, 1);
|
||||
YSCALEYUV2YV12X_ACCURATE(CHR_MMX_FILTER_OFFSET, vDest - uv_off, chrDstW + uv_off, uv_off)
|
||||
}
|
||||
dither_8to32(c, lumDither, 0);
|
||||
if (CONFIG_SWSCALE_ALPHA && aDest) {
|
||||
YSCALEYUV2YV12X_ACCURATE(ALP_MMX_FILTER_OFFSET, aDest, dstW, 0)
|
||||
}
|
||||
|
||||
YSCALEYUV2YV12X_ACCURATE(LUM_MMX_FILTER_OFFSET, yDest, dstW, 0)
|
||||
}
|
||||
|
||||
static void RENAME(yuv2yuv1)(SwsContext *c, const int16_t *lumSrc,
|
||||
const int16_t *chrUSrc, const int16_t *chrVSrc,
|
||||
const int16_t *alpSrc,
|
||||
@ -2095,8 +1896,7 @@ static av_cold void RENAME(sws_init_swScale)(SwsContext *c)
|
||||
if (!is16BPS(dstFormat) && !is9_OR_10BPS(dstFormat) && dstFormat != PIX_FMT_NV12
|
||||
&& dstFormat != PIX_FMT_NV21 && !(c->flags & SWS_BITEXACT)) {
|
||||
if (c->flags & SWS_ACCURATE_RND) {
|
||||
c->yuv2yuv1 = RENAME(yuv2yuv1_ar );
|
||||
c->yuv2yuvX = RENAME(yuv2yuvX_ar );
|
||||
//c->yuv2yuv1 = RENAME(yuv2yuv1_ar );
|
||||
if (!(c->flags & SWS_FULL_CHR_H_INT)) {
|
||||
switch (c->dstFormat) {
|
||||
case PIX_FMT_RGB32: c->yuv2packedX = RENAME(yuv2rgb32_X_ar); break;
|
||||
@ -2108,9 +1908,7 @@ static av_cold void RENAME(sws_init_swScale)(SwsContext *c)
|
||||
}
|
||||
}
|
||||
} else {
|
||||
int should_dither= isNBPS(c->srcFormat) || is16BPS(c->srcFormat);
|
||||
c->yuv2yuv1 = should_dither ? RENAME(yuv2yuv1_ar ) : RENAME(yuv2yuv1 );
|
||||
c->yuv2yuvX = RENAME(yuv2yuvX );
|
||||
//c->yuv2yuv1 = RENAME(yuv2yuv1 );
|
||||
if (!(c->flags & SWS_FULL_CHR_H_INT)) {
|
||||
switch (c->dstFormat) {
|
||||
case PIX_FMT_RGB32: c->yuv2packedX = RENAME(yuv2rgb32_X); break;
|
||||
|
@ -40,16 +40,16 @@ yuv420p9le 9ed4b1dfabc53fd9e586ff6c4c43af80
|
||||
yuv422p c9bba4529821d796a6ab09f6a5fd355a
|
||||
yuv422p10be bdc13b630fd668b34c6fe1aae28dfc71
|
||||
yuv422p10le d0607c260a45c973e6639f4e449730ad
|
||||
yuv422p16be 4e9b3b3467aeebb6a528cee5966800ed
|
||||
yuv422p16le f87c81bf16916b64d201359be0b4b6f4
|
||||
yuv422p16be 5499502e1c29534a158a1fe60e889f60
|
||||
yuv422p16le e3d61fde6978591596bc36b914386623
|
||||
yuv422p9be 29b71579946940a8c00fa844c9dff507
|
||||
yuv422p9le 062b7f9cbb972bf36b5bdb1a7623701a
|
||||
yuv440p 5a064afe2b453bb52cdb3f176b1aa1cf
|
||||
yuv444p 0a98447b78fd476aa39686da6a74fa2e
|
||||
yuv444p10be e65cbae7e4f1892c23defbc8e8052cf6
|
||||
yuv444p10le 767179dd82846cf00ee4c340c9c1ab74
|
||||
yuv444p16be 3ad639fff73e56f3b09dd20c335478d6
|
||||
yuv444p16le 8a7e66dc91ab7971fd24a9105ff2699b
|
||||
yuv444p16be 1c6ea2c2f5e539006112ceec3d4e7d90
|
||||
yuv444p16le 20f86bc2f68d2b3f1f2b48b97b2189f4
|
||||
yuv444p9be 6ab31f4c12b533ce318ecdff83cdd054
|
||||
yuv444p9le f0606604a5c08becab6ba500124c4b7c
|
||||
yuva420p a29884f3f3dfe1e00b961bc17bef3d47
|
||||
|
@ -40,16 +40,16 @@ yuv420p9le 9ed4b1dfabc53fd9e586ff6c4c43af80
|
||||
yuv422p c9bba4529821d796a6ab09f6a5fd355a
|
||||
yuv422p10be bdc13b630fd668b34c6fe1aae28dfc71
|
||||
yuv422p10le d0607c260a45c973e6639f4e449730ad
|
||||
yuv422p16be 4e9b3b3467aeebb6a528cee5966800ed
|
||||
yuv422p16le f87c81bf16916b64d201359be0b4b6f4
|
||||
yuv422p16be 5499502e1c29534a158a1fe60e889f60
|
||||
yuv422p16le e3d61fde6978591596bc36b914386623
|
||||
yuv422p9be 29b71579946940a8c00fa844c9dff507
|
||||
yuv422p9le 062b7f9cbb972bf36b5bdb1a7623701a
|
||||
yuv440p 5a064afe2b453bb52cdb3f176b1aa1cf
|
||||
yuv444p 0a98447b78fd476aa39686da6a74fa2e
|
||||
yuv444p10be e65cbae7e4f1892c23defbc8e8052cf6
|
||||
yuv444p10le 767179dd82846cf00ee4c340c9c1ab74
|
||||
yuv444p16be 3ad639fff73e56f3b09dd20c335478d6
|
||||
yuv444p16le 8a7e66dc91ab7971fd24a9105ff2699b
|
||||
yuv444p16be 1c6ea2c2f5e539006112ceec3d4e7d90
|
||||
yuv444p16le 20f86bc2f68d2b3f1f2b48b97b2189f4
|
||||
yuv444p9be 6ab31f4c12b533ce318ecdff83cdd054
|
||||
yuv444p9le f0606604a5c08becab6ba500124c4b7c
|
||||
yuva420p a29884f3f3dfe1e00b961bc17bef3d47
|
||||
|
@ -33,8 +33,8 @@ yuv422p16be 167e4338811a7d272925a4c6417d60da
|
||||
yuv422p16le 3359395d5875d581fa1e975013d30114
|
||||
yuv440p 2472417d980e395ad6843cbb8b633b29
|
||||
yuv444p 1f151980486848c96bc5585ced99003e
|
||||
yuv444p16be 5d0c0ea66ab43c0c590d8c2a9256e43f
|
||||
yuv444p16le 3c0a747c1b64feb0ab8dfba92f92579a
|
||||
yuv444p16be 1ce8fcd4712d525af983e6179d6a4f9e
|
||||
yuv444p16le 5f1441e18345aadb3f881dac99c6c08a
|
||||
yuva420p 7536753dfbc7932560fb50c921369a0e
|
||||
yuvj420p 21f891093006d42d7683b0e1d773a657
|
||||
yuvj422p 9a43d474c407590ad8f213880586b45e
|
||||
|
@ -29,12 +29,12 @@ yuv420p 2d5c80f9ba2ddd85b2aeda3564cc7d64
|
||||
yuv420p16be 1c4fa93d0744de3cdc6d34ab55db3fb4
|
||||
yuv420p16le 92c74f5759068c381e4a066fe7faf2e0
|
||||
yuv422p 6e728f4eb9eae287c224f396d84be6ea
|
||||
yuv422p16be 69cf0605496c321546899a8442ee64fb
|
||||
yuv422p16le f0b443fea72f4b6f462859a73b159664
|
||||
yuv422p16be a05d43cd62b790087bd37083174557de
|
||||
yuv422p16le 6954abebcbc62d81068d58d0c62bdd5b
|
||||
yuv440p a99e2b57ed601f39852715c9d675d0d3
|
||||
yuv444p 947e47f7bb5fdccc659d19b7df2b6fc3
|
||||
yuv444p16be bc7d53923cff1d7e98d24540845fb64b
|
||||
yuv444p16le 5df206a93f85ef8b77f5bdc81d9b0a0b
|
||||
yuv444p16be 58c012e5ab73b066ef3c2b6411a395f1
|
||||
yuv444p16le 32c12794e184042a59738ab2de608c8d
|
||||
yuva420p d83ec0c01498189f179ec574918185f1
|
||||
yuvj420p df3aaaec3bb157c3bde5f0365af30f4f
|
||||
yuvj422p d113871528d510a192797af59df9c05c
|
||||
|
@ -40,16 +40,16 @@ yuv420p9le 9ed4b1dfabc53fd9e586ff6c4c43af80
|
||||
yuv422p c9bba4529821d796a6ab09f6a5fd355a
|
||||
yuv422p10be bdc13b630fd668b34c6fe1aae28dfc71
|
||||
yuv422p10le d0607c260a45c973e6639f4e449730ad
|
||||
yuv422p16be 4e9b3b3467aeebb6a528cee5966800ed
|
||||
yuv422p16le f87c81bf16916b64d201359be0b4b6f4
|
||||
yuv422p16be 5499502e1c29534a158a1fe60e889f60
|
||||
yuv422p16le e3d61fde6978591596bc36b914386623
|
||||
yuv422p9be 29b71579946940a8c00fa844c9dff507
|
||||
yuv422p9le 062b7f9cbb972bf36b5bdb1a7623701a
|
||||
yuv440p 5a064afe2b453bb52cdb3f176b1aa1cf
|
||||
yuv444p 0a98447b78fd476aa39686da6a74fa2e
|
||||
yuv444p10be e65cbae7e4f1892c23defbc8e8052cf6
|
||||
yuv444p10le 767179dd82846cf00ee4c340c9c1ab74
|
||||
yuv444p16be 3ad639fff73e56f3b09dd20c335478d6
|
||||
yuv444p16le 8a7e66dc91ab7971fd24a9105ff2699b
|
||||
yuv444p16be 1c6ea2c2f5e539006112ceec3d4e7d90
|
||||
yuv444p16le 20f86bc2f68d2b3f1f2b48b97b2189f4
|
||||
yuv444p9be 6ab31f4c12b533ce318ecdff83cdd054
|
||||
yuv444p9le f0606604a5c08becab6ba500124c4b7c
|
||||
yuva420p a29884f3f3dfe1e00b961bc17bef3d47
|
||||
|
@ -33,23 +33,23 @@ yuv411p 1143e7c5cc28fe0922b051b17733bc4c
|
||||
yuv420p fdad2d8df8985e3d17e73c71f713cb14
|
||||
yuv420p10be 6d335e75b553da590135cf8bb999610c
|
||||
yuv420p10le d510ddbabefd03ef39ec943fcb51b709
|
||||
yuv420p16be 2a75942af24fbdc1fdfe189c6e7bf589
|
||||
yuv420p16le c4264d92a7c273967a778f4f5daddbe3
|
||||
yuv420p16be 31988e9a5d6acacaa710f67bc1172f3a
|
||||
yuv420p16le f5390ce399f88e0e4e2621ed7833b250
|
||||
yuv420p9be ec4983b7a949c0472110a7a2c58e278a
|
||||
yuv420p9le c136dce5913a722eee44ab72cff664b2
|
||||
yuv422p 918e37701ee7377d16a8a6c119c56a40
|
||||
yuv422p10be cea7ca6b0e66d6f29539885896c88603
|
||||
yuv422p10le a10c4a5837547716f13cd61918b145f9
|
||||
yuv422p16be 285993ee0c0f4f8e511ee46f93c5f38c
|
||||
yuv422p16le 61bfcee8e54465f760164f5a75d40b5e
|
||||
yuv422p16be e7e34fe9264784763ab6cb406524c0f3
|
||||
yuv422p16le c435b76b08204dda6908640fb5fd4621
|
||||
yuv422p9be 82494823944912f73cebc58ad2979bbd
|
||||
yuv422p9le fc69c8a21f473916a4b4225636b97e06
|
||||
yuv440p 461503fdb9b90451020aa3b25ddf041c
|
||||
yuv444p 81b2eba962d12e8d64f003ac56f6faf2
|
||||
yuv444p10be e9d3c8e744b8b0d8187ca092fa203fc9
|
||||
yuv444p10le 02f0a336e9da062a64df1ba487e102c5
|
||||
yuv444p16be 2677f3074d255f9dab625e9e2e092ca5
|
||||
yuv444p16le 65fa92521ef97088599ea83f9508cd5b
|
||||
yuv444p16be 0da9bed80f5542682ab286f3261cf24c
|
||||
yuv444p16le a0c5d3c7bf3f181db503cf8e450d1335
|
||||
yuv444p9be 9ac2643ce7f7e5c4e17c8c9fd8494d4a
|
||||
yuv444p9le 896a1cc9cccca1ba410dd53942d33cc4
|
||||
yuva420p 8673a9131fb47de69788863f93a50eb7
|
||||
|
@ -40,16 +40,16 @@ yuv420p9le 0f1e371a1374d3cba2205b70cc7cac90
|
||||
yuv422p d7f5cb44d9b0210d66d6a8762640ab34
|
||||
yuv422p10be 588fe319b96513c32e21d3e32b45447f
|
||||
yuv422p10le 11b57f2bd9661024153f3973b9090cdb
|
||||
yuv422p16be c092d083548c2a144c372a98c46875c7
|
||||
yuv422p16le c071b9397a416d51cbe339345cbcba84
|
||||
yuv422p16be 9bd8f8c961822b586fa4cf992be54acc
|
||||
yuv422p16le 9c4a1239605c7952b736ac3130163f14
|
||||
yuv422p9be 7c6f1e140b3999ee7d923854e507752a
|
||||
yuv422p9le 51f10d79c07989060dd06e767e6d7d60
|
||||
yuv440p 876385e96165acf51271b20e5d85a416
|
||||
yuv444p 9c3c667d1613b72d15bc6d851c5eb8f7
|
||||
yuv444p10be 944a4997c4edb3a8dd0f0493cfd5a1fd
|
||||
yuv444p10le 2d0947ae89ecc6a501eee6832cb27e06
|
||||
yuv444p16be 6a954614fd2a8ae0df53e4fd76937af8
|
||||
yuv444p16le 65613965fb58cc4c3cd480a68b6540ea
|
||||
yuv444p16be de2dedfc6f12073ffead113f86e07ecf
|
||||
yuv444p16le 8e83323cf102d6c823a03ae8a7b7e033
|
||||
yuv444p9be 6ac92b7dc9ab2fc59bee99204886899a
|
||||
yuv444p9le 85aef13a654953d3455d89770b0d74bd
|
||||
yuva420p c705d1cf061d8c6580ac690b55f92276
|
||||
|
Loading…
Reference in New Issue
Block a user