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

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

?? bl_init.c

?? ARM Bootloader程序
?? C
字號:
/*****************************************************************************
*  Copyright Statement:
*  --------------------
*  This software is protected by Copyright and the information contained
*  herein is confidential. The software may not be copied and the information
*  contained herein may not be used or disclosed except with the written
*  permission of MediaTek Inc. (C) 2005
*
*  BY OPENING THIS FILE, BUYER HEREBY UNEQUIVOCALLY ACKNOWLEDGES AND AGREES
*  THAT THE SOFTWARE/FIRMWARE AND ITS DOCUMENTATIONS ("MEDIATEK SOFTWARE")
*  RECEIVED FROM MEDIATEK AND/OR ITS REPRESENTATIVES ARE PROVIDED TO BUYER ON
*  AN "AS-IS" BASIS ONLY. MEDIATEK EXPRESSLY DISCLAIMS ANY AND ALL WARRANTIES,
*  EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE IMPLIED WARRANTIES OF
*  MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR NONINFRINGEMENT.
*  NEITHER DOES MEDIATEK PROVIDE ANY WARRANTY WHATSOEVER WITH RESPECT TO THE
*  SOFTWARE OF ANY THIRD PARTY WHICH MAY BE USED BY, INCORPORATED IN, OR
*  SUPPLIED WITH THE MEDIATEK SOFTWARE, AND BUYER AGREES TO LOOK ONLY TO SUCH
*  THIRD PARTY FOR ANY WARRANTY CLAIM RELATING THERETO. MEDIATEK SHALL ALSO
*  NOT BE RESPONSIBLE FOR ANY MEDIATEK SOFTWARE RELEASES MADE TO BUYER'S
*  SPECIFICATION OR TO CONFORM TO A PARTICULAR STANDARD OR OPEN FORUM.
*
*  BUYER'S SOLE AND EXCLUSIVE REMEDY AND MEDIATEK'S ENTIRE AND CUMULATIVE
*  LIABILITY WITH RESPECT TO THE MEDIATEK SOFTWARE RELEASED HEREUNDER WILL BE,
*  AT MEDIATEK'S OPTION, TO REVISE OR REPLACE THE MEDIATEK SOFTWARE AT ISSUE,
*  OR REFUND ANY SOFTWARE LICENSE FEES OR SERVICE CHARGE PAID BY BUYER TO
*  MEDIATEK FOR SUCH MEDIATEK SOFTWARE AT ISSUE. 
*
*  THE TRANSACTION CONTEMPLATED HEREUNDER SHALL BE CONSTRUED IN ACCORDANCE
*  WITH THE LAWS OF THE STATE OF CALIFORNIA, USA, EXCLUDING ITS CONFLICT OF
*  LAWS PRINCIPLES.  ANY DISPUTES, CONTROVERSIES OR CLAIMS ARISING THEREOF AND
*  RELATED THERETO SHALL BE SETTLED BY ARBITRATION IN SAN FRANCISCO, CA, UNDER
*  THE RULES OF THE INTERNATIONAL CHAMBER OF COMMERCE (ICC).
*
*****************************************************************************/

/*****************************************************************************
 *
 * Filename:
 * ---------
 *   bl_Init.c
 *
 * Project:
 * --------
 *   NFB - Bootloader
 *
 * Description:
 * ------------
 *   This file defines the stack distribution, will be referenced in bootarm.s
 *
 * Author:
 * -------
 * -------
 *
 *============================================================================
 *             HISTORY
 * Below this line, this part is controlled by PVCS VM. DO NOT MODIFY!!
 *------------------------------------------------------------------------------
 * removed!
 * removed!
 * removed!
 *
 * removed!
 * removed!
 * removed!
 *
 * removed!
 * removed!
 * removed!
 *
 * removed!
 * removed!
 * removed!
 *
 * removed!
 * removed!
 * removed!
 *
 * removed!
 * removed!
 * removed!
 *
 * removed!
 * removed!
 * removed!
 *
 * removed!
 * removed!
 * removed!
 *
 * removed!
 * removed!
 * removed!
 *
 * removed!
 * removed!
 * removed!
 * removed!
 * removed!
 * removed!
 * removed!
 * removed!
 * removed!
 * removed!
 * removed!
 * removed!
 * removed!
 * removed!
 * removed!
 * removed!
 *------------------------------------------------------------------------------
 * Upper this line, this part is controlled by PVCS VM. DO NOT MODIFY!!
 *============================================================================
 ****************************************************************************/

