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

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

?? mmu.c

?? 一個基于MMU的操作系統
?? C
字號:
#include   	<s3c2410.h>
#include	<mmu.h>

static unsigned long *mmu_tlb_base = (unsigned long *) MMU_TABLE_BASE;


/****************************************************************************
* 段頁表項entry:[31:20]段基址,[11:10]為AP(控制訪問權限),[8:5]域,
*   [3:2]=CP(decide cached&buffered),[1:0]=0b10-->頁表項為段描述符
* MMU_SECDESC:
*   AP=0b11
*   DOMAIN=0
*   [1:0]=0b10--->頁表項為段描述符
* MMU_CACHEABLE:
*   C=1(bit[3])
*1. 將頁表放在SDRAM 開始處,即:MMU_TABLE_BASE = 0x3000000(in mmu.h)
*2. 對于64M SDRAM,其物理地址為0x30000000-0x33f00000,令其虛擬地址=物理地址
*3. 對于SFR,其物理地址為0x48000000-0x60000000,令其虛擬地址等于物理地址(請參考數據手冊P192)
*4. exception vector:虛擬地址0xffff0000,物理地址0x33f000000
*5. 進程號為PID的進程空間塊的虛擬地址為:PID*0x02000000到PID*0x02000000+0x01ffffff
*6. 進程0物理地址:0x30000000-0x300fffff
*7. 進程1物理地址:0x30100000-0x301fffff
*8. 進程2物理地址:0x30200000-0x302fffff
*9. .... ....
*10.進程62物理地址:0x33e00000-0x33efffff
*
******************************************************************************/
void mmu_tlb_init()
{
	unsigned long entry_index;

	/*SDRAM*/
	for(entry_index = SDRAM_BASE ; entry_index < SDRAM_BASE+SDRAM_SIZE; entry_index += 0x100000){
		/*section table's entry:AP=0b11,domain=0,Cached,write-through mode(WT)*/
		*(mmu_tlb_base+(entry_index>>20)) = entry_index |(0x03<<10)|(0<<5)|(1<<4)|(1<<3)|0x02;
	}

	/*SFR*/
	for(entry_index = 0x48000000; entry_index < 0x60000000; entry_index += 0x100000){
		/*section table's entry:AP=0b11,domain=0,NCNB*/		
		*(mmu_tlb_base+(entry_index>>20)) = entry_index |(0x03<<10)|(0<<5)|(1<<4)| 0x02;
	}

	/*進程1-23,25-35,48-62*/
	for(entry_index = 1; entry_index < 24; entry_index++){
		/*section table's entry:AP=0b11,domain=0,Cached,write-through mode(WT)*/		
		*(mmu_tlb_base+((entry_index*0x02000000)>>20)) = (entry_index*0x00100000+SDRAM_BASE) |(0x03<<10)|(0<<5)|(1<<4)|(1<<3)|0x02;
	}

	for(entry_index = 25; entry_index < 36; entry_index++){
		/*section table's entry:AP=0b11,domain=0,Cached,write-through mode(WT)*/		
		*(mmu_tlb_base+((entry_index*0x02000000)>>20)) = (entry_index*0x00100000+SDRAM_BASE) |(0x03<<10)|(0<<5)|(1<<4)|(1<<3)|0x02;
	}

	for(entry_index = 48; entry_index < TASK_NR; entry_index++){
		/*section table's entry:AP=0b11,domain=0,Cached,write-through mode(WT)*/		
		*(mmu_tlb_base+((entry_index*0x02000000)>>20)) = (entry_index*0x00100000+SDRAM_BASE) |(0x03<<10)|(0<<5)|(1<<4)|(1<<3)|0x02;
	}

	/*exception vector*/
	/*section table's entry:AP=0b11,domain=0,Cached,write-through mode(WT)*/			
	*(mmu_tlb_base+(0xffff0000>>20)) = (VECTORS_PHY_BASE)|(0x03<<10)|(0<<5)|(1<<4)|(1<<3)|0x02;

	/*SDRAM_RAW_RW_VA_BASE開始的64M虛擬地址*/
	/*大于32M,所以不需要經過PID轉換即可訪問物理內存*/
	/*用于在不同進程中從nand flash中復制代碼到內存,以及從其他進程訪問另一個進程的空間*/
	for(entry_index = SDRAM_RAW_RW_VA_BASE; entry_index < SDRAM_RAW_RW_VA_BASE + SDRAM_SIZE; entry_index += 0x100000){
		/*section table's entry:AP=0b11,domain=0,Cached,write-through mode(WT)*/		
		*(mmu_tlb_base+((entry_index)>>20)) = (entry_index-SDRAM_RAW_RW_VA_BASE+SDRAM_BASE)|(0x03<<10)|(0<<5)|(1<<4)|(1<<3)|0x02; 
	}
}

