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

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

?? csl_pll.h

?? Ti C6416 環境下
?? H
字號:
/******************************************************************************\
*  Step 1.      Copyright (C) 2001 Texas Instruments Incorporated.
*                           All Rights Reserved
*------------------------------------------------------------------------------
* FILENAME...... csl_pll.h
* DATE CREATED.. 10/29/2001 
* LAST MODIFIED. 11/30/2001
*                11/30/2003 Modified PLL_init() sequence to fix the PLL 
*                           initialization problem
\******************************************************************************/

/******************************************************************************\
* Step 2. Private Macros - Include files - PLL_SUPPORT
\******************************************************************************/
#ifndef _CSL_PLL_H_
#define _CSL_PLL_H_

#include <csl_stdinc.h>
#include <csl_chip.h>
#include <csl_pllhal.h>

#if (PLL_SUPPORT)
/******************************************************************************\
* Step 3. scope and inline control macros  
\******************************************************************************/
#ifdef __cplusplus
#define CSLAPI extern "C" far 
#else
#define CSLAPI extern far
#endif

#undef  USEDEFS
#undef  IDECL
#undef  IDEF

#ifdef  _PLL_MOD_
  #define IDECL CSLAPI
  #define USEDEFS
  #define IDEF
#else
  #ifdef  _INLINE
    #define IDECL static inline
    #define USEDEFS
    #define IDEF  static inline
  #else
    #define IDECL CSLAPI
  #endif
#endif

/******************************************************************************\
* Step 4. global macro declarations
\******************************************************************************/
#define PLL_DIV0  0
#define PLL_DIV1  1
#define PLL_DIV2  2
#define PLL_DIV3  3


/*****************************************************************************\
* Step 5. global typedef declarations
* Example : Config structure 
* typedef struct {
*   Uint32 rg1;
*   Uint32 rg2;
*  } PLL_Config;
\******************************************************************************/
typedef struct{
    Uint32 pllcsr;
    Uint32 pllm;
    Uint32 plldiv0;
    Uint32 plldiv1;
    Uint32 plldiv2;
    Uint32 plldiv3;
    Uint32 oscdiv1;
}PLL_Config;
    
  
typedef struct {
   Uint32  mdiv;
   Uint32  d0ratio;
   Uint32  d1ratio;
   Uint32  d2ratio;
   Uint32  d3ratio;
   Uint32  od1ratio;
 }PLL_Init;	 

/******************************************************************************\
* Step 6. global variable declarations
\******************************************************************************/
/* private vars */
extern far Uint32 _PLL_divAddr[4];


/******************************************************************************\
* Step 7. global function declarations
\******************************************************************************/

/* Private functions (If applicable)*/

static void plldelay(Uint32 count);

/* API functions (Non-Inline function : Source file) */
CSLAPI void PLL_wait100();
CSLAPI Uint32 PLL_wait1();

/******************************************************************************\
* Step 8. inline function declarations ( IDECL keyword)
\******************************************************************************/
IDECL void PLL_config(PLL_Config *config);
IDECL void PLL_configArgs(Uint32 pllcsr, Uint32 pllm, Uint32 plldiv0, Uint32 plldiv1, Uint32 plldiv2, Uint32 plldiv3,Uint32 oscdiv1);
IDECL void PLL_getConfig(PLL_Config *config);

IDECL void PLL_init(PLL_Init *init);

IDECL void PLL_pwrdwn();
IDECL void PLL_operational();
IDECL void PLL_enable();
IDECL void PLL_bypass();
IDECL void PLL_reset();
IDECL void PLL_deassert();


IDECL Uint32 PLL_clkTest();

IDECL void PLL_enablePllDiv(Uint32 divId);
IDECL void PLL_disablePllDiv(Uint32 divId);

IDECL void PLL_enableOscDiv();
IDECL void PLL_disableOscDiv();

IDECL void PLL_setMultiplier(Uint32 val);
IDECL void PLL_setPllRatio(Uint32 divId,Uint32 val);
IDECL void PLL_setOscRatio(Uint32 val);

