42 #define INITIAL_BUFFER_SIZE 32768 44 #define MAX_FIELD_LEN 64 45 #define MAX_CHARACTERISTICS_LEN 512 47 #define MPEG_TIME_BASE 90000 48 #define MPEG_TIME_BASE_Q (AVRational){1, MPEG_TIME_BASE} 334 const char *
url,
const char *base)
360 int key_len,
char **dest,
int *dest_len)
362 if (!strncmp(key,
"BANDWIDTH=", key_len)) {
365 }
else if (!strncmp(key,
"AUDIO=", key_len)) {
367 *dest_len =
sizeof(info->
audio);
368 }
else if (!strncmp(key,
"VIDEO=", key_len)) {
370 *dest_len =
sizeof(info->
video);
371 }
else if (!strncmp(key,
"SUBTITLES=", key_len)) {
384 int key_len,
char **dest,
int *dest_len)
386 if (!strncmp(key,
"METHOD=", key_len)) {
388 *dest_len =
sizeof(info->
method);
389 }
else if (!strncmp(key,
"URI=", key_len)) {
391 *dest_len =
sizeof(info->
uri);
392 }
else if (!strncmp(key,
"IV=", key_len)) {
394 *dest_len =
sizeof(info->
iv);
405 const char *url_base)
441 int key_len,
char **dest,
int *dest_len)
443 if (!strncmp(key,
"URI=", key_len)) {
445 *dest_len =
sizeof(info->
uri);
446 }
else if (!strncmp(key,
"BYTERANGE=", key_len)) {
465 const char *url_base)
469 char *characteristic;
473 if (!strcmp(info->
type,
"AUDIO"))
475 else if (!strcmp(info->
type,
"VIDEO"))
477 else if (!strcmp(info->
type,
"SUBTITLES"))
479 else if (!strcmp(info->
type,
"CLOSED-CAPTIONS"))
516 int langlen = strlen(rend->
language);
517 if (langlen <
sizeof(rend->
language) - 3) {
520 sizeof(rend->
language) - langlen - 2);
526 if (!strcmp(info->
forced,
"YES"))
530 while ((characteristic =
av_strtok(chr_ptr,
",", &saveptr))) {
531 if (!strcmp(characteristic,
"public.accessibility.describes-music-and-sound"))
533 else if (!strcmp(characteristic,
"public.accessibility.describes-video"))
543 int key_len,
char **dest,
int *dest_len)
545 if (!strncmp(key,
"TYPE=", key_len)) {
547 *dest_len =
sizeof(info->
type);
548 }
else if (!strncmp(key,
"URI=", key_len)) {
550 *dest_len =
sizeof(info->
uri);
551 }
else if (!strncmp(key,
"GROUP-ID=", key_len)) {
554 }
else if (!strncmp(key,
"LANGUAGE=", key_len)) {
557 }
else if (!strncmp(key,
"ASSOC-LANGUAGE=", key_len)) {
560 }
else if (!strncmp(key,
"NAME=", key_len)) {
562 *dest_len =
sizeof(info->
name);
563 }
else if (!strncmp(key,
"DEFAULT=", key_len)) {
566 }
else if (!strncmp(key,
"FORCED=", key_len)) {
568 *dest_len =
sizeof(info->
forced);
569 }
else if (!strncmp(key,
"CHARACTERISTICS=", key_len)) {
600 if (*dest && !strlen(*dest))
607 #if !CONFIG_HTTP_PROTOCOL 613 (*pb)->eof_reached = 0;
627 const char *proto_name =
NULL;
635 if (url[6] ==
'+' || url[6] ==
':')
649 "Filename extension of \'%s\' is not a common multimedia extension, blocked for security reasons.\n" 650 "If you wish to override this adjust allowed_extensions, you can set it to \'ALL\' to allow all\n",
659 if (!strncmp(proto_name, url, strlen(proto_name)) && url[strlen(proto_name)] ==
':')
661 else if (
av_strstart(url,
"crypto",
NULL) && !strncmp(proto_name, url + 7, strlen(proto_name)) && url[7 + strlen(proto_name)] ==
':')
663 else if (strcmp(proto_name,
"file") || !strncmp(url,
"file,", 5))
670 }
else if (ret < 0) {
673 "keepalive request failed for '%s', retrying with new connection: %s\n",
682 char *new_cookies =
NULL;
698 *is_http_out = is_http;
706 int ret = 0, is_segment = 0, is_variant = 0;
715 int64_t seg_offset = 0;
716 int64_t seg_size = -1;
728 }
else if (ret < 0) {
731 "keepalive request failed for '%s', retrying with new connection: %s\n",
766 if (strcmp(line,
"#EXTM3U")) {
778 if (
av_strstart(line,
"#EXT-X-STREAM-INF:", &ptr)) {
780 memset(&variant_info, 0,
sizeof(variant_info));
783 }
else if (
av_strstart(line,
"#EXT-X-KEY:", &ptr)) {
789 if (!strcmp(info.
method,
"AES-128"))
791 if (!strcmp(info.
method,
"SAMPLE-AES"))
793 if (!strncmp(info.
iv,
"0x", 2) || !strncmp(info.
iv,
"0X", 2)) {
798 }
else if (
av_strstart(line,
"#EXT-X-MEDIA:", &ptr)) {
803 }
else if (
av_strstart(line,
"#EXT-X-TARGETDURATION:", &ptr)) {
808 }
else if (
av_strstart(line,
"#EXT-X-MEDIA-SEQUENCE:", &ptr)) {
813 }
else if (
av_strstart(line,
"#EXT-X-PLAYLIST-TYPE:", &ptr)) {
817 if (!strcmp(ptr,
"EVENT"))
819 else if (!strcmp(ptr,
"VOD"))
821 }
else if (
av_strstart(line,
"#EXT-X-MAP:", &ptr)) {
829 }
else if (
av_strstart(line,
"#EXT-X-ENDLIST", &ptr)) {
835 }
else if (
av_strstart(line,
"#EXT-X-BYTERANGE:", &ptr)) {
836 seg_size = strtoll(ptr,
NULL, 10);
837 ptr = strchr(ptr,
'@');
839 seg_offset = strtoll(ptr+1,
NULL, 10);
842 }
else if (line[0]) {
867 memcpy(seg->
iv, iv,
sizeof(iv));
870 memset(seg->
iv, 0,
sizeof(seg->
iv));
898 seg->
size = seg_size;
901 seg_offset += seg_size;
973 static const char id3_priv_owner_ts[] =
"com.apple.streaming.transportStreamTimestamp";
977 for (meta = *extra_meta; meta; meta = meta->
next) {
978 if (!strcmp(meta->
tag,
"PRIV")) {
980 if (priv->
datasize == 8 && !strcmp(priv->
owner, id3_priv_owner_ts)) {
984 if ((ts & ~((1ULL << 33) - 1)) == 0)
989 }
else if (!strcmp(meta->
tag,
"APIC") && apic)
1003 if (!oldentry || strcmp(oldentry->
value, entry->
value) != 0)
1031 parse_id3(pls->
ctx, pb, &metadata, ×tamp, &apic, &extra_meta);
1067 int buf_size,
int *
len)
1072 int id3_buf_pos = 0;
1090 }
else if (*len <= 0) {
1101 int64_t maxsize = seg->
size >= 0 ? seg->
size : 1024*1024;
1103 int tag_got_bytes =
FFMIN(taglen, *len);
1104 int remaining = taglen - tag_got_bytes;
1106 if (taglen > maxsize) {
1122 memcpy(pls->
id3_buf + id3_buf_pos, buf, tag_got_bytes);
1123 id3_buf_pos += tag_got_bytes;
1126 *len -= tag_got_bytes;
1127 memmove(buf, buf + tag_got_bytes, *len);
1130 if (remaining > 0) {
1134 id3_buf_pos += remaining;
1145 if (*len >= 0 && (fill_buf || *len == 0)) {
1183 if (seg->
size >= 0) {
1202 if (ret !=
sizeof(pls->
key)) {
1215 iv[32] = key[32] =
'\0';
1216 if (strstr(seg->
url,
"://"))
1217 snprintf(url,
sizeof(url),
"crypto+%s", seg->
url);
1219 snprintf(url,
sizeof(url),
"crypto:%s", seg->
url);
1235 "SAMPLE-AES encryption is not supported yet\n");
1268 static const int max_init_section_size = 1024*1024;
1285 "Failed to open an initialization section in playlist %d\n",
1295 sec_size = max_init_section_size;
1298 "Downloading an initialization section of size %"PRId64
"\n",
1301 sec_size =
FFMIN(sec_size, max_init_section_size);
1334 int stream_needed = 0;
1381 int just_opened = 0;
1382 int reload_count = 0;
1390 int64_t reload_interval;
1425 "skipping %d segments ahead, expired from playlists\n",
1472 c->
http_multiple = strncmp((
const char *)http_version_opt,
"1.1", 3) == 0;
1532 if (rend->
type == type && !strcmp(rend->
group_id, group_id)) {
1563 if (rend->
type != type)
1581 int64_t timestamp,
int *seq_no)
1587 if (timestamp < pos) {
1648 static const char *
const opts[] = {
1649 "headers",
"http_proxy",
"user_agent",
"user-agent",
"cookies",
"referer",
NULL };
1650 const char *
const * opt =
opts;
1671 "A HLS playlist item '%s' referred to an external file '%s'. " 1672 "Opening this file was forbidden for security reasons\n",
1750 int flag_needed = 0;
1787 int highest_cur_seq_no = 0;
1793 c->first_packet = 1;
1820 if (
c->n_variants == 0) {
1827 if (
c->n_playlists > 1 ||
c->playlists[0]->n_segments == 0) {
1828 for (i = 0; i <
c->n_playlists; i++) {
1835 if (
c->variants[0]->playlists[0]->n_segments == 0) {
1843 if (
c->variants[0]->playlists[0]->finished) {
1845 for (i = 0; i <
c->variants[0]->playlists[0]->n_segments; i++)
1846 duration +=
c->variants[0]->playlists[0]->segments[i]->duration;
1851 for (i = 0; i <
c->n_variants; i++) {
1852 struct variant *var =
c->variants[i];
1863 for (i = 0; i <
c->n_variants; i++) {
1864 struct variant *v =
c->variants[i];
1874 for (i = 0; i <
c->n_playlists; i++) {
1885 for (i = 0; i <
c->n_playlists; i++) {
2008 if (cur_needed && !pls->
needed) {
2020 }
else if (first && !cur_needed && pls->
needed) {
2069 int64_t ts_b,
struct playlist *pls_b)
2080 int ret, i, minplaylist = -1;
2139 struct playlist *minpls = minplaylist < 0 ?
2141 if (minplaylist < 0) {
2144 int64_t dts = pls->
pkt.
dts;
2145 int64_t mindts = minpls->
pkt.
dts;
2155 if (minplaylist >= 0) {
2185 av_log(s,
AV_LOG_ERROR,
"stream index inconsistency: index %d, %d main streams, %d subdemuxer streams\n",
2220 int64_t timestamp,
int flags)
2226 int stream_subdemuxer_index;
2243 if (0 < duration && duration < seek_timestamp - first_timestamp)
2252 stream_subdemuxer_index = j;
2288 if (pls != seek_pls) {
2308 if (strncmp(p->
buf,
"#EXTM3U", 7))
2311 if (strstr(p->
buf,
"#EXT-X-STREAM-INF:") ||
2312 strstr(p->
buf,
"#EXT-X-TARGETDURATION:") ||
2313 strstr(p->
buf,
"#EXT-X-MEDIA-SEQUENCE:"))
2318 #define OFFSET(x) offsetof(HLSContext, x) 2319 #define FLAGS AV_OPT_FLAG_DECODING_PARAM 2321 {
"live_start_index",
"segment index to start live streams at (negative values are from the end)",
2323 {
"allowed_extensions",
"List of file extensions that hls is allowed to access",
2325 {.str =
"3gp,aac,avi,flac,mkv,m3u8,m4a,m4s,m4v,mpg,mov,mp2,mp3,mp4,mpeg,mpegts,ogg,ogv,oga,ts,vob,wav"},
2326 INT_MIN, INT_MAX, FLAGS},
2327 {
"max_reload",
"Maximum number of times a insufficient list is attempted to be reloaded",
2329 {
"http_persistent",
"Use persistent HTTP connections",
2331 {
"http_multiple",
"Use multiple HTTP connections for fetching segments",
2344 .
name =
"hls,applehttp",
#define FF_COMPLIANCE_EXPERIMENTAL
Allow nonstandardized experimental things.
int(* io_open)(struct AVFormatContext *s, AVIOContext **pb, const char *url, int flags, AVDictionary **options)
A callback for opening new IO streams.
static int update_init_section(struct playlist *pls, struct segment *seg)
struct segment * init_section
void ff_make_absolute_url(char *buf, int size, const char *base, const char *rel)
Convert a relative url into an absolute url, given a base url.
#define AVERROR_INVALIDDATA
Invalid data found when processing input.
int64_t avio_size(AVIOContext *s)
Get the filesize.
char * headers
holds HTTP headers set as an AVOption to the HTTP protocol context
char assoc_language[MAX_FIELD_LEN]
int strict_std_compliance
AVIOInterruptCB interrupt_callback
Custom interrupt callbacks for the I/O layer.
AVDictionary * id3_initial
static int set_stream_info_from_input_stream(AVStream *st, struct playlist *pls, AVStream *ist)
struct segment ** init_sections
static void handle_init_section_args(struct init_section_info *info, const char *key, int key_len, char **dest, int *dest_len)
static int read_from_url(struct playlist *pls, struct segment *seg, uint8_t *buf, int buf_size, enum ReadFromURLMode mode)
#define AV_LOG_WARNING
Something somehow does not look correct.
unsigned int id3_buf_size
ID3v2ExtraMeta * id3_deferred_extra
#define LIBAVUTIL_VERSION_INT
unsigned char * buf_ptr
Current position in the buffer.
unsigned char * buf_end
End of the data, may be less than buffer+buffer_size if the read function returned less data than req...
int event_flags
Flags for the user to detect events happening on the stream.
static int read_seek(AVFormatContext *ctx, int stream_index, int64_t timestamp, int flags)
static struct rendition * new_rendition(HLSContext *c, struct rendition_info *info, const char *url_base)
static int64_t default_reload_interval(struct playlist *pls)
enum AVCodecID codec_id
Specific type of the encoded data (the codec used).
unsigned int init_sec_data_len
int index
stream index in AVFormatContext
#define ID3v2_DEFAULT_MAGIC
Default magic bytes for ID3v2 header: "ID3".
int64_t avio_seek(AVIOContext *s, int64_t offset, int whence)
fseek() equivalent for AVIOContext.
const char * av_default_item_name(void *ptr)
Return the context name.
#define AVIO_FLAG_READ
read-only
char language[MAX_FIELD_LEN]
unsigned char * buffer
Start of the buffer.
int event_flags
Flags for the user to detect events happening on the file.
int av_dict_copy(AVDictionary **dst, const AVDictionary *src, int flags)
Copy entries from one AVDictionary struct into another.
static void fill_buf(uint8_t *data, int w, int h, int linesize, uint8_t v)
int av_usleep(unsigned usec)
Sleep for a period of time.
static void handle_rendition_args(struct rendition_info *info, const char *key, int key_len, char **dest, int *dest_len)
#define MAX_CHARACTERISTICS_LEN
int ctx_flags
Flags signalling stream properties.
int ff_id3v2_parse_apic(AVFormatContext *s, ID3v2ExtraMeta **extra_meta)
Create a stream for each APIC (attached picture) extracted from the ID3v2 header. ...
static void reset_packet(AVPacket *pkt)
int strict_std_compliance
Allow non-standard and experimental extension.
static int id3_has_changed_values(struct playlist *pls, AVDictionary *metadata, ID3v2ExtraMetaAPIC *apic)
unsigned int nb_stream_indexes
const char * class_name
The name of the class; usually it is the same name as the context structure type to which the AVClass...
#define av_assert0(cond)
assert() equivalent, that is always enabled.
unsigned int init_sec_buf_read_offset
#define ID3v2_HEADER_SIZE
char group_id[MAX_FIELD_LEN]
char audio[MAX_FIELD_LEN]
static void free_rendition_list(HLSContext *c)
int64_t duration
Duration of this packet in AVStream->time_base units, 0 if unknown.
static struct segment * next_segment(struct playlist *pls)
int id
Format-specific stream ID.
static void intercept_id3(struct playlist *pls, uint8_t *buf, int buf_size, int *len)
static struct playlist * new_playlist(HLSContext *c, const char *url, const char *base)
AVInputFormat ff_hls_demuxer
int ff_id3v2_parse_priv_dict(AVDictionary **metadata, ID3v2ExtraMeta **extra_meta)
Parse PRIV tags into a dictionary.
AVStream * avformat_new_stream(AVFormatContext *s, const AVCodec *c)
Add a new stream to a media file.
#define u(width, name, range_min, range_max)
AVStream ** streams
A list of all streams in the file.
static void handle_id3(AVIOContext *pb, struct playlist *pls)
AVFormatContext * avformat_alloc_context(void)
Allocate an AVFormatContext.
#define AVERROR_PROTOCOL_NOT_FOUND
Protocol not found.
AVDictionaryEntry * av_dict_get(const AVDictionary *m, const char *key, const AVDictionaryEntry *prev, int flags)
Get a dictionary entry with matching key.
int flags
Flags modifying the (de)muxer behaviour.
AVProgram * av_new_program(AVFormatContext *s, int id)
static int read_data(void *opaque, uint8_t *buf, int buf_size)
#define AVERROR_EOF
End of file.
unsigned int init_sec_buf_size
static av_cold int read_close(AVFormatContext *ctx)
#define AV_LOG_VERBOSE
Detailed information.
int av_match_ext(const char *filename, const char *extensions)
Return a positive value if the given filename has one of the given extensions, 0 otherwise.
struct rendition ** renditions
static int open_url_keepalive(AVFormatContext *s, AVIOContext **pb, const char *url)
enum AVDiscard discard
selects which program to discard and which to feed to the caller
static void add_metadata_from_renditions(AVFormatContext *s, struct playlist *pls, enum AVMediaType type)
unsigned int * stream_index
static void free_playlist_list(HLSContext *c)
struct rendition ** renditions
int avio_read(AVIOContext *s, unsigned char *buf, int size)
Read size bytes from AVIOContext into buf.
char * http_proxy
holds the address of the HTTP proxy server
#define AV_PKT_FLAG_KEY
The packet contains a keyframe.
struct variant ** variants
static AVRational get_timebase(struct playlist *pls)
int64_t av_rescale_q(int64_t a, AVRational bq, AVRational cq)
Rescale a 64-bit integer by 2 rational numbers.
Callback for checking whether to abort blocking functions.
int av_probe_input_buffer(AVIOContext *pb, AVInputFormat **fmt, const char *url, void *logctx, unsigned int offset, unsigned int max_probe_size)
Like av_probe_input_buffer2() but returns 0 on success.
AVIOContext * playlist_pb
int avcodec_parameters_copy(AVCodecParameters *dst, const AVCodecParameters *src)
Copy the contents of src to dst.
static int compare_ts_with_wrapdetect(int64_t ts_a, struct playlist *pls_a, int64_t ts_b, struct playlist *pls_b)
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered.
#define AV_DICT_MATCH_CASE
Only get an entry with exact-case key match.
AVDictionary * metadata
Metadata that applies to the whole file.
char video_group[MAX_FIELD_LEN]
static const AVClass hls_class
AVIOInterruptCB * interrupt_callback
static void handle_key_args(struct key_info *info, const char *key, int key_len, char **dest, int *dest_len)
#define NULL_IF_CONFIG_SMALL(x)
Return NULL if CONFIG_SMALL is true, otherwise the argument without modification. ...
char * url
input or output URL.
#define AV_LOG_DEBUG
Stuff which is only useful for libav* developers.
int64_t id3_mpegts_timestamp
void av_dict_free(AVDictionary **pm)
Free all the memory allocated for an AVDictionary struct and all keys and values. ...
static void free_segment_list(struct playlist *pls)
int ff_id3v2_parse_priv(AVFormatContext *s, ID3v2ExtraMeta **extra_meta)
Add metadata for all PRIV tags in the ID3v2 header.
enum AVMediaType codec_type
General type of the encoded data.
void ff_id3v2_free_extra_meta(ID3v2ExtraMeta **extra_meta)
Free memory allocated parsing special (non-text) metadata.
simple assert() macros that are a bit more flexible than ISO C assert().
static int update_streams_from_subdemuxer(AVFormatContext *s, struct playlist *pls)
void * av_mallocz(size_t size)
Allocate a memory block with alignment suitable for all memory accesses (including vectors if availab...
static int find_timestamp_in_playlist(HLSContext *c, struct playlist *pls, int64_t timestamp, int *seq_no)
New fields can be added to the end with minor version bumps.
size_t av_strlcpy(char *dst, const char *src, size_t size)
Copy the string src to dst, but no more than size - 1 bytes, and null-terminate dst.
int flags
A combination of AV_PKT_FLAG values.
void av_fast_malloc(void *ptr, unsigned int *size, size_t min_size)
Allocate a buffer, reusing the given one if large enough.
unsigned char * buf
Buffer must have AVPROBE_PADDING_SIZE of extra allocated bytes filled with zero.
unsigned int nb_streams
Number of elements in AVFormatContext.streams.
char group_id[MAX_FIELD_LEN]
static struct segment * current_segment(struct playlist *pls)
int seekable
A combination of AVIO_SEEKABLE_ flags or 0 when the stream is not seekable.
static int nested_io_open(AVFormatContext *s, AVIOContext **pb, const char *url, int flags, AVDictionary **opts)
#define AV_TIME_BASE
Internal time base represented as integer.
void av_program_add_stream_index(AVFormatContext *ac, int progid, unsigned int idx)
#define AV_OPT_SEARCH_CHILDREN
Search in possible children of the given object first.
#define AV_DICT_DONT_STRDUP_VAL
Take ownership of a value that's been allocated with av_malloc() or another memory allocation functio...
char * allowed_extensions
static void add_renditions_to_variant(HLSContext *c, struct variant *var, enum AVMediaType type, const char *group_id)
#define av_err2str(errnum)
Convenience macro, the return value should be used only directly in function arguments but never stan...
static int hls_read_packet(AVFormatContext *s, AVPacket *pkt)
static struct segment * new_init_section(struct playlist *pls, struct init_section_info *info, const char *url_base)
void * av_fast_realloc(void *ptr, unsigned int *size, size_t min_size)
Reallocate the given buffer if it is not large enough, otherwise do nothing.
static struct variant * new_variant(HLSContext *c, struct variant_info *info, const char *url, const char *base)
Usually treated as AVMEDIA_TYPE_DATA.
static void fill_timing_for_id3_timestamped_stream(struct playlist *pls)
struct segment ** segments
#define AVERROR_EXIT
Immediate exit was requested; the called function should not be restarted.
char * cookies
holds HTTP cookie values set in either the initial response or as an AVOption to the HTTP protocol co...
int64_t av_rescale_rnd(int64_t a, int64_t b, int64_t c, enum AVRounding rnd)
Rescale a 64-bit integer with specified rounding.
char subtitles_group[MAX_FIELD_LEN]
static int read_header(FFV1Context *f)
static void update_options(char **dest, const char *name, void *src)
#define AVERROR_PATCHWELCOME
Not yet implemented in FFmpeg, patches welcome.
static int read_packet(void *opaque, uint8_t *buf, int buf_size)
int avformat_queue_attached_pictures(AVFormatContext *s)
static void parse_id3(AVFormatContext *s, AVIOContext *pb, AVDictionary **metadata, int64_t *dts, ID3v2ExtraMetaAPIC **apic, ID3v2ExtraMeta **extra_meta)
#define AV_LOG_INFO
Standard information.
char * av_strdup(const char *s)
Duplicate a string.
char subtitles[MAX_FIELD_LEN]
AVStreamInternal * internal
An opaque field for libavformat internal usage.
int ff_check_interrupt(AVIOInterruptCB *cb)
Check if the user has requested to interrupt a blocking function associated with cb.
#define AV_TIME_BASE_Q
Internal time base represented as fractional value.
char * user_agent
holds HTTP user agent set as an AVOption to the HTTP protocol context
AVIOContext * pb
I/O context.
static int parse_playlist(HLSContext *c, const char *url, struct playlist *pls, AVIOContext *in)
void av_packet_unref(AVPacket *pkt)
Wipe the packet.
uint8_t * data
The data buffer.
static int open_url(AVFormatContext *s, AVIOContext **pb, const char *url, AVDictionary *opts, AVDictionary *opts2, int *is_http_out)
static const AVOption hls_options[]
static int hls_read_header(AVFormatContext *s)
int av_dict_set(AVDictionary **pm, const char *key, const char *value, int flags)
Set the given entry in *pm, overwriting an existing entry.
struct playlist ** playlists
#define AVERROR_BUG
Internal bug, also see AVERROR_BUG2.
static int open_input(HLSContext *c, struct playlist *pls, struct segment *seg, AVIOContext **in)
uint8_t pi<< 24) CONV_FUNC_GROUP(AV_SAMPLE_FMT_FLT, float, AV_SAMPLE_FMT_U8, uint8_t,(*(const uint8_t *) pi - 0x80) *(1.0f/(1<< 7))) CONV_FUNC_GROUP(AV_SAMPLE_FMT_DBL, double, AV_SAMPLE_FMT_U8, uint8_t,(*(const uint8_t *) pi - 0x80) *(1.0/(1<< 7))) CONV_FUNC_GROUP(AV_SAMPLE_FMT_U8, uint8_t, AV_SAMPLE_FMT_S16, int16_t,(*(const int16_t *) pi >> 8)+0x80) CONV_FUNC_GROUP(AV_SAMPLE_FMT_FLT, float, AV_SAMPLE_FMT_S16, int16_t, *(const int16_t *) pi *(1.0f/(1<< 15))) CONV_FUNC_GROUP(AV_SAMPLE_FMT_DBL, double, AV_SAMPLE_FMT_S16, int16_t, *(const int16_t *) pi *(1.0/(1<< 15))) CONV_FUNC_GROUP(AV_SAMPLE_FMT_U8, uint8_t, AV_SAMPLE_FMT_S32, int32_t,(*(const int32_t *) pi >> 24)+0x80) CONV_FUNC_GROUP(AV_SAMPLE_FMT_FLT, float, AV_SAMPLE_FMT_S32, int32_t, *(const int32_t *) pi *(1.0f/(1U<< 31))) CONV_FUNC_GROUP(AV_SAMPLE_FMT_DBL, double, AV_SAMPLE_FMT_S32, int32_t, *(const int32_t *) pi *(1.0/(1U<< 31))) CONV_FUNC_GROUP(AV_SAMPLE_FMT_U8, uint8_t, AV_SAMPLE_FMT_FLT, float, av_clip_uint8(lrintf(*(const float *) pi *(1<< 7))+0x80)) CONV_FUNC_GROUP(AV_SAMPLE_FMT_S16, int16_t, AV_SAMPLE_FMT_FLT, float, av_clip_int16(lrintf(*(const float *) pi *(1<< 15)))) CONV_FUNC_GROUP(AV_SAMPLE_FMT_S32, int32_t, AV_SAMPLE_FMT_FLT, float, av_clipl_int32(llrintf(*(const float *) pi *(1U<< 31)))) CONV_FUNC_GROUP(AV_SAMPLE_FMT_U8, uint8_t, AV_SAMPLE_FMT_DBL, double, av_clip_uint8(lrint(*(const double *) pi *(1<< 7))+0x80)) CONV_FUNC_GROUP(AV_SAMPLE_FMT_S16, int16_t, AV_SAMPLE_FMT_DBL, double, av_clip_int16(lrint(*(const double *) pi *(1<< 15)))) CONV_FUNC_GROUP(AV_SAMPLE_FMT_S32, int32_t, AV_SAMPLE_FMT_DBL, double, av_clipl_int32(llrint(*(const double *) pi *(1U<< 31)))) #define SET_CONV_FUNC_GROUP(ofmt, ifmt) static void set_generic_function(AudioConvert *ac) { } void ff_audio_convert_free(AudioConvert **ac) { if(! *ac) return;ff_dither_free(&(*ac) ->dc);av_freep(ac);} AudioConvert *ff_audio_convert_alloc(AVAudioResampleContext *avr, enum AVSampleFormat out_fmt, enum AVSampleFormat in_fmt, int channels, int sample_rate, int apply_map) { AudioConvert *ac;int in_planar, out_planar;ac=av_mallocz(sizeof(*ac));if(!ac) return NULL;ac->avr=avr;ac->out_fmt=out_fmt;ac->in_fmt=in_fmt;ac->channels=channels;ac->apply_map=apply_map;if(avr->dither_method !=AV_RESAMPLE_DITHER_NONE &&av_get_packed_sample_fmt(out_fmt)==AV_SAMPLE_FMT_S16 &&av_get_bytes_per_sample(in_fmt) > 2) { ac->dc=ff_dither_alloc(avr, out_fmt, in_fmt, channels, sample_rate, apply_map);if(!ac->dc) { av_free(ac);return NULL;} return ac;} in_planar=ff_sample_fmt_is_planar(in_fmt, channels);out_planar=ff_sample_fmt_is_planar(out_fmt, channels);if(in_planar==out_planar) { ac->func_type=CONV_FUNC_TYPE_FLAT;ac->planes=in_planar ? ac->channels :1;} else if(in_planar) ac->func_type=CONV_FUNC_TYPE_INTERLEAVE;else ac->func_type=CONV_FUNC_TYPE_DEINTERLEAVE;set_generic_function(ac);if(ARCH_AARCH64) ff_audio_convert_init_aarch64(ac);if(ARCH_ARM) ff_audio_convert_init_arm(ac);if(ARCH_X86) ff_audio_convert_init_x86(ac);return ac;} int ff_audio_convert(AudioConvert *ac, AudioData *out, AudioData *in) { int use_generic=1;int len=in->nb_samples;int p;if(ac->dc) { av_log(ac->avr, AV_LOG_TRACE, "%d samples - audio_convert: %s to %s (dithered)\", len, av_get_sample_fmt_name(ac->in_fmt), av_get_sample_fmt_name(ac->out_fmt));return ff_convert_dither(ac-> in
Describe the class of an AVClass context structure.
static void update_noheader_flag(AVFormatContext *s)
Rational number (pair of numerator and denominator).
struct segment * cur_init_section
static int save_avio_options(AVFormatContext *s)
#define AV_OPT_ALLOW_NULL
In av_opt_get, return NULL if the option has a pointer type and is set to NULL, rather than returning...
int need_context_update
Whether the internal avctx needs to be updated from codecpar (after a late change to codecpar) ...
struct playlist * playlist
static void add_stream_to_programs(AVFormatContext *s, struct playlist *pls, AVStream *stream)
void avformat_free_context(AVFormatContext *s)
Free an AVFormatContext and all its streams.
This structure contains the data a format has to probe a file.
int av_read_frame(AVFormatContext *s, AVPacket *pkt)
Return the next frame of a stream.
static void handle_variant_args(struct variant_info *info, const char *key, int key_len, char **dest, int *dest_len)
const char * avio_find_protocol_name(const char *url)
Return the name of the protocol that will handle the passed URL.
int size
Size of data in bytes.
URLContext * ffio_geturlcontext(AVIOContext *s)
Return the URLContext associated with the AVIOContext.
void avpriv_report_missing_feature(void *avc, const char *msg,...) av_printf_format(2
Log a generic warning message about a missing feature.
char audio_group[MAX_FIELD_LEN]
int64_t av_gettime_relative(void)
Get the current time in microseconds since some unspecified starting point.
static int recheck_discard_flags(AVFormatContext *s, int first)
int ff_http_do_new_request(URLContext *h, const char *uri)
Send a new HTTP request, reusing the old connection.
char characteristics[MAX_CHARACTERISTICS_LEN]
char * av_strtok(char *s, const char *delim, char **saveptr)
Split the string into several tokens which can be accessed by successive calls to av_strtok()...
int av_strstart(const char *str, const char *pfx, const char **ptr)
Return non-zero if pfx is a prefix of str.
char language[MAX_FIELD_LEN]
#define INITIAL_BUFFER_SIZE
int ff_id3v2_match(const uint8_t *buf, const char *magic)
Detect ID3v2 Header.
int ffio_init_context(AVIOContext *s, unsigned char *buffer, int buffer_size, int write_flag, void *opaque, int(*read_packet)(void *opaque, uint8_t *buf, int buf_size), int(*write_packet)(void *opaque, uint8_t *buf, int buf_size), int64_t(*seek)(void *opaque, int64_t offset, int whence))
static int playlist_needed(struct playlist *pls)
int avformat_find_stream_info(AVFormatContext *ic, AVDictionary **options)
Read packets of a media file to get stream information.
int av_dict_set_int(AVDictionary **pm, const char *key, int64_t value, int flags)
Convenience wrapper for av_dict_set that converts the value to a string and stores it...
int disposition
AV_DISPOSITION_* bit field.
int64_t pos
position in the file of the current buffer
int pts_wrap_bits
number of bits in pts (used for wrapping control)
void av_init_packet(AVPacket *pkt)
Initialize optional fields of a packet with default values.
void avformat_close_input(AVFormatContext **s)
Close an opened input AVFormatContext.
#define AV_INPUT_BUFFER_PADDING_SIZE
Required number of additionally allocated bytes at the end of the input bitstream for decoding...
static int hls_probe(AVProbeData *p)
static int ensure_playlist(HLSContext *c, struct playlist **pls, const char *url)
static int hls_read_seek(AVFormatContext *s, int stream_index, int64_t timestamp, int flags)
static av_always_inline int diff(const uint32_t a, const uint32_t b)
int av_opt_get(void *obj, const char *name, int search_flags, uint8_t **out_val)
void ff_id3v2_read_dict(AVIOContext *pb, AVDictionary **metadata, const char *magic, ID3v2ExtraMeta **extra_meta)
Read an ID3v2 tag into specified dictionary and retrieve supported extra metadata.
int eof_reached
true if eof reached
int ff_id3v2_tag_len(const uint8_t *buf)
Get the length of an ID3v2 tag.
void * priv_data
Format private data.
int avformat_open_input(AVFormatContext **ps, const char *url, AVInputFormat *fmt, AVDictionary **options)
Open an input stream and read the header.
char * referer
holds HTTP referer set as an AVOption to the HTTP protocol context
struct playlist ** playlists
int64_t dts
Decompression timestamp in AVStream->time_base units; the time at which the packet is decompressed...
char video[MAX_FIELD_LEN]
int64_t duration
Duration of the stream, in AV_TIME_BASE fractional seconds.
#define AV_DICT_IGNORE_SUFFIX
Return first entry in a dictionary whose first part corresponds to the search key, ignoring the suffix of the found key string.
AVCodecParameters * codecpar
Codec parameters associated with this stream.
int avio_feof(AVIOContext *s)
feof() equivalent for AVIOContext.
#define FFSWAP(type, a, b)
AVRational time_base
This is the fundamental unit of time (in seconds) in terms of which frame timestamps are represented...
static void free_init_section_list(struct playlist *pls)
static void free_variant_list(HLSContext *c)
int ff_get_chomp_line(AVIOContext *s, char *buf, int maxlen)
Same as ff_get_line but strip the white-space characters in the text tail.
enum AVDiscard discard
Selects which packets can be discarded at will and do not need to be demuxed.
char key_url[MAX_URL_SIZE]
static int hls_close(AVFormatContext *s)
This structure stores compressed data.
mode
Use these values in ebur128_init (or'ed).
int64_t pts
Presentation timestamp in AVStream->time_base units; the time at which the decompressed packet will b...
AVPacket attached_pic
For streams with AV_DISPOSITION_ATTACHED_PIC disposition, this packet will contain the attached pictu...
#define AV_NOPTS_VALUE
Undefined timestamp value.
static av_cold void cleanup(FlashSV2Context *s)
int64_t av_compare_mod(uint64_t a, uint64_t b, uint64_t mod)
Compare the remainders of two integer operands divided by a common divisor.
static int select_cur_seq_no(HLSContext *c, struct playlist *pls)