Dr Andrew Scott G7VAV

My photo
 
June 2025
Mo Tu We Th Fr Sa Su
26 27 28 29 30 31 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 1 2 3 4 5 6


frontend.h
001: /*
002:  * frontend.h
003:  *
004:  * Copyright (C) 2000 Marcus Metzler <marcus@convergence.de>
005:  *                  Ralph  Metzler <ralph@convergence.de>
006:  *                  Holger Waechtler <holger@convergence.de>
007:  *                  Andre Draszik <ad@convergence.de>
008:  *                  for convergence integrated media GmbH
009:  *
010:  * This program is free software; you can redistribute it and/or
011:  * modify it under the terms of the GNU Lesser General Public License
012:  * as published by the Free Software Foundation; either version 2.1
013:  * of the License, or (at your option) any later version.
014:  *
015:  * This program is distributed in the hope that it will be useful,
016:  * but WITHOUT ANY WARRANTY; without even the implied warranty of
017:  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
018:  * GNU General Public License for more details.
019:  *
020:  * You should have received a copy of the GNU Lesser General Public License
021:  * along with this program; if not, write to the Free Software
022:  * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
023:  *
024:  */
025: 
026: #ifndef _DVBFRONTEND_H_
027: #define _DVBFRONTEND_H_
028: 
029: #include <linux/types.h>
030: 
031: typedef enum fe_type {
032:         FE_QPSK,
033:         FE_QAM,
034:         FE_OFDM,
035:         FE_ATSC
036: } fe_type_t;
037: 
038: 
039: typedef enum fe_caps {
040:         FE_IS_STUPID                    = 0,
041:         FE_CAN_INVERSION_AUTO           = 0x1,
042:         FE_CAN_FEC_1_2                  = 0x2,
043:         FE_CAN_FEC_2_3                  = 0x4,
044:         FE_CAN_FEC_3_4                  = 0x8,
045:         FE_CAN_FEC_4_5                  = 0x10,
046:         FE_CAN_FEC_5_6                  = 0x20,
047:         FE_CAN_FEC_6_7                  = 0x40,
048:         FE_CAN_FEC_7_8                  = 0x80,
049:         FE_CAN_FEC_8_9                  = 0x100,
050:         FE_CAN_FEC_AUTO                 = 0x200,
051:         FE_CAN_QPSK                     = 0x400,
052:         FE_CAN_QAM_16                   = 0x800,
053:         FE_CAN_QAM_32                   = 0x1000,
054:         FE_CAN_QAM_64                   = 0x2000,
055:         FE_CAN_QAM_128                  = 0x4000,
056:         FE_CAN_QAM_256                  = 0x8000,
057:         FE_CAN_QAM_AUTO                 = 0x10000,
058:         FE_CAN_TRANSMISSION_MODE_AUTO   = 0x20000,
059:         FE_CAN_BANDWIDTH_AUTO           = 0x40000,
060:         FE_CAN_GUARD_INTERVAL_AUTO      = 0x80000,
061:         FE_CAN_HIERARCHY_AUTO           = 0x100000,
062:         FE_CAN_8VSB                     = 0x200000,
063:         FE_CAN_16VSB                    = 0x400000,
064:         FE_HAS_EXTENDED_CAPS            = 0x800000,   /* We need more bitspace for newer APIs, indicate this. */
065:         FE_CAN_TURBO_FEC                = 0x8000000,  /* frontend supports "turbo fec modulation" */
066:         FE_CAN_2G_MODULATION            = 0x10000000, /* frontend supports "2nd generation modulation" (DVB-S2) */
067:         FE_NEEDS_BENDING                = 0x20000000, /* not supported anymore, don't use (frontend requires frequency bending) */
068:         FE_CAN_RECOVER                  = 0x40000000, /* frontend can recover from a cable unplug automatically */
069:         FE_CAN_MUTE_TS                  = 0x80000000  /* frontend can stop spurious TS data output */
070: } fe_caps_t;
071: 
072: 
073: struct dvb_frontend_info {
074:         char       name[128];
075:         fe_type_t  type;
076:         __u32      frequency_min;
077:         __u32      frequency_max;
078:         __u32      frequency_stepsize;
079:         __u32      frequency_tolerance;
080:         __u32      symbol_rate_min;
081:         __u32      symbol_rate_max;
082:         __u32      symbol_rate_tolerance;       /* ppm */
083:         __u32      notifier_delay;              /* DEPRECATED */
084:         fe_caps_t  caps;
085: };
086: 
087: 
088: /**
089:  *  Check out the DiSEqC bus spec available on http://www.eutelsat.org/ for
090:  *  the meaning of this struct...
091:  */
092: struct dvb_diseqc_master_cmd {
093:         __u8 msg [6];   /*  { framing, address, command, data [3] } */
094:         __u8 msg_len;   /*  valid values are 3...6  */
095: };
096: 
097: 
098: struct dvb_diseqc_slave_reply {
099:         __u8 msg [4];   /*  { framing, data [3] } */
100:         __u8 msg_len;   /*  valid values are 0...4, 0 means no msg  */
101:         int  timeout;   /*  return from ioctl after timeout ms with */
102: };                      /*  errorcode when no message was received  */
103: 
104: 
105: typedef enum fe_sec_voltage {
106:         SEC_VOLTAGE_13,
107:         SEC_VOLTAGE_18,
108:         SEC_VOLTAGE_OFF
109: } fe_sec_voltage_t;
110: 
111: 
112: typedef enum fe_sec_tone_mode {
113:         SEC_TONE_ON,
114:         SEC_TONE_OFF
115: } fe_sec_tone_mode_t;
116: 
117: 
118: typedef enum fe_sec_mini_cmd {
119:         SEC_MINI_A,
120:         SEC_MINI_B
121: } fe_sec_mini_cmd_t;
122: 
123: 
124: typedef enum fe_status {
125:         FE_HAS_SIGNAL   = 0x01,   /* found something above the noise level */
126:         FE_HAS_CARRIER  = 0x02,   /* found a DVB signal  */
127:         FE_HAS_VITERBI  = 0x04,   /* FEC is stable  */
128:         FE_HAS_SYNC     = 0x08,   /* found sync bytes  */
129:         FE_HAS_LOCK     = 0x10,   /* everything's working... */
130:         FE_TIMEDOUT     = 0x20,   /* no lock within the last ~2 seconds */
131:         FE_REINIT       = 0x40    /* frontend was reinitialized,  */
132: } fe_status_t;                    /* application is recommended to reset */
133:                                   /* DiSEqC, tone and parameters */
134: 
135: typedef enum fe_spectral_inversion {
136:         INVERSION_OFF,
137:         INVERSION_ON,
138:         INVERSION_AUTO
139: } fe_spectral_inversion_t;
140: 
141: 
142: typedef enum fe_code_rate {
143:         FEC_NONE = 0,
144:         FEC_1_2,
145:         FEC_2_3,
146:         FEC_3_4,
147:         FEC_4_5,
148:         FEC_5_6,
149:         FEC_6_7,
150:         FEC_7_8,
151:         FEC_8_9,
152:         FEC_AUTO,
153:         FEC_3_5,
154:         FEC_9_10,
155: } fe_code_rate_t;
156: 
157: 
158: typedef enum fe_modulation {
159:         QPSK,
160:         QAM_16,
161:         QAM_32,
162:         QAM_64,
163:         QAM_128,
164:         QAM_256,
165:         QAM_AUTO,
166:         VSB_8,
167:         VSB_16,
168:         PSK_8,
169:         APSK_16,
170:         APSK_32,
171:         DQPSK,
172: } fe_modulation_t;
173: 
174: typedef enum fe_transmit_mode {
175:         TRANSMISSION_MODE_2K,
176:         TRANSMISSION_MODE_8K,
177:         TRANSMISSION_MODE_AUTO,
178:         TRANSMISSION_MODE_4K,
179:         TRANSMISSION_MODE_1K,
180:         TRANSMISSION_MODE_16K,
181:         TRANSMISSION_MODE_32K,
182: } fe_transmit_mode_t;
183: 
184: typedef enum fe_bandwidth {
185:         BANDWIDTH_8_MHZ,
186:         BANDWIDTH_7_MHZ,
187:         BANDWIDTH_6_MHZ,
188:         BANDWIDTH_AUTO,
189:         BANDWIDTH_5_MHZ,
190:         BANDWIDTH_10_MHZ,
191:         BANDWIDTH_1_712_MHZ,
192: } fe_bandwidth_t;
193: 
194: 
195: typedef enum fe_guard_interval {
196:         GUARD_INTERVAL_1_32,
197:         GUARD_INTERVAL_1_16,
198:         GUARD_INTERVAL_1_8,
199:         GUARD_INTERVAL_1_4,
200:         GUARD_INTERVAL_AUTO,
201:         GUARD_INTERVAL_1_128,
202:         GUARD_INTERVAL_19_128,
203:         GUARD_INTERVAL_19_256,
204: } fe_guard_interval_t;
205: 
206: 
207: typedef enum fe_hierarchy {
208:         HIERARCHY_NONE,
209:         HIERARCHY_1,
210:         HIERARCHY_2,
211:         HIERARCHY_4,
212:         HIERARCHY_AUTO
213: } fe_hierarchy_t;
214: 
215: 
216: struct dvb_qpsk_parameters {
217:         __u32           symbol_rate;  /* symbol rate in Symbols per second */
218:         fe_code_rate_t  fec_inner;    /* forward error correction (see above) */
219: };
220: 
221: struct dvb_qam_parameters {
222:         __u32           symbol_rate; /* symbol rate in Symbols per second */
223:         fe_code_rate_t  fec_inner;   /* forward error correction (see above) */
224:         fe_modulation_t modulation;  /* modulation type (see above) */
225: };
226: 
227: struct dvb_vsb_parameters {
228:         fe_modulation_t modulation;  /* modulation type (see above) */
229: };
230: 
231: struct dvb_ofdm_parameters {
232:         fe_bandwidth_t      bandwidth;
233:         fe_code_rate_t      code_rate_HP;  /* high priority stream code rate */
234:         fe_code_rate_t      code_rate_LP;  /* low priority stream code rate */
235:         fe_modulation_t     constellation; /* modulation type (see above) */
236:         fe_transmit_mode_t  transmission_mode;
237:         fe_guard_interval_t guard_interval;
238:         fe_hierarchy_t      hierarchy_information;
239: };
240: 
241: 
242: struct dvb_frontend_parameters {
243:         __u32 frequency;     /* (absolute) frequency in Hz for QAM/OFDM/ATSC */
244:                              /* intermediate frequency in kHz for QPSK */
245:         fe_spectral_inversion_t inversion;
246:         union {
247:                 struct dvb_qpsk_parameters qpsk;
248:                 struct dvb_qam_parameters  qam;
249:                 struct dvb_ofdm_parameters ofdm;
250:                 struct dvb_vsb_parameters vsb;
251:         } u;
252: };
253: 
254: 
255: struct dvb_frontend_event {
256:         fe_status_t status;
257:         struct dvb_frontend_parameters parameters;
258: };
259: 
260: /* S2API Commands */
261: #define DTV_UNDEFINED           0
262: #define DTV_TUNE                1
263: #define DTV_CLEAR               2
264: #define DTV_FREQUENCY           3
265: #define DTV_MODULATION          4
266: #define DTV_BANDWIDTH_HZ        5
267: #define DTV_INVERSION           6
268: #define DTV_DISEQC_MASTER       7
269: #define DTV_SYMBOL_RATE         8
270: #define DTV_INNER_FEC           9
271: #define DTV_VOLTAGE             10
272: #define DTV_TONE                11
273: #define DTV_PILOT               12
274: #define DTV_ROLLOFF             13
275: #define DTV_DISEQC_SLAVE_REPLY  14
276: 
277: /* Basic enumeration set for querying unlimited capabilities */
278: #define DTV_FE_CAPABILITY_COUNT 15
279: #define DTV_FE_CAPABILITY       16
280: #define DTV_DELIVERY_SYSTEM     17
281: 
282: /* ISDB-T and ISDB-Tsb */
283: #define DTV_ISDBT_PARTIAL_RECEPTION     18
284: #define DTV_ISDBT_SOUND_BROADCASTING    19
285: 
286: #define DTV_ISDBT_SB_SUBCHANNEL_ID      20
287: #define DTV_ISDBT_SB_SEGMENT_IDX        21
288: #define DTV_ISDBT_SB_SEGMENT_COUNT      22
289: 
290: #define DTV_ISDBT_LAYERA_FEC                    23
291: #define DTV_ISDBT_LAYERA_MODULATION             24
292: #define DTV_ISDBT_LAYERA_SEGMENT_COUNT          25
293: #define DTV_ISDBT_LAYERA_TIME_INTERLEAVING      26
294: 
295: #define DTV_ISDBT_LAYERB_FEC                    27
296: #define DTV_ISDBT_LAYERB_MODULATION             28
297: #define DTV_ISDBT_LAYERB_SEGMENT_COUNT          29
298: #define DTV_ISDBT_LAYERB_TIME_INTERLEAVING      30
299: 
300: #define DTV_ISDBT_LAYERC_FEC                    31
301: #define DTV_ISDBT_LAYERC_MODULATION             32
302: #define DTV_ISDBT_LAYERC_SEGMENT_COUNT          33
303: #define DTV_ISDBT_LAYERC_TIME_INTERLEAVING      34
304: 
305: #define DTV_API_VERSION         35
306: 
307: #define DTV_CODE_RATE_HP        36
308: #define DTV_CODE_RATE_LP        37
309: #define DTV_GUARD_INTERVAL      38
310: #define DTV_TRANSMISSION_MODE   39
311: #define DTV_HIERARCHY           40
312: 
313: #define DTV_ISDBT_LAYER_ENABLED 41
314: 
315: #define DTV_ISDBS_TS_ID         42
316: 
317: #define DTV_DVBT2_PLP_ID        43
318: 
319: #define DTV_MAX_COMMAND                         DTV_DVBT2_PLP_ID
320: 
321: typedef enum fe_pilot {
322:         PILOT_ON,
323:         PILOT_OFF,
324:         PILOT_AUTO,
325: } fe_pilot_t;
326: 
327: typedef enum fe_rolloff {
328:         ROLLOFF_35, /* Implied value in DVB-S, default for DVB-S2 */
329:         ROLLOFF_20,
330:         ROLLOFF_25,
331:         ROLLOFF_AUTO,
332: } fe_rolloff_t;
333: 
334: typedef enum fe_delivery_system {
335:         SYS_UNDEFINED,
336:         SYS_DVBC_ANNEX_AC,
337:         SYS_DVBC_ANNEX_B,
338:         SYS_DVBT,
339:         SYS_DSS,
340:         SYS_DVBS,
341:         SYS_DVBS2,
342:         SYS_DVBH,
343:         SYS_ISDBT,
344:         SYS_ISDBS,
345:         SYS_ISDBC,
346:         SYS_ATSC,
347:         SYS_ATSCMH,
348:         SYS_DMBTH,
349:         SYS_CMMB,
350:         SYS_DAB,
351:         SYS_DVBT2,
352:         SYS_TURBO,
353: } fe_delivery_system_t;
354: 
355: struct dtv_cmds_h {
356:         char    *name;          /* A display name for debugging purposes */
357: 
358:         __u32   cmd;            /* A unique ID */
359: 
360:         /* Flags */
361:         __u32   set:1;          /* Either a set or get property */
362:         __u32   buffer:1;       /* Does this property use the buffer? */
363:         __u32   reserved:30;    /* Align */
364: };
365: 
366: struct dtv_property {
367:         __u32 cmd;
368:         __u32 reserved[3];
369:         union {
370:                 __u32 data;
371:                 struct {
372:                         __u8 data[32];
373:                         __u32 len;
374:                         __u32 reserved1[3];
375:                         void *reserved2;
376:                 } buffer;
377:         } u;
378:         int result;
379: } __attribute__ ((packed));
380: 
381: /* num of properties cannot exceed DTV_IOCTL_MAX_MSGS per ioctl */
382: #define DTV_IOCTL_MAX_MSGS 64
383: 
384: struct dtv_properties {
385:         __u32 num;
386:         struct dtv_property *props;
387: };
388: 
389: #define FE_SET_PROPERTY            _IOW('o', 82, struct dtv_properties)
390: #define FE_GET_PROPERTY            _IOR('o', 83, struct dtv_properties)
391: 
392: 
393: /**
394:  * When set, this flag will disable any zigzagging or other "normal" tuning
395:  * behaviour. Additionally, there will be no automatic monitoring of the lock
396:  * status, and hence no frontend events will be generated. If a frontend device
397:  * is closed, this flag will be automatically turned off when the device is
398:  * reopened read-write.
399:  */
400: #define FE_TUNE_MODE_ONESHOT 0x01
401: 
402: 
403: #define FE_GET_INFO                _IOR('o', 61, struct dvb_frontend_info)
404: 
405: #define FE_DISEQC_RESET_OVERLOAD   _IO('o', 62)
406: #define FE_DISEQC_SEND_MASTER_CMD  _IOW('o', 63, struct dvb_diseqc_master_cmd)
407: #define FE_DISEQC_RECV_SLAVE_REPLY _IOR('o', 64, struct dvb_diseqc_slave_reply)
408: #define FE_DISEQC_SEND_BURST       _IO('o', 65)  /* fe_sec_mini_cmd_t */
409: 
410: #define FE_SET_TONE                _IO('o', 66)  /* fe_sec_tone_mode_t */
411: #define FE_SET_VOLTAGE             _IO('o', 67)  /* fe_sec_voltage_t */
412: #define FE_ENABLE_HIGH_LNB_VOLTAGE _IO('o', 68)  /* int */
413: 
414: #define FE_READ_STATUS             _IOR('o', 69, fe_status_t)
415: #define FE_READ_BER                _IOR('o', 70, __u32)
416: #define FE_READ_SIGNAL_STRENGTH    _IOR('o', 71, __u16)
417: #define FE_READ_SNR                _IOR('o', 72, __u16)
418: #define FE_READ_UNCORRECTED_BLOCKS _IOR('o', 73, __u32)
419: 
420: #define FE_SET_FRONTEND            _IOW('o', 76, struct dvb_frontend_parameters)
421: #define FE_GET_FRONTEND            _IOR('o', 77, struct dvb_frontend_parameters)
422: #define FE_SET_FRONTEND_TUNE_MODE  _IO('o', 81) /* unsigned int */
423: #define FE_GET_EVENT               _IOR('o', 78, struct dvb_frontend_event)
424: 
425: #define FE_DISHNETWORK_SEND_LEGACY_CMD _IO('o', 80) /* unsigned int */
426: 
427: #endif /*_DVBFRONTEND_H_*/
428: 


for client (none)
© Andrew Scott 2006 - 2025,
All Rights Reserved
http://www.andrew-scott.uk/
Andrew Scott
http://www.andrew-scott.co.uk/