IDECL Uint32 PLL_getMultiplier();
IDECL Uint32 PLL_getPllRatio(Uint32 divnum);
IDECL Uint32 PLL_getOscRatio();

/******************************************************************************\
* Step 9. inline function definitions  ( #if USEDEF - IDEF keywords)
\******************************************************************************/

#ifdef USEDEFS
/*----------------------------------------------------------------------------*/
IDEF void PLL_pwrdwn(){       
      PLL_FSETS(PLLCSR,PLLEN,BYPASS); /* Bypass mode PLLEN = 0 */ 
      PLL_FSETS(PLLCSR,PLLPWRDN,YES); /* PwrDwn mode */

}
/*----------------------------------------------------------------------------*/
IDEF void PLL_operational(){       
      PLL_FSETS(PLLCSR,PLLPWRDN,NO);     /* Operational mode */
      PLL_FSETS(PLLDIV0,D0EN,ENABLE);    /* Enable D0 path   */
      PLL_FSETS(PLLCSR,PLLEN,ENABLE);    /* Enable PLLEN = 1 */ 
}
/*----------------------------------------------------------------------------*/
IDEF void PLL_enable(){
      PLL_FSETS(PLLCSR,PLLEN,ENABLE); /* Bypass mode PLLEN = 1 */ 
}
/*----------------------------------------------------------------------------*/
IDEF void PLL_bypass(){
     PLL_FSETS(PLLCSR,PLLEN,BYPASS); /* Bypass mode PLLEN = 0 */ 
}
/*----------------------------------------------------------------------------*/
IDEF Uint32 PLL_clkTest(){   
     return(PLL_FGET(PLLCSR,STABLE));  
}
/*----------------------------------------------------------------------------*/
IDEF void PLL_reset(){   
     PLL_FSETS(PLLCSR,PLLRST,1);     /* reset mode */
}
/*----------------------------------------------------------------------------*/
IDEF void PLL_deassert(){   
     PLL_FSETS(PLLCSR,PLLRST,0);    /* deassert PLL */ 
}
/*----------------------------------------------------------------------------*/
IDEF void PLL_enablePllDiv(Uint32 divId){
   (*(volatile Uint32*) _PLL_divAddr[divId]) |=(0x00008000u);
}
/*----------------------------------------------------------------------------*/
IDEF void PLL_disablePllDiv(Uint32 divId){
   (*(volatile Uint32*)  _PLL_divAddr[divId]) &=~(0x00008000u);
}
/*----------------------------------------------------------------------------*/
IDEF void PLL_enableOscDiv(){
    PLL_FSET(OSCDIV1,OD1EN,1);
}
/*----------------------------------------------------------------------------*/
IDEF void PLL_disableOscDiv(){
    PLL_FSET(OSCDIV1,OD1EN,0);
}
/*----------------------------------------------------------------------------*/
IDEF void PLL_setPllRatio(Uint32 divId, Uint32 val){
  Uint32  tmp= ((*(volatile Uint32*) _PLL_divAddr[divId])  & 0xFFFFFFE0u);
     (*(volatile Uint32*) _PLL_divAddr[divId]) =(val | tmp );
}
/*----------------------------------------------------------------------------*/
IDEF void PLL_setOscRatio(Uint32 val){
    PLL_FSET(OSCDIV1,RATIO,val);
}
/*----------------------------------------------------------------------------*/
IDEF void PLL_setMultiplier(Uint32 val){
    PLL_FSET(PLLM,PLLM,val);
}
/*----------------------------------------------------------------------------*/
IDEF Uint32 PLL_getPllRatio(Uint32 divId){
    return (Uint32)((*(volatile Uint32*) _PLL_divAddr[divId]) & 0x0000001Fu);
}
/*----------------------------------------------------------------------------*/
IDEF Uint32 PLL_getOscRatio(){
    return(PLL_FGET(OSCDIV1,RATIO));
}
/*----------------------------------------------------------------------------*/
IDEF Uint32 PLL_getMultiplier(){
    return(PLL_FGET(PLLM,PLLM));
}

