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

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

?? dsp280x_sysctrl.c

?? 基于TMS320F2812的數字電源的c源程序2
?? C
字號:
// TI File $Revision: /main/6 $
// Checkin $Date: August 2, 2006   16:58:31 $
//###########################################################################
//
// FILE:   DSP280x_SysCtrl.c
//
// TITLE:  DSP280x Device System Control Initialization & Support Functions.
//
// DESCRIPTION:
//
//         Example initialization of system resources.
//
//###########################################################################
// $TI Release: DSP280x, DSP2801x Header Files V1.41 $
// $Release Date: August 7th, 2006 $
//###########################################################################


#include "DSP280x_Device.h"     // Headerfile Include File
#include "DSP280x_Examples.h"   // Examples Include File

// Functions that will be run from RAM need to be assigned to 
// a different section.  This section will then be mapped to a load and 
// run address using the linker cmd file.

#pragma CODE_SECTION(InitFlash, "ramfuncs");

//---------------------------------------------------------------------------
// InitSysCtrl: 
//---------------------------------------------------------------------------
// This function initializes the System Control registers to a known state.
// - Disables the watchdog
// - Set the PLLCR for proper SYSCLKOUT frequency 
// - Set the pre-scaler for the high and low frequency peripheral clocks
// - Enable the clocks to the peripherals

void InitSysCtrl(void)
{

   // Disable the watchdog        
   DisableDog();
   
   // Initialize the PLL control: PLLCR and CLKINDIV
   // DSP28_PLLCR and DSP28_CLKINDIV are defined in DSP280x_Examples.h
   InitPll(DSP28_PLLCR,DSP28_CLKINDIV);

   // Initialize the peripheral clocks
   InitPeripheralClocks();
}


//---------------------------------------------------------------------------
// Example: InitFlash: 
//---------------------------------------------------------------------------
// This function initializes the Flash Control registers

//                   CAUTION 
// This function MUST be executed out of RAM. Executing it
// out of OTP/Flash will yield unpredictable results

void InitFlash(void)
{
   EALLOW;
   //Enable Flash Pipeline mode to improve performance
   //of code executed from Flash.
   FlashRegs.FOPT.bit.ENPIPE = 1;
   
   //                CAUTION
   //Minimum waitstates required for the flash operating
   //at a given CPU rate must be characterized by TI. 
   //Refer to the datasheet for the latest information.  

   //Set the Paged Waitstate for the Flash
   FlashRegs.FBANKWAIT.bit.PAGEWAIT = 3;

   //Set the Random Waitstate for the Flash
   FlashRegs.FBANKWAIT.bit.RANDWAIT = 3;
   
   //Set the Waitstate for the OTP
   FlashRegs.FOTPWAIT.bit.OTPWAIT = 5;
   
   //                CAUTION
   //ONLY THE DEFAULT VALUE FOR THESE 2 REGISTERS SHOULD BE USED
   FlashRegs.FSTDBYWAIT.bit.STDBYWAIT = 0x01FF;       
   FlashRegs.FACTIVEWAIT.bit.ACTIVEWAIT = 0x01FF;   
   EDIS;

   //Force a pipeline flush to ensure that the write to 
   //the last register configured occurs before returning.  

   asm(" RPT #7 || NOP");
}	


//---------------------------------------------------------------------------
// Example: ServiceDog: 
//---------------------------------------------------------------------------
// This function resets the watchdog timer.
// Enable this function for using ServiceDog in the application 

void ServiceDog(void)
{
    EALLOW;
    SysCtrlRegs.WDKEY = 0x0055;
    SysCtrlRegs.WDKEY = 0x00AA;
    EDIS;
}

//---------------------------------------------------------------------------
// Example: DisableDog: 
//---------------------------------------------------------------------------
// This function disables the watchdog timer.

void DisableDog(void)
{
    EALLOW;
    SysCtrlRegs.WDCR= 0x0068;
    EDIS;
}

//---------------------------------------------------------------------------
// Example: InitPll: 
//---------------------------------------------------------------------------
// This function initializes the PLLCR register.