#include <kal_release.h>
#include <bl_MTK_BB_REG.h>
#include <bl_init.h>

extern void NFIReconfigure(void);
extern void custom_setEMI(void);


/**********************************************************
Description : Setting MCU PLL.
Input       : None
Output      : None
***********************************************************/
static void PLL_Init(void)
{
#if ( defined(MT6228) || defined(MT6229) || defined(MT6230) )

	kal_uint16 i;

#ifdef EXT_26M
   // 1. Power on DSP_DIV2, MCU_DIV2, and CLKSQ
   *(volatile kal_uint16 *)0x80000320 = 0x9800;
   // 2. Enable MCU clock divider
   *(volatile kal_uint16 *)0x80000110 = 0x0008;
#elif defined (EXT_13M)
   // Power on CLKSQ
   *(volatile kal_uint16 *)0x80000320 = 0x0800;
#endif

   // 3. Boost MCU and DSP PLL (MDPLL) to 104MHz (MUST)
   *(volatile kal_uint16 *)0x80000100 = 0x0087;
   *(volatile kal_uint16 *)0x80000100 = 0x0007;

   // 4. Power ou MPLL
   *(volatile kal_uint16 *)0x80000320 = 0x4000;

   // 5. delay until PLL is stable, at least 50us
	for (i=0;i<0x100;i++);

   // 6. Define ARM(CPU, Data cache, TCM) and MCU PLL
#ifdef MCU_104M
   // MCU and BUS clock 2:1
   *(volatile kal_uint16 *)0x80000118 = 0x0703;
#elif defined MCU_52M
   // MCU and BUS clock 1:1
   *(volatile kal_uint16 *)0x80000118 = 0x0303;
#elif defined MCU_26M
   // MCU and BUS clock 1:1
   *(volatile kal_uint16 *)0x80000118 = 0x0101;
#elif defined MCU_13M
   // MCU and BUS clock 1:1
   *(volatile kal_uint16 *)0x80000118 = 0x0000;
#endif

   // 7. Enable MPLL output
   *(volatile kal_uint16 *)0x80000110 |= 0x0002;

#elif defined(MT6225)

	kal_uint16 i;

#ifdef EXT_26M
   // 1. Power on DSP_DIV2, MCU_DIV2, and CLKSQ
   *(volatile kal_uint16 *)0x80000320 = 0x9800;
   // 2. Enable MCU clock divider
   *(volatile kal_uint16 *)0x80000110 = 0x0002;
#elif defined (EXT_13M)
   // Power on CLKSQ
   *(volatile kal_uint16 *)0x80000320 = 0x0800;
#endif

   // 3. Boost MCU and DSP PLL (MDPLL) to 104MHz (MUST)
   *(volatile kal_uint16 *)0x80000100 = 0x0080;
   *(volatile kal_uint16 *)0x80000100 = 0x0000;
   
   // 4. Power ou MPLL
   *(volatile kal_uint16 *)0x80000320 = 0x2000;
   
   // 5. delay until PLL is stable, at least 50us
	for (i=0;i<0x100;i++);
   
   // 6. Define ARM(CPU, Data cache, TCM) and MCU PLL
#ifdef MCU_104M   
   // MCU and BUS clock 2:1
   *(volatile kal_uint16 *)0x80000118 = 0x0703;
#elif defined MCU_52M
   // MCU and BUS clock 1:1
   *(volatile kal_uint16 *)0x80000118 = 0x0303;
#elif defined MCU_26M
   // MCU and BUS clock 1:1
   *(volatile kal_uint16 *)0x80000118 = 0x0101;
#elif defined MCU_13M
   // MCU and BUS clock 1:1
   *(volatile kal_uint16 *)0x80000118 = 0x0000;   
#endif      

   // 7. Enable MPLL output
   *(volatile kal_uint16 *)0x80000100 |= 0x0010; 
   
#endif  /* MT6228 || MT6229 || MT6230 */
}

/**********************************************************
Description : Setting EMI according to MCU clock rate.
Input       : None
Output      : None
***********************************************************/
static void EMI_Setting(void)
{
   custom_setEMI();
}


/**********************************************************
Description : Restart watchdog counter.
Input       : None
Output      : None
***********************************************************/
void WacthDogRestart(void)
{
   *(volatile kal_uint32 *)(0x80040008) = 0x1971;
}

/**********************************************************
Description : Disable watchdog counter.
Input       : None
Output      : None
***********************************************************/
void WacthDogDisable(void)
{
   *(volatile kal_uint32 *)(0x80040000) = 0x2200;
}