/*----------------------------------------------------------------------------*/
IDEF void PLL_init(PLL_Init *init) {

  Uint32 gie ;
  gie = IRQ_globalDisable();

  PLL_FSETS(PLLCSR,PLLEN,BYPASS); /* Bypass mode PLLEN = 0 */ 

  plldelay(20);

  PLL_FSETS(PLLCSR,PLLRST,1);     /* reset mode */
  
  plldelay(20);

  // Set main multiplier/divisor 
  PLL_RSET(PLLM,init->mdiv);
  PLL_RSET(PLLDIV0, PLL_PLLDIV0_RMK(0,init->d0ratio));
  PLL_RSET(OSCDIV1,PLL_OSCDIV1_RMK(0,init->od1ratio));		  
  
  // Set DSP clock 
  PLL_RSET(PLLDIV1,PLL_PLLDIV1_RMK(0,init->d1ratio));
  
  // Set EMIF clock 
  PLL_RSET(PLLDIV3,PLL_PLLDIV3_RMK(0,init->d3ratio));

  plldelay(20);

  //   Take PLL out of reset
  PLL_FSETS(PLLCSR,PLLRST,0);
  plldelay(1500);

  // Enable PLL
  PLL_FSETS(PLLCSR,PLLEN,ENABLE);
  plldelay(20);
 
  IRQ_globalRestore(gie);
}
  

/*----------------------------------------------------------------------------*/
IDEF void PLL_config(PLL_Config *config) {
  Uint32 gie;
  volatile Uint32 *base;
  register Uint32 x0,x1,x2,x3,x4,x5,x6;
 
  gie = IRQ_globalDisable();

  x0 = config->pllcsr;
  x1 = config->pllm;
  x2 = config->plldiv0;
  x3 = config->plldiv1;
  x4 = config->plldiv2;
  x5 = config->plldiv3;
  x6 = config->oscdiv1;


  base = (volatile Uint32 *)(_PLL_BASE_ADDR);

  base[_PLL_PLLM_OFFSET] = x1;
  base[_PLL_PLLDIV0_OFFSET] = x2;
  base[_PLL_PLLDIV1_OFFSET] = x3;
  base[_PLL_PLLDIV2_OFFSET] = x4;
  base[_PLL_PLLDIV3_OFFSET] = x5;
  base[_PLL_OSCDIV1_OFFSET] = x6;
  base[_PLL_PLLCSR_OFFSET] = x0;

  IRQ_globalRestore(gie);
  
}

/*----------------------------------------------------------------------------*/
IDEF void PLL_configArgs(Uint32 pllcsr, Uint32 pllm, Uint32 plldiv0, Uint32 plldiv1, Uint32 plldiv2, Uint32 plldiv3,Uint32 oscdiv1){

  Uint32 gie;
  volatile Uint32 *base;
  gie = IRQ_globalDisable();

  base = (volatile Uint32 *)(_PLL_BASE_ADDR);

  base[_PLL_PLLM_OFFSET] = pllm;
  base[_PLL_PLLDIV0_OFFSET] = plldiv0;
  base[_PLL_PLLDIV1_OFFSET] = plldiv1;
  base[_PLL_PLLDIV2_OFFSET] = plldiv2;
  base[_PLL_PLLDIV3_OFFSET] = plldiv3;
  base[_PLL_OSCDIV1_OFFSET] = oscdiv1;
  base[_PLL_PLLCSR_OFFSET] = pllcsr;

  IRQ_globalRestore(gie);
}


