On Tue, 2 Apr 2024 00:18:04 GMT, Alexander Matveev <almat...@openjdk.org> wrote:

> - Added support for #EXT-X-MEDIA tag to HTTP Live Streaming.
> - Following audio renditions via #EXT-X-MEDIA tag will be supported (see CSR 
> for more details):
>   - MP2T streams with one H.264/AVC video track and elementary AAC audio 
> stream via #EXT-X-MEDIA tag.
>   - fMP4 streams with one H.264/AVC or H.265/HEVC video track and elementary 
> AAC audio stream via #EXT-X-MEDIA tag.
>   - fMP4 streams with one H.264/AVC or H.265/HEVC video track and fMP4 
> streams with one AAC audio track via #EXT-X-MEDIA tag.
> - Separate audio stream will be playback via separate chain of GStreamer 
> elements inside one pipeline. Which means two "javasource" elements will be 
> used inside one pipeline and they will be reading data independently of each 
> other via two separate HLSConnectionHolders. GStreamer will handle audio and 
> video synchronization based on PTS as for other streams. Other solutions were 
> considered such as one "javasource" with multiple source pads, but such 
> implementation will be more complex and does not provide any benefits.
> - HLSConnectionHolder which handles video stream will also parse all 
> information for separate audio stream and then create child 
> HLSConnectionHolder for separate audio stream which will be responsible for 
> downloading audio segments and seek of audio streams.
> - Parser in HLSConnectionHolder was reworked to make it more readable and 
> easy to maintain and extend.
> - JavaDoc updated to point to latest HLS implementation vs old draft. It also 
> updated with information on #EXT-X-MEDIA tag. Also, added missing information 
> on AAC elementary streams and fMP4 from previous fixes.
> - Fixed and improved debug output in Linux AV plugins.
> - Added new property to "dshowwrapper" to disable PTS reset for each new 
> segment, since with #EXT-X-MEDIA tag audio and video segments are not align 
> and they can start at different time.
> - Fixed missing PTS on first buffer after seek in MP2T demuxer in 
> "dshowwrapper". Without it audio and video synchronization breaks with two 
> separate streams.
> - Removed dead code from MediaManager.
> - Added handling for GST_MESSAGE_LATENCY. Based on GStreamer doc we need to 
> call gst_bin_recalculate_latency() when such message received. Not sure if we 
> really need to do this, but with separate video and audio streams we do 
> receive this message when seek is done. Most likely due to video and audio is 
> not align perfectly when we seek. For other streams this message is not 
> received in most cases.

This will need testing on all platforms.

While testing on Linux, I ran into a compilation error on an older Ubuntu 16.04 
system (using the production gcc 13.2 compilers). This suggests that you are 
missing an include that, in some cases, matters:


../../platform/gstreamer/GstAudioPlaybackPipeline.cpp:1069:21: error: 'strstr' 
was not declared in this scope
 1069 |                 if (strstr(mimetype, "audio/unsupported") != NULL)
      |                     ^~~~~~
../../platform/gstreamer/GstAudioPlaybackPipeline.cpp:36:1: note: 'strstr' is 
defined in header '<cstring>'; did you forget to '#include <cstring>'?
   35 | #include <fxplugins_common.h>
  +++ |+#include <cstring>
   36 | 

Makefile:173: recipe for target 
'jfx/modules/javafx.media/build/native/linux/Release/obj/jfxmedia/platform/gstreamer/GstAudioPlaybackPipeline.o'
 failed
make: *** 
[jfx/modules/javafx.media/build/native/linux/Release/obj/jfxmedia/platform/gstreamer/GstAudioPlaybackPipeline.o]
 Error 1
make: *** Waiting for unfinished jobs....

../../platform/gstreamer/GstAVPlaybackPipeline.cpp:184:21: error: 'strstr' was 
not declared in this scope
  184 |                 if (strstr(mimetype, "video/x-h264") != NULL) // H.264
      |                     ^~~~~~
../../platform/gstreamer/GstAVPlaybackPipeline.cpp:37:1: note: 'strstr' is 
defined in header '<cstring>'; did you forget to '#include <cstring>'?
   36 | #include <fxplugins_common.h>
  +++ |+#include <cstring>
   37 | 
make: *** 
[jfx/modules/javafx.media/build/native/linux/Release/obj/jfxmedia/platform/gstreamer/GstAVPlaybackPipeline.o]
 Error 1
Makefile:173: recipe for target 
'jfx/modules/javafx.media/build/native/linux/Release/obj/jfxmedia/platform/gstreamer/GstAVPlaybackPipeline.o'
 failed

-------------

PR Comment: https://git.openjdk.org/jfx/pull/1435#issuecomment-2075846696

Reply via email to