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

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

?? 2440loader-8bit.c

?? 這個是在ADS下燒寫K9F1208的工程
?? C
字號:
/************************************************
 * NAME    : 2440loader.c
 * DESC    : 
 * History : 2002.02.25 ver 0.0
 * rev0.1  : 2003. 05.xx modified for 2440
 * rev0.2  : 2004. 02.xx modified for 2440A(xtal 16.9344MHz)
************************************************/

#include <stdlib.h>
#include <string.h>
#include "def.h"
#include "option.h"
#include "2440addr.h"
#include "2440slib.h"
#include "Nand.h"
#include "2440lib.h"//by xh
#include "sdramtest.h"
#include "k9s1208.h"
//#include "mmu.h"

// Downfile Size, OS Start Address Offset, Core voltage, download address setting
#if 1
#ifdef DOWNFILE_SIZE
#define OS_IMAGE_BLOCK_SIZE ( ((DOWNFILE_SIZE/512)/32) +1 )
#else 
//#define OS_IMAGE_BLOCK_SIZE (0x7b0)	// blocks
#define OS_IMAGE_BLOCK_SIZE (0x10)	// blocks//by xh
//#define OS_IMAGE_BLOCK_SIZE (0x800)	// blocks
//#define OS_IMAGE_BLOCK_SIZE (700)	// blocks
#endif

#ifndef OS_START_ADDR_OFFSET
#define	OS_START_ADDR_OFFSET (0x00200000)		// 0x3020_0000
#endif
//PPC2003 offset	(0x02040000)
//WINCE	offset		(0x00040000)
//Firmware offset	(0x00000000)


#ifndef	COREVOLT_M100
#define	COREVOLT_M100	(120)	// value = voltage(0.8V ~ 1.3V)x100. -> 100->1.0V
#endif

#define DOWNLOAD_ADDRESS (_RAM_STARTADDRESS+OS_START_ADDR_OFFSET)

#else
#define OS_IMAGE_BLOCK_SIZE (0x7b0)	// blocks
#define	OS_START_ADDR_OFFSET (0x02040000)		// 0x3204_0000
#define	COREVOLT_M100	(135)	// value = voltage(0.8V ~ 1.3V)x100. -> 100->1.0V
#define DOWNLOAD_ADDRESS (_RAM_STARTADDRESS+OS_START_ADDR_OFFSET)
#endif

void (*run)(void)=(void (*)(void))(DOWNLOAD_ADDRESS);

void Port_Init(void);
void Led_Display(int);
void Delay(int);

volatile unsigned char *downPt;

void Timer4_Start(void);
void Timer4_Stop(void);
char *hex2char(int val);

void Set_Pre(void);	// for current test


void Main(void)
{
    register page, block, blockcopy_count;
    int i, j;

    MMU_EnableICache();
	
//   	ChangeClockDivider(12,12);	// 1:2:4
//  	ChangeClockDivider(13,12);	// 1:3:6
// 	ChangeClockDivider(14,12);	// 1:4:8
//	ChangeMPllValue(88, 1, 1);	// FCLK=192MHz
//	ChangeMPllValue(246, 13, 0); 	// FCLK=203.2MHz
//	ChangeMPllValue(92, 1, 0); 	// FCLK=400MHz
//	ChangeMPllValue(214, 3, 0);	// FCLK=532MHz


    	Port_Init();

    	Uart_Init(PCLK, 115200);
    	//Uart_Select(1);
    	Uart_Select(0);// by xh
	
    	downPt=(unsigned char *)DOWNLOAD_ADDRESS;

 	// GPA    22         21         20     19      18    17
	//         nFCE   nRSTOUT  nFRE  nFWE  ALE  CLE
    	rGPACON = (rGPACON &~(0x3f<<17)) | (0x3f<<17);
	
    	NF8_Init();
  


  	Max1718_Set(COREVOLT_M100);	// ex)120:1.2V

  	Led_Display(1);
  	    Uart_SendByte(0x0c);//clear screen
  	    Uart_SendByte(0x0c);//clear screen
	    SDRAM_test(0x31000000,0x31800000);
        K9S1208_Menu();
	// To calculation copy time.
     	Timer4_Start();

    	block=0;
    	blockcopy_count=0;
    	while(blockcopy_count<(OS_IMAGE_BLOCK_SIZE)) {		 // Read OS image
		block++;
		if(!NF8_IsBadBlock(block))  continue;      // Skip bad block
		blockcopy_count++;
		for(page=0;page<32;page++) {  // Read 32 page
			if(!NF8_ReadPage(block, page, (U8 *)downPt)) {  //(U32 block,U32 page,U32 *buffer)
			 Led_Display(0x8);   // real ECC Error
			 while(1);
			}
	  	downPt += 512;	
             }
	}
   	 Led_Display(0xf);
 
    	Timer4_Stop();

    	Set_Pre();

	//rCLKCON = (0x0<<16)|(0x6<<12)|(0x9<<8)|(0x2<<4);	// for test
	//Uart_SendString(" Setting CLKCON]\n");
    //SDRAM_test(0x31000000,0x31800000);
    //K9S1208_Menu();
    	run();
	
}