/*----------------------------------------------------------------------------*/
IDEF void PLL_getConfig(PLL_Config *config) {
  Uint32 gie;
  volatile Uint32 *base;
  register Uint32 x0,x1,x2,x3,x4,x5,x6;
 
  gie = IRQ_globalDisable();

  base = (volatile Uint32 *)(_PLL_BASE_ADDR);
 
 x0 = base[_PLL_PLLCSR_OFFSET];
 x1 = base[_PLL_PLLM_OFFSET];
 x2 = base[_PLL_PLLDIV0_OFFSET];
 x3 = base[_PLL_PLLDIV1_OFFSET];
 x4 = base[_PLL_PLLDIV2_OFFSET];
 x5 = base[_PLL_PLLDIV3_OFFSET];
 x6 = base[_PLL_OSCDIV1_OFFSET];

  config->pllcsr = x0;
  config->pllm = x1;
  config->plldiv0 = x2;
  config->plldiv1 = x3;
  config->plldiv2 = x4;
  config->plldiv3 = x5;
  config->oscdiv1 = x6;

  IRQ_globalRestore(gie);
  
}



/*----------------------------------------------------------------------------*/
#endif /* USEDEFS */

/* Local software delay function */

static void plldelay(Uint32 count){
   Uint32 i = count;
   while(i--){
     asm(" NOP 1");
   }
}