/**********************************************************
Description : Wait for 32KHz clock srouce stable.
Input       : None
Output      : None
***********************************************************/
void WaitFor32KStable(void)
{
   kal_uint32 result;
   kal_uint16 result_low;
   kal_uint16 result_high;
   
   * (volatile kal_uint16 *) DRVPDN_CON2_CLR = DRVPDN_CON2_TDMA;
   
   DRV_WriteReg(SM_FMDURATION,0);
       
   while(1)
   {
      DRV_Reg(SM_CTRL) |= SM_CTRL_FM_START;
      
      while(!(DRV_Reg(SM_STAT) & SM_STAT_FM_RDY));
      
      result_low = DRV_Reg(SM_FM_RESULT_LOW);
      result_high = DRV_Reg(SM_FM_RESULT_HIGH) & SM_FM_RESULT_HIGH_MASK;
      result = (result_low | (result_high << 16));
      
      if ((result < 950) && (result > 650))
         break;   	
   }
   
   * (volatile kal_uint16 *) DRVPDN_CON2_SET = DRVPDN_CON2_TDMA;
}


/**********************************************************
Description : Initialization configuration
Input       : None
Output      : None
***********************************************************/
void INTConfig(void)
{
   WacthDogRestart();

   PLL_Init();
   
   EMI_Setting();   
}

#ifdef __CHIP_VERSION_CHECK__
extern void PutUARTByte(kal_uint8 data);
#define HW_VER    ((kal_uint16 *)(CONFIG_base+0x0000)) /* Hardware ver register */
#define HW_CODE   ((kal_uint16 *)(CONFIG_base+0x0008)) /* Hardware ver register */

/**********************************************************
Description : HW ID check with software load version
Input       : None
Output      : None
***********************************************************/
void INT_Version_Check(void)
{
   volatile register kal_uint16 HwCode;
   register kal_uint8 HExtra = ' ';
   register kal_uint16 BuildCode;
   register kal_int32 i;
   
   HwCode = *HW_CODE;
   BuildCode = *HW_VER;
   
   // MT6217AT/AN
   if ((HwCode == 0x6218) && (BuildCode == 0x8B03))
   {
      HwCode = 0x6217;
   }
   // MT6223P
   else if ((HwCode == 0x6223) && (*((volatile kal_uint16 *)(CONFIG_base+0xf010)) & 0x8000))
   {
      HExtra = 'P';
   }
   // MT6226M
   else if ((HwCode == 0x6219) && ((BuildCode & 0xFF00) == 0x8B00))
   {
      HwCode = 0x6226;
      HExtra = 'M';
   }
   // MT6226D
   else if ((HwCode == 0x6226) && ((BuildCode & 0xFF00) == 0x8D00))
   {
      HExtra = 'D';
   }
   // MT6227D
   else if ((HwCode == 0x6227) && ((BuildCode & 0xFF00) == 0x8D00))
   {
      HExtra = 'D';
   }

#if defined(MT6205B)
   BuildCode = 0x6205;
#elif defined(MT6217)
   BuildCode = 0x6217;
#elif defined(MT6219)
   BuildCode = 0x6219;
#elif defined(MT6223)
   BuildCode = 0x6223;
#elif defined (MT6223P)
   BuildCode = 0x6223;
   #define	ExtraVer 'P'
#elif defined(MT6225)
   BuildCode = 0x6225;
#elif defined(MT6226)
   BuildCode = 0x6226;
#elif defined(MT6226D)
   BuildCode = 0x6226;
   #define	ExtraVer 'D'
#elif defined(MT6226M)
   BuildCode = 0x6226;
   #define	ExtraVer 'M'
#elif defined(MT6227)
   BuildCode = 0x6227;
#elif defined(MT6227D)
   BuildCode = 0x6227;
   #define	ExtraVer 'D'
#elif defined(MT6228)
   BuildCode = 0x6228;
#elif defined(MT6229)
   BuildCode = 0x6229;
#elif defined(MT6230)
   BuildCode = 0x6230;
#else
   BuildCode = 0;
#endif

#ifndef ExtraVer
   #define	ExtraVer ' '
#endif

   if ((HwCode != BuildCode) || (HExtra != ExtraVer))
   {
      PutUARTByte('@');
      while(1)
      {
         PutUARTByte(' ');
         PutUARTByte('H');
         PutUARTByte('W');
         PutUARTByte('=');
         PutUARTByte('M');
         PutUARTByte('T');
         for(i = 12; i >= 0; i -= 4)
         {
            PutUARTByte('0' + ((HwCode >> i) & 0x0F));
         }
         PutUARTByte(HExtra);
         PutUARTByte(',');
         PutUARTByte(' ');
         PutUARTByte('S');
         PutUARTByte('W');
         PutUARTByte('=');
         PutUARTByte('M');
         PutUARTByte('T');
         for(i = 12; i >= 0; i -= 4)
         {
            PutUARTByte('0' + ((BuildCode >> i) & 0x0F));
         }
         PutUARTByte(ExtraVer);
         PutUARTByte(' ');
         PutUARTByte('\r');
         PutUARTByte('\n');
         
         for(i = 0xFFFFF; i > 0; i--) ;
         PutUARTByte('#');
      }
   }
}
#endif /* __CHIP_VERSION_CHECK__ */