#define TIMER_IINIT_VAL	(0xffff)

void Timer4_Start(void)
{
    Uart_SendString("\n\nNAND Boot Start\n");
    
    rTCFG0=0xff00;		// Prescaler 0xff+1(256)
    rTCFG1=(0x3<<16);	//T4=PCLK period*256*16 = 
    rTCNTB4=TIMER_IINIT_VAL;
    rTCON=(1<<22)|(1<<21);  //Manual update, to validate TCNTB4 value.
    rTCON=(1<<22)|(1<<20);  //Start T4
}

void Timer4_Stop(void)
{
    int cnt;
	
	rTCON=(1<<22)|(0<<20);  //Stop T4
    cnt=TIMER_IINIT_VAL-rTCNTO4;	// actual count number

    Uart_SendString("NAND Boot End\n");
    Uart_SendString("Boot time=nTCNT*82uS. nTCNT=0x");
    Uart_SendString(hex2char((cnt&0xf000)>>12));
    Uart_SendString(hex2char((cnt&0x0f00)>>8));
    Uart_SendString(hex2char((cnt&0x00f0)>>4));
    Uart_SendString(hex2char((cnt&0x000f)>>0));
	Uart_SendString(". \n");
	
}


char *hex2char(int val)
{
    static char str[2];
	
    str[1]='\0';
    if(val<=9)str[0]='0'+val;
    else str[0]=('a'+val-10);
	
    return str;
}

