-
Notifications
You must be signed in to change notification settings - Fork 346
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
IPTV/HLS/M3U: Failing to parse EXT-X-VERSION 7 #936
Comments
Can you please provide a complete version 7 m3u file? |
HLS version 7 is described here https://datatracker.ietf.org/doc/html/rfc8216 and it looks to be non-trivial undertaking... |
Hi Klaas Please find attached mythtv_936_m3u.zip
Zattoo is offered only in Germany, Switzerland and Austria. Each having their own account and GEO-blocking.
https://www.kodinerds.net/thread/72127-telerising-api-zattoo-blue-tv-sky-ch-f%C3%BCr-tvheadend-und-vlc-web-app/ Currently I am stuck on master of ~August, due to #955, but will be available to test. Cheers, Angela |
Testing with a local IPTV stream for channel EWTN Europe did show up one bug. The tag EXT-X-DISCONTINUITY-SEQUENCE is parsed and executed as EXT-X-DISCONTINUITY which is another tag, and this leads to a total reset every time the tag is encountered. This then causes downloading at maximum bandwidth and in my case this then downloads 60Mbyte per second. Playback however is OK. I vaguely recall that this problem has been reported by somebody long ago. Adding parsing of EXT-X-DISCONTINUITY-SEQUENCE does fix this even when not yet doing anything with the value. To be continued. |
Add parsing of tag EXT-X-DISCONTINUITY-SEQUENCE. Previously, this tag was erroneously parsed and executed as EXT-X-DISCONTINUITY. This then caused continuous downloading at maximum bandwidth. Add parsing of tags EXT-X-INDEPENDENT-SEGMENTS. There is no implementation added but this does prevent parsing failure. Allow EXT-X-VERSION tag values from 1 to 7. There is no implementation added but this does prevent parsing failure. Refs #936
@angelaschmid I have committed a fix to master. With this fix many channels that previously could not be received are now playing good. I have not yet tested with your channels as I could produce already many problems with the readily available IPTV channels. It is possible that your issue is now resolved. Testing is appreciated. |
Fix integer overflow in reading IPTV/HLS segments by computing the segment size times the number of segments now in a 64 bit integer. This fixes playback of the Spanish channel RTVE.es on https://rtvelivestream.akamaized.net/rtvesec/24h/24h_main_dvr_720.m3u8 Refs #936
The above fix does errors in playing the RTVE channel https://rtvelivestream.akamaized.net/rtvesec/24h/24h_main_dvr_720.m3u8. However, the remaining issue is that IPTV/HLS does read all the segments in the segment list. This means it does a readahead of the next two hours. This gives really big recording files even if you do only a few minutes of Live TV watching on that channel. I think that this is not the behavior that we want, especially not with Live TV but maybe also not when making recordings. One possible approach is to limit the read-ahead time to about 1 minute or so (12 segments of 5 seconds each) but how to do that exactly needs to be investigated. |
A snapshot of https://rtvelivestream.akamaized.net/rtvesec/24h/24h_main_dvr_720.m3u8 vlc shows the total time as 2 hours, forwards to the end (starting with the last chunk), and allows the user to skip back. HLSPlaylist HLSReader.cpp:457 (ParseM3U8), is executed every second, it should keep track what already was read. LiveTV would mean, only reading the last, but that might be fragile, so reading some chunks back would make sense. Somebody who want to have near realtime LiveTV, can skip forward. I think the same is expected with recordings, as it should start near time, forgetting too many available previous chunks. Besides your fix, as the channel list contain URLs without an extension, I had to change:
I have seen URLs like 'http://.....m3u8/?....." (from https://github.com/iptv-org/iptv?tab=readme-ov-file#playlists). Within |
About the IsHLSPlaylist function, I do agree with your analysis. The presence of the substring "m3u" either at the end or halfway the URL should not be used to decide on the content of the file. |
Reducing the number of bytes read from 10000 to 1000 does cause failure on playing that RTVE channel so this will remain at 10000 for now. Size of the RTVE file is 7.7 kbyte so to get the last chunk we need to read the whole file. |
Remove the check on the presence of m3u or m3u8 at the end of the url to determine if a file is a HLS file or not. This check prevents some IPTV channels to be played with MythTV. There is already a check on the content of the file pointed to by the url so the check on the url can safely be removed. Refs #936
Start recording, and playback in case of Live TV, from a segment that is near live and discard all segments older than that. Previously, recording started from the oldest segment. Refs #936
Compute the playlist reload interval as a fraction or a multiple of the EXT-X-TARGETDURATION time. Usually this is 0.5 times the target duration time, depending on download timing. The logic for this has not changed, but due to a bug in the code the result of the computation was always 0 seconds, resulting in a reload interval time of 1 second independent of the target duration. This bug is now fixed in this commit. Refs #936
When the IPTV channel scan does not contain a channel number for a channel then a default channel number is used. This is the first unused channel number in the database for that video source. The code for this looks at all channels, but the channels that have been deleted should be excluded. This is now fixed. Refs #936 Refs #973
When a channel found in an IPTV channel scan does not have a channel number but only a name then it does now look in the database for the channel number. The lookup is done on channel name only. The lookup is done in the channels of the video source attached to the capture card used in the channel scan. When there is no channel number found in the IPTV channel scan and also not in the database then a default channel number is used. This is the first unused channel number in the database for that video source. Refs #936 Refs #973
When a channel found in an IPTV channel scan does not have a channel number but only a name then it does now look in the database for the channel number. The lookup is done on channel name only. The lookup is done in the channels of the video source attached to the capture card used in the channel scan. When there is no channel number found in the IPTV channel scan and also not in the database then a default channel number is used. This is the first unused channel number in the database for that video source. Refs #936 Refs #973
Add a simple EXTINF format in the IPTV channel fetcher that can parse the format "EXTINF:0,Channel_Title". Refs MythTV#936
The CardUtil function DeleteAllInputs does delete the content of all four tables related to inputs but it does also delete the content of table iptv_channel. This is not correct; table iptv_channel contains the URLs of the channels that are IPTV channels. This bug has been introduced as part of commit d4c0f13. The entries in table iptv_channel can only be removed when the corresponding channel has been deleted. This is done as part of a periodic housekeeping task. Refs MythTV#936
Add a simple EXTINF format in the IPTV channel fetcher that can parse the format "EXTINF:0,Channel_Title". Refs #936
The CardUtil function DeleteAllInputs does delete the content of all four tables related to inputs but it does also delete the content of table iptv_channel. This is not correct; table iptv_channel contains the URLs of the channels that are IPTV channels. This bug has been introduced as part of commit d4c0f13. The entries in table iptv_channel can only be removed when the corresponding channel has been deleted. This is done as part of a periodic housekeeping task. Refs #936
Slightly longer distance to live to accommodate varying IPTV throughput. Improved log messages and improved comment in the code. Refs MythTV#936
Slightly longer distance to live to accommodate varying IPTV throughput. Improved log messages and improved comment in the code. Refs #936
Status update: EXT-X-VERSION:7 files can be decoded now. Most of the channels present in https://iptv-org.github.io/iptv/countries/nl.m3u can be played; the ones that cannot do not exist anymore, are geo-blocked or are encrypted. All the fixes to get this far have been fairly trivial. The biggest remaining issue is that some channels do have video playback but no sound. This is because the EXT-X-MEDIA tag is not yet implemented. @angelaschmid I expect that the streams that you mention in this issue can al be played by MythTV but al the streams that use the EXT-X-MEDIA tag to specify the audio URL will play without sound. Can you please check? To be continued. |
Hi @kmdewaal I tested with latest master (includes your latest channel scanning updates) and found the following issues:
|
Hi @angelaschmid thanks for testing. I will have a look at all issues raised, starting with the channel scan. About channel callsign and name. About the xmltvid |
Exactly, the callsign is the "technical" name and can be "cryptic". But the callsign is used in the guides for the channel name, which I think is wrong. Better would be IMO to use the channel.name in the guide. For USA and DVB these can be (initially) the same. xmltvid; IPTV does not come with guide data, so has to be sourced in from a third-party. These have different xmltvid's, which needs to be configured in xmltvid by the user. Saving tvg-id into it, would overwrite the settings with a channel re-scan.
Just noticed a funny side-effect, I removed all IPTV channels, but loaded guide data in a non-existing source (/usr/bin/mythfilldatabase --sourceid 5 --file --xmlfile $XMLFILE), which generated the channels.
|
Retrieve channel number from tvg-chno or channel-number tags. Retrieve channel name from tvg-name; if not present then search for the channel name at the end of the line. Retrieve channel logo url from tvg-logo but this is not yet processed. Process channel names as UTF-8 supporting diacritical marks. Refs #936
Add the IPTV channels in ascending numerical channel number order. In the QMap the order is based on channel number as string which is not the same unless all channel numbers have the same number of digits. Refs #936
Fixed.
Fixed. |
In the IPTV channel scan, download the channel icon (logo) when there is an URL given for this in the EXTINF line. Refs #936
User friendly channel namesThe program guide channel list in the Arclight theme previously used a template displaying the callsign for channel names. This has been updated to utilize the The following areas still use the callsign (hardcoded):
Your latest changesI will have a look into your latest changes by end of next week. |
The EXT-X-DISCONTINUITY tag indicates that there can be a change in file format, number and identifiers of tracks and a bit more as described in https://datatracker.ietf.org/doc/html/rfc8216#section-4.3.2.3 When the seqeunce number is reset then all segments described in the playlist are played again, causing repeated reload and redisplay of segments that have already been displayed. This is not something that should be done when a EXT-X-DISCONTINUITY tag is seen. Example stream is https://food-us.xumo.wurl.tv/playlist.m3u8 where the sections between the items are marked with the EXT-X-DISCONTINUITY tag. The new behavior is similar to that of VLC on the example stream. Refs #936
Running latest master.
Streams from Zattoo, Teleboy, famous IPTV providers in Germany/Switzerland, are failing to play in MythTV. They play fine in VLC.
MythTV does not have version 7 M3U implemented.
The stream contains the following M3U data:
#EXTM3U
#EXT-X-VERSION:7
#EXT-X-INDEPENDENT-SEGMENTS
#EXT-X-MEDIA:TYPE=AUDIO,GROUP-ID="audio",NAME="deutsch",DEFAULT=YES,AUTOSELECT=YES,LANGUAGE="deu",URI="https://zba6-0-hls7-live.zahs.tv/telebielingue/t_track_audio_bw_128000000_num_0_tid_2_p_10_l_de_nd_1600_mbr_2999.m3u8?z32=MF2......"
#EXT-X-STREAM-INF:BANDWIDTH=2999000,CODECS="avc1.4d4020,mp4a.40.2",RESOLUTION=1024x576,FRAME-RATE=50,AUDIO="audio",CLOSED-CAPTIONS=NONE
https://zba6-0-hls7-live.zahs.tv/telebielingue/t_track_video_bw_2799000_num_0_tid_1_nd_1600_mbr_2999.m3u8?z32=MF2......
MythTV version:
Latest master
Component:
mythbackend
What do you see instead?
Logfile mythbackend:
StreamHandler m3u.cpp:106 (ParseVersion) - #EXT-X-VERSION is 7, but we only understand 0 through 3
Changing the source to also allow version 7, gives the following failures, and the stream does not play:
2024-08-05 10:41:19.523190 I [344463/352425] StreamHandler m3u.cpp:120 (ParseStreamInformation) - Parsing stream from https://zba6-1-hls7-live.zahs.tv/HD_s1/t_track_video_bw_7800000_num_0_tid_1_nd_1600_mbr_8000.m3u8?z32=MF2WI2L
2024-08-05 10:41:19.523196 I [344463/352425] StreamHandler m3u.cpp:132 (ParseStreamInformation) - #EXT-X-STREAM-INF: expected PROGRAM-ID=, using -1
2024-08-05 10:41:19.523200 I [344463/352425] StreamHandler m3u.cpp:157 (ParseStreamInformation) - bandwidth adaptation detected (program-id=-1, bandwidth=8000000
2024-08-05 10:41:20.590946 D [344463/352428] HLSPlaylist m3u.cpp:367 (ParseProgramDateTime) - https://zba6-1-hls7-live.zahs.tv/HD_s1/t_track_video_bw_7800000_num_0_tid_1_nd_1600_mbr_8000.m3u8?z32=MF2WI2L tag not supported: #EXT-X-PROGRAM-DATE-TIME #EXT-X-PROGRAM-DATE-TIME:2024-08-05T08:39:56.800+00:00
2024-08-05 10:41:21.603634 D [344463/352428] HLSPlaylist m3u.cpp:367 (ParseProgramDateTime) - https://zba6-1-hls7-live.zahs.tv/HD_s1/t_track_video_bw_7800000_num_0_tid_1_nd_1600_mbr_8000.m3u8?z32=MF2WI2L tag not supported: #EXT-X-PROGRAM-DATE-TIME #EXT-X-PROGRAM-DATE-TIME:2024-08-05T08:39:56.800+00:00
2024-08-05 10:41:22.615515 D [344463/352428] HLSPlaylist m3u.cpp:367 (ParseProgramDateTime) - https://zba6-1-hls7-live.zahs.tv/HD_s1/t_track_video_bw_7800000_num_0_tid_1_nd_1600_mbr_8000.m3u8?z32=MF2WI2L tag not supported: #EXT-X-PROGRAM-DATE-TIME #EXT-X-PROGRAM-DATE-TIME:2024-08-05T08:39:58.400+00:00
2024-08-05 10:44:24.025961 I [344463/358923] StreamHandler m3u.cpp:120 (ParseStreamInformation) - Parsing stream from https://zh4-11-hls7-live.zahs.tv/HD_s1/t_track_video_bw_7800000_num_0_tid_1_nd_1600_mbr_8000.m3u8?z32=MF2W
2024-08-05 10:44:24.025965 I [344463/358923] StreamHandler m3u.cpp:132 (ParseStreamInformation) - #EXT-X-STREAM-INF: expected PROGRAM-ID=, using -1
2024-08-05 10:44:24.025969 I [344463/358923] StreamHandler m3u.cpp:157 (ParseStreamInformation) - bandwidth adaptation detected (program-id=-1, bandwidth=8000000
2024-08-05 10:44:25.103642 D [344463/358926] HLSPlaylist m3u.cpp:367 (ParseProgramDateTime) - https://zh4-11-hls7-live.zahs.tv/HD_s1/t_track_video_bw_7800000_num_0_tid_1_nd_1600_mbr_8000.m3u8?z32=MF2Wtag not supported: #EXT-X-PROGRAM-DATE-TIME #EXT-X-PROGRAM-DATE-TIME:2024-08-05T08:43:00.800+00:00
2024-08-05 10:44:26.117132 D [344463/358926] HLSPlaylist m3u.cpp:367 (ParseProgramDateTime) - https://zh4-11-hls7-live.zahs.tv/HD_s1/t_track_video_bw_7800000_num_0_tid_1_nd_1600_mbr_8000.m3u8?z32=MF2Wtag not supported: #EXT-X-PROGRAM-DATE-TIME #EXT-X-PROGRAM-DATE-TIME:2024-08-05T08:43:02.400+00:00
The text was updated successfully, but these errors were encountered: