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

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

?? mmue500alib.s

?? vxworks的源代碼
?? S
字號:
/* mmuE500ALib.s -  *//* Copyright 1984-2002 Wind River Systems, Inc. */	.data	.globl	copyright_wind_river	.long	copyright_wind_river/*modification history--------------------01b,07jan03,dtr  Adding functions for static TLB accesses.01a,13dec02,dtr  Moving defines to ppc85xx.h.*//* */#define _ASMLANGUAGE#include "vxWorks.h"#if (CPU==PPC85XX)# include <arch/ppc/ppc85xx.h># include <arch/ppc/mmuE500Lib.h>#endif /* CPU *//* defines */#if	(CPU == PPC85XX)# define TLB_V_BIT	0	/* valid bit is at bit 22 of word 0 */# define TLB_N_WORDS	3	/* three TLB words, 0, 1, and 2 */# define L2_ENTRY_SIZE	4	/* power of 2 => 16 bytes */#else	/* CPU */# error "CPU value not supported"#endif	/* CPU *//* * stack frame used for saving and restoring registers during the miss calls */#define TLB_FRAME_SIZE	   0x18#define R18_OFFSET	   (TLB_FRAME_SIZE - 0x04)#define CR_OFFSET	   (TLB_FRAME_SIZE - 0x08)#define R19_OFFSET	   (TLB_FRAME_SIZE - 0x0C)#define R20_OFFSET	   (TLB_FRAME_SIZE - 0x10)#define R21_OFFSET	   (TLB_FRAME_SIZE - 0x14)#define R22_OFFSET	   (TLB_FRAME_SIZE - 0x18)/* externals */	DATA_IMPORT(mmuAddrMapArray)/* globals */	FUNC_EXPORT(mmuPpcPidSet)		/* set the PID register */	FUNC_EXPORT(mmuPpcPidGet)		/* get the PID register */	FUNC_EXPORT(mmuE500TlbDynamicInvalidate) /* Invalidate L1 dynamic TLB1 entries */	FUNC_EXPORT(mmuE500TlbStaticInvalidate)  /* Invalidate L2 static (CAM) TLB1 entries */	FUNC_EXPORT(mmuPpcE500Tlbie)		/* get ESR */	FUNC_EXPORT(mmuPpcInstTlbMissHandler)	/* instr tlb miss handler */	FUNC_EXPORT(mmuPpcDataTlbMissHandler)	/* data tlb miss handler */	FUNC_EXPORT(mmuPpcTlbWriteEntryWord0)	/* write TLB entry word 0 */	FUNC_EXPORT(mmuPpcTlbWriteEntryWord1)	/* write TLB entry word 1 */	FUNC_EXPORT(mmuPpcTlbWriteEntryWord2)	/* write TLB entry word 2 */	FUNC_EXPORT(mmuPpcTlbWriteExecute)	/* execute MAS registers and sync tlb */		_WRS_TEXT_SEG_START/********************************************************************************* mmuPpcTlbWriteEntryWord0 - TLB Write Entry Word 0**/FUNC_BEGIN(mmuPpcTlbWriteEntryWord0)	mtspr MAS1,r3	isync	blrFUNC_END(mmuPpcTlbWriteEntryWord0)/********************************************************************************* mmuPpcTlbWriteEntryWord1 - TLB Write Entry Word 1**/FUNC_BEGIN(mmuPpcTlbWriteEntryWord1)	mtspr MAS2,r3	isync	blrFUNC_END(mmuPpcTlbWriteEntryWord1)/********************************************************************************* mmuPpcTlbWriteEntryWord0 - TLB Write Entry Word 0**/FUNC_BEGIN(mmuPpcTlbWriteEntryWord2)	mtspr MAS3,r3	isync	blrFUNC_END(mmuPpcTlbWriteEntryWord2)/********************************************************************************* mmuPpcTlbWriteExecute - Execute TLB Update **/FUNC_BEGIN(mmuPpcTlbWriteExecute)	mtspr MAS0,r3	isync	tlbwe	tlbsync	blrFUNC_END(mmuPpcTlbWriteExecute)/********************************************************************************* mmuE500TlbDynamicInvalidate - Invalidate TLB1 dynamic entries **/FUNC_BEGIN(mmuE500TlbDynamicInvalidate)	lis p0, HIADJ( _PPC_MMUCSR0_DL1MMU_FI | \		       _PPC_MMUCSR0_IL1MMU_FI | \		       _PPC_MMUCSR0_L2TLB0_FI)		addi p0, p0, LO ( _PPC_MMUCSR0_DL1MMU_FI | \		          _PPC_MMUCSR0_IL1MMU_FI | \			  _PPC_MMUCSR0_L2TLB0_FI)	mtspr MMUCSR0, p0	isync	tlbsync	blrFUNC_END(mmuE500TlbDynamicInvalidate)/********************************************************************************* mmuE500TlbStaticInvalidate - Invalidate TLB1 static entries **/FUNC_BEGIN(mmuE500TlbStaticInvalidate)	lis p0, HIADJ(_PPC_MMUCSR0_L2TLB1_FI)		addi p0, p0, LO (_PPC_MMUCSR0_L2TLB1_FI)	mtspr MMUCSR0, p0	isync	tlbsync	blrFUNC_END(mmuE500TlbStaticInvalidate)/********************************************************************************* mmuPpcPidSet - set the PID register**/FUNC_BEGIN(mmuPpcPidSet)	mtspr	PID, r3	blrFUNC_END(mmuPpcPidSet)/********************************************************************************* mmuPpcPidGet - get the PID register**/FUNC_BEGIN(mmuPpcPidGet)	mfspr	r3, PID	blrFUNC_END(mmuPpcPidGet)/********************************************************************************* mmuPpcE500Tlbie - Invalidate tlb entry for the specified effective addr** INPUTS: effectiveAddr (EA) in r4** USAGE: int mmuPpcE500Tlbie (MMU_TRANS_TBL *pTransTbl,void * effAddr);** RETURNS: None.**/FUNC_BEGIN(mmuPpcE500Tlbie)        sync        tlbivax r0,r4        tlbsync        blr             FUNC_END(mmuPpcE500Tlbie)/********************************************************************************* mmuPpcInstTlbMissHandler - Instruction TLB Miss handler for PPC4XX**/FUNC_BEGIN(mmuPpcInstTlbMissHandler)	addi	sp, sp, -TLB_FRAME_SIZE	stw	r18, R18_OFFSET(r1)	/* save R18 */	mfcr	r18		stw	r18, CR_OFFSET(r1)  /* save CR (because we modify it later) */	stw	r19, R19_OFFSET(r1)	/* save R19 */	stw	r20, R20_OFFSET(r1)	/* save R20 */	stw	r21, R21_OFFSET(r1)	/* save R21 */	stw	r22, R22_OFFSET(r1)	/* save R22 */	mfsrr0	r18  	 	/* load R18 with instr. miss eff. address */	mfspr	r19, PID 	/* read current PID register */		lis	r20, HI(mmuAddrMapArray)	/* read addr of mmu map table */	ori	r20, r20, LO(mmuAddrMapArray) 	li	r21, 2		/* size of each addr map entry in power of 2 */	slw	r19, r19, r21	add	r20, r20, r19	/* index into mmu map table */	lwz	r20, 0(r20)	/* read pointer to MMU_TRANS_TBL struct */	lwz	r20, 0(r20)	/* read pointer to Level 1 table */	mr	r19, r18	/* get instr miss addr */	rlwinm	r19, r19, 10, 22, 31	/* get index into level 1 table */		slw	r19, r19, r21	/* multiply index by size of L1 entry */	add	r20, r20, r19	/* index into L1 table */	lwz	r20, 0(r20)	/* load Level 1 page entry */	rlwinm. r19, r20, 0, 31, 31	/* test Valid bit */	beq	mmuPpcInstTlbError	/* if entry not valid then exit */	rlwinm	r20, r20, 0, 0, 29	/* mask of lower 2 bits */					/* r20 now has the base of l2 table */	mr	r19, r18	/* get instr miss addr */	rlwinm	r19, r19, 20, 22, 31 /* get index into level 2 table */	li	r21, L2_ENTRY_SIZE	/* each L2 entry is 2^size words long */	slw	r19, r19, r21	/* multiply index by size of L2 entry */	add	r18, r20, r19	/* index into L2 table */	lwz	r20, 0(r18)	/* word 0 of tlb entry */	lwz 	r21, 4(r18)	/* word 1 of tlb entry */	lwz 	r22, 8(r18)	/* word 2 of tlb entry */	rlwinm. r19, r20, 0, TLB_V_BIT, TLB_V_BIT 	/* test Valid bit */	beq	mmuPpcInstTlbError	/* if entry not valid then exit */        sync        mtspr   MAS1, r20        mtspr   MAS2, r21        mtspr   MAS3, r22        tlbwe        isync	lwz	r22, R22_OFFSET(r1)	/* load R22 */	lwz	r21, R21_OFFSET(r1)	/* load R21 */	lwz	r20, R20_OFFSET(r1)	/* load R20 */	lwz	r19, R19_OFFSET(r1)	/* load R19 */	lwz	r18, CR_OFFSET(r1)  /* load CR  */	mtcr	r18	lwz	r18, R18_OFFSET(r1)	/* load R18 */	addi	sp, sp, TLB_FRAME_SIZE	rfimmuPpcInstTlbError:	lwz	r22, R22_OFFSET(r1)	/* load R22 */	lwz	r21, R21_OFFSET(r1)	/* load R21 */	lwz	r20, R20_OFFSET(r1)	/* load R20 */	lwz	r19, R19_OFFSET(r1)	/* load R19 */	lwz	r18, CR_OFFSET(r1)  /* load CR  */	mtcr	r18	lwz	r18, R18_OFFSET(r1)	/* load R18 */	addi	sp, sp, TLB_FRAME_SIZE        .long   0x48000402      /* ba vector 400 (instruction access				 * exception)				 */FUNC_END(mmuPpcInstTlbMissHandler)/********************************************************************************* mmuPpcDataTlbMissHandler - Data TLB Miss handler for PPC4XX**/FUNC_BEGIN(mmuPpcDataTlbMissHandler)	addi	sp, sp, -TLB_FRAME_SIZE	stw	r18, R18_OFFSET(r1)	/* save R18 */	mfcr	r18		stw	r18, CR_OFFSET(r1)  /* save CR (because we modify it later) */	stw	r19, R19_OFFSET(r1)	/* save R19 */	stw	r20, R20_OFFSET(r1)	/* save R20 */	stw	r21, R21_OFFSET(r1)	/* save R21 */	stw	r22, R22_OFFSET(r1)	/* save R22 */	mfspr	r18, DEAR       /* load R18 with data miss effective address */	mfspr	r19, PID 	/* read current PID register */		lis	r20, HI(mmuAddrMapArray)	/* read addr of mmu map table */	ori	r20, r20, LO(mmuAddrMapArray) 	li	r21, 2		/* size of each addr map entry in power of 2 */	slw	r19, r19, r21		add	r20, r20, r19	/* index into mmu map table */	lwz	r20, 0(r20)	/* read pointer to MMU_TRANS_TBL struct */	lwz	r20, 0(r20)	/* read pointer to Level 1 table */	mr	r19, r18	/* get data miss addr */	rlwinm	r19, r19, 10, 22, 31	/* get index into level 1 table */	slw	r19, r19, r21	/* multiply index by size of L1 entry */	add	r20, r20, r19	/* index into L1 table */	lwz	r20, 0(r20)	/* load Level 1 page entry */	rlwinm. r19, r20, 0, 31, 31	/* test Valid bit */	beq	mmuPpcDataTlbError	/* if entry not valid then exit */	rlwinm	r20, r20, 0, 0, 29	/* mask of lower 2 bits */					/* r20 now has the base of l2 table */	mr	r19, r18	/* get data miss addr */	rlwinm	r19, r19, 20, 22, 31 /* get index into level 2 table */	li	r21, L2_ENTRY_SIZE	/* each L2 entry is 2^size words long */	slw	r19, r19, r21	/* multiply index by size of L2 entry */	add	r18, r20, r19	/* index into L2 table */	lwz	r20, 0(r18)	/* word 0 of tlb entry */	lwz 	r21, 4(r18)	/* word 1 of tlb entry */	lwz 	r22, 8(r18)	/* word 2 of tlb entry */	rlwinm. r19, r20, 0, TLB_V_BIT, TLB_V_BIT	/* test Valid bit */	beq	mmuPpcDataTlbError	/* if entry not valid then exit */        sync        mtspr   MAS1, r20        mtspr   MAS2, r21        mtspr   MAS3, r22        tlbwe        isync	lwz	r22, R22_OFFSET(r1)	/* load R22 */	lwz	r21, R21_OFFSET(r1)	/* load R21 */	lwz	r20, R20_OFFSET(r1)	/* load R20 */	lwz	r19, R19_OFFSET(r1)	/* load R19 */	lwz	r18, CR_OFFSET(r1)  /* load CR  */	mtcr	r18	lwz	r18, R18_OFFSET(r1)	/* load R18 */	addi	sp, sp, TLB_FRAME_SIZE	rfimmuPpcDataTlbError:	lwz	r22, R22_OFFSET(r1)	/* load R22 */	lwz	r21, R21_OFFSET(r1)	/* load R21 */	lwz	r20, R20_OFFSET(r1)	/* load R20 */	lwz	r19, R19_OFFSET(r1)	/* load R19 */	lwz	r18, CR_OFFSET(r1)  /* load CR  */	mtcr	r18	lwz	r18, R18_OFFSET(r1)	/* load R18 */	addi	sp, sp, TLB_FRAME_SIZE        .long   0x48000302      /* ba vector 300 (data access				 * exception)				 */FUNC_END(mmuPpcDataTlbMissHandler)

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
午夜精品国产更新| 亚洲天天做日日做天天谢日日欢| 亚洲欧美中日韩| 91精彩视频在线| 亚洲午夜久久久久久久久电影院 | 欧美日韩国产精品成人| 亚洲国产一区视频| 亚洲午夜激情av| 日韩精彩视频在线观看| 中文在线免费一区三区高中清不卡| 波多野结衣在线一区| 日韩视频一区二区在线观看| 国内成+人亚洲+欧美+综合在线 | 色综合咪咪久久| 精品一区二区在线视频| 洋洋av久久久久久久一区| 日韩欧美综合在线| 久久久久久久久99精品| 色欧美88888久久久久久影院| 色婷婷久久综合| 666欧美在线视频| 91麻豆国产福利在线观看| 麻豆精品视频在线观看视频| 中文字幕 久热精品 视频在线 | 国产风韵犹存在线视精品| 天天色 色综合| 激情另类小说区图片区视频区| 国产制服丝袜一区| www.av亚洲| 欧美一区二区三区色| 欧美日本在线一区| 国产夜色精品一区二区av| 日韩精品最新网址| 欧美高清精品3d| 欧美精品一卡两卡| 国产精品无码永久免费888| www国产成人| 欧美大片免费久久精品三p | 欧美性一级生活| 91丨porny丨国产入口| 欧美日韩在线不卡| 91视频91自| 精品国精品国产| 精品国产乱码久久久久久久| 亚洲日穴在线视频| 国产一区二区影院| 国产精品888| 处破女av一区二区| 99久久夜色精品国产网站| 99久久综合精品| 日韩欧美一区二区视频| 亚洲黄色小说网站| 亚洲综合av网| 午夜视频一区二区三区| www.亚洲精品| 久久精品亚洲乱码伦伦中文| 免费成人小视频| 国产精品18久久久| 欧美成人福利视频| 国产午夜精品在线观看| 日本不卡在线视频| 国产一区欧美一区| 欧美一区二视频| 婷婷中文字幕综合| 欧美高清性hdvideosex| 一区二区三区不卡在线观看| 91碰在线视频| 精品福利视频一区二区三区| 丝袜亚洲另类丝袜在线| 欧美综合亚洲图片综合区| 欧美日韩一区二区三区在线| 国产精品美女一区二区三区| 国产xxx精品视频大全| 色伊人久久综合中文字幕| 国产精品久久国产精麻豆99网站| 亚洲午夜久久久久| 欧美三级日本三级少妇99| 一区二区三区四区av| 色狠狠一区二区| 亚洲成人7777| 国产高清在线精品| 国产日韩综合av| 日韩中文字幕一区二区三区| 欧美日本一区二区| 美脚の诱脚舐め脚责91 | 91国偷自产一区二区三区成为亚洲经典| 色婷婷久久99综合精品jk白丝| 亚洲欧洲综合另类| 精品一区二区免费看| 欧美精品一区二区三区蜜桃视频| 极品少妇一区二区| 中文字幕国产一区二区| 一本久久精品一区二区| 亚洲成人自拍网| 精品国产免费人成电影在线观看四季| 老司机午夜精品| 欧美老肥妇做.爰bbww视频| 日韩成人一级大片| 久久亚洲精精品中文字幕早川悠里| 国产精品综合网| 一区二区免费看| 亚洲精品一区二区三区福利 | 亚洲一区二区三区在线看| 制服.丝袜.亚洲.中文.综合| 国产精品自拍在线| 一区二区三区在线观看视频| 日韩情涩欧美日韩视频| av电影在线观看不卡| 亚洲综合一区在线| 精品国产青草久久久久福利| 99久久综合国产精品| 日韩成人一级片| 亚洲欧洲一区二区在线播放| 制服.丝袜.亚洲.中文.综合| heyzo一本久久综合| 免费人成在线不卡| 亚洲狼人国产精品| 国产情人综合久久777777| 欧美视频一二三区| www.66久久| 国产精品一级片| 午夜欧美视频在线观看| 日韩一区有码在线| 精品国产电影一区二区 | 久久国产免费看| 亚洲国产视频一区| 中文字幕在线播放不卡一区| 日韩视频一区二区在线观看| 欧美色网站导航| 色欲综合视频天天天| 国产99一区视频免费 | www.成人在线| 国产成人亚洲综合a∨猫咪| 美国十次综合导航| 日韩av高清在线观看| 尤物av一区二区| 亚洲视频一区在线| 欧美激情综合五月色丁香| 精品国产乱码久久久久久夜甘婷婷 | 欧美日韩国产高清一区| 99精品视频在线播放观看| 高清不卡一区二区| 国产乱妇无码大片在线观看| 蜜臀av性久久久久蜜臀aⅴ流畅 | 日韩影院精彩在线| 午夜av一区二区三区| 亚洲国产精品麻豆| 亚洲精品视频一区| 亚洲视频图片小说| 亚洲精选一二三| 成人免费在线播放视频| 综合色中文字幕| 亚洲视频综合在线| 亚洲国产一区二区三区青草影视| 伊人色综合久久天天人手人婷| 国产精品嫩草99a| 国产精品久久久久久户外露出| 国产精品毛片大码女人| 国产精品久久久久久久久图文区| 国产精品电影一区二区三区| 国产精品久线在线观看| 亚洲人成人一区二区在线观看 | 精品99久久久久久| 久久影院视频免费| 国产精品色在线| 亚洲精品视频一区二区| 日韩中文字幕亚洲一区二区va在线 | 欧美在线影院一区二区| 欧美日韩久久不卡| 日韩欧美色综合网站| 久久精品亚洲麻豆av一区二区| 专区另类欧美日韩| 亚洲香蕉伊在人在线观| 青青青爽久久午夜综合久久午夜| 久久99深爱久久99精品| 高清日韩电视剧大全免费| 色综合久久天天综合网| 制服丝袜av成人在线看| 国产农村妇女精品| 亚洲午夜私人影院| 国产乱码字幕精品高清av| 91麻豆123| 久久亚洲私人国产精品va媚药| 国产精品理论片| 日本亚洲三级在线| 成人国产精品免费观看视频| 欧美综合视频在线观看| 久久久久久久久久美女| 一区二区三区精品在线观看| 美女精品自拍一二三四| 91看片淫黄大片一级在线观看| 91精品国产乱| 最新国产精品久久精品| 人人精品人人爱| 在线视频观看一区| 精品国产污污免费网站入口 | 欧美日韩国产经典色站一区二区三区| 久久久噜噜噜久久中文字幕色伊伊| 亚洲综合免费观看高清完整版在线 | 亚洲欧美激情一区二区|