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

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

?? ocotea.c

?? 友善mini2440嵌入式
?? C
?? 第 1 頁 / 共 2 頁
字號:
	mtsdram (mem_clktr, 0x40000000);	/* clkp=1 (90 deg wr) dcdt=0    */	/*--------------------------------------------------------------------	 * Setup for board-specific specific mem	 *------------------------------------------------------------------*/	/*	 * Following for CAS Latency = 2.5 @ 133 MHz PLB	 */	mtsdram (mem_b0cr, 0x000a4001);	/* SDBA=0x000 128MB, Mode 3, enabled */	mtsdram (mem_tr0, 0x410a4012);	/* WR=2  WD=1 CL=2.5 PA=3 CP=4 LD=2 */	/* RA=10 RD=3                       */	mtsdram (mem_tr1, 0x8080082f);	/* SS=T2 SL=STAGE 3 CD=1 CT=0x02f   */	mtsdram (mem_rtr, 0x08200000);	/* Rate 15.625 ns @ 133 MHz PLB     */	mtsdram (mem_cfg1, 0x00000000);	/* Self-refresh exit, disable PM    */	udelay (400);			/* Delay 200 usecs (min)            */	/*--------------------------------------------------------------------	 * Enable the controller, then wait for DCEN to complete	 *------------------------------------------------------------------*/	mtsdram (mem_cfg0, 0x86000000);	/* DCEN=1, PMUD=1, 64-bit           */	for (;;) {		mfsdram (mem_mcsts, reg);		if (reg & 0x80000000)			break;	}	return (128 * 1024 * 1024);	/* 128 MB                           */}#endif	/* !defined(CONFIG_SPD_EEPROM) *//************************************************************************* *  pci_pre_init * *  This routine is called just prior to registering the hose and gives *  the board the opportunity to check things. Returning a value of zero *  indicates that things are bad & PCI initialization should be aborted. * *	Different boards may wish to customize the pci controller structure *	(add regions, override default access routines, etc) or perform *	certain pre-initialization actions. * ************************************************************************/#if defined(CONFIG_PCI) && defined(CFG_PCI_PRE_INIT)int pci_pre_init(struct pci_controller * hose ){	unsigned long strap;	/*--------------------------------------------------------------------------+	 *	The ocotea board is always configured as the host & requires the	 *	PCI arbiter to be enabled.	 *--------------------------------------------------------------------------*/	mfsdr(sdr_sdstp1, strap);	if( (strap & SDR0_SDSTP1_PAE_MASK) == 0 ){		printf("PCI: SDR0_STRP1[%08lX] - PCI Arbiter disabled.\n",strap);		return 0;	}	return 1;}#endif /* defined(CONFIG_PCI) && defined(CFG_PCI_PRE_INIT) *//************************************************************************* *  pci_target_init * *	The bootstrap configuration provides default settings for the pci *	inbound map (PIM). But the bootstrap config choices are limited and *	may not be sufficient for a given board. * ************************************************************************/#if defined(CONFIG_PCI) && defined(CFG_PCI_TARGET_INIT)void pci_target_init(struct pci_controller * hose ){	/*--------------------------------------------------------------------------+	 * Disable everything	 *--------------------------------------------------------------------------*/	out32r( PCIX0_PIM0SA, 0 ); /* disable */	out32r( PCIX0_PIM1SA, 0 ); /* disable */	out32r( PCIX0_PIM2SA, 0 ); /* disable */	out32r( PCIX0_EROMBA, 0 ); /* disable expansion rom */	/*--------------------------------------------------------------------------+	 * Map all of SDRAM to PCI address 0x0000_0000. Note that the 440 strapping	 * options to not support sizes such as 128/256 MB.	 *--------------------------------------------------------------------------*/	out32r( PCIX0_PIM0LAL, CFG_SDRAM_BASE );	out32r( PCIX0_PIM0LAH, 0 );	out32r( PCIX0_PIM0SA, ~(gd->ram_size - 1) | 1 );	out32r( PCIX0_BAR0, 0 );	/*--------------------------------------------------------------------------+	 * Program the board's subsystem id/vendor id	 *--------------------------------------------------------------------------*/	out16r( PCIX0_SBSYSVID, CFG_PCI_SUBSYS_VENDORID );	out16r( PCIX0_SBSYSID, CFG_PCI_SUBSYS_DEVICEID );	out16r( PCIX0_CMD, in16r(PCIX0_CMD) | PCI_COMMAND_MEMORY );}#endif /* defined(CONFIG_PCI) && defined(CFG_PCI_TARGET_INIT) *//************************************************************************* *  is_pci_host * *	This routine is called to determine if a pci scan should be *	performed. With various hardware environments (especially cPCI and *	PPMC) it's insufficient to depend on the state of the arbiter enable *	bit in the strap register, or generic host/adapter assumptions. * *	Rather than hard-code a bad assumption in the general 440 code, the *	440 pci code requires the board to decide at runtime. * *	Return 0 for adapter mode, non-zero for host (monarch) mode. * * ************************************************************************/#if defined(CONFIG_PCI)int is_pci_host(struct pci_controller *hose){    /* The ocotea board is always configured as host. */    return(1);}#endif /* defined(CONFIG_PCI) */void fpga_init(void){	unsigned long group;	unsigned long sdr0_pfc0;	unsigned long sdr0_pfc1;	unsigned long sdr0_cust0;	unsigned long pvr;	mfsdr (sdr_pfc0, sdr0_pfc0);	mfsdr (sdr_pfc1, sdr0_pfc1);	group = SDR0_PFC1_EPS_DECODE(sdr0_pfc1);	pvr = get_pvr ();	sdr0_pfc0 = (sdr0_pfc0 & ~SDR0_PFC0_GEIE_MASK) | SDR0_PFC0_GEIE_TRE;	if ( ((pvr == PVR_440GX_RA) || (pvr == PVR_440GX_RB)) && ((group == 4) || (group == 5))) {		sdr0_pfc0 = (sdr0_pfc0 & ~SDR0_PFC0_TRE_MASK) | SDR0_PFC0_TRE_DISABLE;		sdr0_pfc1 = (sdr0_pfc1 & ~SDR0_PFC1_CTEMS_MASK) | SDR0_PFC1_CTEMS_EMS;		out8(FPGA_REG2, (in8(FPGA_REG2) & ~FPGA_REG2_EXT_INTFACE_MASK) |		     FPGA_REG2_EXT_INTFACE_ENABLE);		mtsdr (sdr_pfc0, sdr0_pfc0);		mtsdr (sdr_pfc1, sdr0_pfc1);	} else {		sdr0_pfc0 = (sdr0_pfc0 & ~SDR0_PFC0_TRE_MASK) | SDR0_PFC0_TRE_ENABLE;		switch (group)		{		case 0:		case 1:		case 2:			/* CPU trace A */			out8(FPGA_REG2, (in8(FPGA_REG2) & ~FPGA_REG2_EXT_INTFACE_MASK) |			     FPGA_REG2_EXT_INTFACE_ENABLE);			sdr0_pfc1 = (sdr0_pfc1 & ~SDR0_PFC1_CTEMS_MASK) | SDR0_PFC1_CTEMS_EMS;			mtsdr (sdr_pfc0, sdr0_pfc0);			mtsdr (sdr_pfc1, sdr0_pfc1);			break;		case 3:		case 4:		case 5:		case 6:			/* CPU trace B - Over EBMI */			sdr0_pfc1 = (sdr0_pfc1 & ~SDR0_PFC1_CTEMS_MASK) | SDR0_PFC1_CTEMS_CPUTRACE;			mtsdr (sdr_pfc0, sdr0_pfc0);			mtsdr (sdr_pfc1, sdr0_pfc1);			out8(FPGA_REG2, (in8(FPGA_REG2) & ~FPGA_REG2_EXT_INTFACE_MASK) |			     FPGA_REG2_EXT_INTFACE_DISABLE);			break;		}	}	/* Initialize the ethernet specific functions in the fpga */	mfsdr(sdr_pfc1, sdr0_pfc1);	mfsdr(sdr_cust0, sdr0_cust0);	if ( (SDR0_PFC1_EPS_DECODE(sdr0_pfc1) == 4) &&	    ((SDR0_CUST0_RGMII2_DECODE(sdr0_cust0) == RGMII_FER_GMII) ||	     (SDR0_CUST0_RGMII2_DECODE(sdr0_cust0) == RGMII_FER_TBI)))	{		if ((in8(FPGA_REG0) & FPGA_REG0_ECLS_MASK) == FPGA_REG0_ECLS_VER1)		{			out8(FPGA_REG3, (in8(FPGA_REG3) & ~FPGA_REG3_ENET_MASK1) |			     FPGA_REG3_ENET_GROUP7);		}		else		{			if (SDR0_CUST0_RGMII2_DECODE(sdr0_cust0) == RGMII_FER_GMII)			{				out8(FPGA_REG3, (in8(FPGA_REG3) & ~FPGA_REG3_ENET_MASK2) |				     FPGA_REG3_ENET_GROUP7);			}			else			{				out8(FPGA_REG3, (in8(FPGA_REG3) & ~FPGA_REG3_ENET_MASK2) |				     FPGA_REG3_ENET_GROUP8);			}		}	}	else	{		if ((in8(FPGA_REG0) & FPGA_REG0_ECLS_MASK) == FPGA_REG0_ECLS_VER1)		{			out8(FPGA_REG3, (in8(FPGA_REG3) & ~FPGA_REG3_ENET_MASK1) |			     FPGA_REG3_ENET_ENCODE1(SDR0_PFC1_EPS_DECODE(sdr0_pfc1)));		}		else		{			out8(FPGA_REG3, (in8(FPGA_REG3) & ~FPGA_REG3_ENET_MASK2) |			     FPGA_REG3_ENET_ENCODE2(SDR0_PFC1_EPS_DECODE(sdr0_pfc1)));		}	}	out8(FPGA_REG4, FPGA_REG4_GPHY_MODE10 |	     FPGA_REG4_GPHY_MODE100 | FPGA_REG4_GPHY_MODE1000 |	     FPGA_REG4_GPHY_FRC_DPLX | FPGA_REG4_CONNECT_PHYS);	/* reset the gigabyte phy if necessary */	if (SDR0_PFC1_EPS_DECODE(sdr0_pfc1) >= 3)	{		if ((in8(FPGA_REG0) & FPGA_REG0_ECLS_MASK) == FPGA_REG0_ECLS_VER1)		{			out8(FPGA_REG3, in8(FPGA_REG3) & ~FPGA_REG3_GIGABIT_RESET_DISABLE);			udelay(10000);			out8(FPGA_REG3, in8(FPGA_REG3) | FPGA_REG3_GIGABIT_RESET_DISABLE);		}		else		{			out8(FPGA_REG2, in8(FPGA_REG2) & ~FPGA_REG2_GIGABIT_RESET_DISABLE);			udelay(10000);			out8(FPGA_REG2, in8(FPGA_REG2) | FPGA_REG2_GIGABIT_RESET_DISABLE);		}	}	/*	 * new Ocotea with Rev. F (pass 3) chips has SMII PHY reset	 */	if ((in8(FPGA_REG0) & FPGA_REG0_ECLS_MASK) == FPGA_REG0_ECLS_VER2) {		out8(FPGA_REG2, in8(FPGA_REG2) & ~FPGA_REG2_SMII_RESET_DISABLE);		udelay(10000);		out8(FPGA_REG2, in8(FPGA_REG2) | FPGA_REG2_SMII_RESET_DISABLE);	}	/* Turn off the LED's */	out8(FPGA_REG3, (in8(FPGA_REG3) & ~FPGA_REG3_STAT_MASK) |	     FPGA_REG3_STAT_LED8_DISAB | FPGA_REG3_STAT_LED4_DISAB |	     FPGA_REG3_STAT_LED2_DISAB | FPGA_REG3_STAT_LED1_DISAB);	return;}#ifdef CONFIG_POST/* * Returns 1 if keys pressed to start the power-on long-running tests * Called from board_init_f(). */int post_hotkeys_pressed(void){	return (ctrlc());}#endif

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久99最新地址| 亚洲午夜久久久久| 国产激情一区二区三区四区 | 久久久久久久久免费| 老司机午夜精品| 久久蜜桃一区二区| 不卡的看片网站| 亚洲精品菠萝久久久久久久| 91成人网在线| 免费黄网站欧美| 国产无一区二区| 91农村精品一区二区在线| 亚洲影院久久精品| 日韩欧美国产综合一区 | 色综合天天在线| 亚洲国产成人va在线观看天堂| 555www色欧美视频| 国产九色精品成人porny| 亚洲欧美综合在线精品| 欧美日本不卡视频| 国产麻豆9l精品三级站| 亚洲精品老司机| 精品国产制服丝袜高跟| 99国产精品视频免费观看| 亚洲一区二区三区爽爽爽爽爽 | 国产精品美女久久久久久久久 | 国内精品伊人久久久久av影院| 国产日韩欧美电影| 色哟哟亚洲精品| 狠狠色丁香婷综合久久| 亚洲欧美一区二区三区极速播放 | 久久综合成人精品亚洲另类欧美 | 国产精品性做久久久久久| 亚洲色图视频网| www国产精品av| 欧美体内she精高潮| 国产精品中文字幕一区二区三区| 一区二区三区久久久| 久久久不卡网国产精品二区| 欧美三级资源在线| www.在线成人| 国产一区二区三区高清播放| 午夜精品123| 亚洲图片激情小说| 国产日韩欧美精品电影三级在线| 91麻豆精品国产91久久久使用方法| 国产91精品免费| 久久精品国产成人一区二区三区| 亚洲与欧洲av电影| 中文字幕精品一区二区三区精品| 欧美一区二区三区四区五区| 在线免费视频一区二区| 成人国产精品视频| 国产自产视频一区二区三区| 美女视频一区二区三区| 亚洲国产欧美在线| 亚洲男女一区二区三区| 国产精品久久久久久久久晋中| 337p粉嫩大胆色噜噜噜噜亚洲| 欧美高清一级片在线| 色狠狠av一区二区三区| 99久久免费视频.com| 国产成人av电影在线播放| 经典三级在线一区| 精品一区二区三区在线播放视频| 日韩高清不卡一区二区三区| 视频一区二区中文字幕| 视频一区二区三区中文字幕| 亚洲1区2区3区4区| 天堂在线亚洲视频| 亚洲一区二区三区四区五区黄| 一区二区三区视频在线看| 亚洲色图欧美在线| 亚洲麻豆国产自偷在线| 一区二区国产盗摄色噜噜| 亚洲三级在线免费观看| 国产精品一区免费在线观看| 韩国女主播一区二区三区| 国产一区二区成人久久免费影院| 国内精品伊人久久久久av一坑 | 国产成人一级电影| 国产一区二区三区免费播放| 懂色av一区二区在线播放| 国产成人h网站| 91在线观看污| 在线精品视频免费播放| 欧美在线视频你懂得| 欧美欧美欧美欧美首页| 日韩丝袜情趣美女图片| 精品国产亚洲在线| 国产精品日韩成人| 一区二区激情小说| 六月丁香婷婷色狠狠久久| 国产一区二区三区久久久 | 国模大尺度一区二区三区| 国产传媒一区在线| 91免费版在线| 欧美日韩高清在线| 久久人人超碰精品| 成人免费小视频| 三级在线观看一区二区| 国产精品66部| 色婷婷国产精品| 日韩一级二级三级精品视频| 国产亚洲欧美色| 亚洲国产日产av| 黄一区二区三区| 色伊人久久综合中文字幕| 日韩一区二区不卡| 国产精品毛片a∨一区二区三区| 亚洲狼人国产精品| 美女看a上一区| 99久久久国产精品免费蜜臀| 日韩一区二区三区四区五区六区| 国产视频一区二区三区在线观看| 亚洲精品视频在线| 久草中文综合在线| 色诱视频网站一区| 精品免费国产二区三区| 一区二区在线免费观看| 激情综合网av| 欧美吞精做爰啪啪高潮| 国产亚洲视频系列| 偷拍日韩校园综合在线| 不卡的电影网站| 精品国产在天天线2019| 亚洲午夜在线电影| 成人午夜短视频| 精品美女被调教视频大全网站| 亚洲人成网站在线| 国产福利视频一区二区三区| 666欧美在线视频| 1024亚洲合集| 国产aⅴ综合色| 日韩一区二区在线播放| 一区二区三区国产豹纹内裤在线| 国产成人精品亚洲日本在线桃色| 制服.丝袜.亚洲.另类.中文| 亚洲人成精品久久久久久| 欧美日韩小视频| 亚洲欧洲另类国产综合| 国产一区视频在线看| 91精品国产91久久久久久最新毛片 | 91免费视频观看| 久久久蜜桃精品| 美女视频一区在线观看| 欧美精品少妇一区二区三区| 亚洲乱码中文字幕综合| 成人高清视频免费观看| 久久久久久97三级| 韩国成人精品a∨在线观看| 日韩一区二区三区在线视频| 亚洲va欧美va国产va天堂影院| 91视频.com| 亚洲免费伊人电影| 91麻豆.com| 一区二区三区国产豹纹内裤在线 | 国产伦精品一区二区三区免费 | 亚洲综合视频在线观看| 色综合色综合色综合| 中文字幕亚洲视频| 95精品视频在线| 亚洲欧洲日韩女同| 99久久亚洲一区二区三区青草| 日本一区二区视频在线| 国产成人综合网| 国产精品毛片久久久久久| 成人va在线观看| 亚洲免费观看高清完整版在线观看 | 99在线精品视频| 1区2区3区国产精品| 色婷婷av一区二区三区软件 | 久久久综合九色合综国产精品| 精品一区二区三区不卡 | 亚洲视频在线一区二区| 色素色在线综合| 视频一区二区中文字幕| 欧美大尺度电影在线| 国产在线播放一区三区四| 精品久久久久久久久久久久包黑料 | 成人免费小视频| 91蝌蚪porny成人天涯| 亚洲一卡二卡三卡四卡五卡| 欧美日韩精品综合在线| 奇米在线7777在线精品| 亚洲精品在线免费播放| 国产99久久久国产精品免费看| 成人免费在线观看入口| 欧美日韩一级片在线观看| 日本vs亚洲vs韩国一区三区二区 | 91在线国产福利| 亚洲成人av在线电影| 日韩一区二区三区av| 国产iv一区二区三区| 亚洲精品日韩综合观看成人91| 欧美色视频在线观看| 精品午夜久久福利影院| 亚洲图片欧美激情| 日韩亚洲欧美在线观看| 大胆欧美人体老妇|