1cabdff1aSopenharmony_ci/* 2cabdff1aSopenharmony_ci * AVS2 video stream probe. 3cabdff1aSopenharmony_ci * 4cabdff1aSopenharmony_ci * Copyright (C) 2018 Huiwen Ren, <hwrenx@126.com> 5cabdff1aSopenharmony_ci * 6cabdff1aSopenharmony_ci * This file is part of FFmpeg. 7cabdff1aSopenharmony_ci * 8cabdff1aSopenharmony_ci * FFmpeg is free software; you can redistribute it and/or 9cabdff1aSopenharmony_ci * modify it under the terms of the GNU Lesser General Public 10cabdff1aSopenharmony_ci * License as published by the Free Software Foundation; either 11cabdff1aSopenharmony_ci * version 2.1 of the License, or (at your option) any later version. 12cabdff1aSopenharmony_ci * 13cabdff1aSopenharmony_ci * FFmpeg is distributed in the hope that it will be useful, 14cabdff1aSopenharmony_ci * but WITHOUT ANY WARRANTY; without even the implied warranty of 15cabdff1aSopenharmony_ci * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 16cabdff1aSopenharmony_ci * Lesser General Public License for more details. 17cabdff1aSopenharmony_ci * 18cabdff1aSopenharmony_ci * You should have received a copy of the GNU Lesser General Public 19cabdff1aSopenharmony_ci * License along with FFmpeg; if not, write to the Free Software 20cabdff1aSopenharmony_ci * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA 21cabdff1aSopenharmony_ci */ 22cabdff1aSopenharmony_ci 23cabdff1aSopenharmony_ci#include "avformat.h" 24cabdff1aSopenharmony_ci#include "rawdec.h" 25cabdff1aSopenharmony_ci#include "libavcodec/startcode.h" 26cabdff1aSopenharmony_ci#include "libavutil/intreadwrite.h" 27cabdff1aSopenharmony_ci 28cabdff1aSopenharmony_ci#define AVS2_ISSQH(x) ((x) == 0xB0) 29cabdff1aSopenharmony_ci#define AVS2_ISEND(x) ((x) == 0xB1) 30cabdff1aSopenharmony_ci#define AVS2_ISPIC(x) ((x) == 0xB3 || (x) == 0xB6) 31cabdff1aSopenharmony_ci#define AVS2_ISUNIT(x) (AVS2_ISSQH(x) || AVS2_ISEND(x) || (x) == 0xB2 || AVS2_ISPIC(x) || (x) == 0xB5 || (x) == 0xB7) 32cabdff1aSopenharmony_ci#define AVS2_ISPROFILE(x) ((x) == 0x20 || (x) == 0x22 || (x) == 0x30 || (x) == 0x32) 33cabdff1aSopenharmony_ci 34cabdff1aSopenharmony_cistatic int avs2_probe(const AVProbeData *p) 35cabdff1aSopenharmony_ci{ 36cabdff1aSopenharmony_ci uint32_t code = -1, hds = 0, pic = 0, seq = 0; 37cabdff1aSopenharmony_ci uint8_t state = 0; 38cabdff1aSopenharmony_ci const uint8_t *ptr = p->buf, *end = p->buf + p->buf_size, *sqb = 0; 39cabdff1aSopenharmony_ci if (AV_RB32(p->buf) != 0x1B0){ 40cabdff1aSopenharmony_ci return 0; 41cabdff1aSopenharmony_ci } 42cabdff1aSopenharmony_ci 43cabdff1aSopenharmony_ci while (ptr < end) { 44cabdff1aSopenharmony_ci ptr = avpriv_find_start_code(ptr, end, &code); 45cabdff1aSopenharmony_ci state = code & 0xFF; 46cabdff1aSopenharmony_ci if ((code & 0xffffff00) == 0x100) { 47cabdff1aSopenharmony_ci if (AVS2_ISUNIT(state)) { 48cabdff1aSopenharmony_ci if (sqb && !hds) { 49cabdff1aSopenharmony_ci hds = ptr - sqb; 50cabdff1aSopenharmony_ci } 51cabdff1aSopenharmony_ci if (AVS2_ISSQH(state)) { 52cabdff1aSopenharmony_ci if (!AVS2_ISPROFILE(*ptr)) 53cabdff1aSopenharmony_ci return 0; 54cabdff1aSopenharmony_ci sqb = ptr; 55cabdff1aSopenharmony_ci seq++; 56cabdff1aSopenharmony_ci } else if (AVS2_ISPIC(state)) { 57cabdff1aSopenharmony_ci pic++; 58cabdff1aSopenharmony_ci } else if (AVS2_ISEND(state)) { 59cabdff1aSopenharmony_ci break; 60cabdff1aSopenharmony_ci } 61cabdff1aSopenharmony_ci } 62cabdff1aSopenharmony_ci } 63cabdff1aSopenharmony_ci } 64cabdff1aSopenharmony_ci if (seq && hds >= 21 && pic){ 65cabdff1aSopenharmony_ci return AVPROBE_SCORE_EXTENSION + 2; // more than cavs 66cabdff1aSopenharmony_ci } 67cabdff1aSopenharmony_ci 68cabdff1aSopenharmony_ci return 0; 69cabdff1aSopenharmony_ci} 70cabdff1aSopenharmony_ci 71cabdff1aSopenharmony_ciFF_DEF_RAWVIDEO_DEMUXER(avs2, "raw AVS2-P2/IEEE1857.4", avs2_probe, "avs,avs2", AV_CODEC_ID_AVS2) 72