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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? driv0299.c

?? 這是DVB tuner驅(qū)動部分和其它相關(guān)的源碼和一些技術(shù)資料文檔.
?? 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;

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲视频你懂的| 99久久婷婷国产| 国产精品一级黄| 91原创在线视频| 久久久99精品免费观看| 亚洲九九爱视频| 激情成人综合网| 日本韩国一区二区| 精品国产免费久久| 亚洲欧美成aⅴ人在线观看| 精品一区二区三区在线观看 | 日本一区二区三区四区在线视频 | 一区二区在线电影| 欧美日韩一区小说| 欧美国产精品一区二区三区| 日韩电影一区二区三区四区| 91麻豆免费看| 日韩中文字幕区一区有砖一区 | 99麻豆久久久国产精品免费优播| 91精品国产黑色紧身裤美女| 亚洲视频 欧洲视频| 欧美日韩中文一区| 韩国欧美国产一区| 日韩美女久久久| 在线电影欧美成精品| 1024成人网色www| 国产.欧美.日韩| 欧美日韩五月天| 色狠狠一区二区三区香蕉| 蜜臀精品一区二区三区在线观看 | 一区2区3区在线看| 亚洲成人激情av| 成人黄色a**站在线观看| 精品国产91洋老外米糕| 91网页版在线| 国产一区不卡视频| 国产日产欧美精品一区二区三区| 在线观看av不卡| 亚洲成a人v欧美综合天堂| 2020国产精品自拍| 国产精品69久久久久水密桃| 亚洲一区av在线| 日韩欧美一区电影| 国产一区二区影院| 午夜在线成人av| 国产精品灌醉下药二区| 99久久精品99国产精品| 久久国产三级精品| 国产欧美日韩不卡免费| 欧洲中文字幕精品| 成人app软件下载大全免费| 麻豆精品视频在线| 日韩国产在线观看| 亚洲国产aⅴ成人精品无吗| 欧美一级久久久久久久大片| 国产美女精品在线| 男女性色大片免费观看一区二区 | 欧美成人精品3d动漫h| 国产麻豆视频精品| 日韩av电影免费观看高清完整版 | 欧美一区二区人人喊爽| 91久久精品一区二区三| 不卡一卡二卡三乱码免费网站| 韩国av一区二区三区四区| 青娱乐精品在线视频| 亚洲成人免费视| 亚洲一区二区视频在线| 亚洲黄色性网站| 亚洲日本青草视频在线怡红院 | 亚洲精品日韩一| 1024亚洲合集| 亚洲人被黑人高潮完整版| 国产精品二区一区二区aⅴ污介绍| 国产偷国产偷亚洲高清人白洁| 欧美精品一区二区三区在线播放| 欧美一区二区高清| 欧美一二三四区在线| 精品免费国产二区三区| 精品日韩欧美在线| 久久久久久久久久久久久久久99 | 成人午夜av电影| 亚洲bt欧美bt精品| 婷婷中文字幕综合| 国产精品电影一区二区| 国产精品久久久久影院| 亚洲天堂中文字幕| 亚洲成人在线观看视频| 天天综合日日夜夜精品| 秋霞电影一区二区| 精品亚洲国产成人av制服丝袜 | 99久久精品99国产精品| 一道本成人在线| 国内精品伊人久久久久av一坑 | eeuss鲁一区二区三区| 91片在线免费观看| 9191久久久久久久久久久| av成人老司机| 在线亚洲免费视频| 日韩精品资源二区在线| 亚洲精品一区二区在线观看| 国产精品欧美极品| 国产午夜精品久久久久久久| 亚洲视频你懂的| 日韩专区在线视频| 国产大陆亚洲精品国产| 久久爱www久久做| 成人免费高清视频| 欧美体内she精高潮| 在线观看网站黄不卡| 欧美精品国产精品| 中文字幕成人av| 亚洲va国产天堂va久久en| 国产乱妇无码大片在线观看| 91论坛在线播放| 精品三级在线观看| 亚洲精品国产一区二区精华液| 奇米影视7777精品一区二区| 成人精品免费网站| 欧美精品第1页| 中文字幕一区二区三| 人人超碰91尤物精品国产| 成人国产精品免费观看动漫 | 色综合久久99| 欧美精品一区二区三区久久久| 亚洲美女区一区| 国产精一品亚洲二区在线视频| 色婷婷久久久亚洲一区二区三区| 精品久久五月天| 亚洲国产精品自拍| 岛国一区二区三区| 日韩一区二区精品| 亚洲综合丝袜美腿| 不卡一区二区在线| 久久久久久久综合狠狠综合| 午夜免费欧美电影| 91视频你懂的| 欧美高清在线一区| 韩国成人在线视频| 欧美一区二区三区在线看| 亚洲精品免费看| 国产69精品久久99不卡| 欧美成va人片在线观看| 亚洲成av人影院在线观看网| 99re这里只有精品首页| 国产亚洲欧美日韩在线一区| 美洲天堂一区二卡三卡四卡视频| 在线免费观看成人短视频| 国产精品人妖ts系列视频| 国内欧美视频一区二区 | 欧美日韩在线直播| 亚洲人成网站色在线观看| 成人在线视频一区| 欧美精品一区二区三区蜜桃| 久久福利视频一区二区| 欧美军同video69gay| 午夜精品免费在线| 欧美视频完全免费看| 伊人色综合久久天天人手人婷| 成人国产精品免费网站| 激情综合色播激情啊| 国产成人无遮挡在线视频| 日韩免费视频一区| 日本不卡的三区四区五区| 欧美日本韩国一区二区三区视频| 日本福利一区二区| 中文字幕欧美一| 91影院在线观看| 亚洲女人小视频在线观看| 99久久夜色精品国产网站| 亚洲天堂网中文字| 欧美影视一区在线| 亚洲一级电影视频| 色婷婷久久99综合精品jk白丝| 亚洲男人的天堂网| 欧美体内she精视频| 婷婷中文字幕一区三区| 91精品国产乱码久久蜜臀| 激情综合色播五月| 久久久av毛片精品| 99久久精品国产麻豆演员表| 亚洲综合一二区| 日韩欧美色电影| 欧美午夜精品一区二区蜜桃| 首页国产丝袜综合| 日韩欧美在线网站| 国产成人在线观看| 亚洲乱码国产乱码精品精的特点 | 日韩中文字幕1| 精品国产麻豆免费人成网站| 一区二区三区成人| 亚洲第一狼人社区| 91精品国产91综合久久蜜臀| 石原莉奈在线亚洲二区| 欧美不卡激情三级在线观看| 国产成人午夜精品影院观看视频| 亚洲图片另类小说| 日韩一区二区中文字幕| 国产成人aaaa| 亚洲国产日韩综合久久精品| 精品国产乱码久久久久久浪潮|