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

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

?? cache_4xx.s

?? u-boot1.3.0的原碼,從配了網(wǎng)絡(luò)驅(qū)動和FLASH的驅(qū)動,并該用ESC竟如
?? S
字號:
/* * (C) Copyright 2007 * Wolfgang Denk, DENX Software Engineering, wd@denx.de. * * Author: Igor Lisitsin <igor@emcraft.com> * * 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 */#include <config.h>#ifdef CONFIG_POST#include <post.h>#include <ppc_asm.tmpl>#include <ppc_defs.h>#include <asm/cache.h>#include <asm/mmu.h>#if CONFIG_POST & CFG_POST_CACHE	.text	/*	 * All 44x variants deal with cache management differently	 * because they have the address translation always enabled.	 * The 40x ppc's don't use address translation in U-Boot at all,	 * so we have to distinguish here between 40x and 44x.	 */#ifdef CONFIG_440/* void cache_post_disable (int tlb) */cache_post_disable:	tlbre	r0, r3, 0x0002	ori	r0, r0, TLB_WORD2_I_ENABLE@l	tlbwe	r0, r3, 0x0002	sync	isync	blr/* void cache_post_wt (int tlb) */cache_post_wt:	tlbre	r0, r3, 0x0002	ori	r0, r0, TLB_WORD2_W_ENABLE@l	andi.	r0, r0, ~TLB_WORD2_I_ENABLE@l	tlbwe	r0, r3, 0x0002	sync	isync	blr/* void cache_post_wb (int tlb) */cache_post_wb:	tlbre	r0, r3, 0x0002	andi.	r0, r0, ~TLB_WORD2_W_ENABLE@l	andi.	r0, r0, ~TLB_WORD2_I_ENABLE@l	tlbwe	r0, r3, 0x0002	sync	isync	blr#else/* void cache_post_disable (int tlb) */cache_post_disable:	lis	r0, 0x0000	ori	r0, r0, 0x0000	mtdccr	r0	sync	isync	blr/* void cache_post_wt (int tlb) */cache_post_wt:	lis	r0, 0x8000	ori	r0, r0, 0x0000	mtdccr	r0	lis	r0, 0x8000	ori	r0, r0, 0x0000	mtdcwr	r0	sync	isync	blr/* void cache_post_wb (int tlb) */cache_post_wb:	lis	r0, 0x8000	ori	r0, r0, 0x0000	mtdccr	r0	lis	r0, 0x0000	ori	r0, r0, 0x0000	mtdcwr	r0	sync	isync	blr#endif/* void cache_post_dinvalidate (void *p, int size) */cache_post_dinvalidate:	dcbi	r0, r3	addi	r3, r3, CFG_CACHELINE_SIZE	subic.	r4, r4, CFG_CACHELINE_SIZE	bgt	cache_post_dinvalidate	sync	blr/* void cache_post_dstore (void *p, int size) */cache_post_dstore:	dcbst	r0, r3	addi	r3, r3, CFG_CACHELINE_SIZE	subic.	r4, r4, CFG_CACHELINE_SIZE	bgt	cache_post_dstore	sync	blr/* void cache_post_dtouch (void *p, int size) */cache_post_dtouch:	dcbt	r0, r3	addi	r3, r3, CFG_CACHELINE_SIZE	subic.	r4, r4, CFG_CACHELINE_SIZE	bgt	cache_post_dtouch	sync	blr/* void cache_post_iinvalidate (void) */cache_post_iinvalidate:	iccci	r0, r0	sync	blr/* void cache_post_memset (void *p, int val, int size) */cache_post_memset:	mtctr	r51:	stb	r4, 0(r3)	addi	r3, r3, 1	bdnz	1b	blr/* int cache_post_check (void *p, int size) */cache_post_check:	mtctr	r41:	lbz	r0, 0(r3)	addi	r3, r3, 1	cmpwi	r0, 0xff	bne	2f	bdnz	1b	li	r3, 0	blr2:	li	r3, -1	blr#define CACHE_POST_DISABLE()		\	mr	r3, r10;		\	bl	cache_post_disable#define CACHE_POST_WT()			\	mr	r3, r10;		\	bl	cache_post_wt#define CACHE_POST_WB()			\	mr	r3, r10;		\	bl	cache_post_wb#define CACHE_POST_DINVALIDATE()	\	mr	r3, r11;		\	mr	r4, r12;		\	bl	cache_post_dinvalidate#define CACHE_POST_DFLUSH()		\	mr	r3, r11;		\	mr	r4, r12;		\	bl	cache_post_dflush#define CACHE_POST_DSTORE()		\	mr	r3, r11;		\	mr	r4, r12;		\	bl	cache_post_dstore#define CACHE_POST_DTOUCH()		\	mr	r3, r11;		\	mr	r4, r12;		\	bl	cache_post_dtouch#define CACHE_POST_IINVALIDATE()	\	bl	cache_post_iinvalidate#define CACHE_POST_MEMSET(val)		\	mr	r3, r11;		\	li	r4, val;		\	mr	r5, r12;		\	bl	cache_post_memset#define CACHE_POST_CHECK()		\	mr	r3, r11;		\	mr	r4, r12;		\	bl	cache_post_check;	\	mr	r13, r3/* * Write and read 0xff pattern with caching enabled. */	.global cache_post_test1cache_post_test1:	mflr	r9	mr	r10, r3		/* tlb		*/	mr	r11, r4		/* p		*/	mr	r12, r5		/* size		*/	CACHE_POST_WB()	CACHE_POST_DINVALIDATE()	/* Write the negative pattern to the test area */	CACHE_POST_MEMSET(0xff)	/* Read the test area */	CACHE_POST_CHECK()	CACHE_POST_DINVALIDATE()	CACHE_POST_DISABLE()	mr	r3, r13	mtlr	r9	blr/* * Write zeroes with caching enabled. * Write 0xff pattern with caching disabled. * Read 0xff pattern with caching enabled. */	.global cache_post_test2cache_post_test2:	mflr	r9	mr	r10, r3		/* tlb		*/	mr	r11, r4		/* p		*/	mr	r12, r5		/* size		*/	CACHE_POST_WB()	CACHE_POST_DINVALIDATE()	/* Write the zero pattern to the test area */	CACHE_POST_MEMSET(0)	CACHE_POST_DINVALIDATE()	CACHE_POST_DISABLE()	/* Write the negative pattern to the test area */	CACHE_POST_MEMSET(0xff)	CACHE_POST_WB()	/* Read the test area */	CACHE_POST_CHECK()	CACHE_POST_DINVALIDATE()	CACHE_POST_DISABLE()	mr	r3, r13	mtlr	r9	blr/* * Write-through mode test. * Write zeroes, store the cache, write 0xff pattern. * Invalidate the cache. * Check that 0xff pattern is read. */	.global cache_post_test3cache_post_test3:	mflr	r9	mr	r10, r3		/* tlb		*/	mr	r11, r4		/* p		*/	mr	r12, r5		/* size		*/	CACHE_POST_WT()	CACHE_POST_DINVALIDATE()	/* Cache the test area */	CACHE_POST_DTOUCH()	/* Write the zero pattern to the test area */	CACHE_POST_MEMSET(0)	CACHE_POST_DSTORE()	/* Write the negative pattern to the test area */	CACHE_POST_MEMSET(0xff)	CACHE_POST_DINVALIDATE()	CACHE_POST_DISABLE()	/* Read the test area */	CACHE_POST_CHECK()	mr	r3, r13	mtlr	r9	blr/* * Write-back mode test. * Write 0xff pattern, store the cache, write zeroes. * Invalidate the cache. * Check that 0xff pattern is read. */	.global cache_post_test4cache_post_test4:	mflr	r9	mr	r10, r3		/* tlb		*/	mr	r11, r4		/* p		*/	mr	r12, r5		/* size		*/	CACHE_POST_WB()	CACHE_POST_DINVALIDATE()	/* Cache the test area */	CACHE_POST_DTOUCH()	/* Write the negative pattern to the test area */	CACHE_POST_MEMSET(0xff)	CACHE_POST_DSTORE()	/* Write the zero pattern to the test area */	CACHE_POST_MEMSET(0)	CACHE_POST_DINVALIDATE()	CACHE_POST_DISABLE()	/* Read the test area */	CACHE_POST_CHECK()	mr	r3, r13	mtlr	r9	blr/* * Load the test instructions into the instruction cache. * Replace the test instructions. * Check that the original instructions are executed. */	.global cache_post_test5cache_post_test5:	mflr	r9	mr	r10, r3		/* tlb		*/	mr	r11, r4		/* p		*/	mr	r12, r5		/* size		*/	CACHE_POST_WT()	CACHE_POST_IINVALIDATE()	/* Compute r13 = cache_post_test_inst */	bl	cache_post_test5_reloccache_post_test5_reloc:	mflr	r13	lis	r0, (cache_post_test_inst - cache_post_test5_reloc)@h	ori	r0, r0, (cache_post_test_inst - cache_post_test5_reloc)@l	add	r13, r13, r0	/* Copy the test instructions to the test area */	lwz	r0, 0(r13)	stw	r0, 0(r11)	lwz	r0, 8(r13)	stw	r0, 4(r11)	sync	/* Invalidate the cache line */	icbi	r0, r11	sync	isync	/* Execute the test instructions */	mtlr	r11	blrl	/* Replace the test instruction */	lwz	r0, 4(r13)	stw	r0, 0(r11)	sync	/* Do not invalidate the cache line */	isync	/* Execute the test instructions */	mtlr	r11	blrl	mr	r13, r3	CACHE_POST_IINVALIDATE()	CACHE_POST_DINVALIDATE()	CACHE_POST_DISABLE()	mr	r3, r13	mtlr	r9	blr/* * Load the test instructions into the instruction cache. * Replace the test instructions and invalidate the cache. * Check that the replaced instructions are executed. */	.global cache_post_test6cache_post_test6:	mflr	r9	mr	r10, r3		/* tlb		*/	mr	r11, r4		/* p		*/	mr	r12, r5		/* size		*/	CACHE_POST_WT()	CACHE_POST_IINVALIDATE()	/* Compute r13 = cache_post_test_inst */	bl	cache_post_test6_reloccache_post_test6_reloc:	mflr	r13	lis	r0, (cache_post_test_inst - cache_post_test6_reloc)@h	ori	r0, r0, (cache_post_test_inst - cache_post_test6_reloc)@l	add	r13, r13, r0	/* Copy the test instructions to the test area */	lwz	r0, 4(r13)	stw	r0, 0(r11)	lwz	r0, 8(r13)	stw	r0, 4(r11)	sync	/* Invalidate the cache line */	icbi	r0, r11	sync	isync	/* Execute the test instructions */	mtlr	r11	blrl	/* Replace the test instruction */	lwz	r0, 0(r13)	stw	r0, 0(r11)	sync	/* Invalidate the cache line */	icbi	r0, r11	sync	isync	/* Execute the test instructions */	mtlr	r11	blrl	mr	r13, r3	CACHE_POST_IINVALIDATE()	CACHE_POST_DINVALIDATE()	CACHE_POST_DISABLE()	mr	r3, r13	mtlr	r9	blr/* Test instructions. */cache_post_test_inst:	li	r3, 0	li	r3, -1	blr#endif /* CONFIG_POST & CFG_POST_CACHE */#endif /* CONFIG_POST */

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久九九国产精品| 精品国产免费一区二区三区香蕉 | 91高清视频免费看| 91视频免费看| 欧美午夜精品电影| 欧美日韩一级黄| 日韩欧美一级精品久久| 日韩一区二区三区视频在线观看| 国产日韩欧美一区二区三区乱码 | 91小视频免费看| 北条麻妃国产九九精品视频| 成人免费看视频| 日韩**一区毛片| 成人动漫一区二区三区| 秋霞午夜鲁丝一区二区老狼| 日韩不卡一二三区| 国产不卡视频在线播放| 99v久久综合狠狠综合久久| 色欧美片视频在线观看| 欧美久久久影院| 精品国产乱码久久久久久图片| 久久你懂得1024| 亚洲久草在线视频| 美美哒免费高清在线观看视频一区二区| 精品在线视频一区| 97se狠狠狠综合亚洲狠狠| 欧美性三三影院| 久久青草欧美一区二区三区| 亚洲日本va午夜在线影院| 丝袜美腿一区二区三区| 国产成人在线视频网址| 91在线观看视频| 精品久久久久av影院| 国产精品久久久久久久久快鸭| 午夜久久久久久电影| 丁香婷婷综合激情五月色| 成人综合在线视频| 在线不卡欧美精品一区二区三区| 久久欧美中文字幕| 亚洲国产精品影院| 福利视频网站一区二区三区| 欧美午夜不卡在线观看免费| 久久久久久电影| 日韩成人一区二区| 99久久er热在这里只有精品15| 欧美日韩精品是欧美日韩精品| 国产天堂亚洲国产碰碰| 亚洲成人av免费| 99天天综合性| 国产欧美精品一区| 日韩不卡一区二区三区| 欧美网站一区二区| 国产精品国产自产拍高清av王其 | 91精品蜜臀在线一区尤物| 亚洲欧美怡红院| 国产东北露脸精品视频| 欧美一级一级性生活免费录像| 一区二区三区精品久久久| 岛国av在线一区| 日韩一区二区高清| 午夜av区久久| 欧美色图在线观看| 亚洲美女视频一区| 色婷婷综合久久久久中文一区二区| 久久久国际精品| 国产一区二区三区在线观看免费| 欧美精品高清视频| 午夜影院久久久| 欧美性一区二区| 亚洲国产日韩a在线播放| 91免费在线视频观看| 亚洲欧洲精品一区二区精品久久久 | 成人国产视频在线观看| 亚洲国产成人午夜在线一区 | 91免费小视频| 亚洲影院免费观看| 欧美疯狂做受xxxx富婆| 日韩精品欧美成人高清一区二区| 欧美麻豆精品久久久久久| 婷婷综合另类小说色区| 欧美美女网站色| 男人的j进女人的j一区| 精品国产免费一区二区三区四区| 久久国内精品自在自线400部| 日韩欧美一级二级| 国产毛片精品国产一区二区三区| 久久综合狠狠综合久久激情 | 欧美日韩电影在线| 美脚の诱脚舐め脚责91| 国产片一区二区| av不卡一区二区三区| 一区二区三区精品| 欧美xxxxx牲另类人与| 国产精品香蕉一区二区三区| 国产精品久久久久影视| 欧美性生活一区| 韩国v欧美v日本v亚洲v| 中文字幕一区二区三区视频| 欧美午夜一区二区三区免费大片| 日韩高清不卡在线| 国产精品网曝门| 欧美图区在线视频| 蜜桃精品视频在线观看| 国产清纯白嫩初高生在线观看91| 色视频一区二区| 蜜臀av性久久久久蜜臀aⅴ流畅| 精品久久久影院| 色综合中文字幕国产| 亚洲国产wwwccc36天堂| 精品久久久久久久久久久久久久久| 99久久精品免费观看| 日韩国产一区二| 国产精品久久久久一区二区三区 | 岛国av在线一区| 亚洲.国产.中文慕字在线| 久久综合久久99| 欧美伊人久久久久久久久影院 | 蜜乳av一区二区| 亚洲精品日日夜夜| 国产午夜精品在线观看| 日本韩国欧美三级| 精品一区二区免费看| 亚洲一区自拍偷拍| 国产天堂亚洲国产碰碰| 日韩视频123| 欧洲激情一区二区| av资源站一区| 国产电影一区二区三区| 奇米一区二区三区| 亚洲黄色尤物视频| 国产精品电影一区二区三区| 精品伦理精品一区| 欧美一级国产精品| 91精品国产综合久久久久久久| 色综合久久中文综合久久97| 风间由美一区二区三区在线观看| 日韩极品在线观看| 亚洲韩国精品一区| 亚洲图片一区二区| 一区二区三区日韩| 亚洲乱码国产乱码精品精小说| 日本一二三不卡| 国产精品久久久久影视| 欧美国产一区二区| 亚洲国产精品精华液2区45| 国产视频一区二区三区在线观看| 精品久久久久久久久久久久久久久 | 成人精品gif动图一区| 国产精品69久久久久水密桃| 激情欧美日韩一区二区| 激情欧美日韩一区二区| 国产中文字幕一区| 国产福利精品导航| 成人激情小说乱人伦| 成人性生交大片免费看中文网站| 丁香一区二区三区| 97精品国产97久久久久久久久久久久 | 丁香啪啪综合成人亚洲小说 | 一区二区在线观看av| 亚洲色图丝袜美腿| 亚洲国产aⅴ天堂久久| 日韩精品成人一区二区在线| 蜜臀va亚洲va欧美va天堂| 韩国三级电影一区二区| 国产宾馆实践打屁股91| 91在线小视频| 91精品中文字幕一区二区三区| 91精品国产欧美日韩| 精品精品国产高清a毛片牛牛 | 亚洲黄网站在线观看| 日韩专区欧美专区| 国内偷窥港台综合视频在线播放| 国产成人精品综合在线观看| 99国产精品久久久久久久久久久| 欧美在线free| 精品国产电影一区二区| 国产精品久久久久久久久免费丝袜| 一个色综合av| 日本美女视频一区二区| 成人av免费在线观看| 欧美精品一卡二卡| 久久久久久久久97黄色工厂| 亚洲激情六月丁香| 麻豆久久久久久久| 99精品欧美一区二区蜜桃免费| 欧美精品日韩精品| 中文字幕va一区二区三区| 亚洲成人手机在线| 成人涩涩免费视频| 91精品国产免费| 亚洲精选免费视频| 国产乱国产乱300精品| 欧洲一区在线观看| 久久亚洲一级片| 午夜精品福利一区二区三区蜜桃| 国产美女精品人人做人人爽| 在线视频一区二区三| 久久久久久久久免费| 免费看日韩精品| 欧美日韩国产精选|