| Age | Commit message (Collapse) | Author | 
|---|
|  | and that each stream object is removed from its parent xine object's
list before it starts destroying itself. | 
|  | audio channels. So we must keep discarding packets that cannot be used to
initialise the codec until we receive one that can be. | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | The problem
When watching live DVB, data is delivered strictly at the broadcasters
speed. We cannot change it through server commands. Our local systems clock
usually runs slightly faster or slower than that, causing a/v fifos to run
empty or full after a few minutes.
Standard network buffering control only handles the first case by pausing
the engine (not nice). The latter case ends up in severe stuttering and an
a/v lag of several seconds (annoying).
I tried quite a few differnt algorithms, and this one made it:
a 3 point controller.
There is a target buffer fill window with a center and some tolerated width:
Minimum:
  definition: 1 second
  safety: clamped to 38% of fio size
  action: switch playback speed to 99.5%
Center:
  definition: 2 seconds
  safety: clamped to 73% fifo size
  action: switch to normal playback speed
Maximum:
  definition: 3 seconds
  safety: clamped to 98% fifo fill
  action: switch playback speed to 100.5%
If the usual dvb audio to video muxing delay is more than 1 second, center
time is increased. On low bitrate radio, window width is increased.
Real TVs do adjust playback audio sampling rate to follow delivery speed.
Some PC sound cards can do that, too. It could be implemented transparently
(although I don't know yet how). This comes quite close, resampling audio to
stretch.
That half percent is large enough to cover clock deviation, and it is small
enough not to cause audible pitch bending. Speed control consists of
adjusting SCR and telling audio out. Doing just the first will cause
metronom to drop and/or insert whole audio frames, not nice with music.
BTW. this one needs demux_ts to send BUF_FLAG_FRAME_START. | 
|  | I've now tested this patch on Fedora 15 (FFmpeg 0.7) and Fedora 14 (FFmpeg
0.6), and am happy to report that it works fine on F15 and doesn't break
xine-lib on F14.  On F14, it also has the happy side effect of no longer
trying to decode an LATM AAC stream with the xineplug_decode_faad.so plugin.
(Which was something which never ended well anyway.) | 
|  | --HG--
rename : src/xine-engine/buffer.h => include/xine/buffer.h
rename : src/libxineadec/xine_lpcm_decoder.c => src/audio_dec/xine_lpcm_decoder.c
rename : src/libspuhdmv/xine_hdmv_decoder.c => src/spu_dec/spuhdmv_decoder.c | 
|  | When watching TV with Kaffeine I frequently had complete engine lockups.
Multiple mutexes were waiting on each other. net_buf_ctrl requires the
demuxer to keep running while playback is still paused.
The diff might look a bit confusing. Basically, all I did was to replace
  phtread_mutex_lock ();
  ...
  pthread_mutex_unlock ();
with
  if (pthread_mutex_trylock ()) {
    ...
    pthread_mutex_unlock ();
  }
at a place where it does the least damage. | 
|  | xine_play () gets suspended after start or seek until first frame gets
displayed. This often wont work on slow machines when first frame gets
dropped because its too old. Consequently, UI freezes for full 10 seconds.
Let's wake up xine_play when this happens as well.
OK, this is a luxury convenience fix ;-) | 
|  | Audio decoder loop creates a sorted map of available audio channels on the
fly. If neither user nor dvdnav intervene, it will pass the first (= lowest
index) audio channel to decoders.
Now imagine a TV recording with 2 audio channels:
audio.0: eac3 5.1 (fra)
audio.1: eac3 stereo (qaa)
By chance, first audio frame to be demuxed is for channel #1.
Track map will be
[0]: eac3, channel 1
Audio loop opens ffmpeg audio decoder / stereo out. Fine.
Then, first frame for channel #0 comes in.
[0]: eac3, channel 0
[1]: eac3, channel 1
Both are same codec, so audio loop just switches to channel 0 without
further notice. Audio decoder then runs into a mem leak, or worse, crashes
audio out who still thinks we're only stereo.
Whenever we insert something at track map index 0, and its going to be
auto-selected later, reset current codec type. This forces a clean
decoder/output switch. | 
|  |  | 
|  |  | 
|  | Certain ffmpeg audio decoders use 32 bit float samples internally (wma,
eac3, ...). They are then exported to the calling application as 16 bit
integer.
That conversion is done by faster sse2 code if your processor supports it.
However, sse2 instructions require data buffers to be 16 byte aligned, or
hit a segfault otherwise.
Plain malloc() / realloc() ensures only 8 byte alignment, giving a 50%
chance of a crash.
FFmpeg internally uses aligned buffers a lot. It seems to be a good idea to
do likewise for input buffers as well, even if current version does not
strictly need it yet.
Libavutil/av_realloc() has a bug that can break the alignment when enlarging
an existing buffer. Thus I included a fixed version of it within
ff_audio_decoder.c. | 
|  |  | 
|  |  | 
|  |  | 
|  | avcodec_thread_init() was deprecated in lavc 52.112.0 (2011-02-09) | 
|  | This is a small mistake, but I'm fairly sure the index should be "j" and not
"i". | 
|  |  | 
|  |  | 
|  | Demuxer does not send PCM header.
Decoder can't handle raw PCM stream without configuration. | 
|  | all descriptors | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | Check used (NULL) target pointer instead of length and would be always false | 
|  |  | 
|  | _x_set_file_close_on_exec() and _x_set_socket_close_on_exec() prototypes were missing.
We need the prototypes because of visibility attributes. | 
|  | Now all used decoders work without header/preview buffers. | 
|  |  | 
|  |  | 
|  | pids. | 
|  | negative value (that results writing out of buffer when buffering payload). Check buffer size before checking substream header bytes. | 
|  | skips pes header | 
|  | parsing pts. | 
|  | 6 is not enough ; anything less than 9 is invalid (header length byte at [8] can't be used if it is outside of buffer). Moved check to beginning of parse_pes_header() to avoid reading outside of buffer. | 
|  | stream_id >= 0xbc) | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | 4 lowest bits are 0 --> Handle as 24-bit BluRay PCM. | 
|  | bit BE, not in DVD format. | 
|  |  | 
|  |  |