/**********************************************************
Description : Start GPT Timer 3
Input       : None
Output      : None
***********************************************************/
void startGPTTImer3(void)
{
   *(volatile kal_uint32 *)(0x8010001c) = 0;
   *(volatile kal_uint32 *)(0x80100024) = 0x07;
   *(volatile kal_uint32 *)(0x8010001c) = 1;

   return;
}


/**********************************************************
Description : Stop GPT Timer 3 and get the counter
Input       : None
Output      : 16bits counter duration
***********************************************************/
kal_uint16 stopGPTTImer3(void)
{
   kal_uint16 duration;
   
   duration = *(volatile kal_uint32 *)(0x80100020);
   *(volatile kal_uint32 *)(0x8010001c) = 0;
   
   return duration;
}


/**********************************************************
Description : Device initialization according to definition.
Input       : None
Output      : None
***********************************************************/
void DriverInit(void)
{
   kal_uint16  delay;

   for (delay=0; delay<0xffff; delay++);

   WacthDogRestart();
   
   WaitFor32KStable();
   
   WacthDogRestart();

   uart_init();

   NFIReconfigure();
   
   // Disable power-down control of DMA
   *(volatile kal_uint32 *)(0x80000320) = 0x01;
}




?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美久久久久久久久久| 91国产免费看| 亚洲欧洲日韩女同| 欧美电视剧在线看免费| 99国产精品久久久久| 一区二区免费视频| 欧美一级夜夜爽| 在线精品国精品国产尤物884a| 蜜桃视频在线观看一区| 日本在线观看不卡视频| 青娱乐精品视频| 免费成人av在线| 成人动漫一区二区| 欧美日韩免费高清一区色橹橹 | 精品日韩99亚洲| 欧美激情一二三区| 亚洲主播在线观看| 精品亚洲免费视频| 在线一区二区观看| 精品日本一线二线三线不卡| 中文字幕一区二区三区av| 亚洲高清免费视频| 国产毛片精品一区| 精品区一区二区| 欧美国产精品一区二区三区| 亚洲精品欧美专区| 国产在线精品免费av| 91网上在线视频| 国产午夜精品久久| 国产美女娇喘av呻吟久久| 7777精品伊人久久久大香线蕉| 国产精品美女久久久久久久久 | 亚洲3atv精品一区二区三区| 成人一区二区在线观看| 欧美精品一区二区三区四区| 亚洲国产精品欧美一二99| 成人午夜在线视频| 亚洲精品一区二区三区蜜桃下载| 一个色妞综合视频在线观看| 国产精品综合久久| 日韩欧美一级精品久久| 一个色综合av| 91蜜桃传媒精品久久久一区二区| 国产午夜精品一区二区三区视频| 精品综合免费视频观看| 欧美电视剧在线观看完整版| 免费观看一级特黄欧美大片| 欧美二区在线观看| 精彩视频一区二区三区| 欧美电影免费观看高清完整版在| 蜜桃一区二区三区在线观看| 538prom精品视频线放| 午夜久久久久久电影| 欧美日韩国产精品自在自线| 午夜私人影院久久久久| 欧美日本免费一区二区三区| 狠狠v欧美v日韩v亚洲ⅴ| 91精品在线观看入口| 日韩电影免费一区| 欧美一级高清片在线观看| 亚洲最大成人网4388xx| 欧美日本不卡视频| 久久99精品久久久久久国产越南| 欧美tickling网站挠脚心| 国产九色sp调教91| 亚洲一区二区在线免费观看视频| av在线不卡观看免费观看| 亚洲国产视频网站| 亚洲精品在线免费观看视频| av电影天堂一区二区在线观看| 亚洲精品免费在线观看| 日韩欧美一二三四区| 成人avav在线| 午夜精彩视频在线观看不卡| 欧美精品在线观看播放| 国产一区福利在线| 亚洲va欧美va人人爽| 中文字幕一区av| 欧美一区二区三区视频在线观看 | 激情图区综合网| 91精品国产综合久久精品麻豆 | 久久久.com| 欧美日韩国产一区二区三区地区| 国产一区二区精品久久91| 亚洲国产乱码最新视频 | 日韩欧美的一区| 久久99精品久久久| 日韩一区二区三区视频| 极品少妇xxxx精品少妇| 国产精品女上位| 日韩一区二区中文字幕| 国产高清不卡二三区| 中文字幕中文字幕在线一区| 在线这里只有精品| 国产成人精品影视| 国产精品家庭影院| 欧美日韩精品欧美日韩精品| 日本不卡在线视频| 欧美韩日一区二区三区| 一本到高清视频免费精品| 日韩**一区毛片| 久久精品欧美一区二区三区麻豆| 99久久伊人网影院| 久久99精品久久久久久动态图| 1区2区3区欧美| 日韩久久精品一区| 777午夜精品免费视频| 91在线观看污| 九一久久久久久| 五月天精品一区二区三区| 欧美国产欧美亚州国产日韩mv天天看完整| 97久久超碰精品国产| 久久国产精品无码网站| 亚洲电影中文字幕在线观看| 久久蜜桃av一区精品变态类天堂 | 国产原创一区二区三区| 亚洲蜜臀av乱码久久精品蜜桃| 久久毛片高清国产| 日韩女优视频免费观看| 欧美人体做爰大胆视频| 99re成人精品视频| 99久久精品99国产精品| 国产69精品久久99不卡| 蜜乳av一区二区| 蜜乳av一区二区三区| 天天爽夜夜爽夜夜爽精品视频| 亚洲日本电影在线| 悠悠色在线精品| 亚洲国产人成综合网站| 亚洲成av人**亚洲成av**| 午夜精品久久一牛影视| 亚洲福利一区二区三区| 亚洲成人福利片| 美女在线视频一区| 蜜桃视频一区二区| 国产精品一区二区在线观看不卡 | 成人av第一页| 色综合色综合色综合| 91视频www| 欧美一区二区视频在线观看2022| 日韩欧美亚洲国产另类 | 97国产一区二区| 日本道免费精品一区二区三区| 欧美日韩另类国产亚洲欧美一级| 精品视频一区二区三区免费| 精品毛片乱码1区2区3区| 国产午夜精品一区二区三区嫩草| 久久久久国产精品免费免费搜索| 国产精品毛片大码女人| 亚洲线精品一区二区三区八戒| 亚洲大片在线观看| 成人av在线网| 日韩欧美一区电影| 亚洲免费观看视频| 国模冰冰炮一区二区| av日韩在线网站| 日韩一卡二卡三卡国产欧美| 中文字幕免费观看一区| 日韩电影在线一区二区| 波多野结衣亚洲| 日韩欧美中文字幕公布| 国产精品三级视频| 午夜精品123| 色综合久久综合网欧美综合网| 日韩免费在线观看| 日韩国产高清在线| 欧美性受极品xxxx喷水| 国产精品传媒在线| 本田岬高潮一区二区三区| 久久蜜桃av一区二区天堂 | 亚洲欧美另类久久久精品2019| 国产一区免费电影| 精品av久久707| 老司机精品视频导航| 色婷婷香蕉在线一区二区| 中文字幕+乱码+中文字幕一区| 美女精品一区二区| 大陆成人av片| 欧美精品一区二区久久久| 视频一区在线播放| 欧美一级二级三级乱码| 亚洲激情在线激情| 91成人看片片| 日韩电影免费在线看| 日韩欧美成人一区| 国产成人a级片| 国产精品国产三级国产普通话99 | 亚洲国产一二三| 日韩欧美中文字幕公布| 国产精品一品视频| 综合色天天鬼久久鬼色| 91蝌蚪国产九色| 亚洲成av人影院| 欧美精品一区二区在线观看| 国产一区二区三区四区在线观看| 亚洲午夜一区二区| 91精品国产综合久久精品app| 亚洲国产婷婷综合在线精品| 色婷婷一区二区三区四区| 一区二区三区 在线观看视频|