/***************************************************************************
* 1.Invalidate I,D caches,drain write buffer,invalidate I,D TLBS
* 2.Load page table pointer
* 3.Write domain ID
* 4.Set MMU control registers(read-modify-write):
*	a.read: mrc p15, 0, r0, c1, c0, 0
*	b.modify:
*	       bit[13]=0,異常向量起始地址為0x00000000
*	       bit[12]=0,Instruction cache disable
*	       bit[9:8]=0b00,RS=0b00(因為頁表中AP=0b11,所以RS的作用忽略)
*	       bit[7]=0,Little-endian operation
*	       bit[2]=0b000,Data cache disabel
*	       bit[1:0]=0b11,Data alignment checking enable,MMU enable
*	c.write: mcr p15, 0, r0, c1, c0, 0
***************************************************************************/
void mmu_init()
{
	unsigned long ttb = MMU_TABLE_BASE;

__asm__(
	"mov	r0, #0\n"
	
	/* invalidate I,D caches on v4 */
	"mcr	p15, 0, r0, c7, c7, 0\n"
	
	/* drain write buffer on v4 */
	"mcr	p15, 0, r0, c7, c10, 4\n"
	
	/* invalidate I,D TLBs on v4 */
	"mcr	p15, 0, r0, c8, c7, 0\n"
	
	/* Load page table pointer */
	"mov	r4, %0\n"
	"mcr	p15, 0, r4, c2, c0, 0\n"
	
	/* Write domain id (cp15_r3) */
	"mvn	r0, #0\n"		/*0b11=Manager*/
	"mcr	p15, 0, r0, c3, c0, 0\n"
	
	/* Set control register v4 */
	"mrc	p15, 0, r0, c1, c0, 0\n"
	
	/* Clear out 'unwanted' bits (then put them in if we need them) */
	"ldr 	r1, =0x1384\n"
	"bic	r0, r0, r1\n"
	
	/* Turn on what we want */
	/*Base location of exceptions = 0xffff0000*/
	"orr	r0, r0, #0x2000\n"	
	/* Fault checking enabled */
	"orr	r0, r0, #0x0002\n"
#ifdef CONFIG_CPU_D_CACHE_ON		/*is not set*/
	"orr	r0, r0, #0x0004\n"
#endif  
#ifdef CONFIG_CPU_I_CACHE_ON		/*is not set*/ 
	"orr	r0, r0, #0x1000\n"
#endif  
	/* MMU enabled */
	"orr	r0, r0, #0x0001\n"
	
	/* write control register *//*write control register P545*/
	"mcr	p15, 0, r0, c1, c0, 0\n"
	: /* no outputs */
	: "r" (ttb) );	
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
99视频精品免费视频| 国产成人在线网站| 中文字幕一区二区日韩精品绯色| 在线精品国精品国产尤物884a| 99精品国产一区二区三区不卡| 国产精品亚洲午夜一区二区三区| 久久99在线观看| 激情欧美一区二区| 国产成人在线影院| 99精品视频在线播放观看| 成人免费观看视频| 91污片在线观看| 在线观看视频一区二区 | 91片黄在线观看| 不卡视频一二三四| 99综合影院在线| 在线欧美小视频| 欧美精品第1页| 日韩免费观看高清完整版| 久久视频一区二区| 中文字幕国产一区| 一区二区三区四区国产精品| 亚洲主播在线观看| 青娱乐精品视频在线| 国v精品久久久网| 99亚偷拍自图区亚洲| 欧美中文字幕一区二区三区| 国产成人免费视频精品含羞草妖精| 国产成人啪午夜精品网站男同| 成人免费高清视频| 欧美日韩一区二区三区免费看| 欧美一区二区三区四区视频| 久久精品网站免费观看| 亚洲男同性视频| 激情五月激情综合网| 91美女在线看| 精品欧美一区二区三区精品久久 | 日韩一区二区三区四区五区六区| 欧美mv日韩mv| 亚洲免费在线电影| 美女高潮久久久| 91视频免费看| 欧美精品一区二区在线播放| 亚洲精品成人少妇| 国内精品国产成人| 欧美在线啊v一区| 国产三级精品视频| 日本女优在线视频一区二区| av中文字幕在线不卡| 日韩欧美亚洲国产精品字幕久久久| 亚洲国产成人自拍| 老司机午夜精品| 91福利在线观看| 中文字幕av一区 二区| 蜜臀91精品一区二区三区| 91丨九色丨尤物| 国产欧美精品一区二区色综合朱莉| 亚洲成人av在线电影| 91亚洲精华国产精华精华液| 久久精品免费在线观看| 久久精品国产一区二区三区免费看| 99久久久久久99| 国产日韩精品久久久| 寂寞少妇一区二区三区| 91精品婷婷国产综合久久| 亚洲一区二区四区蜜桃| 99精品偷自拍| 国产精品久久久久影视| 国产精品1024| 久久久91精品国产一区二区精品| 美脚の诱脚舐め脚责91| 91精品国产综合久久久蜜臀粉嫩 | 亚洲自拍偷拍麻豆| 91老师片黄在线观看| 国产精品三级在线观看| 国产成人丝袜美腿| 欧美国产精品v| 成人av电影在线网| 国产精品久久久久国产精品日日| 国产精品99久久久久久久vr | 国产成人aaa| 国产视频一区二区在线| 国产原创一区二区| 久久女同精品一区二区| 国产在线精品视频| 国产日韩欧美一区二区三区乱码| 国产精品123| 中文字幕成人在线观看| 成人app网站| 夜夜嗨av一区二区三区中文字幕| 一本大道av一区二区在线播放| 日韩码欧中文字| 欧美日韩亚洲综合一区| 轻轻草成人在线| 欧美激情一区在线| 一本到不卡精品视频在线观看| 亚洲综合999| 日韩亚洲欧美在线观看| 黄色精品一二区| 亚洲欧美中日韩| 欧美视频精品在线观看| 麻豆免费看一区二区三区| 久久精品欧美一区二区三区麻豆| 99精品偷自拍| 天天色天天爱天天射综合| 精品国产乱子伦一区| 成人看片黄a免费看在线| 亚洲一区二区中文在线| 久久久蜜臀国产一区二区| 成人av免费在线观看| 午夜精品久久久久久久久| 欧美精品一区二区三| 91免费观看在线| 黄色日韩网站视频| 亚洲综合视频在线| 久久久久久久久岛国免费| 日本久久电影网| 经典一区二区三区| 亚洲国产欧美在线人成| 国产欧美日韩不卡| 69av一区二区三区| 色婷婷综合激情| 国产一区二区三区久久悠悠色av| 亚洲精品成人精品456| 亚洲精品在线免费观看视频| 91亚洲国产成人精品一区二区三| 久久超碰97中文字幕| 亚洲欧美激情插| 国产亚洲欧美日韩日本| 91.麻豆视频| 色8久久精品久久久久久蜜 | 久久久不卡影院| 欧美吻胸吃奶大尺度电影| 国产成人免费视频网站| 麻豆国产欧美日韩综合精品二区| 亚洲视频资源在线| 欧美高清在线一区| 精品国产乱码久久久久久久| 欧美日韩一区不卡| 91蜜桃视频在线| av成人老司机| 成人免费看视频| 国产馆精品极品| 韩日av一区二区| 九九久久精品视频| 裸体在线国模精品偷拍| 日本va欧美va欧美va精品| 亚洲成年人网站在线观看| 一区二区三区日韩在线观看| 亚洲丝袜另类动漫二区| 国产精品久久久久久久久免费丝袜| 精品av综合导航| 日韩色视频在线观看| 日韩欧美一区二区在线视频| 欧美精品久久久久久久久老牛影院| 欧美日韩在线播放三区| 欧美中文字幕久久 | 亚洲激情五月婷婷| 伊人夜夜躁av伊人久久| 玉米视频成人免费看| 亚洲黄色免费电影| 亚洲成人免费观看| 日韩精品成人一区二区在线| 视频一区二区欧美| 卡一卡二国产精品 | 国产在线精品一区二区三区不卡| 免费久久99精品国产| 蜜桃一区二区三区在线观看| 久久精品国产一区二区| 激情综合网av| 粗大黑人巨茎大战欧美成人| 99久久综合99久久综合网站| 99久久婷婷国产综合精品| 欧美在线观看你懂的| 色哟哟日韩精品| 欧美日高清视频| 日韩你懂的在线观看| 国产欧美综合色| 怡红院av一区二区三区| 免费精品99久久国产综合精品| 精品系列免费在线观看| 成人美女视频在线看| 色悠久久久久综合欧美99| 777欧美精品| 国产丝袜欧美中文另类| 亚洲一区二区av电影| 美女一区二区久久| 不卡的av电影在线观看| 欧美日韩一二三| 国产农村妇女毛片精品久久麻豆| 亚洲免费高清视频在线| 日本美女一区二区三区视频| 国产成人在线观看免费网站| 色偷偷成人一区二区三区91| 日韩欧美中文字幕一区| 日韩一区在线免费观看| 久久精品国产一区二区三| 99久久精品免费看国产免费软件| 91精品国产品国语在线不卡| 国产精品久久久久婷婷二区次|