/******************************************************************************\
* Step 10. #endif for PLL_SUPPORT and CSL_PLL_H Macro + Footer
\******************************************************************************/
#endif /* PLL_SUPPORT */
#endif /* _CSL_PLL_H_ */
/******************************************************************************\
* End of csl_module.h
\******************************************************************************/

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产真实乱偷精品视频免| 天天综合日日夜夜精品| 国产激情视频一区二区三区欧美 | 亚洲一区二区三区四区在线| 91激情五月电影| 性做久久久久久免费观看欧美| 欧美老女人第四色| 蜜臀99久久精品久久久久久软件| 精品久久人人做人人爰| 成人性色生活片免费看爆迷你毛片| 国产精品久久毛片a| 日本韩国精品一区二区在线观看| 午夜视频在线观看一区| 欧美成人video| 99精品视频在线免费观看| 亚洲一级片在线观看| 精品少妇一区二区三区视频免付费| 国产乱码精品1区2区3区| 亚洲欧美一区二区不卡| 91精品国产91热久久久做人人| 国内不卡的二区三区中文字幕 | 国产精品中文字幕日韩精品 | 午夜视频在线观看一区二区| 日韩精品中文字幕在线不卡尤物| 成人午夜免费电影| 亚洲第一久久影院| 国产亚洲欧美日韩在线一区| 在线观看精品一区| 国产一区二区在线免费观看| 亚洲精品成人在线| 国产亚洲一区字幕| 欧美精品一卡两卡| 972aa.com艺术欧美| 美女视频一区二区三区| 伊人夜夜躁av伊人久久| 精品国产乱码久久久久久浪潮 | 亚洲免费电影在线| 久久天堂av综合合色蜜桃网| 欧美无人高清视频在线观看| 高清av一区二区| 日韩 欧美一区二区三区| 亚洲日本在线观看| 久久综合色播五月| 欧美日韩精品久久久| 92精品国产成人观看免费| 狠狠色丁香九九婷婷综合五月| 亚洲综合免费观看高清完整版在线| 久久综合九色综合欧美98 | 91久久奴性调教| 国产精品综合在线视频| 日韩电影在线一区二区| 亚洲永久精品国产| 国产精品久久久久一区| 久久噜噜亚洲综合| 欧美一二三四在线| 91麻豆精品国产91久久久资源速度| 97se亚洲国产综合自在线不卡| 国产美女主播视频一区| 精品在线观看视频| 日日骚欧美日韩| 亚洲国产一区二区视频| 一区二区三区中文字幕电影| 中文字幕亚洲电影| 亚洲欧美一区二区视频| 国产精品国产馆在线真实露脸| 国产欧美一区二区精品性色超碰| 精品日韩欧美在线| 日韩欧美专区在线| 日韩亚洲欧美一区| 欧美一卡2卡3卡4卡| 91精品免费观看| 欧美丰满美乳xxx高潮www| 欧美日韩午夜影院| 欧美人成免费网站| 欧美精品xxxxbbbb| 欧美日韩亚洲丝袜制服| 欧美日韩高清一区二区不卡| 欧美另类久久久品| 欧美一区日本一区韩国一区| 欧美高清视频在线高清观看mv色露露十八| 日本道精品一区二区三区| 色美美综合视频| 欧美三级日韩三级| 欧美一级国产精品| 精品久久久久一区二区国产| 久久婷婷国产综合国色天香| 久久精品人人爽人人爽| 日本一区二区视频在线| 综合欧美一区二区三区| 亚洲一区成人在线| 奇米亚洲午夜久久精品| 精品系列免费在线观看| 国产成人精品免费看| 91小视频在线免费看| 欧美在线观看一二区| 日韩一区二区在线播放| 久久综合九色综合久久久精品综合| 国产欧美一区二区精品仙草咪| **欧美大码日韩| 五月综合激情日本mⅴ| 久久91精品国产91久久小草 | 91亚洲国产成人精品一区二区三| 色吊一区二区三区| 欧美一级高清大全免费观看| 国产视频一区不卡| 亚洲精品v日韩精品| 免费av网站大全久久| 成熟亚洲日本毛茸茸凸凹| 色噜噜狠狠成人中文综合| 5858s免费视频成人| 日本一区二区三区在线观看| 悠悠色在线精品| 久久99国产精品免费| 91蜜桃在线免费视频| 欧美一区二区久久| 国产精品初高中害羞小美女文| 午夜日韩在线观看| 国产激情视频一区二区在线观看 | 99久久伊人精品| 宅男在线国产精品| **网站欧美大片在线观看| 日韩激情视频网站| av亚洲精华国产精华精| 在线成人高清不卡| 国产精品久久久久永久免费观看 | 亚洲一二三四久久| 国产成人精品1024| 91精品国产色综合久久| 亚洲免费伊人电影| 国产乱人伦偷精品视频免下载| 在线观看欧美精品| 中文字幕不卡一区| 极品少妇一区二区| 欧美精品99久久久**| 亚洲精品免费在线播放| 国产一区二区主播在线| 91精品国产91久久综合桃花 | 亚洲欧洲日韩综合一区二区| 日本女优在线视频一区二区| 91免费国产在线| 欧美国产综合一区二区| 久久精品二区亚洲w码| 欧美日韩精品欧美日韩精品 | 久久精品99久久久| 精品视频免费看| 亚洲乱码国产乱码精品精的特点 | 91丨九色丨尤物| 国产三级久久久| 国产精品白丝av| 久久这里只精品最新地址| 日本vs亚洲vs韩国一区三区 | 色哟哟一区二区在线观看| 欧美激情在线看| 国产麻豆成人精品| 精品国产3级a| 狠狠色综合日日| 精品动漫一区二区三区在线观看| 视频在线观看一区| 在线综合视频播放| 日韩国产欧美视频| 日韩一区二区三区在线| 日韩激情视频网站| 日韩一区二区三区免费看| 日韩精品色哟哟| 日韩欧美一卡二卡| 日本vs亚洲vs韩国一区三区二区| 欧美精品一级二级| 免费av成人在线| 精品国产伦理网| 国产麻豆精品theporn| 欧美激情在线看| 99久精品国产| 一区二区视频在线| 欧美三级在线播放| 日韩激情视频在线观看| 日韩免费看的电影| 国产一区二区三区av电影| 亚洲国产成人在线| 色悠悠久久综合| 日日夜夜免费精品| 欧美精品一区二区久久婷婷| 韩国三级电影一区二区| 亚洲国产精品av| 色婷婷国产精品久久包臀| 天天爽夜夜爽夜夜爽精品视频| 欧美一区二区大片| 国产成人精品免费网站| 亚洲女同女同女同女同女同69| 欧美性大战久久| 美女视频黄a大片欧美| 久久久久久久久久久黄色| av网站免费线看精品| 亚洲电影中文字幕在线观看| 日韩一级完整毛片| 丰满少妇在线播放bd日韩电影| 亚洲精品欧美专区| 精品国产乱码久久久久久久| 不卡欧美aaaaa| 婷婷成人综合网| 国产精品久久久久影院亚瑟 |