void InitPll(Uint16 val, Uint16 clkindiv)
{
   volatile Uint16 iVol;   

   // Make sure the PLL is not running in limp mode
   if (SysCtrlRegs.PLLSTS.bit.MCLKSTS != 0)
   {
      // Missing external clock has been detected
      // Replace this line with a call to an appropriate
      // SystemShutdown(); function. 
      asm("        ESTOP0");
   }

   // CLKINDIV MUST be 0 before PLLCR can be changed from
   // 0x0000. It is set to 0 by an external reset XRSn
   if (SysCtrlRegs.PLLSTS.bit.CLKINDIV != 0)
   {
       SysCtrlRegs.PLLSTS.bit.CLKINDIV = 0;
   }
   
   // Change the PLLCR
   if (SysCtrlRegs.PLLCR.bit.DIV != val)
   {
       
      EALLOW;
      // Before setting PLLCR turn off missing clock detect logic
      SysCtrlRegs.PLLSTS.bit.MCLKOFF = 1;
      SysCtrlRegs.PLLCR.bit.DIV = val;
      EDIS;
   
      // Optional: Wait for PLL to lock.
      // During this time the CPU will switch to OSCCLK/2 until
      // the PLL is stable.  Once the PLL is stable the CPU will 
      // switch to the new PLL value. 
      //
      // This time-to-lock is monitored by a PLL lock counter.   
      //   
      // Code is not required to sit and wait for the PLL to lock.   
      // However, if the code does anything that is timing critical, 
      // and requires the correct clock be locked, then it is best to 
      // wait until this switching has completed.  
  
      // Wait for the PLL lock bit to be set.  
      // Note this bit is not available on 281x devices.  For those devices
      // use a software loop to perform the required count. 

      // The watchdog should be disabled before this loop, or fed within 
      // the loop via ServiceDog().   
      
	  // Uncomment to disable the watchdog
      DisableDog();
   
      while(SysCtrlRegs.PLLSTS.bit.PLLLOCKS != 1) 
      {
	      // Uncomment to service the watchdog
          // ServiceDog();
      }

      EALLOW;
      SysCtrlRegs.PLLSTS.bit.MCLKOFF = 0;
      SysCtrlRegs.PLLSTS.bit.CLKINDIV != clkindiv;      
      EDIS;   
    }
}

//--------------------------------------------------------------------------
// Example: InitPeripheralClocks: 
//---------------------------------------------------------------------------
// This function initializes the clocks to the peripheral modules.
// First the high and low clock prescalers are set
// Second the clocks are enabled to each peripheral.
// To reduce power, leave clocks to unused peripherals disabled
//
// Note: If a peripherals clock is not enabled then you cannot 
// read or write to the registers for that peripheral 

