123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268 |
- /*
- * Copyright (c) 2011-2014 - Mauro Carvalho Chehab
- *
- * This program is free software; you can redistribute it and/or
- * modify it under the terms of the GNU General Public License
- * as published by the Free Software Foundation version 2
- * of the License.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
- * Or, point your browser to http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
- *
- * Per-delivery system properties defined at libdvbv5 scope, following
- * the same model as defined at the Linux DVB media specs:
- * http://linuxtv.org/downloads/v4l-dvb-apis/FE_GET_SET_PROPERTY.html
- */
- #ifndef _DVB_V5_STD_H
- #define _DVB_V5_STD_H
- #include <stddef.h>
- #include "dvb-frontend.h"
- /**
- * @file dvb-v5-std.h
- * @ingroup frontend
- * @brief Provides libdvbv5 defined properties for the frontend.
- * @copyright GNU General Public License version 2 (GPLv2)
- * @author Mauro Carvalho Chehab
- *
- * @par Bug Report
- * Please submit bug reports and patches to linux-media@vger.kernel.org
- */
- /*
- * User DTV codes, for internal usage. There are two sets of
- * properties. One for DTV properties and another one for statistics
- */
- /*
- * First set: DTV properties that don't belong to Kernelspace
- *
- * Those properties contain data that comes from the MPEG-TS
- * tables, like audio/video/other PIDs, and satellite config
- */
- /**
- * @def DTV_USER_COMMAND_START
- * @brief Start number for libdvbv5 user commands
- * @ingroup frontend
- * @def DTV_POLARIZATION
- * @brief Satellite polarization (for Satellite delivery systems)
- * @ingroup frontend
- * @def DTV_AUDIO_PID
- * @brief Audio PID
- * @ingroup frontend
- * @def DTV_VIDEO_PID
- * @brief Video PID
- * @ingroup frontend
- * @def DTV_SERVICE_ID
- * @brief MPEG TS service ID
- * @ingroup frontend
- * @def DTV_CH_NAME
- * @brief Digital TV service name
- * @ingroup frontend
- * @def DTV_VCHANNEL
- * @brief Digital TV channel number. May contain symbols
- * @ingroup frontend
- * @def DTV_SAT_NUMBER
- * @brief Number of the satellite (used on multi-dish Satellite systems)
- * @ingroup frontend
- * @def DTV_DISEQC_WAIT
- * @brief Extra time needed to wait for DiSeqC to complete, in ms.
- * The minimal wait time is 15 ms. The time here will be
- * added to the minimal time.
- * @ingroup frontend
- * @def DTV_DISEQC_LNB
- * @brief LNBf name
- * @ingroup frontend
- * @def DTV_FREQ_BPF
- * @brief SCR/Unicable band-pass filter frequency in kHz
- * @ingroup frontend
- * @def DTV_PLS_CODE
- * @brief DVB-T2 PLS code. Not used internally. It is needed
- * only for file conversion.
- * @ingroup frontend
- * @def DTV_PLS_MODE
- * @brief DVB-T2 PLS mode. Not used internally. It is needed
- * only for file conversion.
- * @ingroup frontend
- * @def DTV_COUNTRY_CODE
- * @brief Country variant of international delivery system standard.
- in ISO 3166-1 two letter code.
- * @ingroup frontend
- * @def DTV_MAX_USER_COMMAND
- * @brief Last user command
- * @ingroup frontend
- * @def DTV_USER_NAME_SIZE
- * @brief Number of user commands
- * @ingroup frontend
- */
- #define DTV_USER_COMMAND_START 256
- #define DTV_POLARIZATION (DTV_USER_COMMAND_START + 0)
- #define DTV_VIDEO_PID (DTV_USER_COMMAND_START + 1)
- #define DTV_AUDIO_PID (DTV_USER_COMMAND_START + 2)
- #define DTV_SERVICE_ID (DTV_USER_COMMAND_START + 3)
- #define DTV_CH_NAME (DTV_USER_COMMAND_START + 4)
- #define DTV_VCHANNEL (DTV_USER_COMMAND_START + 5)
- #define DTV_SAT_NUMBER (DTV_USER_COMMAND_START + 6)
- #define DTV_DISEQC_WAIT (DTV_USER_COMMAND_START + 7)
- #define DTV_DISEQC_LNB (DTV_USER_COMMAND_START + 8)
- #define DTV_FREQ_BPF (DTV_USER_COMMAND_START + 9)
- #define DTV_PLS_CODE (DTV_USER_COMMAND_START + 10)
- #define DTV_PLS_MODE (DTV_USER_COMMAND_START + 11)
- #define DTV_COUNTRY_CODE (DTV_USER_COMMAND_START + 12)
- #define DTV_MAX_USER_COMMAND DTV_COUNTRY_CODE
- #define DTV_USER_NAME_SIZE (1 + DTV_MAX_USER_COMMAND - DTV_USER_COMMAND_START)
- /**
- * @enum dvb_sat_polarization
- * @brief Polarization types for Satellite systems
- * @ingroup satellite
- *
- * @param POLARIZATION_OFF Polarization disabled/unused.
- * @param POLARIZATION_H Horizontal polarization
- * @param POLARIZATION_V Vertical polarization
- * @param POLARIZATION_L Left circular polarization (C-band)
- * @param POLARIZATION_R Right circular polarization (C-band)
- */
- enum dvb_sat_polarization {
- POLARIZATION_OFF = 0,
- POLARIZATION_H = 1,
- POLARIZATION_V = 2,
- POLARIZATION_L = 3,
- POLARIZATION_R = 4,
- };
- /*
- * Second set: DTV statistics
- *
- * Those properties contain statistics measurements that aren't
- * either provided by the Kernel via property cmd/value pair,
- * like status (with has its own ioctl), or that are derivated
- * measures from two or more Kernel reported stats.
- */
- /**
- * @def DTV_STAT_COMMAND_START
- * @brief Start number for libdvbv5 statistics commands
- * @ingroup frontend
- * @def DTV_STATUS
- * @brief Lock status of a DTV frontend. This actually comes from
- * the Kernel, but it uses a separate ioctl.
- * @ingroup frontend
- * @def DTV_BER
- * @brief Bit Error Rate. This is a parameter that it is
- * derivated from two counters at the Kernel side
- * @ingroup frontend
- * @def DTV_PER
- * @brief Packet Error Rate. This is a parameter that it is
- * derivated from two counters at the Kernel side
- * @ingroup frontend
- * @def DTV_QUALITY
- * @brief A quality indicator that represents if a locked
- * channel provides a good, OK or poor signal. This is
- * estimated considering the error rates, signal strengh
- * and/or S/N ratio of the carrier.
- * @ingroup frontend
- * @def DTV_PRE_BER
- * @brief Bit Error Rate before Viterbi. This is the error rate
- * before applying the Forward Error Correction. This is
- * a parameter that it is derivated from two counters
- * at the Kernel side.
- * @ingroup frontend
- * @def DTV_MAX_STAT_COMMAND
- * @brief Last statistics command
- * @ingroup frontend
- * @def DTV_STAT_NAME_SIZE
- * @brief Number of statistics commands
- * @ingroup frontend
- * @def DTV_NUM_KERNEL_STATS
- * @brief Number of statistics commands provided by the Kernel
- * @ingroup frontend
- * @def DTV_NUM_STATS_PROPS
- * @brief Total number of statistics commands
- * @ingroup frontend
- */
- #define DTV_STAT_COMMAND_START 512
- #define DTV_STATUS (DTV_STAT_COMMAND_START + 0)
- #define DTV_BER (DTV_STAT_COMMAND_START + 1)
- #define DTV_PER (DTV_STAT_COMMAND_START + 2)
- #define DTV_QUALITY (DTV_STAT_COMMAND_START + 3)
- #define DTV_PRE_BER (DTV_STAT_COMMAND_START + 4)
- #define DTV_MAX_STAT_COMMAND DTV_PRE_BER
- #define DTV_STAT_NAME_SIZE (1 + DTV_MAX_STAT_COMMAND - DTV_STAT_COMMAND_START)
- /* There are currently 8 stats provided on Kernelspace */
- #define DTV_NUM_KERNEL_STATS 8
- #define DTV_NUM_STATS_PROPS (DTV_NUM_KERNEL_STATS + DTV_STAT_NAME_SIZE)
- /**
- * @enum dvb_quality
- * @brief Provides an estimation about the user's experience
- * while watching to a given MPEG stream
- * @ingroup frontend
- *
- * @param DVB_QUAL_UNKNOWN Quality could not be estimated, as the Kernel driver
- * doesn't provide enough statistics
- *
- * @param DVB_QUAL_POOR The signal reception is poor. Signal loss or packets
- * can be lost too frequently.
- * @param DVB_QUAL_OK The signal reception is ok. Eventual artifacts could
- * be expected, but it should work.
- * @param DVB_QUAL_GOOD The signal is good, and not many errors are happening.
- * The user should have a good experience watching the
- * stream.
- */
- enum dvb_quality {
- DVB_QUAL_UNKNOWN = 0,
- DVB_QUAL_POOR,
- DVB_QUAL_OK,
- DVB_QUAL_GOOD,
- };
- #ifndef _DOXYGEN
- /*
- * Some tables to translate from value to string
- *
- * These tables are raw ways to translate from some DTV values into strings.
- * Please use the API-provided function dvb_cmd_name() and dvb_dvb_attr_names(),
- * instead of using the tables directly.
- */
- extern const unsigned int sys_dvbt_props[];
- extern const unsigned int sys_dvbt2_props[];
- extern const unsigned int sys_isdbt_props[];
- extern const unsigned int sys_atsc_props[];
- extern const unsigned int sys_atscmh_props[];
- extern const unsigned int sys_dvbc_annex_ac_props[];
- extern const unsigned int sys_dvbc_annex_b_props[];
- extern const unsigned int sys_dvbs_props[];
- extern const unsigned int sys_dvbs2_props[];
- extern const unsigned int sys_turbo_props[];
- extern const unsigned int sys_isdbs_props[];
- extern const unsigned int *dvb_v5_delivery_system[];
- extern const char *dvb_sat_pol_name[6];
- extern const char *dvb_user_name[DTV_USER_NAME_SIZE + 1];
- extern const char *dvb_stat_name[DTV_STAT_NAME_SIZE + 1];
- extern const void *dvb_user_attr_names[];
- #endif /* DOXYGEN_SHOULD_SKIP_THIS */
- #endif
|