61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync#ifndef __FI1236_H__
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync#define __FI1236_H__
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync#include "xf86i2c.h"
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync/* why someone has defined NUM someplace else is beyoung me.. */
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync#undef NUM
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsynctypedef struct {
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync CARD32 fcar; /* 16 * fcar_Mhz */
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync CARD32 min_freq; /* 16 * min_freq_Mhz */
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync CARD32 max_freq; /* 16 * max_freq_Mhz */
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync CARD32 threshold1; /* 16 * Value_Mhz */
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync CARD32 threshold2; /* 16 * Value_Mhz */
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync CARD8 band_low;
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync CARD8 band_mid;
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync CARD8 band_high;
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync CARD8 control;
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync} FI1236_parameters;
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsynctypedef struct {
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync /* what we want */
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync /* all frequencies are in Mhz */
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync double f_rf; /* frequency to tune to */
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync double f_if1; /* first intermediate frequency */
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync double f_if2; /* second intermediate frequency */
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync double f_ref; /* reference frequency */
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync double f_ifbw; /* bandwidth */
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync double f_step; /* step */
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync /* what we compute */
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync double f_lo1;
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync double f_lo2;
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync int LO1I;
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync int LO2I;
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync int SEL;
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync int STEP;
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync int NUM;
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync} MT2032_parameters;
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsynctypedef struct {
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync I2CDevRec d;
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync int type;
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync void *afc_source; /* The AFC source may be another chip like TDA988x */
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync int afc_delta;
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync CARD32 original_frequency;
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync Bool afc_timer_installed;
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync int afc_count;
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync int last_afc_hint;
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync double video_if;
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync FI1236_parameters parm;
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync int xogc; /* for MT2032 */
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync struct {
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync CARD8 div1;
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync CARD8 div2;
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync CARD8 control;
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync CARD8 band;
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync CARD8 aux; /* this is for MK3 tuners */
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync } tuner_data;
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync} FI1236Rec, *FI1236Ptr;
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync#define TUNER_TYPE_FI1236 0
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync#define TUNER_TYPE_FI1216 1
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync#define TUNER_TYPE_TEMIC_FN5AL 2
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync#define TUNER_TYPE_MT2032 3
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync#define TUNER_TYPE_FI1246 4
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync#define TUNER_TYPE_FI1256 5
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync#define TUNER_TYPE_FI1236W 6
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync#define TUNER_TYPE_FM1216ME 7
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync#define FI1236_ADDR(a) ((a)->d.SlaveAddr)
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync#define FI1236_ADDR_1 0xC6
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync#define FI1236_ADDR_2 0xC0
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync#define TUNER_TUNED 0
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync#define TUNER_JUST_BELOW 1
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync#define TUNER_JUST_ABOVE -1
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync#define TUNER_OFF 4
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync#define TUNER_STILL_TUNING 5
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsyncvoid FI1236_tune(FI1236Ptr f, CARD32 frequency);
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync#define FI1236SymbolsList \
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync "Detect_FI1236", \
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync "FI1236_set_tuner_type", \
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync "TUNER_set_frequency"
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync#define xf86_Detect_FI1236 Detect_FI1236
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsyncextern _X_EXPORT FI1236Ptr Detect_FI1236(I2CBusPtr b, I2CSlaveAddr addr);
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync#define xf86_FI1236_set_tuner_type FI1236_set_tuner_type
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsyncextern _X_EXPORT void FI1236_set_tuner_type(FI1236Ptr f, int type);
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync#define xf86_TUNER_set_frequency TUNER_set_frequency
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsyncextern _X_EXPORT void TUNER_set_frequency(FI1236Ptr f, CARD32 frequency);
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync#define xf86_FI1236_AFC FI1236_AFC
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsyncextern _X_EXPORT int FI1236_AFC(FI1236Ptr f);
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync#define xf86_TUNER_get_afc_hint TUNER_get_afc_hint
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsyncextern _X_EXPORT int TUNER_get_afc_hint(FI1236Ptr f);
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync#define xf86_fi1236_dump_status fi1236_dump_status
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsyncextern _X_EXPORT void fi1236_dump_status(FI1236Ptr f);
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync#endif