Quellcodebibliothek Statistik Leitseite products/Sources/formale Sprachen/C/Linux/drivers/media/dvb-frontends/   (Open Source Betriebssystem Version 6.17.9©)  Datei vom 24.10.2025 mit Größe 3 kB image not shown  

Quelle  stb0899_drv.h   Sprache: C

 
/* SPDX-License-Identifier: GPL-2.0-or-later */
/*
STB0899 Multistandard Frontend driver
Copyright (C) Manu Abraham (abraham.manu@gmail.com)

Copyright (C) ST Microelectronics

*/


#ifndef __STB0899_DRV_H
#define __STB0899_DRV_H

#include <linux/kernel.h>
#include <linux/module.h>

#include <media/dvb_frontend.h>

#define STB0899_TSMODE_SERIAL  1
#define STB0899_CLKPOL_FALLING  2
#define STB0899_CLKNULL_PARITY  3
#define STB0899_SYNC_FORCED  4
#define STB0899_FECMODE_DSS  5

struct stb0899_s1_reg {
 u16 address;
 u8 data;
};

struct stb0899_s2_reg {
 u16 offset;
 u32 base_address;
 u32 data;
};

enum stb0899_inversion {
 IQ_SWAP_OFF = +1, /* inversion affects the sign of e. g. */
 IQ_SWAP_ON = -1, /* the derotator frequency register    */
};

#define STB0899_GPIO00    0xf140
#define STB0899_GPIO01    0xf141
#define STB0899_GPIO02    0xf142
#define STB0899_GPIO03    0xf143
#define STB0899_GPIO04    0xf144
#define STB0899_GPIO05    0xf145
#define STB0899_GPIO06    0xf146
#define STB0899_GPIO07    0xf147
#define STB0899_GPIO08    0xf148
#define STB0899_GPIO09    0xf149
#define STB0899_GPIO10    0xf14a
#define STB0899_GPIO11    0xf14b
#define STB0899_GPIO12    0xf14c
#define STB0899_GPIO13    0xf14d
#define STB0899_GPIO14    0xf14e
#define STB0899_GPIO15    0xf14f
#define STB0899_GPIO16    0xf150
#define STB0899_GPIO17    0xf151
#define STB0899_GPIO18    0xf152
#define STB0899_GPIO19    0xf153
#define STB0899_GPIO20    0xf154

#define STB0899_GPIOPULLUP   0x01 /* Output device is connected to Vdd */
#define STB0899_GPIOPULLDN   0x00 /* Output device is connected to Vss */

#define STB0899_POSTPROC_GPIO_POWER  0x00
#define STB0899_POSTPROC_GPIO_LOCK  0x01

/*
 * Post process output configuration control
 * 1. POWER ON/OFF (index 0)
 * 2. FE_HAS_LOCK/LOCK_LOSS (index 1)
 *
 * @gpio = one of the above listed GPIO's
 * @level = output state: pulled up or low
 */

struct stb0899_postproc {
 u16 gpio;
 u8 level;
};

struct stb0899_config {
 const struct stb0899_s1_reg *init_dev;
 const struct stb0899_s2_reg *init_s2_demod;
 const struct stb0899_s1_reg *init_s1_demod;
 const struct stb0899_s2_reg *init_s2_fec;
 const struct stb0899_s1_reg *init_tst;

 const struct stb0899_postproc *postproc;

 enum stb0899_inversion  inversion;

 u32 xtal_freq;

 u8 demod_address;
 u8 ts_output_mode;
 u8 block_sync_mode;
 u8 ts_pfbit_toggle;

 u8 clock_polarity;
 u8 data_clk_parity;
 u8 fec_mode;
 u8 data_output_ctl;
 u8 data_fifo_mode;
 u8 out_rate_comp;
 u8 i2c_repeater;
// int inversion;
 int lo_clk;
 int hi_clk;

 u32 esno_ave;
 u32 esno_quant;
 u32 avframes_coarse;
 u32 avframes_fine;
 u32 miss_threshold;
 u32 uwp_threshold_acq;
 u32 uwp_threshold_track;
 u32 uwp_threshold_sof;
 u32 sof_search_timeout;

 u32 btr_nco_bits;
 u32 btr_gain_shift_offset;
 u32 crl_nco_bits;
 u32 ldpc_max_iter;

 int (*tuner_set_frequency)(struct dvb_frontend *fe, u32 frequency);
 int (*tuner_get_frequency)(struct dvb_frontend *fe, u32 *frequency);
 int (*tuner_set_bandwidth)(struct dvb_frontend *fe, u32 bandwidth);
 int (*tuner_get_bandwidth)(struct dvb_frontend *fe, u32 *bandwidth);
 int (*tuner_set_rfsiggain)(struct dvb_frontend *fe, u32 rf_gain);
};

#if IS_REACHABLE(CONFIG_DVB_STB0899)

extern struct dvb_frontend *stb0899_attach(struct stb0899_config *config,
        struct i2c_adapter *i2c);

#else

static inline struct dvb_frontend *stb0899_attach(struct stb0899_config *config,
        struct i2c_adapter *i2c)
{
 printk(KERN_WARNING "%s: Driver disabled by Kconfig\n", __func__);
 return NULL;
}

#endif //CONFIG_DVB_STB0899


#endif

Messung V0.5
C=94 H=83 G=88

¤ Dauer der Verarbeitung: 0.3 Sekunden  ¤

*© Formatika GbR, Deutschland






Wurzel

Suchen

Beweissystem der NASA

Beweissystem Isabelle

NIST Cobol Testsuite

Cephes Mathematical Library

Wiener Entwicklungsmethode

Haftungshinweis

Die Informationen auf dieser Webseite wurden nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit, noch Qualität der bereit gestellten Informationen zugesichert.

Bemerkung:

Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.