36 #define NUT_MAX_STREAMS 256     
   39                                   int64_t *pos_arg, int64_t pos_limit);
 
   47     while (len > maxlen) {
 
   55         string[
FFMIN(len, maxlen - 1)] = 0;
 
   90 static inline uint64_t get_v_trace(
AVIOContext *bc, 
const char *file,
 
   96            v, v, file, func, line);
 
  100 static inline int64_t get_s_trace(
AVIOContext *bc, 
const char *file,
 
  106            v, v, file, func, line);
 
  110 static inline uint64_t get_4cc_trace(
AVIOContext *bc, 
char *file,
 
  116            v, v, file, func, line);
 
  119 #define ffio_read_varlen(bc) get_v_trace(bc,  __FILE__, __PRETTY_FUNCTION__, __LINE__) 
  120 #define get_s(bc)            get_s_trace(bc,  __FILE__, __PRETTY_FUNCTION__, __LINE__) 
  121 #define get_fourcc(bc)       get_4cc_trace(bc, __FILE__, __PRETTY_FUNCTION__, __LINE__) 
  125                             int calculate_checksum, uint64_t startcode)
 
  154         state = (state << 8) | 
avio_r8(bc);
 
  155         if ((state >> 56) != 
'N')
 
  180         if (startcode == code)
 
  182         else if (startcode == 0)
 
  192     for (i = 0; i < p->
buf_size-8; i++) {
 
  201 #define GET_V(dst, check)                                                     \ 
  203         tmp = ffio_read_varlen(bc);                                           \ 
  205             av_log(s, AV_LOG_ERROR, "Error " #dst " is (%"PRId64")\n", tmp);  \ 
  206             ret = AVERROR_INVALIDDATA;                                        \ 
  233     unsigned int stream_count;
 
  234     int i, j, 
count, ret;
 
  235     int tmp_stream, tmp_mul, tmp_pts, tmp_size, tmp_res, tmp_head_idx;
 
  276     for (i = 0; i < 256;) {
 
  297             count = tmp_mul - tmp_size;
 
  303         while (tmp_fields-- > 8) {
 
  317         if (tmp_stream >= stream_count) {
 
  323         for (j = 0; j < 
count; j++, i++) {
 
  380     for (i = 0; i < stream_count; i++)
 
  398     int class, stream_id, ret;
 
  406     stc = &nut->
stream[stream_id];
 
  411     class                = ffio_read_varlen(bc);
 
  449                "Unknown codec tag '0x%04x' for stream number %d\n",
 
  450                (
unsigned int) tmp, stream_id);
 
  484                "stream header %d checksum mismatch\n", stream_id);
 
  493     if (st && st->
codec) {
 
  511         if (stream_id == i || stream_id == -1)
 
  519     uint64_t tmp, chapter_start, chapter_len;
 
  520     unsigned int stream_id_plus1, 
count;
 
  521     int chapter_id, i, ret = 0;
 
  523     char name[256], str_value[1024], type_str[256];
 
  525     int *event_flags        = 
NULL;
 
  529     int metadata_flag       = 0;
 
  535     chapter_id    = 
get_s(bc);
 
  540     if (chapter_id && !stream_id_plus1) {
 
  545                                      start, start + chapter_len, 
NULL);
 
  551     } 
else if (stream_id_plus1) {
 
  552         st       = s->
streams[stream_id_plus1 - 1];
 
  562     for (i = 0; i < 
count; i++) {
 
  563         ret = 
get_str(bc, name, 
sizeof(name));
 
  573             ret = 
get_str(bc, str_value, 
sizeof(str_value));
 
  574         } 
else if (value == -2) {
 
  575             ret = 
get_str(bc, type_str, 
sizeof(type_str));
 
  581             ret = 
get_str(bc, str_value, 
sizeof(str_value));
 
  582         } 
else if (value == -3) {
 
  585         } 
else if (value == -4) {
 
  588         } 
else if (value < -4) {
 
  605         if (!strcmp(type, 
"UTF-8")) {
 
  606             if (chapter_id == 0 && !strcmp(name, 
"Disposition")) {
 
  611             if (stream_id_plus1 && !strcmp(name, 
"r_frame_rate")) {
 
  622                     *event_flags |= metadata_flag;
 
  633     return FFMIN(ret, 0);
 
  697     int i, j, syncpoint_count;
 
  699     int64_t *syncpoints = 
NULL;
 
  701     int8_t *has_keyframe = 
NULL;
 
  726     GET_V(syncpoint_count, tmp < INT_MAX / 8 && tmp > 0);
 
  729     if (!syncpoints || !has_keyframe) {
 
  733     for (i = 0; i < syncpoint_count; i++) {
 
  735         if (syncpoints[i] <= 0)
 
  738             syncpoints[i] += syncpoints[i - 1];
 
  743         for (j = 0; j < syncpoint_count;) {
 
  751                 if (n + x >= syncpoint_count + 1) {
 
  752                     av_log(s, 
AV_LOG_ERROR, 
"index overflow A %d + %"PRIu64
" >= %d\n", n, x, syncpoint_count + 1);
 
  756                     has_keyframe[n++] = 
flag;
 
  757                 has_keyframe[n++] = !
flag;
 
  764                     if (n >= syncpoint_count + 1) {
 
  768                     has_keyframe[n++] = x & 1;
 
  772             if (has_keyframe[0]) {
 
  777             for (; j < n && j < syncpoint_count; j++) {
 
  778                 if (has_keyframe[j]) {
 
  825     int initialized_stream_count;
 
  841     for (initialized_stream_count = 0; initialized_stream_count < s->
nb_streams;) {
 
  848             initialized_stream_count++;
 
  857         if (startcode == 0) {
 
  895     int64_t channel_layout = 0;
 
  901     for (i=0; i<
count; i++) {
 
  906         ret = 
get_str(bc, name, 
sizeof(name));
 
  914             ret = 
get_str(bc, str_value, 
sizeof(str_value));
 
  920         } 
else if (value == -2) {
 
  922             int64_t v64, value_len;
 
  924             ret = 
get_str(bc, type_str, 
sizeof(type_str));
 
  932             if (!strcmp(name, 
"Palette")) {
 
  934             } 
else if (!strcmp(name, 
"Extradata")) {
 
  936             } 
else if (sscanf(name, 
"CodecSpecificSide%"SCNd64
"", &v64) == 1) {
 
  942             } 
else if (!strcmp(name, 
"ChannelLayout") && value_len == 8) {
 
  953         } 
else if (value == -3) {
 
  955         } 
else if (value == -4) {
 
  957         } 
else if (value < -4) {
 
  960             if (!strcmp(name, 
"SkipStart")) {
 
  962             } 
else if (!strcmp(name, 
"SkipEnd")) {
 
  964             } 
else if (!strcmp(name, 
"Channels")) {
 
  966             } 
else if (!strcmp(name, 
"SampleRate")) {
 
  968             } 
else if (!strcmp(name, 
"Width")) {
 
  970             } 
else if (!strcmp(name, 
"Height")) {
 
  978     if (channels || channel_layout || sample_rate || width || height) {
 
  982         bytestream_put_le32(&dst,
 
  989             bytestream_put_le32(&dst, channels);
 
  991             bytestream_put_le64(&dst, channel_layout);
 
  993             bytestream_put_le32(&dst, sample_rate);
 
  994         if (width || height){
 
  995             bytestream_put_le32(&dst, width);
 
  996             bytestream_put_le32(&dst, height);
 
 1000     if (skip_start || skip_end) {
 
 1015                                uint8_t *header_idx, 
int frame_code)
 
 1020     int size, 
flags, size_mul, pts_delta, i, reserved_count, ret;
 
 1026                "Last frame must have been damaged %"PRId64
" > %"PRId64
" + %d\n",
 
 1046     stc = &nut->
stream[*stream_id];
 
 1064     for (i = 0; i < reserved_count; i++) {
 
 1101     int size, stream_id, discard, ret;
 
 1102     int64_t 
pts, last_IP_pts;
 
 1110     stc = &nut->
stream[stream_id];
 
 1119          last_IP_pts > pts) ||
 
 1143         pkt->
size -= sm_size;
 
 1168     int i, frame_code = 0, ret, skip;
 
 1169     int64_t ts, back_ptr;
 
 1182             if (frame_code == 
'N') {
 
 1184                 for (i = 1; i < 8; i++)
 
 1185                     tmp = (tmp << 8) + 
avio_r8(bc);
 
 1223                                   int64_t *pos_arg, int64_t pos_limit)
 
 1227     int64_t pos, 
pts, back_ptr;
 
 1229            stream_index, *pos_arg, pos_limit);
 
 1243     if (stream_index == -2)
 
 1256     Syncpoint *
sp, *next_node[2] = { &nopts_sp, &nopts_sp };
 
 1257     int64_t pos, pos2, ts;
 
 1275                      (
void **) next_node);
 
 1277                next_node[0]->pos, next_node[1]->pos, next_node[0]->ts,
 
 1280                             next_node[1]->
pos, next_node[1]->
pos,
 
 1281                             next_node[0]->
ts, next_node[1]->
ts,
 
 1287             dummy.
pos    = pos + 16;
 
 1288             next_node[1] = &nopts_sp;
 
 1290                          (
void **) next_node);
 
 1292                                  next_node[1]->
pos, next_node[1]->
pos,
 
 1311     if (pos2 > pos || pos2 + 15 < pos)
 
 1331     .extensions     = 
"nut",
 
uint64_t ffio_read_varlen(AVIOContext *bc)
discard all frames except keyframes 
#define AVERROR_INVALIDDATA
Invalid data found when processing input. 
int64_t avio_size(AVIOContext *s)
Get the filesize. 
void av_free_packet(AVPacket *pkt)
Free a packet. 
int64_t last_syncpoint_pos
int av_add_index_entry(AVStream *st, int64_t pos, int64_t timestamp, int size, int distance, int flags)
Add an index entry into a sorted list. 
enum AVDurationEstimationMethod duration_estimation_method
The duration field can be estimated through various ways, and this field can be used to know how the ...
#define AV_LOG_WARNING
Something somehow does not look correct. 
int64_t pos
byte position in stream, -1 if unknown 
void av_shrink_packet(AVPacket *pkt, int size)
Reduce packet size, correctly zeroing padding. 
const AVCodecTag ff_nut_audio_extra_tags[]
int event_flags
Flags for the user to detect events happening on the stream. 
static int get_str(AVIOContext *bc, char *string, unsigned int maxlen)
AVRational sample_aspect_ratio
sample aspect ratio (0 if unknown) 
int64_t avio_seek(AVIOContext *s, int64_t offset, int whence)
fseek() equivalent for AVIOContext. 
AVIndexEntry * index_entries
Only used if the format does not support seeking natively. 
AVFormatInternal * internal
An opaque field for libavformat internal usage. 
int event_flags
Flags for the user to detect events happening on the file. 
static void set_disposition_bits(AVFormatContext *avf, char *value, int stream_id)
int64_t avio_skip(AVIOContext *s, int64_t offset)
Skip given number of bytes forward. 
static int decode_main_header(NUTContext *nut)
const uint8_t * header[128]
static int decode_frame_header(NUTContext *nut, int64_t *pts, int *stream_id, uint8_t *header_idx, int frame_code)
static int64_t nut_read_timestamp(AVFormatContext *s, int stream_index, int64_t *pos_arg, int64_t pos_limit)
#define av_assert0(cond)
assert() equivalent, that is always enabled. 
void * av_tree_find(const AVTreeNode *t, void *key, int(*cmp)(void *key, const void *b), void *next[2])
Opaque data information usually continuous. 
static int nut_probe(AVProbeData *p)
enum AVCodecID av_codec_get_id(const struct AVCodecTag *const *tags, unsigned int tag)
Get the AVCodecID for the given codec tag tag. 
const AVCodecTag ff_codec_movvideo_tags[]
unsigned int avio_rb32(AVIOContext *s)
static av_cold int end(AVCodecContext *avctx)
uint8_t * extradata
some codecs need / can use extradata like Huffman tables. 
AVStream * avformat_new_stream(AVFormatContext *s, const AVCodec *c)
Add a new stream to a media file. 
uint64_t_TMPL AV_WL64 unsigned int_TMPL AV_WL32 unsigned int_TMPL AV_WL24 unsigned int_TMPL AV_WL16 uint64_t_TMPL AV_WB64 unsigned int_TMPL AV_RB32
AVStream ** streams
A list of all streams in the file. 
const AVMetadataConv ff_nut_metadata_conv[]
static double av_q2d(AVRational a)
Convert rational to double. 
static int decode_frame(NUTContext *nut, AVPacket *pkt, int frame_code)
#define AVERROR_EOF
End of file. 
static av_cold int read_close(AVFormatContext *ctx)
#define AV_LOG_VERBOSE
Detailed information. 
const AVCodecTag ff_nut_data_tags[]
uint64_t avio_rb64(AVIOContext *s)
static av_always_inline int64_t avio_tell(AVIOContext *s)
ftell() equivalent for AVIOContext. 
int ff_nut_sp_pos_cmp(const Syncpoint *a, const Syncpoint *b)
int avio_read(AVIOContext *s, unsigned char *buf, int size)
Read size bytes from AVIOContext into buf. 
#define AV_PKT_FLAG_KEY
The packet contains a keyframe. 
int64_t av_rescale_q(int64_t a, AVRational bq, AVRational cq)
Rescale a 64-bit integer by 2 rational numbers. 
int av_new_packet(AVPacket *pkt, int size)
Allocate the payload of a packet and initialize its fields with default values. 
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered. 
AVDictionary * metadata
Metadata that applies to the whole file. 
int has_b_frames
Size of the frame reordering buffer in the decoder. 
void ff_nut_free_sp(NUTContext *nut)
int av_index_search_timestamp(AVStream *st, int64_t timestamp, int flags)
Get the index for a specific timestamp. 
unsigned int avio_rl32(AVIOContext *s)
discard all bidirectional frames 
An AV_PKT_DATA_PARAM_CHANGE side data packet is laid out as follows: 
int64_t timestamp
Timestamp in AVStream.time_base units, preferably the time from which on correctly decoded frames are...
#define NULL_IF_CONFIG_SMALL(x)
Return NULL if CONFIG_SMALL is true, otherwise the argument without modification. ...
#define AV_LOG_DEBUG
Stuff which is only useful for libav* developers. 
simple assert() macros that are a bit more flexible than ISO C assert(). 
int64_t av_gcd(int64_t a, int64_t b)
Return the greatest common divisor of a and b. 
static int nut_read_packet(AVFormatContext *s, AVPacket *pkt)
const AVCodecTag ff_nut_audio_tags[]
static int decode_stream_header(NUTContext *nut)
const AVCodecTag ff_codec_wav_tags[]
int ff_nut_sp_pts_cmp(const Syncpoint *a, const Syncpoint *b)
int flags
A combination of AV_PKT_FLAG values. 
int avio_r8(AVIOContext *s)
AVCodecContext * codec
Codec context associated with this stream. 
static int nut_read_close(AVFormatContext *s)
int buf_size
Size of buf except extra allocated bytes. 
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. 
void ffio_init_checksum(AVIOContext *s, unsigned long(*update_checksum)(unsigned long c, const uint8_t *p, unsigned int len), unsigned long checksum)
int seekable
A combination of AVIO_SEEKABLE_ flags or 0 when the stream is not seekable. 
void ff_nut_reset_ts(NUTContext *nut, AVRational time_base, int64_t val)
#define AV_TIME_BASE
Internal time base represented as integer. 
const AVCodecTag ff_codec_bmp_tags[]
int av_strcasecmp(const char *a, const char *b)
Locale-independent case-insensitive compare. 
int width
picture width / height. 
static uint64_t find_any_startcode(AVIOContext *bc, int64_t pos)
GLsizei GLboolean const GLfloat * value
unsigned long ff_crc04C11DB7_update(unsigned long checksum, const uint8_t *buf, unsigned int len)
static int find_and_decode_index(NUTContext *nut)
int64_t ff_lsb2full(StreamContext *stream, int64_t lsb)
internal header for RIFF based (de)muxers do NOT include this in end user applications ...
static uint64_t get_fourcc(AVIOContext *bc)
static int get_packetheader(NUTContext *nut, AVIOContext *bc, int calculate_checksum, uint64_t startcode)
#define FFABS(a)
Absolute value, Note, INT_MIN / INT64_MIN result in undefined behavior as they are not representable ...
struct AVTreeNode * syncpoints
static int nut_read_header(AVFormatContext *s)
static int read_header(FFV1Context *f)
static int decode_syncpoint(NUTContext *nut, int64_t *ts, int64_t *back_ptr)
static int read_packet(void *opaque, uint8_t *buf, int buf_size)
static int read_sm_data(AVFormatContext *s, AVIOContext *bc, AVPacket *pkt, int is_meta, int64_t maxpos)
#define AV_LOG_INFO
Standard information. 
enum AVMediaType codec_type
const AVCodecTag ff_nut_subtitle_tags[]
#define AV_TIME_BASE_Q
Internal time base represented as fractional value. 
int sample_rate
samples per second 
AVIOContext * pb
I/O context. 
unsigned int codec_tag
fourcc (LSB first, so "ABCD" -> ('D'<<24) + ('C'<<16) + ('B'<<8) + 'A'). 
Data found in BlockAdditional element of matroska container. 
int av_dict_set(AVDictionary **pm, const char *key, const char *value, int flags)
Set the given entry in *pm, overwriting an existing entry. 
#define GET_V(dst, check)
BYTE int const BYTE int int int height
rational number numerator/denominator 
Recommmends skipping the specified number of samples. 
unsigned long ffio_get_checksum(AVIOContext *s)
int(* func)(AVBPrint *dst, const char *in, const char *arg)
static int skip_reserved(AVIOContext *bc, int64_t pos)
static int64_t find_startcode(AVIOContext *bc, uint64_t code, int64_t pos)
Find the given startcode. 
This structure contains the data a format has to probe a file. 
static int read_seek(AVFormatContext *s, int stream_index, int64_t pts, int flags)
void * av_calloc(size_t nmemb, size_t size)
Allocate a block of nmemb * size bytes with alignment suitable for all memory accesses (including vec...
static int64_t pts
Global timestamp for the audio frames. 
static int64_t find_duration(NUTContext *nut, int64_t filesize)
const Dispositions ff_nut_dispositions[]
unsigned int avio_rl16(AVIOContext *s)
static int decode_info_header(NUTContext *nut)
FrameCode frame_code[256]
int disposition
AV_DISPOSITION_* bit field. 
const AVCodecTag ff_nut_video_tags[]
int ff_nut_add_sp(NUTContext *nut, int64_t pos, int64_t back_ptr, int64_t ts)
#define SYNCPOINT_STARTCODE
int eof_reached
true if eof reached 
AVInputFormat ff_nut_demuxer
int channels
number of audio channels 
static int64_t get_s(AVIOContext *bc)
void * priv_data
Format private data. 
int64_t duration
Duration of the stream, in AV_TIME_BASE fractional seconds. 
#define av_malloc_array(a, b)
int avio_feof(AVIOContext *s)
feof() equivalent for AVIOContext. 
uint8_t * av_packet_new_side_data(AVPacket *pkt, enum AVPacketSideDataType type, int size)
Allocate new information of a packet. 
AVRational time_base
This is the fundamental unit of time (in seconds) in terms of which frame timestamps are represented...
enum AVDiscard discard
Selects which packets can be discarded at will and do not need to be demuxed. 
AVRational r_frame_rate
Real base framerate of the stream. 
const AVCodecTag *const ff_nut_codec_tags[]
This structure stores compressed data. 
uint64_t avio_rl64(AVIOContext *s)
unsigned int time_base_count
int64_t pts
Presentation timestamp in AVStream->time_base units; the time at which the decompressed packet will b...
#define AV_NOPTS_VALUE
Undefined timestamp value. 
unsigned int max_distance