From Fedora Project Wiki
(Move original page to FedoraLegacy for F21 and earlier users.)
 
(4 intermediate revisions by the same user not shown)
Line 1: Line 1:
= Digital Television in Fedora =
= Digital Television in Fedora =


This page provides information on setting up a Fedora based system to operate with Digital Video Broadcasting (DVB) tuner hardware, so that television programs can be viewed.
This page provides information on setting up a Fedora based system to operate with [http://en.wikipedia.org/wiki/Digital_Video_Broadcasting|Digital Video Broadcasting] (DVB) tuner hardware, so that television programs can be viewed.


== Introduction ==
== Introduction ==
In many parts of the world, television stations have begun transmitting digital television signals. While different digital transmission systems have been created, this document is about devices and viewers using the [[http://en.wikipedia.org/wiki/Dvb DVB]] standard.
In the majority of countries of the world, television stations now transmit digital television signals. While different digital transmission systems have been created, this document is about devices and viewers using the [[http://en.wikipedia.org/wiki/Dvb DVB]] standard.


Typically, as digital TV is introduced to a region, the TV stations continue to transmit their older analogue signals, and add the newer digital TV signals on a previously unused TV channel. By adding a DVB compliant TV tuner to a PC, a Fedora PC will be able to access these channels. There is however, some setup of hardware, drivers, and application software required so that the full range of tuning channels, recording, watching and manipulation of off-air TV channels can be enjoyed.
By adding a DVB compliant TV tuner to a PC, a Fedora PC will be able to tune these channels. There is however, some setup of hardware, drivers, and application software required so that the full range of tuning channels, recording, watching and manipulation of off-air TV channels can be enjoyed.


{{admon/note|DVD playback within RPM Fusion|Since the Fedora distribution is based in a country where MPEG patents are recognised, it is not possible to play back DVB TV channels using only Fedora software. This guide shows how to use an external software repository to provide pre-compiled software for the actual TV playback.}}
{{admon/note|DVB playback|The encoding scheme used in most digital television system is either MPEG 2 or MPEG 4. Since the Fedora distribution is based in a country where MPEG patents are recognized, it is not possible to play back DVB TV channels using only Fedora software. This guide shows how to use an external software repository (RPM Fusion) to provide pre-compiled software for the actual TV playback.}}


== Hardware Setup ==
== Hardware Setup ==
Line 22: Line 22:
A good starting point for determining if specific hardware will work with Linux is the <span class="plainlinks">[http://www.mythtv.org/wiki/Category:Hardware hardware page at Mythtv.org]</span>.
A good starting point for determining if specific hardware will work with Linux is the <span class="plainlinks">[http://www.mythtv.org/wiki/Category:Hardware hardware page at Mythtv.org]</span>.


In all cases, a good antenna signal, and cable will be required to plug into the RF antenna socket of the device; "rabbit ears" antennas might work in an area of excellent TV coverage.
In all cases, a good antenna signal, and lead-in antenna cable will be required to plug into the RF antenna socket of the device; "rabbit ears" antennas might work in an area of excellent TV signal coverage.


=== PCI ===
=== PCI ===
Line 29: Line 29:
Find out more information by using the pci identifier listed in the previous result:
Find out more information by using the pci identifier listed in the previous result:
<pre>lspci -v -s 01:09.0</pre>
<pre>lspci -v -s 01:09.0</pre>
With luck this includes a line indicating the kernel module loaded that is handling the device, eg. bttv.
With luck this includes a line indicating the kernel driver in use and the kernel module loaded that is handling the device, eg. bttv.


=== USB ===
=== USB ===
Line 35: Line 35:
<pre>su -c 'tail -f /var/log/messages'</pre>
<pre>su -c 'tail -f /var/log/messages'</pre>
Plug the tuner device into the machine. In the terminal some information about detection of the USB hotplug event and perhaps some firmware and or driver loading activity will be seen.
Plug the tuner device into the machine. In the terminal some information about detection of the USB hotplug event and perhaps some firmware and or driver loading activity will be seen.
(To be improved ;-) Instead of <code>lspci</code>, use <code>lsusb</code> to determine which usb ID is the TV tuner device, and then use <code>lsusb -v</code> to determine more information about that item.
Use <code>lsusb</code> to determine which usb ID is the TV tuner device, and then use <code>lsusb -v</code> to determine more information about that device.


=== FireWire ===
=== FireWire ===
Line 50: Line 50:


== Driver ==
== Driver ==
All devices require a series of drivers to enable their capabilities. There will be a hardware specific driver eg. ''dvb_bt8xx'', ''pvrusb2''. This driver is often a kernel module, but it might have been accepted to be a part of the kernel proper, or might be an external compilable module.  
All devices require a series of drivers to enable their capabilities. There will be a hardware specific driver e.g. ''dvb_bt8xx'', ''pvrusb2''. This driver is sometimes an external kernel module, but it might have been accepted to be a part of the kernel proper.
If the driver is already loaded, it may have been shown in the earlier ''lspci'' status example. If the driver is not loaded automatically, it will be necessary to read the manufacturer's instructions, web site and google to determine how to proceed.
 
If the driver is already loaded, it may have been shown in the earlier ''lspci'' status example. If the driver is not loaded automatically, it will be necessary to read the manufacturer's instructions, web site, or web search to determine how to proceed.


If a driver makes it into the ''kernel-firmware package'', it can then be trigger to load automatically when a device that it is known to require it is detected.
If a driver makes it into the ''kernel-firmware package'', it can then be trigger to load automatically when a device that it is known to require it is detected.


== DVB utilities ==
== DVBv5 utilities ==
All the DVB drivers make use of the kernel DVB subsystem module ''dvb_core''. There are user tools to work with the DVB subsystem. They are found in the ''dvb-apps'' package using [[dnf|DNF]]:
All the DVB drivers make use of the kernel DVB subsystem module ''dvb_core''. There are user tools to work with the [http://linuxtv.org/wiki/index.php/DVBv5_Tools|DVBv5] subsystem. They are found in the ''v4l-utils'' package using [[dnf|DNF]]:
<pre>dnf install dvb-apps</pre>
<pre>dnf install v4l-utils dtv-scan-tables</pre>


To see what tools get installed:
To see what tools are installed by the above:
<pre>rpm -q --fileprovide dvb-apps</pre>
<pre>rpm -ql v4l-utils</pre>
Use these tools to confirm correct detection and operation of the DVB subsystem using the following tools.
Use these tools to confirm correct detection and operation of the DVB subsystem using the following tools.


=== Initial tuning data file ===
=== Initial tuning data file ===
<code>/usr/share/dvbv5/dvb-t/country-location</code>: provides an initial-tuning-data-file for a specific country-location. If available for your area tuning time will be shortened.
<code>/usr/share/dvbv5/dvb-t/country-location</code>: provides an initial-tuning-data-file for a specific country-location. If available for your area the time taken to scan for channels will be much shorter (. however if one is not available for your location, ''auto-country'' or ''auto-Default'' can scan a large list of standard frequencies.


=== scandvb ===
=== dvbv5-scan ===
Scan for all channels on all transponders (carriers) present in the the initial tuning data file, and create a channels.conf eg:
Scan for all channels on all transponders (carriers) present in the the initial tuning data file, and creates dvb_channel.conf in the current folder e.g.:
<pre>scandvb /usr/share/dvbv5/dvb-t/au-Coonabarabran</pre>
<pre>dvbv5-scan /usr/share/dvbv5/dvb-t/au-Coonabarabran
If this creates output, then make a channels.conf with:
ls -l dvb_channel.conf</pre>
<pre>scandvb /usr/share/dvbv5/dvb-t/au-Coonabarabran >channels.conf</pre>
Note: An existing dvb_channel.conf would be overwritten by this command.
to create the channels definition file.
 
Review the detected channels using a text editor:
<pre>gedit dvb_channel.conf</pre>


=== w_scan ===
=== w_scan ===
If there is no initial file for your area, you can use '''w_scan''' to scan for providers.
If there is no initial tuning file for your area, you can use '''w_scan''' to [http://www.linuxtv.org/wiki/index.php/W_scan#Generating_c.2Fs.2Ftzap_tuning_data|scan for providers]. For the '''-c''' option use your country code:
<pre>dnf|yum install w_scan
<pre>dnf install w_scan
w_scan -X -c au
w_scan -X -c au
... wait 10 minutes.
... wait 10 minutes.
Line 87: Line 90:
A status line is shown indicating information such as signal strength, bit error rate and so on. It is updated once each second.
A status line is shown indicating information such as signal strength, bit error rate and so on. It is updated once each second.


=== femon ===
 
Shows the current tuning and decoding statistics of the tuner each second.
=== dvb-fe-tool ===
<pre>femon</pre>
Show the capabilities of the DVB tuner hardware:
<pre>dvb-fe-tool</pre>
Press '''[control-c]''' to finish monitoring.
 
Monitor the DVB tuner hardware providing signal, carrier to noise, and post-correction bit error rate (more interesting if a channel has been ''zapped''):
<pre>dvb-fe-tool --femon</pre>
Press '''[control-c]''' to finish monitoring.
Press '''[control-c]''' to finish monitoring.


=== lowlevel recording of a digital TV station ===
=== lowlevel recording of a digital TV station ===

Latest revision as of 20:43, 29 November 2015

Digital Television in Fedora

This page provides information on setting up a Fedora based system to operate with Video Broadcasting (DVB) tuner hardware, so that television programs can be viewed.

Introduction

In the majority of countries of the world, television stations now transmit digital television signals. While different digital transmission systems have been created, this document is about devices and viewers using the [DVB] standard.

By adding a DVB compliant TV tuner to a PC, a Fedora PC will be able to tune these channels. There is however, some setup of hardware, drivers, and application software required so that the full range of tuning channels, recording, watching and manipulation of off-air TV channels can be enjoyed.

Note.png
DVB playback
The encoding scheme used in most digital television system is either MPEG 2 or MPEG 4. Since the Fedora distribution is based in a country where MPEG patents are recognized, it is not possible to play back DVB TV channels using only Fedora software. This guide shows how to use an external software repository (RPM Fusion) to provide pre-compiled software for the actual TV playback.

Hardware Setup

There are at least three major types of DVB tuner: [PCI], [USB] and [FireWire]. Your choice about which type to use should depend on things like do I:

  • have a PCI slot available ? (-> PCI)
  • have a USB port available ? (-> USB)
  • have a FireWire port available ? (-> Firewire)
  • mind opening my PC up ? (-> PCI)
  • want to be able to use the tuner on different PCs ? (-> USB, maybe Firewire)
  • want it to be portable ? (-> USB)
  • want it to be a clean installation ? (-> PCI)
  • some notebook PCs might come with a miniPCI or USB tuner built-in.

A good starting point for determining if specific hardware will work with Linux is the hardware page at Mythtv.org.

In all cases, a good antenna signal, and lead-in antenna cable will be required to plug into the RF antenna socket of the device; "rabbit ears" antennas might work in an area of excellent TV signal coverage.

PCI

Use the manufacturer's instructions to install the card into the system. When Fedora is booted, attempt to locate the device using

lspci |grep Multimedia

Find out more information by using the pci identifier listed in the previous result:

lspci -v -s 01:09.0

With luck this includes a line indicating the kernel driver in use and the kernel module loaded that is handling the device, eg. bttv.

USB

Start a terminal session and

su -c 'tail -f /var/log/messages'

Plug the tuner device into the machine. In the terminal some information about detection of the USB hotplug event and perhaps some firmware and or driver loading activity will be seen. Use lsusb to determine which usb ID is the TV tuner device, and then use lsusb -v to determine more information about that device.

FireWire

(To be improved ;-) Need information on how this stuff works with FireWire.

Firmware

Some devices require the machine that they are plugged into to download the firmware into the device before the device can begin to work. Firmware for some devices might:

  • be included inside the device; the device just works
  • already be packaged as part of the kernel-firmware package (this is true for some of the Hauppauge cards)
  • be available as an internal something-firmware package within the Fedora software repository
  • be available outside Fedora, but already packaged as an RPM
  • be available as some other archive (perhaps the windows driver disk), that needs to be manually extracted and placed in the appropriate place

Various pieces of technology can assist with loading the device firmware. However, this relies on users reporting the steps needed to be taken to enable specific hardware. This includes getting information on lsusb/lspci device tables, HAL event triggers, and PackageKit software installation triggers.

Driver

All devices require a series of drivers to enable their capabilities. There will be a hardware specific driver e.g. dvb_bt8xx, pvrusb2. This driver is sometimes an external kernel module, but it might have been accepted to be a part of the kernel proper.

If the driver is already loaded, it may have been shown in the earlier lspci status example. If the driver is not loaded automatically, it will be necessary to read the manufacturer's instructions, web site, or web search to determine how to proceed.

If a driver makes it into the kernel-firmware package, it can then be trigger to load automatically when a device that it is known to require it is detected.

DVBv5 utilities

All the DVB drivers make use of the kernel DVB subsystem module dvb_core. There are user tools to work with the [1] subsystem. They are found in the v4l-utils package using DNF:

dnf install v4l-utils dtv-scan-tables

To see what tools are installed by the above:

rpm -ql v4l-utils

Use these tools to confirm correct detection and operation of the DVB subsystem using the following tools.

Initial tuning data file

/usr/share/dvbv5/dvb-t/country-location: provides an initial-tuning-data-file for a specific country-location. If available for your area the time taken to scan for channels will be much shorter (. however if one is not available for your location, auto-country or auto-Default can scan a large list of standard frequencies.

dvbv5-scan

Scan for all channels on all transponders (carriers) present in the the initial tuning data file, and creates dvb_channel.conf in the current folder e.g.:

dvbv5-scan /usr/share/dvbv5/dvb-t/au-Coonabarabran
ls -l dvb_channel.conf

Note: An existing dvb_channel.conf would be overwritten by this command.

Review the detected channels using a text editor:

gedit dvb_channel.conf

w_scan

If there is no initial tuning file for your area, you can use w_scan to for providers. For the -c option use your country code:

dnf install w_scan
w_scan -X -c au
... wait 10 minutes.

If this is successful, please send the created file upstream to the dvb-apps authors.

Xzap

Uses the channels.conf to tune the frontend to a specific transponder (carrier) and demultiplex the particular channel. The preceding X represents either ATSC, Cable, Satellite, or Terrestrial.

tzap -c ~/.xine/channels.conf -r "channelname"

A status line is shown indicating information such as signal strength, bit error rate and so on. It is updated once each second.


dvb-fe-tool

Show the capabilities of the DVB tuner hardware:

dvb-fe-tool

Press [control-c] to finish monitoring.

Monitor the DVB tuner hardware providing signal, carrier to noise, and post-correction bit error rate (more interesting if a channel has been zapped):

dvb-fe-tool --femon

Press [control-c] to finish monitoring.


lowlevel recording of a digital TV station

Once a Xzap has tuned a station, another terminal window can be used to record DVB channel (aka MPEG2 Program Stream), to a file:

cat /dev/dvb/adapterX/dvr0 >/mediastoragepath/programname.datetime.mpg

Once that has run for a minute or so, press [control-c] to terminate the concatenation. The stream can then be viewed using any mpeg2 video decoding software.

DVB Application Software

Live TV playback

There are various mpeg2 playback software available for Fedora, none of which are available in Fedora's own repos. Use an external rpm repository like RPM Fusion, by first enabling the repository. Since you will probably like to examine a few different applications to determine which is the most suitable for your needs:

yum install mplayer-gui xine gstreamer-plugins-ugly w_scan dvbcut

... please provide some simple usage information if you know how ;-)

The "ABC TV" name must exactly match the channel name in your channels.conf file.

mplayer dvb://"ABC TV"
xine dvb://ABC TV

Recording and scheduled recordings

yum install vdr-femon klear

... please provide some simple usage information / page if you know how ;-)

Full TV / media recording and playback suite

yum install mythtv-suite

... please provide some simple usage information / page if you know how ;-)

An alternate method could be using the Fedora-based MythTV distribution known as Mythdora. In either case, MythTV brings together a number of features/functions into what is generally known as a home theater server. MythTV features can include (assuming proper hardware, subscriptions, and/or plugins):

  • Viewing of live television
  • Automated recordings of shows based on search terms (show, title, date/time, actor or character name, etc.)
  • Playback on your computer, a remote computer, or to a television
  • Playback of locally (or remotely) stored media (audio and/or video)
  • Playback of Internet streams (audio and/or video)
  • Streaming of media (audio and/or video) to other devices or services
  • Clustering of MythTV services on multiple devices
  • Announcement of incoming calls
  • The local weather conditions/forecast
  • A web interface for scheduling and playback of recordings
  • A slide show of stored pictures
  • A SqueezeCenter interface
  • A SIP interface (think Asterisk!)
  • Themes and skins for the front end, backend, and some remote players
  • and much more

Updates

We hope this has been useful in getting your DVB hardware working with Fedora. In any case feel free to update text on this page or link to other references if you feel they would have helped you get your tuner going more easily ;-)

Note: after review, this will possibly have links to [external software repositories] [removed].

Sources/Further Reading