void Set_Pre(void)
{

	int i;

	i = rGPDCON; 

	rGPDCON = (rGPFCON & ~(3<<4)) | (0<<4);
	if((rGPFDAT&(1<<2))==0) {    // If EINT2 key is pressed.
		Uart_SendString("I/O Strength Max\n");
		// Set I/O strength control.
		rDSC0 = (0<<31)|(0<<8)|(0<<0);
		rDSC1 = (0<<28)|(0<<26)|(0x000000<<0);
	} else {
		Uart_SendString("I/O Strength Min\n");
		// Set I/O strength control.
		rDSC0 = (0<<31)|(3<<8)|(3<<0);
		// nEN_DSC  [31]    : 0:I/O drive strength enable, 1:Disable
		// DSC_ADR  [9:8]   : Addr drive strength, 0:10mA, 1:8mA, 2:6mA, 3:4mA
		// DSC_DATA [7:0]   : DATA drive strength, 0:12mA, 1:10mA, 2:8mA, 3:6mA
		
		rDSC1 = (3<<28)|(3<<26)|(0xffffff<<0);
		// DSC_SCK1 [29:28] : SCLK1, 0:16mA, 1:12mA, 2:8mA, 3:6mA 
		// DSC_SCK0 [27:26] : SCLK0, 0:16mA, 1:12mA, 2:8mA, 3:6mA 
		// DSC_SCKE [25:24] : SCLKE, 0:10mA, 1:8mA, 2:6mA, 3:4mA 
		// DSC_SDR  [23:22] : nRAS/nCAS, 0:10mA, 1:8mA, 2:6mA, 3:4mA 
		// DSC_NFC  [21:20] : Nand flash(nFCE,nFRE,nFWE,CLE,ALE), 0:10mA, 1:8mA, 2:6mA, 3:4mA 
		// DSC_BE   [19:18] : nBE[3:0], 0:10mA, 1:8mA, 2:6mA, 3:4mA 
		// DSC_WOE  [17:16] : nBE[3:0], 0:10mA, 1:8mA, 2:6mA, 3:4mA 
		// DSC_CS7  [15:14] : nGCS7, 0:10mA, 1:8mA, 2:6mA, 3:4mA 
		// DSC_CS6  [13:12] : nGCS6, 0:10mA, 1:8mA, 2:6mA, 3:4mA 
		// DSC_CS5  [11:10] : nGCS5, 0:10mA, 1:8mA, 2:6mA, 3:4mA 
		// DSC_CS4  [9:8]   : nGCS4, 0:10mA, 1:8mA, 2:6mA, 3:4mA 
		// DSC_CS3  [7:6]   : nGCS3, 0:10mA, 1:8mA, 2:6mA, 3:4mA 
		// DSC_CS2  [5:4]   : nGCS2, 0:10mA, 1:8mA, 2:6mA, 3:4mA 
		// DSC_CS1  [3:2]   : nGCS1, 0:10mA, 1:8mA, 2:6mA, 3:4mA 
		// DSC_CS0  [1:0]   : nGCS0, 0:10mA, 1:8mA, 2:6mA, 3:4mA 
	
		}
	rGPDCON = i;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲美女少妇撒尿| 亚洲欧美一区二区三区极速播放| www.亚洲国产| 国产一区二区免费看| 久久国产夜色精品鲁鲁99| 奇米在线7777在线精品| 五月天一区二区| 天天亚洲美女在线视频| 偷拍日韩校园综合在线| 日本中文字幕一区二区有限公司| 日韩精品亚洲一区二区三区免费| 亚洲线精品一区二区三区| 亚洲第一福利一区| 日韩avvvv在线播放| 久久 天天综合| 国产精品一区二区免费不卡 | 亚洲第一av色| 一区二区三区精密机械公司| 一区二区三区电影在线播| 亚洲成人在线网站| 国产精品一区二区男女羞羞无遮挡 | 6080国产精品一区二区| 91精品国产欧美一区二区 | 国产成人综合在线播放| 国产91精品一区二区麻豆亚洲| 成人av网站在线观看免费| 99久久99久久精品免费看蜜桃| 日本精品一级二级| 日韩亚洲欧美成人一区| 久久久不卡网国产精品一区| 中文字幕日韩欧美一区二区三区| 亚洲品质自拍视频| 免费人成精品欧美精品| 粗大黑人巨茎大战欧美成人| 欧美性色综合网| 欧美精品一区二区三区高清aⅴ| 国产精品人成在线观看免费| 亚洲一区中文在线| 国产精品99久| 欧美狂野另类xxxxoooo| 日本一区二区三区视频视频| 亚洲成av人片一区二区三区| 国产美女在线精品| 欧美天堂亚洲电影院在线播放| 精品国产乱码久久久久久1区2区 | 一本一道综合狠狠老| 91精品福利在线一区二区三区| 国产亚洲一区字幕| 丝袜亚洲精品中文字幕一区| av在线不卡观看免费观看| 欧美日韩电影在线播放| 久久久精品tv| 老司机精品视频在线| 欧美亚洲图片小说| 国产精品久久久久久久久快鸭| 日本不卡的三区四区五区| 91在线porny国产在线看| 2023国产精品| 久久国产精品99久久久久久老狼| 欧美日韩一卡二卡三卡| 一区二区三区日韩欧美| 成人18精品视频| 久久久久久久久免费| 免费人成精品欧美精品| 91精品国产一区二区| 亚洲影院久久精品| 欧美综合一区二区三区| 亚洲丝袜精品丝袜在线| www.日本不卡| 一色屋精品亚洲香蕉网站| 国产91精品精华液一区二区三区| 精品久久一区二区三区| 美女视频黄免费的久久 | 秋霞午夜av一区二区三区| 色天使久久综合网天天| 亚洲日本丝袜连裤袜办公室| 成人免费看的视频| 国产精品久久久99| 色综合网色综合| 亚洲欧美精品午睡沙发| 94-欧美-setu| 亚洲综合在线免费观看| 欧洲精品一区二区| 午夜私人影院久久久久| 欧美精品第1页| 日本成人在线视频网站| 精品对白一区国产伦| 久久精品二区亚洲w码| 精品国产伦一区二区三区观看方式| 久久精品99国产精品日本| 欧美大片国产精品| 国产福利一区二区三区视频在线| 国产三级一区二区三区| 成人动漫一区二区在线| 亚洲一级片在线观看| 日韩精品中文字幕一区| 国产黄色91视频| 亚洲精品国产无天堂网2021| 欧美日韩dvd在线观看| 日本三级亚洲精品| 久久久午夜精品| 91视频一区二区| 日韩**一区毛片| 欧美国产激情一区二区三区蜜月| 91色porny蝌蚪| 日韩中文字幕av电影| 久久毛片高清国产| 一本大道综合伊人精品热热| 日韩激情一二三区| 欧美国产精品劲爆| 9191国产精品| av成人动漫在线观看| 天天操天天干天天综合网| 久久久天堂av| 欧美三级一区二区| 国产成人免费高清| 亚洲成人精品在线观看| 久久综合九色综合欧美亚洲| 91欧美一区二区| 国产精品自拍网站| 天天射综合影视| 日韩一区中文字幕| 精品毛片乱码1区2区3区| 色婷婷久久综合| 国产aⅴ精品一区二区三区色成熟| 一区二区三区四区不卡视频| 久久久精品tv| 日韩欧美中文字幕一区| 色综合色综合色综合| 极品少妇xxxx精品少妇| 亚洲国产欧美在线人成| 国产精品欧美精品| 久久综合久色欧美综合狠狠| 欧美精品在线观看一区二区| 91在线观看美女| 国产成人精品1024| 日本aⅴ亚洲精品中文乱码| 一区二区三区丝袜| 亚洲另类在线视频| 国产精品久久久久久久蜜臀| 亚洲精品在线一区二区| 91精品久久久久久久91蜜桃| 欧美最猛黑人xxxxx猛交| 一本色道**综合亚洲精品蜜桃冫| 成人丝袜视频网| 国产精品一区二区黑丝| 精品一区二区三区免费播放| 日韩精品成人一区二区在线| 亚洲一区二区偷拍精品| 一区二区三区精密机械公司| 一区二区欧美精品| 一区二区三区四区不卡在线| 亚洲激情网站免费观看| 亚洲欧美成aⅴ人在线观看| 中文字幕亚洲成人| 亚洲另类在线一区| 亚洲综合色自拍一区| 午夜精品一区在线观看| 天天操天天色综合| 精品一区免费av| 国产成人av一区二区三区在线| 国产精品一区2区| jlzzjlzz亚洲日本少妇| 91美女片黄在线观看| 欧美在线观看一区| 日韩视频永久免费| 国产亚洲成aⅴ人片在线观看| 国产丝袜美腿一区二区三区| 国产精品高潮呻吟久久| 一区二区久久久久久| 日韩主播视频在线| 国产精品自在在线| 91蝌蚪porny| 制服.丝袜.亚洲.中文.综合| 欧美α欧美αv大片| 中文字幕第一区综合| 亚洲综合区在线| 久久精品国产99久久6| 成人高清视频免费观看| 欧美撒尿777hd撒尿| 欧美精品一区二区三区蜜桃视频| 国产精品视频观看| 亚洲妇熟xx妇色黄| 国产精品一区二区在线播放| 91精彩视频在线观看| 日韩区在线观看| 中文字幕五月欧美| 免费不卡在线观看| 99久久精品费精品国产一区二区| 欧美精品一级二级三级| 国产女人18毛片水真多成人如厕| 亚洲精品自拍动漫在线| 久久激情综合网| 91官网在线观看| 久久久青草青青国产亚洲免观| 亚洲色欲色欲www| 国内一区二区视频| 91国偷自产一区二区三区成为亚洲经典 | 国产精品视频在线看| 人人狠狠综合久久亚洲|