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

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

?? board.c

?? colilo,COLDFIRE MCF5282的bootloader
?? C
字號:
/* *  vendors/Motorola/M5249C3-1MB/board.c *  CoLiLo MCF5249 Development board port  * *  (C) Copyright April 2003, Jeremy Andrus <jeremy@jeremya.com> * */#include "arch.h"#include "mcfuart.h"#include "ledstate.h"char	ident[] = "Motorola MCF5249 C3";char	copyright[] = "(C) 2003, Jeremy Andrus <jeremy@jeremya.com>";extern unsigned int downloadPort;extern unsigned int image_size;extern unsigned char *xfer_addr;extern unsigned char *down_addr;extern unsigned char *dest_addr;extern unsigned char *source_addr;extern unsigned long consoleBase;void configureConsole();void configureAuxSerial();void setLED(int state);void setImageParams();void setupBoard();static int delay(int size);void setupDRAM();#define	IMAGE_ADDR  0xfff08000  /* colilo shouldn't be more than 32k */#define IMAGE_SIZE 0x000f7fff   /* You really can't get any bigger than 1MB - 32 k :-) */#define XFER_ADDR 0x20000#define DEFAULT_PORT 1void configureConsole(){	/** Note: The UART timer in the 5249 uses the bus clock (PSTCLK / 2) to generate the baud ***/	consoleBase = MCFUART_BASE1;	configureSerial(MCFUART_BASE1, 19200, MCF_BUSCLK); /* dBUG compliance: 19200 it is. */}void configureAuxSerial(){	configureSerial(MCFUART_BASE2, 115200, MCF_BUSCLK); /* This can be used for image transfers */}/*  *  State to LED mapping: *  The gpio pins 53,52,51,34,19,18,12,11,9 will serve as a nice boot-up state indicator  * */void setLED(int state){	/*  Note: LEDs asserted low  */	/*  M5249C3 Diode Layout	 *	 *  gpio | led | diode 	 *   19  |  0  |  13  	 *   18  |  1  |  14  	 *   34  |  2  |  15  	 *   11  |  3  |  16  	 *  ------------------	 *   12  |  4  |  17  	 *    9  |  5  |  18  	 *   53  |  6  |  19  	 *  ------------------	 *   52  |  7  |  20  	 *   51  |  8  |  21  	 *  ------------------	 *	 */	/* bits = gpio[31..0], bits1 = gpio[63..32] */	unsigned long bits, bits1;	/* boot (led[3..0]) indicates the major boot step */	switch(state) {	  case LED_STATUS_INIT:	    bits = 0xffffffff;	    bits1 = 0xffffffff;	    break;	  case LED_STATUS_MEM:	    bits = 0xfff7ffff;	    bits1 = 0xffffffff;	    break;	  case LED_STATUS_RUNTIME:	    bits = 0xfffbffff;	    bits1 = 0xffffffff;	    break;	  case LED_STATUS_UART:	    bits = 0xfff3ffff;	    bits1 = 0xffffffff;	    break;	  case LED_STATUS_UI:	    bits = 0xffffffff;	    bits1 = 0xfffffffb;	    break;	  case LED_STATUS_DLOAD:	    bits = 0xfff7ffff;	    bits1 = 0xfffffffb;	    break;	  case LED_STATUS_DDECOMPGO:	  case LED_STATUS_DDECOMPRESS:	    bits = 0xfffbffff;	    bits1 = 0xfffffffb;	    break;	  case LED_STATUS_RUNIMAGE:	    bits = 0xfff3ffff;	    bits1 = 0xfffffffb;	    break;	  /*	   *  This is a binary counter, so if we ever need more states	   *  they're right here :-)  ~Jeremy	   */	  /**********************	  case 8:	    bits = 0xfffff7ff;	    bits1 = 0xffffffff;	    break;	  case 9:	    bits = 0xfff7f7ff;	    bits1 = 0xffffffff;	    break;	  case 10:	    bits = 0xfffbf7ff;	    bits1 = 0xffffffff;	    break;	  case 11:	    bits = 0xfff3f7ff;	    bits1 = 0xffffffff;	    break;	  case 12:	    bits = 0xfffff7ff;	    bits1 = 0xfffffffb;	    break;	  case 13:	    bits = 0xfff7f7ff;	    bits1 = 0xfffffffb;	    break;	  case 14:	    bits = 0xfffbf7ff;	    bits1 = 0xfffffffb;	    break;	  ***********************/	  case LED_STATUS_ERROR:	    bits = 0xfff3f7ff;	    bits1 = 0xfffffffb;	    break;	  default:	    bits = 0xffffffff;	    bits1 = 0xffffffff;	    break;	}	switch (state) {	  case LED_STATUS_MEMPRECHARGE:	  case LED_STATUS_CS6:	  case LED_STATUS_COPYDATA:	    bits ^= 0x00001000;	    bits1 ^= 0x00000000;	    break;	  case LED_STATUS_MEMREFRESH:	  case LED_STATUS_CS5:	  case LED_STATUS_ZEROBSS:	    bits ^= 0x00000200;	    bits1 ^= 0x00000000;	    break;	  case LED_STATUS_MEMMRI:	  case LED_STATUS_CS4:	  case LED_STATUS_INITVEC:	    bits ^= 0x00001200;	    bits1 ^= 0x00000000;	    break;	  case LED_STATUS_CS3:	  case LED_STATUS_DECOMP1:	    bits ^= 0x00000000;	    bits1 ^= 0x00200000;	    break;	  case LED_STATUS_CS2:	  case LED_STATUS_DECOMP2:	    bits ^= 0x00001000;	    bits1 ^= 0x00200000;	    break;	  case LED_STATUS_CS1:	  case LED_STATUS_LOAD1:	    bits ^= 0x00000200;	    bits1 ^= 0x00200000;	    break;	  case LED_STATUS_CS0:	  case LED_STATUS_LOAD2:	    bits ^= 0x00001200;	    bits1 ^= 0x00200000;	    break;	  default:	    bits ^= 0x00000000;	    bits1 ^= 0x00000000;	    break;	}	switch (state) {  	  case LED_STATUS_ENSWT:	    bits1 ^= 0x00100000;	    break;	  case LED_STATUS_STARTIMG:	    bits1 ^= 0x00080000;	    break;	/** Kept this here to keep the binary counter 	  case 3:	    bits1 ^= 0x00180000;	    break;	**/	  default:	    bits1 ^= 0x00000000;	    break;	}	mbar2_writeLong(MCFSIM_GPIO_OUT, bits);    // Write the new LED config to the gpio pins	mbar2_writeLong(MCFSIM_GPIO1_OUT, bits1);}void setImageParams(){	downloadPort = DEFAULT_PORT;	image_size  = IMAGE_SIZE;	source_addr = (unsigned char *)IMAGE_ADDR;	down_addr   = (unsigned char *)IMAGE_ADDR;	xfer_addr   = (unsigned char *)XFER_ADDR;	dest_addr   = (unsigned char *)XFER_ADDR;}void setupBoard(){	/* 	 *  Setup the PLL to run at the specified speed 	 *  	 */	volatile unsigned long cpll = mbar2_readLong(MCFSIM_PLLCR);  // Current PLL value	unsigned long pllcr;#ifdef __MCF_FAST_CLK__  	pllcr = 0x925a3100;  // ~140MHz clock (PLL bypass = 0)#else 	pllcr = 0x135a4140;  // ~72MHz clock (PLL bypass = 0)#endif	cpll = cpll & 0xfffffffe; 		  // Set PLL bypass mode = 0 (PSTCLK = crystal)	mbar2_writeLong(MCFSIM_PLLCR, cpll); 	  // Set the PLL to bypass mode (PSTCLK = crystal)	mbar2_writeLong(MCFSIM_PLLCR, pllcr);  	  // set the clock speed 	pllcr ^= 0x00000001; 		      	  // Set pll bypass to 1 	mbar2_writeLong(MCFSIM_PLLCR, pllcr);  	  // Start locking (pll bypass = 1)	delay(0x20); // Wait for a lock . . . 			/*	 *  Turn off the two LEDs that are on by default: D18, D19	 *  We will start flashing LEDs in just a minute ;-)	  	 *    These are on GPIO pins on the 5349C3 board	 *  	 *  NOTE: by setting the GPIO_FUNCTION registers, we ensure that the UART pins	 *        (UART0: gpio 30,27, UART1: gpio 31, 28) will be used as UART pins 	 *        which is their primary function.	 *        ~Jeremy	 */	mbar2_writeLong(MCFSIM_GPIO_FUNC, 0x000C1A00);   // Enable gpio pins: 19,18,112,11,9 (LEDs)	mbar2_writeLong(MCFSIM_GPIO1_FUNC, 0x00380004);  // Enable gpio pins: 53,52,51,34 (LEDs)	mbar2_writeLong(MCFSIM_GPIO_EN, 0x000C1A00);     // Map the pins to the corresponding gpio	mbar2_writeLong(MCFSIM_GPIO1_EN, 0x00380004);    	setLED(LED_STATUS_INIT); // Actualy clear the LEDs: Starting up . . . 	/* 	 *  dBug Compliance:	 *    You can verify these values by using dBug's 'ird' 	 *    (Internal Register Display) command	 *    ~Jeremy	 * 	 */	mbar_writeByte(MCFSIM_MPARK, 0x30);    // 5249 Internal Core takes priority over DMA 	mbar_writeByte(MCFSIM_SYPCR, 0x00);	mbar_writeByte(MCFSIM_SWIVR, 0x0f);	mbar_writeByte(MCFSIM_SWSR, 0x00);	mbar_writeLong(MCFSIM_IMR, 0xfffffbff);	mbar_writeByte(MCFSIM_SWDICR, 0x00);	mbar_writeByte(MCFSIM_TIMER1ICR, 0x00);	mbar_writeByte(MCFSIM_TIMER2ICR, 0x88);	mbar_writeByte(MCFSIM_I2CICR, 0x00);	mbar_writeByte(MCFSIM_UART1ICR, 0x00);	mbar_writeByte(MCFSIM_UART2ICR, 0x00);	mbar_writeByte(MCFSIM_ICR6, 0x00);	mbar_writeByte(MCFSIM_ICR7, 0x00);	mbar_writeByte(MCFSIM_ICR8, 0x00);	mbar_writeByte(MCFSIM_ICR9, 0x00);	mbar_writeByte(MCFSIM_QSPIICR, 0x00);	mbar2_writeLong(MCFSIM_GPIO_INT_EN, 0x00000080);	mbar2_writeByte(MCFSIM_INTBASE, 0x40);  // Base interrupts at 64	mbar2_writeByte(MCFSIM_SPURVEC, 0x00);	mbar2_writeLong(MCFSIM_IDECONFIG1, 0x00000020);  // Enable a 1 cycle pre-drive cycle on CS1		/* Setup interrupt priorities for gpio7 */	// mbar2_writeLong(MCFSIM_INTLEV5, 0x70000000);	/* IDE Config registers */	mbar2_writeLong(MCFSIM_IDECONFIG1, 0x00000020);	mbar2_writeLong(MCFSIM_IDECONFIG2, 0x00000000);	/*	 *  Setup chip selects...	 */	setLED(LED_STATUS_CS3);	/* CS3 - IDE interface */	mbar_writeShort(MCFSIM_CSAR3, 0x0202);	mbar_writeShort(MCFSIM_CSCR3, 0x34b8);	mbar_writeLong(MCFSIM_CSMR3, 0xbdb4017a);	setLED(LED_STATUS_CS2);	/* CS2 - IDE interface */	mbar_writeShort(MCFSIM_CSAR2, 0x5000);	mbar_writeShort(MCFSIM_CSCR2, 0x0080);	mbar_writeLong(MCFSIM_CSMR2, 0x001f0000);	setLED(LED_STATUS_CS1);	/* CS1 - SMSC LAN91C111 ethernet, address 0xe0000000 */	mbar_writeShort(MCFSIM_CSAR1,0xe000);	mbar_writeShort(MCFSIM_CSCR1, 0x0080);  // WS=0100 (4 wait states), AA=1, PS=10 (16bit port)	mbar_writeLong(MCFSIM_CSMR1, 0x00000021);  // , AA=0, WP=0, C/I=1, V=1	setLED(LED_STATUS_CS0);	/* CS0 - AMD Flash */	mbar_writeShort(MCFSIM_CSAR0,0xfff0);	mbar_writeShort(MCFSIM_CSCR0, 0x1180);  // WS=0100 (4 wait states), AA=1, PS=10 (16bit port)		/** Note: There is a CSMR0/DRAM vector problem, need to disable C/I ***/	mbar_writeLong(MCFSIM_CSMR0, 0x000f0021);  // 1MB of flash (the bottom half), WP=0, C/I=1, V=1}static int delay(int size){	int i;	for (i = 0; (i < size); i++)	  nop();}/* *  SDRAM is pretty confusing.  *  Please read _all_ the docs before meddling with this code :-) *	~Jeremy */void setupDRAM(){	volatile unsigned char *mbar = (unsigned char *)MCF_MBAR;	unsigned long	junk = 0xa5a59696;	/* 	 *  Note: 	 *	RC = ([(RefreshTime/#rows) / (1/BusClk)] / 16) - 1	 */#ifdef __MCF_FAST_CLK__	// Busclk=70MHz, RefreshTime=64ms, #rows=4096 (4K)	// SO=1, NAM=0, COC=0, RTIM=01 (6clk refresh), RC=39 	mbar_writeShort(MCFSIM_DCR, 0x8239);  #else	// Busclk=36MHz, RefreshTime=64ms, #rows=4096 (4K)	// SO=1, NAM=0, COC=0, RTIM=01 (6clk refresh), RC=22 (562 bus clock cycles)	mbar_writeShort(MCFSIM_DCR, 0x8222);  #endif	// SDRAM starts at 0x0000_0000, CASL=10, CBM=010, PS=10 (16bit port), PM=1 (continuous page mode)	// RE=0 (keep auto-refresh disabled while setting up registers)	mbar_writeLong(MCFSIM_DACR0, 0x00003224);  	// BAM=007c (bits 22,21 are bank selects; 256kB blocks)	mbar_writeLong(MCFSIM_DMR0, 0x007c0001);	/** Precharge sequence **/	mbar_writeLong(MCFSIM_DACR0, 0x0000322c); // Set DACR0[IP] (bit 3)	*((volatile unsigned long *) 0x00) = junk; // write to a memory location to init. precharge	delay(0x10); // Allow several Precharge cycles	/** Refresh Sequence **/	mbar_writeLong(MCFSIM_DACR0, 0x0000b224); // Enable the refresh bit, DACR0[RE] (bit 15)	delay(0x7d0); // Allow gobs of refresh cycles	/** Mode Register initialization **/	mbar_writeLong(MCFSIM_DACR0, 0x0000b264);  // Enable DACR0[IMRS] (bit 6); RE remains enabled	*((volatile unsigned long *) 0x800) = junk; // Access RAM to initialize the mode register}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产99精品视频| 91福利视频在线| 91尤物视频在线观看| 欧美高清视频不卡网| 1024精品合集| 国产主播一区二区| 欧美精品第1页| 亚洲色图.com| 成人国产精品免费观看视频| 4438x亚洲最大成人网| 亚洲人xxxx| www.99精品| 欧美国产精品v| 国产一区 二区| 2023国产一二三区日本精品2022| 亚洲一区二区三区在线看| 91香蕉视频在线| 国产精品毛片无遮挡高清| 国产v综合v亚洲欧| 26uuu亚洲| 极品瑜伽女神91| 精品久久久久一区二区国产| 麻豆视频观看网址久久| 91精品国产aⅴ一区二区| 五月天久久比比资源色| 欧美色偷偷大香| 亚洲午夜在线电影| 欧美性大战久久久久久久| 亚洲视频每日更新| 91蝌蚪国产九色| 亚洲欧美日韩久久| 色成年激情久久综合| 一区二区三区中文字幕| 在线观看亚洲一区| 亚洲一区欧美一区| 欧美精品123区| 久久国产福利国产秒拍| 欧美va在线播放| 国产美女一区二区三区| 国产精品视频一二三| 风间由美中文字幕在线看视频国产欧美 | 日本精品视频一区二区| 中文字幕在线观看一区| 色婷婷av一区| 日韩综合小视频| 精品久久久久久无| 国产一区二区福利视频| 国产欧美一区视频| 99v久久综合狠狠综合久久| 亚洲视频一二区| 69堂成人精品免费视频| 麻豆成人免费电影| 国产精品人成在线观看免费| 色噜噜狠狠色综合中国| 视频一区视频二区中文字幕| 日韩精品最新网址| 91偷拍与自偷拍精品| 午夜视黄欧洲亚洲| 91精品久久久久久久99蜜桃| 国产精品中文字幕日韩精品| 一区视频在线播放| 91精品国产欧美一区二区18| 国产精品一级黄| 亚洲狠狠爱一区二区三区| 日韩写真欧美这视频| 成人午夜在线视频| 午夜伦理一区二区| 欧美国产禁国产网站cc| 欧美喷水一区二区| 成人免费看的视频| 爽爽淫人综合网网站| 中文字幕免费在线观看视频一区| 欧美日本一区二区在线观看| 国产精品一区二区免费不卡| 亚洲午夜久久久久久久久久久 | 国产成a人亚洲精| 亚洲国产成人91porn| 国产欧美日韩在线视频| 欧美日本在线观看| 不卡视频在线观看| 久久成人羞羞网站| 亚洲一区二区免费视频| 国产女人18毛片水真多成人如厕| 欧美亚洲精品一区| aaa国产一区| 国产美女主播视频一区| 秋霞电影一区二区| 亚洲一区二区三区在线| 国产精品久久久久影院| 欧美精品一区二区三区蜜桃| 欧美日韩精品免费观看视频| 99久久精品国产毛片| 国产毛片精品一区| 久久电影国产免费久久电影| 午夜精品福利在线| 亚洲在线观看免费视频| 国产精品久久久久婷婷| 久久久久久麻豆| 精品国产自在久精品国产| 欧美浪妇xxxx高跟鞋交| 欧美亚洲禁片免费| 日本道色综合久久| 色屁屁一区二区| 色综合久久66| 色屁屁一区二区| 色www精品视频在线观看| 91视频在线观看| 91丨porny丨中文| 97se狠狠狠综合亚洲狠狠| 成人精品在线视频观看| 成人性色生活片免费看爆迷你毛片| 久久69国产一区二区蜜臀| 蜜桃av一区二区| 国产美女在线观看一区| 国产jizzjizz一区二区| 高清成人免费视频| 北条麻妃国产九九精品视频| 成人av网站在线| 99久久精品国产一区| 色香蕉久久蜜桃| 欧美日韩免费观看一区二区三区| 91视频在线看| 欧美日韩一区二区在线观看视频| 欧美在线观看视频在线| 欧美喷水一区二区| 精品成a人在线观看| 久久婷婷一区二区三区| 亚洲国产精品激情在线观看| 最近中文字幕一区二区三区| 亚洲精品国产第一综合99久久 | 欧美精品成人一区二区三区四区| 欧美日韩一区二区三区不卡| 在线不卡中文字幕播放| 欧美成人精品高清在线播放 | 粉嫩嫩av羞羞动漫久久久| 成人动漫av在线| 欧美午夜精品免费| 日韩欧美中文字幕一区| 欧美激情一区三区| 一区二区三区久久| 蜜桃视频在线一区| 99久久精品一区二区| 制服丝袜日韩国产| www国产成人免费观看视频 深夜成人网| 欧美国产一区二区| 日韩精品欧美成人高清一区二区| 国产一区二区三区在线观看免费视频| 成人免费观看视频| 91麻豆精品国产91久久久久久| 久久综合一区二区| 亚洲精品日产精品乱码不卡| 奇米精品一区二区三区在线观看一| 国产一区二区免费在线| 91在线免费视频观看| 91麻豆精品国产91| 国产精品乱码一区二区三区软件| 亚洲国产视频直播| 成人夜色视频网站在线观看| 欧美日韩另类国产亚洲欧美一级| 国产蜜臀97一区二区三区| 日本亚洲欧美天堂免费| 大胆欧美人体老妇| 欧美成人一级视频| 亚洲影视在线观看| 成人网男人的天堂| 精品毛片乱码1区2区3区| 亚洲另类春色校园小说| 国产成人日日夜夜| 日韩欧美视频一区| 亚洲一区二区综合| 成人av在线资源网站| 欧美白人最猛性xxxxx69交| 亚洲国产成人porn| 色综合色综合色综合色综合色综合| 久久久久久久av麻豆果冻| 人禽交欧美网站| 欧美日韩精品一区二区天天拍小说| 中文字幕av一区二区三区高| 精彩视频一区二区三区| 91精品国产色综合久久| 亚洲一区二区欧美日韩| 99久久综合国产精品| 久久久久久亚洲综合| 精品一区二区精品| 日韩精品一区二区三区视频在线观看 | 久久综合久色欧美综合狠狠| 亚洲国产欧美一区二区三区丁香婷| av激情成人网| 最新日韩在线视频| av在线不卡观看免费观看| 亚洲国产精品黑人久久久| 国产91精品在线观看| 久久青草国产手机看片福利盒子| 狠狠色狠狠色合久久伊人| 日韩三级免费观看| 精品一区二区在线播放| 精品少妇一区二区三区在线视频| 奇米精品一区二区三区在线观看 | 亚洲欧洲色图综合| 国产精品夜夜爽|