亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? driv0299.c

?? 這是DVB tuner驅動部分和其它相關的源碼和一些技術資料文檔.
?? C
?? 第 1 頁 / 共 3 頁
字號:
/*****************************************************************************File Name   : driv0299.cDescription : STV0299 front-end driver routines.Copyright (C) 2000 STMicroelectronicsRevision History    :    04/02/00        Code based on original implementation by CBB.    21/03/00        Received code modifications that eliminate compiler                    warnings.                    Added defensive check to Mclk == 0 during parameter                    initialization routine to avoid potential divide by                    zero exceptions.Reference           :*****************************************************************************/#include <stdio.h>                      /* C libs */#include <stdlib.h>#include <string.h>#include "stddefs.h"                    /* STAPI common includes */#include "stv299.h"                     /* Local includes */#include "driv0299.h"#include "reg0299.h"#define INTERPOLATE( LutLow, LutHigh, RealLow, RealHigh, Real) \    (LutLow + (((Real - RealLow) * (LutHigh - LutLow)) / \               (RealHigh - RealLow)))typedef struct{    S32 Real;    S32 Lookup;} LUT_t;static const LUT_t BerLUT[] ={    { ((U16)-1), 200000 },    { 9600, 160000 },    { 9450, 120000 },                   /* 2 */    { 9260, 97000 },                    /* 2.5 */    { 9000, 82000 },                    /* 3 */    { 8760, 73000 },                    /* 3.5 */    { 8520, 61500 },                    /* 4 */    { 8250, 51000 },                    /* 4.5 */    { 7970, 42000 },                    /* 5 */    { 7690, 34000 },                    /* 5.5 */    { 7360, 26000 },                    /* 6 */    { 7080, 20600 },                    /* 6.5 */    { 6770, 15000 },                    /* 7 */    { 6470, 11200 },                    /* 7.5 */    { 6200, 8000 },                     /* 8 */    { 5900, 5400 },                     /* 8.5 */    { 5670, 3600 },                     /* 9 */    { 5420, 2320 },                     /* 9.5 */    { 5190, 1450 },                     /* 10 */    { 4960, 840 },                      /* 10.5 */    { 4740, 480 },                      /* 11 */    { 4550, 225 },                      /* 11.5 */    { 4360, 130 },                      /* 12 */    { 4170, 60 },                       /* 12.5 */    { 4010, 30 },                       /* 13 */    { 3860, 12 },                       /* 13.5 */    { 3710, 4 },                        /* 14 */    { 3580, 1 },                        /* 14.5 */    { 3440, 0 },                        /* 15 */    { 0, 0 },    { ((U32)-1), 0 }                    /* End */};static const LUT_t SignalNoiseLUT[] ={    { ((U16)-1), 0 },                   /* 1 */    { 9600, 19 },                       /* 1.5 */    { 9450, 22 },                       /* 2 */    { 9260, 25 },                       /* 2.5 */    { 9000, 28 },                       /* 3 */    { 8760, 31 },                       /* 3.5 */    { 8520, 34 },                       /* 4 */    { 8250, 37 },                       /* 4.5 */    { 7970, 40 },                       /* 5 */    { 7690, 43 },                       /* 5.5 */    { 7360, 46 },                       /* 6 */    { 7080, 49 },                       /* 6.5 */    { 6770, 52 },                       /* 7 */    { 6470, 55 },                       /* 7.5 */    { 6200, 58 },                       /* 8 */    { 5900, 61 },                       /* 8.5 */    { 5670, 64 },                       /* 9 */    { 5420, 67 },                       /* 9.5 */    { 5190, 70 },                       /* 10 */    { 4960, 73 },                       /* 10.5 */    { 4740, 76 },                       /* 11 */    { 4550, 79 },                       /* 11.5 */    { 4360, 82 },                       /* 12 */    { 4170, 85 },                       /* 12.5 */    { 4010, 88 },                       /* 13 */    { 3860, 91 },                       /* 13.5 */    { 3710, 94 },                       /* 14 */    { 3580, 97 },                       /* 14.5 */    { 3440, 100 },                      /* 15 */    { 0, 100 },    { ((U32)-1), 0 }                          /* End */};static const LUT_t AgcLUT[] ={    { 127, 255 },                       /* 0dBm */    { 115, 215 },                       /* -20dBm */    { 99,  205 },                       /* -25dBm */    { 83, 195 },                        /* -30dBm */    { 70, 185 },                        /* -35dBm */    { 60, 175 },                        /* -40dBm */    { 54, 165 },                        /* -45dBm */    { 47, 155 },                        /* -50dBm */    { 40, 145 },                        /* -55dBm */    { 27, 135 },                        /* -60dBm */    { 9, 125 },                         /* -65dBm */    { -20, 115 },                       /* -70dBm */    { -64, 105 },                       /* -75dBm */    { -116, 95 },                       /* -80dBm */    { -128, 92 },                       /* -81dBm */    { -128, 92 },    { ((U32)-1), 0 }                    /* End */};long PowOf2(int number);/* Delay routine */#define SystemWaitFor(x)                STV0299_Delay((x*1000))/*****************************************************--FUNCTION  ::    WaitTuner--ACTION    ::    Wait for tuner locked--PARAMS IN ::    TimeOut    ->    Maximum waiting time (in ms)--PARAMS OUT::    NONE--RETURN    ::    NONE--***************************************************/void WaitTuner(STV0299_ControlBlock_t *Dev_p, int TimeOut){    int Time=0;    BOOL TunerLocked = FALSE;    while(!TunerLocked && (Time<TimeOut))    {        SystemWaitFor(1);        TNR_IsTunerLocked(TNR_HANDLE(Dev_p), &TunerLocked);        Time++;    }    Time--;}/****************************************************--FUNCTION    ::    CheckAgc1--ACTION    ::    Check agc1 value--PARAMS IN    ::    pParams    ->    Pointer to SEARCHPARAMS structure--PARAMS OUT::    pParams->State is modified--RETURN    ::    NOAGC1 if AGC1=-128, AGC1SATURATION--                if AGC1=127, AGC1OK otherwise--**************************************************/SIGNALTYPE CheckAgc1(STV0299_ControlBlock_t *Dev_p, SEARCHPARAMS *pParams){    int AGC1Value;    int Agc1Threshold = -128;    AGC1Value = RegGetField(Dev_p, AGCINTEGRATORVALUE);    if (AGC1Value == Agc1Threshold )        pParams->State = NOAGC1;    else if(AGC1Value == 127)        pParams->State = AGC1SATURATION;    else        pParams->State = AGC1OK;    return pParams->State;}/*****************************************************--FUNCTION  ::    CheckTiming--ACTION    ::    Check for timing locked--PARAMS IN ::    pParams->Ttiming    =>    Time to wait for timing loop locked--PARAMS OUT::    pParams->State        =>    result of the check--RETURN    ::    NOTIMING if timing not locked, TIMINGOK otherwise--***************************************************/SIGNALTYPE CheckTiming(STV0299_ControlBlock_t *Dev_p, SEARCHPARAMS *pParams){    int locked, timing;    SystemWaitFor(pParams->Ttiming);    locked=RegGetField(Dev_p, TLIR);    timing=abs(RegGetField(Dev_p, RTF));	if(locked >= 43)	{		if((locked > 48) && (timing >= 110))			pParams->State = ANALOGCARRIER;		else			pParams->State = TIMINGOK;	}	else		pParams->State = NOTIMING;    return pParams->State;}/*****************************************************--FUNCTION  ::    CenterTimingLoop--ACTION    ::    Timing loop centring--PARAMS IN ::    SymbolRate    ->    Current symbol rate value--                MasterClock    ->    Current master clock frequency--PARAMS OUT::    NONE--RETURN    ::    New symbol rate--***************************************************/long CenterTimingLoop(STV0299_ControlBlock_t *Dev_p, long SymbolRate, long MasterClock){    long Correction    ;    long NewSymbolRate;    /*    Read register    */    RegGetField(Dev_p, RTF);    /*    Centring the timing loop    */    Correction    = (RegGetField(Dev_p, RTF)*(SymbolRate/8))/(MasterClock/2) ;    /*    rounding    */    Correction = (Correction >= 0) ? (Correction + 1)/2 : (Correction - 1)/2 ;    NewSymbolRate = RegIncrSymbolRate(Dev_p, Correction) ;    return NewSymbolRate;}/*****************************************************--FUNCTION  ::    CheckAgc2--ACTION    ::    Check agc2 value--PARAMS IN ::    NbSample    ->    Number of samples--PARAMS OUT::    Agc2Value    ->    Mean of Agc2 values--RETURN    ::    NOAGC2 if AGC2 =0 or AGC2 = 32767, AGC2OK otherwise--***************************************************/SIGNALTYPE CheckAgc2(STV0299_ControlBlock_t *Dev_p, int NbSample,long *Agc2Value){    int        Agc2Threshold =    0,i;    long    Agc2Limit     = 32767*(long)NbSample ;  /* cast added to eliminate compiler warning --SFS */    SIGNALTYPE Agc2Level;    for (i=0; i < NbSample ; i++)    {        SystemWaitFor( 1 );                /*    1ms delay: settling time    */        RegGetRegisters(Dev_p, R_AGC2I1,2);    /*    Read AGC2I1 and AGC2I2 registers    */	 /* use int cast below to eliminate compile warning;  why does this work??? (I would think it should be caste to long) --SFS */        *Agc2Value += (int)((FieldGetVal(Dev_p, AGC2INTEGRATORMSB)<<8) + FieldGetVal(Dev_p, AGC2INTEGRATORLSB));    }    if ( ( *Agc2Value > Agc2Threshold ) && ( *Agc2Value < Agc2Limit ) )    {        Agc2Level =    AGC2OK;        *Agc2Value = *Agc2Value / NbSample;    }    else    {        Agc2Level = NOAGC2;        *Agc2Value = 0;    }    return Agc2Level;}/*****************************************************--FUNCTION  ::    CheckCarrier--ACTION    ::    Check for carrier founded--PARAMS IN ::    pParams        =>    Pointer to SEARCHPARAMS structure--PARAMS OUT::    pParams->State    => Result of the check--RETURN    ::    NOCARRIER carrier not founded, CARRIEROK otherwise--***************************************************/SIGNALTYPE CheckCarrier(STV0299_ControlBlock_t *Dev_p, SEARCHPARAMS *pParams){    SystemWaitFor(pParams->Tderot);                        /*    wait for derotator ok    */    RegSetField(Dev_p, CFD_ALGO,0);    if (RegGetField(Dev_p, CF))        pParams->State = CARRIEROK;    else        pParams->State = NOCARRIER;    return pParams->State;}/*****************************************************--FUNCTION  ::    CarrierWidth--ACTION    ::    Compute the width of the carrier--PARAMS IN ::    SymbolRate    ->    Symbol rate of the carrier (Kbauds or Mbauds)--                RollOff        ->    Rolloff * 100--PARAMS OUT::    NONE--RETURN    ::    Width of the carrier (KHz or MHz)--***************************************************/long CarrierWidth(long SymbolRate, long RollOff){    return (SymbolRate  + (SymbolRate*RollOff)/100);}/*****************************************************--FUNCTION  ::    CheckData--ACTION    ::    Check for data founded--PARAMS IN ::    pParams        =>    Pointer to SEARCHPARAMS structure--PARAMS OUT::    pParams->State    => Result of the check--RETURN    ::    NODATA data not founded, DATAOK otherwise--***************************************************/SIGNALTYPE CheckData(STV0299_ControlBlock_t *Dev_p, SEARCHPARAMS *pParams){	printf("\npParams->Tdata=%d\n",pParams->Tdata ) ;
    SystemWaitFor(pParams->Tdata);                    /*    Wait for data    */
    if (RegGetField(Dev_p, LK))        pParams->State = DATAOK;    else        pParams->State = NODATA;    return pParams->State;}/*****************************************************--FUNCTION  ::    IQInvertion--ACTION    ::    Invert I and Q--PARAMS IN ::    NONE--PARAMS OUT::    NONE--RETURN    ::    NONE--***************************************************/void IQInvertion(STV0299_ControlBlock_t *Dev_p){    RegSetField(Dev_p, IQ,0x01 & (~RegGetField(Dev_p, IQ)));    /* inverting the I/Q configuration */}/*****************************************************--FUNCTION  ::    CalcTimingTimeConstant--ACTION    ::    Compute the amount of time needed by the timing loop to lock--PARAMS IN ::    SymbolRate    ->    symbol rate value--PARAMS OUT::    NONE--RETURN    ::    Timing loop time constant (ms)--***************************************************/long CalcTimingTimeConstant(long SymbolRate){    return (200000/(SymbolRate/1000));}/*****************************************************--FUNCTION  ::    CalcDerotTimeConstant--ACTION    ::    Compute the amount of time needed by the Derotator to lock--PARAMS IN ::    SymbolRate    ->    symbol rate value--PARAMS OUT::    NONE--RETURN    ::    Derotator time constant (ms)--***************************************************/long CalcDerotTimeConstant(long SymbolRate){    return (10000/(SymbolRate/1000));}/*****************************************************--FUNCTION  ::    CalcDataTimeConstant--ACTION    ::    Compute the amount of time needed to capture data--PARAMS IN ::    Er        ->    Viterbi rror rate--                Sn        ->  viterbi averaging period--                To        ->  viterbi time out--                Hy        ->    viterbi hysteresis--                SymbolRate    ->    symbol rate value--PARAMS OUT::    NONE--RETURN    ::    Data time constant--***************************************************/long CalcDataTimeConstant(int Er, int Sn,int To,int Hy,long SymbolRate){    long    Tviterbi = 0,    TimeOut    =0,    THysteresis    = 0,    PhaseNumber[5] = {1,3,2,6,8},    averaging[4] = {1024L,4096L,16384L,65536L},    InnerCode = 1000,    HigherRate = 1000;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久久综合九色合综国产精品| 91浏览器打开| 午夜视频一区二区三区| 亚洲午夜激情av| 亚洲午夜视频在线| 亚洲一区免费在线观看| 亚洲国产另类av| 视频一区免费在线观看| 日韩中文字幕一区二区三区| 日韩中文字幕亚洲一区二区va在线 | 久久综合狠狠综合久久激情| 日韩三级高清在线| 精品国产一区二区三区久久久蜜月 | 欧美韩日一区二区三区| 国产欧美日韩久久| 亚洲免费在线观看| 图片区小说区国产精品视频| 免费人成在线不卡| 国产精品一区二区不卡| 成人激情黄色小说| 欧美三区免费完整视频在线观看| 欧美精品日日鲁夜夜添| 日韩免费电影一区| 国产精品国产三级国产普通话99 | 国产在线播放一区| 高清不卡在线观看| 91国内精品野花午夜精品| 91精品国产一区二区三区香蕉| 精品国产凹凸成av人网站| 亚洲男同性恋视频| 久久成人麻豆午夜电影| 国产精品一区二区在线观看不卡 | 韩国精品主播一区二区在线观看| 国产成人在线色| 欧美系列一区二区| 久久综合视频网| 亚洲综合男人的天堂| 国产精品综合一区二区三区| 91搞黄在线观看| 久久老女人爱爱| 日韩国产精品久久久| 粉嫩在线一区二区三区视频| 欧美日韩午夜在线视频| 国产精品人妖ts系列视频| 奇米精品一区二区三区四区 | 国产精品自拍一区| 欧美视频精品在线观看| 亚洲国产精品激情在线观看 | 国产不卡视频在线播放| 51午夜精品国产| 亚洲免费观看在线视频| 韩国v欧美v亚洲v日本v| 欧美剧情片在线观看| 亚洲人123区| 国产91高潮流白浆在线麻豆| 在线综合+亚洲+欧美中文字幕| 亚洲美女视频在线观看| 91丝袜美女网| 久久亚洲精华国产精华液 | 91黄色激情网站| 国产精品视频看| 国产一区二区三区美女| 26uuu久久综合| 麻豆精品新av中文字幕| 欧美群妇大交群中文字幕| 亚洲精品中文在线| 91天堂素人约啪| 亚洲人精品一区| 91在线一区二区三区| 中文字幕一区二区不卡| 粉嫩绯色av一区二区在线观看| 久久一区二区三区国产精品| 天天射综合影视| 欧美精品丝袜中出| 三级久久三级久久久| 欧美日韩dvd在线观看| 性感美女久久精品| 欧美日韩精品综合在线| 丝袜亚洲另类丝袜在线| 日韩一区二区三区免费观看| 日韩av一二三| 久久这里只有精品首页| 国产精品一卡二卡| 国产午夜精品一区二区| 福利一区福利二区| 中文字幕亚洲在| 欧美日韩三级一区| 奇米色一区二区| 欧美成人精品高清在线播放| 久久99久久久久久久久久久| 久久综合色鬼综合色| www.在线成人| 午夜精品一区二区三区三上悠亚| 3d动漫精品啪啪1区2区免费| 国产一区久久久| 亚洲美女电影在线| 日韩一级片在线观看| 国产综合久久久久久鬼色| 国产三级精品三级| 在线日韩国产精品| 老色鬼精品视频在线观看播放| 久久久美女艺术照精彩视频福利播放| jvid福利写真一区二区三区| 一区二区三国产精华液| 欧美精品第1页| 国内久久精品视频| 一区二区在线电影| 精品国产亚洲一区二区三区在线观看| 国产传媒欧美日韩成人| 亚洲伦在线观看| 精品三级在线观看| 色婷婷综合激情| 国产乱一区二区| 首页亚洲欧美制服丝腿| 中文字幕一区二区三区不卡在线| 日韩欧美国产电影| 色综合天天综合色综合av | 欧美日韩另类一区| 国产99久久久国产精品| 日韩综合小视频| 亚洲三级免费观看| 精品福利在线导航| 欧美色精品天天在线观看视频| 丰满白嫩尤物一区二区| 久久国内精品视频| 亚洲午夜久久久久久久久电影网| 欧美激情在线一区二区三区| 欧美一级片免费看| 欧美不卡激情三级在线观看| 色综合久久88色综合天天| 国产美女av一区二区三区| 婷婷中文字幕一区三区| 一区二区三区在线观看国产 | 亚洲电影一区二区| 中文乱码免费一区二区| 久久在线免费观看| 日韩精品中文字幕在线不卡尤物 | 欧美日韩国产天堂| 色偷偷久久一区二区三区| 成人久久18免费网站麻豆| 精品一区二区免费| 奇米888四色在线精品| 亚洲va韩国va欧美va精品| 亚洲自拍另类综合| 亚洲天堂网中文字| 亚洲女女做受ⅹxx高潮| 中文字幕av一区二区三区免费看| 久久久久综合网| 国产视频一区在线观看| 国产色91在线| 欧美极品美女视频| 国产拍揄自揄精品视频麻豆| 国产欧美日韩精品a在线观看| 精品国产电影一区二区| 欧美不卡在线视频| 久久久久久久久久久久久久久99| 精品久久久网站| 国产日韩av一区| 中文字幕一区二区三区四区不卡 | 精品国产免费一区二区三区四区 | 欧美一区二区三区视频| 欧美一级专区免费大片| 日韩免费在线观看| 久久蜜桃一区二区| 中文字幕日韩一区| 亚洲一区二区三区影院| 天堂资源在线中文精品| 国产在线一区二区| 成人综合婷婷国产精品久久| 色香蕉成人二区免费| 欧美人伦禁忌dvd放荡欲情| 欧美不卡一区二区三区| 国产精品丝袜久久久久久app| 亚洲精品中文字幕在线观看| 婷婷国产在线综合| 国产精品一级黄| 在线观看一区不卡| 日韩精品综合一本久道在线视频| 精品处破学生在线二十三| 国产精品国模大尺度视频| 午夜欧美在线一二页| 高清不卡在线观看av| 欧美日韩在线免费视频| 久久新电视剧免费观看| 日本美女一区二区三区| 国产九九视频一区二区三区| 在线中文字幕一区| 久久精品一二三| 亚洲午夜电影在线| 成人性色生活片免费看爆迷你毛片| 91福利资源站| 亚洲国产精品成人综合| 香蕉加勒比综合久久| av不卡免费在线观看| 日韩精品在线一区二区| 一区二区三区四区在线播放| 国产乱一区二区| 日韩欧美一级精品久久| 久久久久久久久岛国免费| 午夜久久久久久久久久一区二区|