43 #define PRI_PRETTY_GUID \
44 "%08"PRIx32"-%04"PRIx16"-%04"PRIx16"-%02x%02x%02x%02x%02x%02x%02x%02x"
45 #define ARG_PRETTY_GUID(g) \
46 AV_RL32(g),AV_RL16(g+4),AV_RL16(g+6),g[8],g[9],g[10],g[11],g[12],g[13],g[14],g[15]
47 #define LEN_PRETTY_GUID 35
85 while(nread < buf_size) {
87 int read_request =
FFMIN(buf_size - nread, remaining_in_sector);
95 if (n == remaining_in_sector) {
105 return nread ? nread : n;
118 else if (whence == SEEK_CUR)
120 else if (whence == SEEK_END)
140 for (
i = 0;
i < count;
i++) {
176 }
else if (depth == 1) {
183 }
else if (depth == 2) {
194 for (
i = 0;
i < nb_sectors1;
i++) {
217 length &= 0xFFFFFFFFFFFF;
260 const uint8_t *buf_end = buf + buf_size;
262 while(buf + 48 <= buf_end) {
263 int dir_length, name_size, first_sector, depth;
264 uint64_t file_length;
268 "remaining directory entries ignored\n",
FF_ARG_GUID(buf));
271 dir_length =
AV_RL16(buf + 16);
272 file_length =
AV_RL64(buf + 24);
273 name_size = 2 *
AV_RL32(buf + 32);
276 "bad filename length, remaining directory entries ignored\n");
279 if (dir_length == 0) {
281 "bad dir length, remaining directory entries ignored\n");
284 if (48 + (
int64_t)name_size > buf_end - buf) {
285 av_log(
s,
AV_LOG_ERROR,
"filename exceeds buffer size; remaining directory entries ignored\n");
288 first_sector =
AV_RL32(buf + 40 + name_size);
289 depth =
AV_RL32(buf + 44 + name_size);
293 if (name_size >= filename_size &&
294 !memcmp(
name, filename, filename_size) &&
295 (name_size < filename_size + 2 || !
AV_RN16(
name + filename_size)))
303 #define wtvfile_open(s, buf, buf_size, filename) \
304 wtvfile_open2(s, buf, buf_size, filename, sizeof(filename))
341 {0x48,0xC0,0xCE,0x5D,0xB9,0xD0,0x63,0x41,0x87,0x2C,0x4F,0x32,0x22,0x3B,0xE8,0x8A};
343 {0x6D,0x66,0x92,0xE2,0x02,0x9C,0x8D,0x44,0xAA,0x8D,0x78,0x1A,0x93,0xFD,0xC3,0x95};
345 {0x1C,0xD4,0x7B,0x10,0xDA,0xA6,0x91,0x46,0x83,0x69,0x11,0xB2,0xCD,0xAA,0x28,0x8E};
347 {0xE6,0xA2,0xB4,0x3A,0x47,0x42,0x34,0x4B,0x89,0x6C,0x30,0xAF,0xA5,0xD2,0x1C,0x24};
349 {0xD9,0x79,0xE7,0xEf,0xF0,0x97,0x86,0x47,0x80,0x0D,0x95,0xCF,0x50,0x5D,0xDC,0x66};
351 {0xC4,0xE1,0xD4,0x4B,0xA1,0x90,0x09,0x41,0x82,0x36,0x27,0xF0,0x0E,0x7D,0xCC,0x5B};
353 {0x68,0xAB,0xF1,0xCA,0x53,0xE1,0x41,0x4D,0xA6,0xB3,0xA7,0xC9,0x98,0xDB,0x75,0xEE};
355 {0x50,0xD9,0x99,0x95,0x33,0x5F,0x17,0x46,0xAF,0x7C,0x1E,0x54,0xB5,0x10,0xDA,0xA3};
357 {0xBE,0xBF,0x1C,0x50,0x49,0xB8,0xCE,0x42,0x9B,0xE9,0x3D,0xB8,0x69,0xFB,0x82,0xB3};
363 {0x81,0xEB,0x36,0xE4,0x4F,0x52,0xCE,0x11,0x9F,0x53,0x00,0x20,0xAF,0x0B,0xA7,0x70};
365 {0x6C,0x17,0x5F,0x45,0x06,0x4B,0xCE,0x47,0x9A,0xEF,0x8C,0xAE,0xF7,0x3D,0xF7,0xB5};
367 {0x20,0x80,0x6D,0xE0,0x46,0xDB,0xCF,0x11,0xB4,0xD1,0x00,0x80,0x5F,0x6C,0xBB,0xEA};
369 {0x89,0x8A,0x8B,0xB8,0x49,0xB0,0x80,0x4C,0xAD,0xCF,0x58,0x98,0x98,0x5E,0x22,0xC1};
373 {0xC3,0xCB,0xFF,0x34,0xB3,0xD5,0x71,0x41,0x90,0x02,0xD4,0xC6,0x03,0x01,0x69,0x7F};
375 {0xE3,0x76,0x2A,0xF7,0x0A,0xEB,0xD0,0x11,0xAC,0xE4,0x00,0x00,0xC0,0xCC,0x16,0xBA};
377 {0xAA,0xDD,0x2A,0xF5,0xF0,0x36,0xF5,0x43,0x95,0xEA,0x6D,0x86,0x64,0x84,0x26,0x2A};
379 {0x79,0x85,0x9F,0x4A,0xF8,0x6B,0x92,0x43,0x8A,0x6D,0xD2,0xDD,0x09,0xFA,0x78,0x61};
392 time_t t = (
value / 10000000LL) - 11644473600LL;
394 struct tm *tm =
gmtime_r(&t, &tmbuf);
397 if (!strftime(buf, buf_size,
"%Y-%m-%d %H:%M:%S", tm))
408 time_t t = (
value / 10000000LL) - 719162LL*86400LL;
410 struct tm *tm =
gmtime_r(&t, &tmbuf);
413 if (!strftime(buf, buf_size,
"%Y-%m-%d %H:%M:%S", tm))
426 struct tm *tm=
gmtime_r(&t, &tmbuf);
429 if (!strftime(buf, buf_size,
"%Y-%m-%d %H:%M:%S", tm))
443 if (strcmp(mime,
"image/jpeg"))
454 st =
s->streams[
s->nb_streams - 1];
465 unsigned dict_flags = 0;
467 if (!strcmp(
key,
"WM/MediaThumbType")) {
472 if (
type == 0 && length == 4) {
474 }
else if (
type == 1) {
475 int buflen =
FFMIN(length + length / 2
U + 1, INT_MAX);
485 }
else if (
type == 3 && length == 4) {
486 strcpy(buf,
avio_rl32(pb) ?
"true" :
"false");
487 }
else if (
type == 4 && length == 8) {
489 if (!strcmp(
key,
"WM/EncodingTime") ||
490 !strcmp(
key,
"WM/MediaOriginalBroadcastDateTime")) {
493 }
else if (!strcmp(
key,
"WM/WMRVEncodeTime") ||
494 !strcmp(
key,
"WM/WMRVEndTime")) {
497 }
else if (!strcmp(
key,
"WM/WMRVExpirationDate")) {
500 }
else if (!strcmp(
key,
"WM/WMRVBitrate"))
503 snprintf(buf,
sizeof(buf),
"%"PRIi64, num);
504 }
else if (
type == 5 && length == 2) {
506 }
else if (
type == 6 && length == 16) {
510 }
else if (
type == 2 && !strcmp(
key,
"WM/Picture")) {
538 "remaining metadata entries ignored\n",
FF_ARG_GUID(guid));
779 int len, sid, consumed;
783 if (len < 32 || len > INT_MAX - 7) {
806 if (size < 0 || size > INT_MAX - 92 - consumed)
809 consumed += 92 +
size;
813 if (stream_index >= 0 &&
s->streams[stream_index]->priv_data && !((
WtvStream*)
s->streams[stream_index]->priv_data)->seen_data) {
822 if (size < 0 || size > INT_MAX - 76 - consumed)
825 consumed += 76 +
size;
834 if (stream_index >= 0) {
837 const uint8_t *pbuf = buf;
848 buf_size =
FFMIN(
len - consumed,
sizeof(buf));
849 if (
avio_read(pb, buf, buf_size) != buf_size)
851 consumed += buf_size;
856 if (stream_index >= 0) {
863 else if (audio_type == 3)
869 if (stream_index >= 0) {
872 av_log(
s,
AV_LOG_WARNING,
"DVB scrambled stream detected (st:%d), decoding will likely fail\n", stream_index);
877 if (stream_index >= 0) {
892 if (stream_index >= 0) {
910 if (
mode ==
SEEK_TO_DATA && stream_index >= 0 &&
len > 32 &&
s->streams[stream_index]->priv_data) {
911 WtvStream *wst =
s->streams[stream_index]->priv_data;
918 }
else if (!
ff_guidcmp(
g, (
const ff_asf_guid){0x83,0x95,0x74,0x40,0x9D,0x6B,0xEC,0x4E,0xB4,0x3C,0x67,0xA1,0x80,0x1E,0x1A,0x9B})) {
920 if (stream_index >= 0)
921 av_log(
s,
AV_LOG_WARNING,
"encrypted stream detected (st:%d), decoding will likely fail\n", stream_index);
923 !
ff_guidcmp(
g, (
const ff_asf_guid){0x14,0x56,0x1A,0x0C,0xCD,0x30,0x40,0x4F,0xBC,0xBF,0xD0,0x3E,0x52,0x30,0x62,0x07}) ||
924 !
ff_guidcmp(
g, (
const ff_asf_guid){0x79,0x66,0xB5,0xE0,0xB9,0x12,0xCC,0x43,0xB7,0xDF,0x57,0x8C,0xAA,0x5A,0x7B,0x63}) ||
925 !
ff_guidcmp(
g, (
const ff_asf_guid){0x02,0xAE,0x5B,0x2F,0x8F,0x7B,0x60,0x4F,0x82,0xD6,0xE4,0xEA,0x2F,0x1F,0x4C,0x99}) ||
927 !
ff_guidcmp(
g, (
const ff_asf_guid){0xCC,0x32,0x64,0xDD,0x29,0xE2,0xDB,0x40,0x80,0xF6,0xD2,0x63,0x28,0xD2,0x76,0x1F}) ||
928 !
ff_guidcmp(
g, (
const ff_asf_guid){0xE5,0xC5,0x67,0x90,0x5C,0x4C,0x05,0x42,0x86,0xC8,0x7A,0xFE,0x20,0xFE,0x1E,0xFA}) ||
929 !
ff_guidcmp(
g, (
const ff_asf_guid){0x80,0x6D,0xF3,0x41,0x32,0x41,0xC2,0x4C,0xB1,0x21,0x01,0xA4,0x32,0x19,0xD8,0x1B}) ||
930 !
ff_guidcmp(
g, (
const ff_asf_guid){0x51,0x1D,0xAB,0x72,0xD2,0x87,0x9B,0x48,0xBA,0x11,0x0E,0x08,0xDC,0x21,0x02,0x43}) ||
931 !
ff_guidcmp(
g, (
const ff_asf_guid){0x65,0x8F,0xFC,0x47,0xBB,0xE2,0x34,0x46,0x9C,0xEF,0xFD,0xBF,0xE6,0x26,0x1D,0x5C}) ||
932 !
ff_guidcmp(
g, (
const ff_asf_guid){0xCB,0xC5,0x68,0x80,0x04,0x3C,0x2B,0x49,0xB4,0x7D,0x03,0x08,0x82,0x0D,0xCE,0x51}) ||
933 !
ff_guidcmp(
g, (
const ff_asf_guid){0xBC,0x2E,0xAF,0x82,0xA6,0x30,0x64,0x42,0xA8,0x0B,0xAD,0x2E,0x13,0x72,0xAC,0x60}) ||
934 !
ff_guidcmp(
g, (
const ff_asf_guid){0x1E,0xBE,0xC3,0xC5,0x43,0x92,0xDC,0x11,0x85,0xE5,0x00,0x12,0x3F,0x6F,0x73,0xB9}) ||
935 !
ff_guidcmp(
g, (
const ff_asf_guid){0x3B,0x86,0xA2,0xB1,0xEB,0x1E,0xC3,0x44,0x8C,0x88,0x1C,0xA3,0xFF,0xE3,0xE7,0x6A}) ||
936 !
ff_guidcmp(
g, (
const ff_asf_guid){0x4E,0x7F,0x4C,0x5B,0xC4,0xD0,0x38,0x4B,0xA8,0x3E,0x21,0x7F,0x7B,0xBF,0x52,0xE7}) ||
937 !
ff_guidcmp(
g, (
const ff_asf_guid){0x63,0x36,0xEB,0xFE,0xA1,0x7E,0xD9,0x11,0x83,0x08,0x00,0x07,0xE9,0x5E,0xAD,0x8D}) ||
938 !
ff_guidcmp(
g, (
const ff_asf_guid){0x70,0xE9,0xF1,0xF8,0x89,0xA4,0x4C,0x4D,0x83,0x73,0xB8,0x12,0xE0,0xD5,0xF8,0x1E}) ||
942 !
ff_guidcmp(
g, (
const ff_asf_guid){0xF7,0x10,0x02,0xB9,0xEE,0x7C,0xED,0x4E,0xBD,0x7F,0x05,0x40,0x35,0x86,0x18,0xA1})) {
958 unsigned root_sector;
972 if (root_size >
sizeof(root)) {
982 root_size =
avio_read(
s->pb, root, root_size);
1012 if (
s->nb_streams) {
1031 uint64_t last_position = 0;
1035 while (e <= e_end && frame_nb > e->
size) {
1036 e->
pos = last_position;
1041 last_position = position;
1043 e_end->
pos = last_position;
1059 int stream_index,
len,
ret;
1062 if (stream_index < 0)
1063 return stream_index;
1090 ts_relative -= wtv->
epoch;