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

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

?? start.s

?? 利用開發(fā)板上的/dev/mem設備,進行內(nèi)存映射,驅動cpu的GPIO口,點亮和熄滅led燈.附makefile文件
?? S
?? 第 1 頁 / 共 4 頁
字號:
/* *  Copyright (C) 1998	Dan Malek <dmalek@jlc.net> *  Copyright (C) 1999	Magnus Damm <kieraypc01.p.y.kie.era.ericsson.se> *  Copyright (C) 2000,2001,2002 Wolfgang Denk <wd@denx.de> * * See file CREDITS for list of people who contributed to this * project. * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License as * published by the Free Software Foundation; either version 2 of * the License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.	 See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * MA 02111-1307 USA *//*------------------------------------------------------------------------------+ *//* *//*	 This source code has been made available to you by IBM on an AS-IS *//*	 basis.	 Anyone receiving this source is licensed under IBM *//*	 copyrights to use it in any way he or she deems fit, including *//*	 copying it, modifying it, compiling it, and redistributing it either *//*	 with or without modifications.	 No license under IBM patents or *//*	 patent applications is to be implied by the copyright license. *//* *//*	 Any user of this software should understand that IBM cannot provide *//*	 technical support for this software and will not be responsible for *//*	 any consequences resulting from the use of this software. *//* *//*	 Any person who transfers this source code or any derivative work *//*	 must include the IBM copyright notice, this paragraph, and the *//*	 preceding two paragraphs in the transferred software. *//* *//*	 COPYRIGHT   I B M   CORPORATION 1995 *//*	 LICENSED MATERIAL  -  PROGRAM PROPERTY OF I B M *//*------------------------------------------------------------------------------- *//*  U-Boot - Startup Code for IBM 4xx PowerPC based Embedded Boards * * *  The processor starts at 0xfffffffc and the code is executed *  from flash/rom. *  in memory, but as long we don't jump around before relocating. *  board_init lies at a quite high address and when the cpu has *  jumped there, everything is ok. *  This works because the cpu gives the FLASH (CS0) the whole *  address space at startup, and board_init lies as a echo of *  the flash somewhere up there in the memorymap. * *  board_init will change CS0 to be positioned at the correct *  address and (s)dram will be positioned at address 0 */#include <config.h>#include <mpc8xx.h>#include <ppc4xx.h>#include <version.h>#define _LINUX_CONFIG_H 1	/* avoid reading Linux autoconf.h file	*/#include <ppc_asm.tmpl>#include <ppc_defs.h>#include <asm/cache.h>#include <asm/mmu.h>#ifndef	 CONFIG_IDENT_STRING#define	 CONFIG_IDENT_STRING ""#endif#ifdef CFG_INIT_DCACHE_CS# if (CFG_INIT_DCACHE_CS == 0)#  define PBxAP pb0ap#  define PBxCR pb0cr# endif# if (CFG_INIT_DCACHE_CS == 1)#  define PBxAP pb1ap#  define PBxCR pb1cr# endif# if (CFG_INIT_DCACHE_CS == 2)#  define PBxAP pb2ap#  define PBxCR pb2cr# endif# if (CFG_INIT_DCACHE_CS == 3)#  define PBxAP pb3ap#  define PBxCR pb3cr# endif# if (CFG_INIT_DCACHE_CS == 4)#  define PBxAP pb4ap#  define PBxCR pb4cr# endif# if (CFG_INIT_DCACHE_CS == 5)#  define PBxAP pb5ap#  define PBxCR pb5cr# endif# if (CFG_INIT_DCACHE_CS == 6)#  define PBxAP pb6ap#  define PBxCR pb6cr# endif# if (CFG_INIT_DCACHE_CS == 7)#  define PBxAP pb7ap#  define PBxCR pb7cr# endif#endif /* CFG_INIT_DCACHE_CS *//* We don't want the  MMU yet.*/#undef	MSR_KERNEL#define MSR_KERNEL ( MSR_ME  )	/* Machine Check */	.extern ext_bus_cntlr_init	.extern sdram_init/* * Set up GOT: Global Offset Table * * Use r14 to access the GOT */	START_GOT	GOT_ENTRY(_GOT2_TABLE_)	GOT_ENTRY(_FIXUP_TABLE_)	GOT_ENTRY(_start)	GOT_ENTRY(_start_of_vectors)	GOT_ENTRY(_end_of_vectors)	GOT_ENTRY(transfer_to_handler)	GOT_ENTRY(__init_end)	GOT_ENTRY(_end)	GOT_ENTRY(__bss_start)	END_GOT/* * 440 Startup -- on reset only the top 4k of the effective * address space is mapped in by an entry in the instruction * and data shadow TLB. The .bootpg section is located in the * top 4k & does only what's necessary to map in the the rest * of the boot rom. Once the boot rom is mapped in we can * proceed with normal startup. * * NOTE: CS0 only covers the top 2MB of the effective address * space after reset. */#if defined(CONFIG_440)    .section .bootpg,"ax"    .globl _start_440/**************************************************************************/_start_440:	/*----------------------------------------------------------------*/	/* Clear and set up some registers. */	/*----------------------------------------------------------------*/	iccci	r0,r0		/* NOTE: operands not used for 440 */	dccci	r0,r0		/* NOTE: operands not used for 440 */	sync	li	r0,0	mtspr	srr0,r0	mtspr	srr1,r0	mtspr	csrr0,r0	mtspr	csrr1,r0#if defined (CONFIG_440GX) /* NOTE: 440GX adds machine check status regs */	mtspr	mcsrr0,r0	mtspr	mcsrr1,r0	mfspr	r1, mcsr	mtspr	mcsr,r1#endif	/*----------------------------------------------------------------*/	/* Initialize debug */	/*----------------------------------------------------------------*/	mtspr	dbcr0,r0	mtspr	dbcr1,r0	mtspr	dbcr2,r0	mtspr	iac1,r0	mtspr	iac2,r0	mtspr	iac3,r0	mtspr	dac1,r0	mtspr	dac2,r0	mtspr	dvc1,r0	mtspr	dvc2,r0	mfspr	r1,dbsr	mtspr	dbsr,r1		/* Clear all valid bits */	/*----------------------------------------------------------------*/	/* CCR0 init */	/*----------------------------------------------------------------*/	/* Disable store gathering & broadcast, guarantee inst/data	* cache block touch, force load/store alignment	* (see errata 1.12: 440_33)	*/	lis	r1,0x0030	/* store gathering & broadcast disable */	ori	r1,r1,0x6000	/* cache touch */	mtspr	ccr0,r1	/*----------------------------------------------------------------*/	/* Setup interrupt vectors */	/*----------------------------------------------------------------*/	mtspr	ivpr,r0		/* Vectors start at 0x0000_0000 */	li	r1,0x0100	mtspr	ivor0,r1	/* Critical input */	li	r1,0x0200	mtspr	ivor1,r1	/* Machine check */	li	r1,0x0300	mtspr	ivor2,r1	/* Data storage */	li	r1,0x0400	mtspr	ivor3,r1	/* Instruction storage */	li	r1,0x0500	mtspr	ivor4,r1	/* External interrupt */	li	r1,0x0600	mtspr	ivor5,r1	/* Alignment */	li	r1,0x0700	mtspr	ivor6,r1	/* Program check */	li	r1,0x0800	mtspr	ivor7,r1	/* Floating point unavailable */	li	r1,0x0c00	mtspr	ivor8,r1	/* System call */	li	r1,0x1000	mtspr	ivor10,r1	/* Decrementer (PIT for 440) */	li	r1,0x1400	mtspr	ivor13,r1	/* Data TLB error */	li	r1,0x1300	mtspr	ivor14,r1	/* Instr TLB error */	li	r1,0x2000	mtspr	ivor15,r1	/* Debug */	/*----------------------------------------------------------------*/	/* Configure cache regions  */	/*----------------------------------------------------------------*/	mtspr	inv0,r0	mtspr	inv1,r0	mtspr	inv2,r0	mtspr	inv3,r0	mtspr	dnv0,r0	mtspr	dnv1,r0	mtspr	dnv2,r0	mtspr	dnv3,r0	mtspr	itv0,r0	mtspr	itv1,r0	mtspr	itv2,r0	mtspr	itv3,r0	mtspr	dtv0,r0	mtspr	dtv1,r0	mtspr	dtv2,r0	mtspr	dtv3,r0	/*----------------------------------------------------------------*/	/* Cache victim limits */	/*----------------------------------------------------------------*/	/* floors 0, ceiling max to use the entire cache -- nothing locked	*/	lis	r1,0x0001	ori	r1,r1,0xf800	mtspr	ivlim,r1	mtspr	dvlim,r1	/*----------------------------------------------------------------*/	/* Clear all TLB entries -- TID = 0, TS = 0 */	/*----------------------------------------------------------------*/	mtspr	mmucr,r0	li	r1,0x003f	/* 64 TLB entries */	mtctr	r10:	tlbwe	r0,r1,0x0000	/* Invalidate all entries (V=0)*/	subi	r1,r1,0x0001	bdnz	0b	/*----------------------------------------------------------------*/	/* TLB entry setup -- step thru tlbtab */	/*----------------------------------------------------------------*/	bl	tlbtab		/* Get tlbtab pointer */	mr	r5,r0	li	r1,0x003f	/* 64 TLB entries max */	mtctr	r1	li	r4,0		/* TLB # */	addi	r5,r5,-41:	lwzu	r0,4(r5)	cmpwi	r0,0	beq	2f		/* 0 marks end */	lwzu	r1,4(r5)	lwzu	r2,4(r5)	tlbwe	r0,r4,0		/* TLB Word 0 */	tlbwe	r1,r4,1		/* TLB Word 1 */	tlbwe	r2,r4,2		/* TLB Word 2 */	addi	r4,r4,1		/* Next TLB */	bdnz	1b	/*----------------------------------------------------------------*/	/* Continue from 'normal' start */	/*----------------------------------------------------------------*/2:	bl	3f	b	_start3:	li	r0,0	mtspr	srr1,r0		/* Keep things disabled for now */	mflr	r1	mtspr	srr0,r1	rfi#endif /* CONFIG_440 *//* * r3 - 1st arg to board_init(): IMMP pointer * r4 - 2nd arg to board_init(): boot flag */	.text	.long	0x27051956		/* U-Boot Magic Number			*/	.globl	version_stringversion_string:	.ascii U_BOOT_VERSION	.ascii " (", __DATE__, " - ", __TIME__, ")"	.ascii CONFIG_IDENT_STRING, "\0"/* * Maybe this should be moved somewhere else because the current * location (0x100) is where the CriticalInput Execption should be. */	. = EXC_OFF_SYS_RESET	.globl	_start_start:/*****************************************************************************/#if defined(CONFIG_440)	/*----------------------------------------------------------------*/	/* Clear and set up some registers. */	/*----------------------------------------------------------------*/	li	r0,0x0000	lis	r1,0xffff	mtspr	dec,r0			/* prevent dec exceptions */	mtspr	tbl,r0			/* prevent fit & wdt exceptions */	mtspr	tbu,r0	mtspr	tsr,r1			/* clear all timer exception status */	mtspr	tcr,r0			/* disable all */	mtspr	esr,r0			/* clear exception syndrome register */	mtxer	r0			/* clear integer exception register */#if !defined(CONFIG_440GX)	lis	r1,0x0002		/* set CE bit (Critical Exceptions) */	ori	r1,r1,0x1000		/* set ME bit (Machine Exceptions) */	mtmsr	r1			/* change MSR */#elif !defined(CONFIG_440EP) && !defined(CONFIG_440GR)	bl	__440gx_msr_set	b	__440gx_msr_continue__440gx_msr_set:	lis	r1, 0x0002		/* set CE bit (Critical Exceptions) */	ori	r1,r1,0x1000	/* set ME bit (Machine Exceptions) */	mtspr	srr1,r1	mflr	r1	mtspr	srr0,r1	rfi__440gx_msr_continue:#endif	/*----------------------------------------------------------------*/	/* Debug setup -- some (not very good) ice's need an event*/	/* to establish control :-( Define CFG_INIT_DBCR to the dbsr */	/* value you need in this case 0x8cff 0000 should do the trick */	/*----------------------------------------------------------------*/#if defined(CFG_INIT_DBCR)	lis	r1,0xffff	ori	r1,r1,0xffff	mtspr	dbsr,r1			/* Clear all status bits */	lis	r0,CFG_INIT_DBCR@h	ori	r0,r0,CFG_INIT_DBCR@l	mtspr	dbcr0,r0	isync#endif	/*----------------------------------------------------------------*/	/* Setup the internal SRAM */	/*----------------------------------------------------------------*/	li	r0,0#if defined(CONFIG_440EP) || defined(CONFIG_440GR)	/* Clear Dcache to use as RAM */	addis	r3,r0,CFG_INIT_RAM_ADDR@h	ori	r3,r3,CFG_INIT_RAM_ADDR@l	addis	r4,r0,CFG_INIT_RAM_END@h	ori	r4,r4,CFG_INIT_RAM_END@l	rlwinm. r5,r4,0,27,31	rlwinm	r5,r4,27,5,31	beq	..d_ran	addi	r5,r5,0x0001..d_ran:	mtctr	r5..d_ag:	dcbz	r0,r3	addi	r3,r3,32	bdnz	..d_ag#else#if defined (CONFIG_440GX)	mtdcr	l2_cache_cfg,r0		/* Ensure L2 Cache is off */#endif	mtdcr	isram0_sb1cr,r0		/* Disable bank 1 */	li	r2,0x7fff	ori	r2,r2,0xffff	mfdcr	r1,isram0_dpc	and	r1,r1,r2		/* Disable parity check */	mtdcr	isram0_dpc,r1	mfdcr	r1,isram0_pmeg	andis.	r1,r1,r2		/* Disable pwr mgmt */	mtdcr	isram0_pmeg,r1	lis	r1,0x8000		/* BAS = 8000_0000 */#if defined(CONFIG_440GX)	ori	r1,r1,0x0980		/* first 64k */	mtdcr	isram0_sb0cr,r1	lis	r1,0x8001	ori	r1,r1,0x0980		/* second 64k */	mtdcr	isram0_sb1cr,r1	lis	r1, 0x8002	ori	r1,r1, 0x0980		/* third 64k */	mtdcr	isram0_sb2cr,r1	lis	r1, 0x8003	ori	r1,r1, 0x0980		/* fourth 64k */	mtdcr	isram0_sb3cr,r1#else	ori	r1,r1,0x0380		/* 8k rw */	mtdcr	isram0_sb0cr,r1#endif#endif	/*----------------------------------------------------------------*/	/* Setup the stack in internal SRAM */	/*----------------------------------------------------------------*/

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
中文字幕日韩一区二区| 5566中文字幕一区二区电影 | 性久久久久久久久久久久| 91视频在线观看免费| 亚洲另类在线制服丝袜| 欧美系列亚洲系列| 午夜不卡在线视频| 欧美大尺度电影在线| 精品一区二区国语对白| 国产亚洲一区字幕| 一本色道亚洲精品aⅴ| 亚洲v中文字幕| 日韩午夜激情电影| 国产成人精品亚洲日本在线桃色 | 欧美在线一二三| 亚洲aaa精品| 精品国产123| 成人黄色在线网站| 亚洲电影视频在线| 精品国产亚洲在线| 91亚洲午夜精品久久久久久| 亚洲在线中文字幕| 日韩久久免费av| 99国产精品久久久久| 日韩精品成人一区二区三区| 久久综合九色综合欧美亚洲| 91视频国产观看| 全国精品久久少妇| 中文字幕日本不卡| 91精品国产91久久久久久最新毛片 | 久久精品日产第一区二区三区高清版| 粉嫩在线一区二区三区视频| 一二三四社区欧美黄| 精品三级av在线| 99精品偷自拍| 久久精品国产精品亚洲综合| 亚洲人成小说网站色在线 | 91婷婷韩国欧美一区二区| 天堂成人国产精品一区| 国产蜜臀97一区二区三区| 精品视频123区在线观看| 国产成人午夜片在线观看高清观看| 樱花草国产18久久久久| 久久毛片高清国产| 欧美日韩在线不卡| 97精品国产97久久久久久久久久久久| 日本伊人精品一区二区三区观看方式| 国产精品国模大尺度视频| 日韩欧美在线123| 色偷偷88欧美精品久久久 | av网站一区二区三区| 日本不卡视频在线观看| 亚洲精品你懂的| 国产午夜精品久久久久久久 | 久久国产精品第一页| 亚洲精品国产一区二区精华液 | 粉嫩高潮美女一区二区三区| 日本在线不卡视频| 香蕉影视欧美成人| 一区二区成人在线| 综合久久一区二区三区| 国产日韩欧美亚洲| 精品日韩一区二区| 日韩午夜中文字幕| 7777精品久久久大香线蕉 | 视频一区在线播放| 亚洲在线一区二区三区| 自拍偷自拍亚洲精品播放| 国产视频一区在线观看| 日韩久久精品一区| 欧美一区二区三区精品| 7777女厕盗摄久久久| 欧美电影一区二区| 91精品中文字幕一区二区三区| 欧美中文字幕一区| 欧美日韩国产影片| 欧美色视频一区| 欧美这里有精品| 精品视频在线免费看| 欧美日韩一区二区三区不卡| 欧美日韩一区二区在线观看| 欧美日韩久久不卡| 这里只有精品电影| 日韩欧美国产电影| 精品国产乱码久久| 国产清纯白嫩初高生在线观看91 | 欧美一区二区三区视频免费播放| 欧美日韩成人在线一区| 欧美高清视频不卡网| 欧美一区二区高清| 久久综合给合久久狠狠狠97色69| 26uuu色噜噜精品一区| 国产午夜三级一区二区三| 国产精品麻豆99久久久久久| 国产精品女上位| 亚洲黄色性网站| 日韩国产欧美在线视频| 久久成人羞羞网站| 国产成人av一区二区| 精品乱人伦小说| 久久久久久麻豆| 国产精品二区一区二区aⅴ污介绍| 国产精品久久影院| 亚洲午夜免费福利视频| 视频一区二区三区入口| 国内精品免费在线观看| www.亚洲色图| 欧美欧美欧美欧美首页| 亚洲精品一线二线三线无人区| 国产欧美日韩卡一| 一二三四社区欧美黄| 蜜桃视频第一区免费观看| 岛国精品一区二区| 欧美亚洲综合色| 精品福利在线导航| 亚洲美女偷拍久久| 免费看日韩精品| 成人美女视频在线观看18| 欧美性猛交xxxx黑人交| 精品国产免费人成电影在线观看四季 | 欧美电影免费观看高清完整版在线观看 | 欧美一区二区三区啪啪| 国产日韩精品一区| 亚洲国产精品麻豆| 国产精品资源在线观看| 91久久精品一区二区三区| 欧美v日韩v国产v| 亚洲精品福利视频网站| 国内精品国产成人国产三级粉色| av一区二区三区在线| 日韩欧美在线影院| 亚洲精品久久久久久国产精华液| 国内成人免费视频| 欧美日韩国产123区| 中文字幕一区二区三区乱码在线| 免费成人你懂的| 色哟哟欧美精品| 久久亚洲精品小早川怜子| 三级久久三级久久久| 91网站在线播放| 国产欧美一区二区精品性色超碰| 天堂一区二区在线| 色88888久久久久久影院按摩| 国产亚洲综合在线| 青青草国产成人99久久| 欧美性猛交xxxx乱大交退制版| 国产精品免费视频网站| 激情六月婷婷久久| 4438成人网| 亚洲自拍偷拍网站| 91视频免费观看| 中文字幕中文字幕在线一区| 国产一区二区三区黄视频 | 亚洲欧美怡红院| 国产精品一卡二| 欧美xxxxxxxxx| 久久国产人妖系列| 日韩三级高清在线| 青青青爽久久午夜综合久久午夜| 欧美视频在线观看一区| 亚洲日本一区二区| 97久久人人超碰| 日韩美女啊v在线免费观看| 成人国产精品免费观看视频| 国产日产亚洲精品系列| 国产高清在线观看免费不卡| 精品国内片67194| 久久福利资源站| 精品国产91乱码一区二区三区 | 亚洲午夜久久久久中文字幕久| 99久久久精品免费观看国产蜜| 中文字幕电影一区| 国产91在线看| 国产精品美女久久福利网站| 不卡在线视频中文字幕| 亚洲色图欧洲色图婷婷| 色婷婷综合激情| 亚洲国产精品一区二区久久恐怖片 | 久久久久久9999| 国产麻豆成人精品| 欧美激情资源网| 91免费看视频| 天天色天天操综合| 日韩欧美国产一区二区三区 | 成人av网址在线观看| 自拍偷拍欧美精品| 欧美在线观看一区| 日本欧美加勒比视频| 欧美一卡二卡在线| 国产成人在线看| 亚洲免费电影在线| 欧美一级免费大片| 国产电影一区二区三区| 亚洲色图色小说| 欧美顶级少妇做爰| 国产精品亚洲第一区在线暖暖韩国 | 9191成人精品久久| 国产精品99久久久| 亚洲资源中文字幕| 精品日产卡一卡二卡麻豆|