void InitPeripheralClocks(void)
{
   EALLOW;

// HISPCP/LOSPCP prescale register settings, normally it will be set to default values
   SysCtrlRegs.HISPCP.all = 0x0001;
   SysCtrlRegs.LOSPCP.all = 0x0004;

// XCLKOUT to SYSCLKOUT ratio.  By default XCLKOUT = 1/4 SYSCLKOUT
   SysCtrlRegs.XCLK.bit.XCLKOUTDIV=2;
      	
// Peripheral clock enables set for the selected peripherals.   
// If you are not using a peripheral leave the clock off
// to save on power. 
// 
// Note: not all peripherals are available on all 280x derivates.
// Refer to the datasheet for your particular device. 
//
// This function is not written to be an example of efficient code.

   SysCtrlRegs.PCLKCR0.bit.ADCENCLK = 1;    // ADC
   SysCtrlRegs.PCLKCR0.bit.I2CAENCLK = 0;   // I2C
   SysCtrlRegs.PCLKCR1.bit.ECAP1ENCLK = 0;  // eCAP1
   SysCtrlRegs.PCLKCR1.bit.ECAP2ENCLK = 0;  // eCAP2
   SysCtrlRegs.PCLKCR1.bit.EPWM1ENCLK = 1;  // ePWM1
   SysCtrlRegs.PCLKCR1.bit.EPWM2ENCLK = 1;  // ePWM2
   SysCtrlRegs.PCLKCR1.bit.EPWM3ENCLK = 0;  // ePWM3
   SysCtrlRegs.PCLKCR0.bit.SCIAENCLK = 1;   // SCI-A
   SysCtrlRegs.PCLKCR0.bit.SPIAENCLK = 0;   // SPI-A

   if(DevEmuRegs.PARTID.bit.PARTNO != PARTNO_28015 &&
      DevEmuRegs.PARTID.bit.PARTNO != PARTNO_28016)
   {
      SysCtrlRegs.PCLKCR1.bit.EQEP1ENCLK = 0;  // eQEP1
      SysCtrlRegs.PCLKCR0.bit.SPIBENCLK = 0;   // SPI-B     
   }

   if(DevEmuRegs.PARTID.bit.PARTNO != PARTNO_2801 &&
      DevEmuRegs.PARTID.bit.PARTNO != PARTNO_2802)
   {
	   SysCtrlRegs.PCLKCR1.bit.EPWM4ENCLK = 0;  // ePWM4
   }
    
   if(DevEmuRegs.PARTID.bit.PARTNO != PARTNO_28015)
   {
      SysCtrlRegs.PCLKCR0.bit.ECANAENCLK=0;    // eCAN-A  
   }
   
   if(DevEmuRegs.PARTID.bit.PARTNO == PARTNO_2809 || 
      DevEmuRegs.PARTID.bit.PARTNO == PARTNO_2808 ||
      DevEmuRegs.PARTID.bit.PARTNO == PARTNO_2806 )
   {
	   SysCtrlRegs.PCLKCR1.bit.ECAP3ENCLK = 0;  // eCAP3
	   SysCtrlRegs.PCLKCR1.bit.ECAP4ENCLK = 0;  // eCAP4
	   SysCtrlRegs.PCLKCR1.bit.EPWM5ENCLK = 0;  // ePWM5
	   SysCtrlRegs.PCLKCR1.bit.EPWM6ENCLK = 0;  // ePWM6
	   SysCtrlRegs.PCLKCR0.bit.SCIBENCLK = 0;   // SCI-B
	   SysCtrlRegs.PCLKCR0.bit.SPICENCLK = 0;   // SPI-C
	   SysCtrlRegs.PCLKCR0.bit.SPIDENCLK = 0;   // SPI-D
	   SysCtrlRegs.PCLKCR1.bit.EQEP2ENCLK = 0;  // eQEP2
 
   }
   if(DevEmuRegs.PARTID.bit.PARTNO == PARTNO_2808 ||
      DevEmuRegs.PARTID.bit.PARTNO == PARTNO_2809)
   {  
	   SysCtrlRegs.PCLKCR0.bit.ECANBENCLK=0;    // eCAN-B
   }

   SysCtrlRegs.PCLKCR0.bit.TBCLKSYNC = 1;       // Enable TBCLK within the ePWM  
                           
   EDIS;
}

	
//===========================================================================
// End of file.
//===========================================================================

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩精品电影| 精品乱码亚洲一区二区不卡| 337p亚洲精品色噜噜| 欧美国产日本韩| 日日嗨av一区二区三区四区| www.日韩大片| 久久久久久99精品| 日本不卡视频在线观看| 欧美伊人久久久久久午夜久久久久| 欧美成人国产一区二区| 亚洲国产精品一区二区www在线| 福利电影一区二区| 精品日韩成人av| 日韩国产成人精品| 欧洲精品中文字幕| 亚洲色图色小说| 成人午夜短视频| 久久夜色精品国产噜噜av| 日韩成人一级片| 88在线观看91蜜桃国自产| 亚洲自拍偷拍综合| 色菇凉天天综合网| 中文字幕一区二区三区色视频| 国产福利精品导航| 国产无一区二区| 国产成a人亚洲精品| 精品国产乱码久久久久久浪潮| 日本成人超碰在线观看| 欧美日韩视频在线一区二区| 亚洲午夜电影在线观看| 欧美亚洲禁片免费| 午夜精品久久久久久久| 欧美军同video69gay| 日韩专区一卡二卡| 日韩视频永久免费| 国内国产精品久久| 国产亲近乱来精品视频| 成人动漫一区二区在线| 综合激情成人伊人| 在线一区二区三区四区五区| 亚洲第一综合色| 欧美区在线观看| 麻豆中文一区二区| 久久久久久久久久久99999| 成人免费视频网站在线观看| 中文字幕综合网| 欧美在线观看视频一区二区三区| 亚洲成av人**亚洲成av**| 欧美一区永久视频免费观看| 国内不卡的二区三区中文字幕| 国产欧美精品一区| 色婷婷综合久久久久中文| 天天免费综合色| 久久婷婷久久一区二区三区| 成人免费不卡视频| 亚洲国产成人91porn| 欧美sm极限捆绑bd| 不卡免费追剧大全电视剧网站| 亚洲已满18点击进入久久| 日韩无一区二区| 北岛玲一区二区三区四区| 亚洲国产综合在线| 久久综合久久综合亚洲| 91视频免费观看| 久久成人久久鬼色| 亚洲免费观看高清| 日韩女优毛片在线| 成人av免费观看| 日本va欧美va欧美va精品| 成人免费在线观看入口| 制服.丝袜.亚洲.中文.综合| 国产69精品久久久久777| 亚洲午夜一区二区三区| 久久久精品免费免费| 欧美日韩在线播放三区四区| 国产一区二区美女诱惑| 一区二区三区高清| 国产欧美一区二区精品性色超碰| 欧美综合天天夜夜久久| 国产成人午夜精品影院观看视频| 洋洋av久久久久久久一区| 久久久精品国产免大香伊| 欧美日韩国产不卡| av一本久道久久综合久久鬼色| 麻豆国产欧美日韩综合精品二区| 中文字幕色av一区二区三区| 精品国产一二三区| 在线播放中文字幕一区| 91免费看`日韩一区二区| 国产一区不卡在线| 日本免费在线视频不卡一不卡二 | 国产一区二区0| 日韩国产欧美在线视频| 亚洲黄色av一区| 欧美极品另类videosde| 精品欧美乱码久久久久久1区2区| 欧美少妇xxx| 91成人看片片| 91久久一区二区| 亚洲欧美偷拍另类a∨色屁股| 午夜久久久影院| 国产精品久久二区二区| 精品日韩一区二区| 精品日韩成人av| 欧美一区二区二区| 欧美日韩在线综合| 欧美午夜精品理论片a级按摩| 91在线观看污| 91亚洲精华国产精华精华液| 国产91清纯白嫩初高中在线观看| 国产精品一区二区在线观看网站| 美女在线一区二区| 久久精品免费观看| 久久www免费人成看片高清| 美女mm1313爽爽久久久蜜臀| 欧美aⅴ一区二区三区视频| 日韩二区三区四区| 蜜桃视频一区二区| 狠狠狠色丁香婷婷综合激情 | 天天综合天天综合色| 午夜欧美电影在线观看| 日韩电影在线免费观看| 日本不卡一区二区三区| 激情欧美一区二区| 国产福利视频一区二区三区| 99久久久精品免费观看国产蜜| 99国产精品久久久久久久久久| 久久精品一二三| 国产精品美日韩| 亚洲综合在线电影| 日本女优在线视频一区二区| 国内精品在线播放| 91在线porny国产在线看| 在线欧美小视频| 日韩视频一区二区三区在线播放 | 久久精品99国产国产精| 激情都市一区二区| 成人黄色电影在线| 欧美影片第一页| 日韩免费观看2025年上映的电影| 国产亚洲欧美中文| 亚洲精品高清视频在线观看| 蜜臀av性久久久久蜜臀aⅴ流畅| 国产电影精品久久禁18| 99天天综合性| 欧美一区二区视频在线观看2022| 精品国产凹凸成av人网站| 中文字幕在线一区| 丝袜美腿成人在线| 成人免费观看男女羞羞视频| 欧美视频一区二区三区| 精品播放一区二区| 亚洲欧美日韩在线| 麻豆国产精品视频| 一本大道av伊人久久综合| 日韩一区二区三区视频| 国产精品麻豆视频| 蜜臀av性久久久久蜜臀aⅴ| 成人福利在线看| 91精品国产综合久久香蕉的特点| 国产精品视频麻豆| 男人的天堂亚洲一区| 91传媒视频在线播放| 中文字幕欧美区| 国产一区在线观看视频| 欧美群妇大交群中文字幕| 欧美国产精品专区| 久久97超碰色| 欧美日韩不卡一区二区| 亚洲视频免费在线| 国产一区二区免费在线| 日韩一卡二卡三卡国产欧美| 亚洲女同ⅹxx女同tv| 国产91精品入口| 久久综合色播五月| 日本美女一区二区三区视频| 日本高清不卡aⅴ免费网站| 欧美激情一区二区三区不卡 | 亚洲一区二区三区四区五区黄| 国产福利一区二区三区在线视频| 在线观看亚洲一区| 国产激情视频一区二区三区欧美 | 日韩精品一区二区三区蜜臀| 亚洲综合精品自拍| 波多野洁衣一区| 国产欧美日韩精品一区| 精品午夜一区二区三区在线观看| 69堂亚洲精品首页| 亚洲午夜电影在线| 色国产精品一区在线观看| 国产精品久久久久aaaa| 懂色av一区二区三区免费观看| 精品国产一二三| 国产一区二区精品久久| 久久综合色之久久综合| 国产福利一区二区三区在线视频| 久久久精品国产免大香伊| 国产成人h网站| 中文字幕av在线一区二区三区| 成熟亚洲日本毛茸茸凸凹|