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

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

?? mmui86lib.c

?? vxwork源代碼
?? C
?? 第 1 頁 / 共 3 頁
字號:
 * mismatch in virtual/physical address space, or the called out function's  * disapearance.  It is guaranteed that this code is in physical memory. */#define MMU_ON() \    do { int tempReg; WRS_ASM ("movl %%cr0,%0; orl $0x80010000,%0; \    movl %0,%%cr0; jmp 0f; 0:" : "=r" (tempReg) : : "memory"); } while (0)#define MMU_OFF() \    do { int tempReg; WRS_ASM ("movl %%cr0,%0; andl $0x7ffeffff,%0; \    movl %0,%%cr0; jmp 0f; 0:" : "=r" (tempReg) : : "memory"); } while (0)#define MMU_UNLOCK(wasEnabled, oldLevel) \    do { if (((wasEnabled) = mmuI86Enabled) == TRUE) \	{INT_LOCK (oldLevel); MMU_OFF (); } \    } while (0)#define MMU_LOCK(wasEnabled, oldLevel) \    do { if ((wasEnabled) == TRUE) \        {MMU_ON (); INT_UNLOCK (oldLevel);} \    } while (0)/* inline version of mmuI86TLBFlush() */#define	MMU_TLB_FLUSH() \    do { int tempReg; WRS_ASM ("pushfl; cli; movl %%cr3,%0; \    movl %0,%%cr3; jmp 0f; 0: popfl; " : "=r" (tempReg) : : "memory"); \    } while (0)/******************************************************************************** mmuI86LibInit - initialize module** Build a dummy translation table that will hold the page table entries* for the global translation table.  The MMU remains disabled upon* completion.** RETURNS: OK if no error, ERROR otherwise** ERRNO: S_mmuLib_INVALID_PAGE_SIZE*/STATUS mmuI86LibInit     (    int pageSize	/* system pageSize (must be 4096 for i86) */    )    {    PTE *pDirectoryTable;    int i;    /* initialize the data objects that are shared with vmLib.c */    mmuStateTransArray = &mmuStateTransArrayLocal [0];    mmuStateTransArraySize =          sizeof (mmuStateTransArrayLocal) / sizeof (STATE_TRANS_TUPLE);    mmuLibFuncs = mmuLibFuncsLocal;    mmuPageBlockSize = PAGE_BLOCK_SIZE;    /* we assume a 4096 byte page size */    if (pageSize != PAGE_SIZE)	{	errno = S_mmuLib_INVALID_PAGE_SIZE;	return (ERROR);	}    mmuI86Enabled = FALSE;    mmuPageSize = pageSize;    /* allocate the global page block array to keep track of which parts     * of virtual memory are handled by the global translation tables.     * Allocate on page boundry so we can write protect it.     */    globalPageBlock = (BOOL *) memalign (pageSize, pageSize);    bzero ((char *) globalPageBlock, pageSize);    /* build a dummy translation table which will hold the pte's for     * global memory.  All real translation tables will point to this     * one for controling the state of the global virtual memory       */    /* allocate a page to hold the directory table */    mmuGlobalTransTbl.pDirectoryTable = pDirectoryTable = 	(PTE *) memalign (pageSize, pageSize);    if (pDirectoryTable == NULL)	return (ERROR);    /* invalidate all the directory table entries */    for (i = 0; i < (PAGE_SIZE / sizeof(PTE)) ;i++)	{	pDirectoryTable[i].field.present	= 0;	pDirectoryTable[i].field.rw		= 0;	pDirectoryTable[i].field.us		= 0;	pDirectoryTable[i].field.pwt		= 0;	pDirectoryTable[i].field.pcd		= 0;	pDirectoryTable[i].field.access		= 0;	pDirectoryTable[i].field.dirty		= 0;	pDirectoryTable[i].field.zero		= 0;	pDirectoryTable[i].field.avail		= 0;	pDirectoryTable[i].field.page		= -1;	}    return (OK);    }/******************************************************************************** mmuPteGet - get the pte for a given page** mmuPteGet traverses a translation table and returns the (physical) address of* the pte for the given virtual address.** RETURNS: OK or ERROR if there is no virtual space for the given address **/LOCAL STATUS mmuPteGet     (    MMU_TRANS_TBL *pTransTbl, 	/* translation table */    void *virtAddr,		/* virtual address */     PTE **result		/* result is returned here */    )    {    PTE *pDte;    PTE *pPageTable;    pDte = &pTransTbl->pDirectoryTable [(UINT) virtAddr >> DIRECTORY_INDEX];    pPageTable = (PTE *) (pDte->bits & PTE_TO_ADDR);     if ((UINT) pPageTable == 0xfffff000)	return (ERROR);    *result = &pPageTable[((UINT) virtAddr & TABLE_BITS) >> TABLE_INDEX];    return (OK);    }/******************************************************************************** mmuTransTblCreate - create a new translation table.** create a i86 translation table.  Allocates space for the MMU_TRANS_TBL* data structure and calls mmuTransTblInit on that object.  ** RETURNS: address of new object or NULL if allocation failed,*          or NULL if initialization failed.*/LOCAL MMU_TRANS_TBL *mmuTransTblCreate     (    )    {    MMU_TRANS_TBL *newTransTbl;    newTransTbl = (MMU_TRANS_TBL *) malloc (sizeof (MMU_TRANS_TBL));    if (newTransTbl == NULL)	return (NULL);    if (mmuTransTblInit (newTransTbl) == ERROR)	{	free ((char *) newTransTbl);	return (NULL);	}    return (newTransTbl);    }/******************************************************************************** mmuTransTblInit - initialize a new translation table ** Initialize a new translation table.  The directory table is copyed from the* global translation mmuGlobalTransTbl, so that we* will share the global virtual memory with all* other translation tables.* * RETURNS: OK or ERROR if unable to allocate memory for directory table.*/LOCAL STATUS mmuTransTblInit     (    MMU_TRANS_TBL *newTransTbl		/* translation table to be inited */    )    {    FAST PTE *pDirectoryTable;    /* allocate a page to hold the directory table */    newTransTbl->pDirectoryTable = pDirectoryTable = 	(PTE *) memalign (mmuPageSize, mmuPageSize);    if (pDirectoryTable == NULL)	return (ERROR);    /* copy the directory table from mmuGlobalTransTbl,     * so we get the global virtual memory      */    bcopy ((char *) mmuGlobalTransTbl.pDirectoryTable, 	   (char *) pDirectoryTable, mmuPageSize);    /* write protect virtual memory pointing to the the directory table in      * the global translation table to insure that it can't be corrupted      */    mmuStateSet (&mmuGlobalTransTbl, (void *) pDirectoryTable, 		 MMU_STATE_MASK_WRITABLE, MMU_STATE_WRITABLE_NOT);    return (OK);    }/******************************************************************************** mmuTransTblDelete - delete a translation table.* * mmuTransTblDelete deallocates all the memory used to store the translation* table entries.  It does not deallocate physical pages mapped into the* virtual memory space.** RETURNS: OK**/LOCAL STATUS mmuTransTblDelete     (    MMU_TRANS_TBL *transTbl		/* translation table to be deleted */    )    {    FAST int i;    FAST PTE *pDte = transTbl->pDirectoryTable;    FAST PTE *pPageTable;    /* write enable the physical page containing the directory table */    mmuStateSet (&mmuGlobalTransTbl, transTbl->pDirectoryTable, 		 MMU_STATE_MASK_WRITABLE, MMU_STATE_WRITABLE);    /* deallocate only non-global page blocks */    for (i = 0; i < (PAGE_SIZE / sizeof(PTE)); i++, pDte++)	if ((pDte->field.present == 1) && !globalPageBlock[i]) 	    {	    pPageTable = (PTE *) (pDte->bits & PTE_TO_ADDR);	    mmuStateSet (&mmuGlobalTransTbl, pPageTable,			 MMU_STATE_MASK_WRITABLE, MMU_STATE_WRITABLE);	    free (pPageTable);	    }    /* free the page holding the directory table */    free (transTbl->pDirectoryTable);    /* free the translation table data structure */    free (transTbl);        return (OK);    }/******************************************************************************** mmuVirtualPageCreate - set up translation tables for a virtual page** simply check if there's already a page table that has a* pte for the given virtual page.  If there isn't, create one.** RETURNS OK or ERROR if couldn't allocate space for a page table.*/LOCAL STATUS mmuVirtualPageCreate     (    MMU_TRANS_TBL *thisTbl, 		/* translation table */    void *virtPageAddr			/* virtual addr to create */    )    {    PTE *pDte;    FAST PTE *pPageTable;    FAST UINT i;    PTE *dummy;    if (mmuPteGet (thisTbl, virtPageAddr, &dummy) == OK)	return (OK);    pPageTable = (PTE *) memalign (mmuPageSize, mmuPageSize);    if (pPageTable == NULL)	return (ERROR);    /* invalidate every page in the new page block */    for (i = 0; i < (PAGE_SIZE / sizeof(PTE)); i++)	{	pPageTable[i].field.present	= 0;	pPageTable[i].field.rw		= 0;	pPageTable[i].field.us		= 0;	pPageTable[i].field.pwt		= 0;	pPageTable[i].field.pcd		= 0;	pPageTable[i].field.access	= 0;	pPageTable[i].field.dirty	= 0;	pPageTable[i].field.zero	= 0;	pPageTable[i].field.avail	= 0;	pPageTable[i].field.page	= -1;	}    /* write protect the new physical page containing the pte's       for this new page block */    mmuStateSet (&mmuGlobalTransTbl, pPageTable,    		 MMU_STATE_MASK_WRITABLE, MMU_STATE_WRITABLE_NOT);     /* unlock the physical page containing the directory table,       so we can modify it */    mmuStateSet (&mmuGlobalTransTbl, thisTbl->pDirectoryTable, 		 MMU_STATE_MASK_WRITABLE, MMU_STATE_WRITABLE);    pDte = &thisTbl->pDirectoryTable [(UINT) virtPageAddr >> DIRECTORY_INDEX];    

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
中文字幕中文字幕中文字幕亚洲无线| 久久亚洲私人国产精品va媚药| 久久精品国产成人一区二区三区| 一区二区国产视频| 国产精品久久久一区麻豆最新章节| 久久美女艺术照精彩视频福利播放| 欧美电影免费观看高清完整版 | 99久久夜色精品国产网站| 久久精品72免费观看| 日韩av一区二区三区四区| 日本不卡1234视频| 国产一区在线观看视频| 精品午夜久久福利影院| 国内精品自线一区二区三区视频| 国产精品77777| 成人免费高清在线| av网站一区二区三区| 97久久久精品综合88久久| a美女胸又www黄视频久久| 色先锋aa成人| 欧美挠脚心视频网站| 日韩一区二区三区视频在线观看| 欧美精品一区二区精品网| 欧美—级在线免费片| 亚洲色图清纯唯美| 亚洲成av人片一区二区梦乃| 久久99精品网久久| 成人av高清在线| 欧美日韩国产一区二区三区地区| 精品国产区一区| 国产精品成人免费在线| 亚洲成人久久影院| 成人毛片老司机大片| 欧美人妖巨大在线| 中国av一区二区三区| 亚洲福利视频导航| 国产成人高清在线| 欧美日韩一二三| 欧美国产精品中文字幕| 五月婷婷综合网| 成人午夜激情视频| 91精品国产手机| 日韩美女视频19| 国产精品影视天天线| 欧美日韩一区二区欧美激情| 国产精品丝袜在线| 久久99国产精品久久99果冻传媒| 色综合久久六月婷婷中文字幕| 欧美一级在线免费| 亚洲美女视频在线观看| 国产麻豆视频一区二区| 欧美日韩免费一区二区三区 | 国产精品一区二区在线观看网站| 色综合天天视频在线观看| 久久影院电视剧免费观看| 亚洲国产色一区| 99精品视频一区二区三区| 久久亚洲综合色一区二区三区| 午夜视频在线观看一区二区三区| 99久久久久久| 国产精品久久久久久久久久久免费看 | 99久久精品国产精品久久| 欧美一区二区三区免费大片| 一区二区日韩av| 色偷偷一区二区三区| 国产精品久久精品日日| 国产精品香蕉一区二区三区| 日韩亚洲欧美综合| 久久精品国产精品青草| 91精品欧美一区二区三区综合在 | 国产精品一区二区在线观看网站| 日韩欧美亚洲国产精品字幕久久久 | 色偷偷成人一区二区三区91| 国产精品―色哟哟| 福利视频网站一区二区三区| 久久免费的精品国产v∧| 免费成人在线网站| 欧美成人aa大片| 国产一区啦啦啦在线观看| 日韩三级电影网址| 久久99精品视频| 337p日本欧洲亚洲大胆精品| 国产伦精品一区二区三区免费迷| 久久日韩粉嫩一区二区三区| 国产精品一区二区x88av| 日本一区二区三区在线观看| 国产宾馆实践打屁股91| 国产精品理论在线观看| 91麻豆精品在线观看| 亚洲午夜私人影院| 欧美一区二区成人| 国产精品99久久久久久久女警 | 欧美另类z0zxhd电影| 热久久国产精品| 国产三级精品视频| 色噜噜狠狠色综合中国| 婷婷中文字幕综合| 久久久久久免费网| 91丨porny丨蝌蚪视频| 亚洲二区视频在线| 欧美精品一区二区三区蜜桃 | 免费的成人av| 中文字幕精品一区二区三区精品 | 免费成人你懂的| 国产精品色噜噜| 欧美日韩免费观看一区三区| 国内精品伊人久久久久av一坑 | 日本亚洲天堂网| 国产校园另类小说区| 色天天综合色天天久久| 秋霞av亚洲一区二区三| 中文一区一区三区高中清不卡| 在线精品视频免费播放| 久久99精品国产麻豆不卡| 亚洲人成在线观看一区二区| 欧美一区二区视频在线观看| 92精品国产成人观看免费| 日韩精品电影在线| 国产精品三级电影| 日韩欧美中文字幕公布| 91麻豆免费观看| 国产精品18久久久久久久网站| 性欧美疯狂xxxxbbbb| 国产精品私人自拍| 欧美xxxxx裸体时装秀| 色综合天天综合网天天狠天天 | 色婷婷精品大视频在线蜜桃视频| 麻豆精品国产91久久久久久| 尤物av一区二区| 中文字幕欧美日韩一区| 日韩欧美国产精品一区| 日本韩国一区二区| 丰满少妇在线播放bd日韩电影| 麻豆91精品视频| 午夜精品久久久久久久久久| 最新中文字幕一区二区三区| 久久久久国产成人精品亚洲午夜| 51精品国自产在线| 欧美影院一区二区| 色女孩综合影院| av成人老司机| 成人黄色在线视频| 岛国精品在线播放| 国产乱码一区二区三区| 韩日av一区二区| 国产在线视视频有精品| 黄页视频在线91| 精品在线亚洲视频| 青娱乐精品在线视频| 日韩精品福利网| 美女视频网站久久| 蜜桃精品视频在线| 日本不卡视频一二三区| 奇米一区二区三区av| 日本在线不卡视频| 久久成人综合网| 国产精品一色哟哟哟| 国产jizzjizz一区二区| 成人综合在线观看| 成人18精品视频| 色综合久久久久久久| 欧美日韩在线播放一区| 欧美福利视频导航| 欧美一激情一区二区三区| 日韩一区二区免费在线观看| 精品国产伦理网| 久久久久高清精品| 中文字幕字幕中文在线中不卡视频| 亚洲精品网站在线观看| 午夜精品一区二区三区电影天堂| 日本伊人色综合网| 国产老女人精品毛片久久| 福利视频网站一区二区三区| 91九色02白丝porn| 欧美一三区三区四区免费在线看| 日韩欧美一二三四区| 国产精品毛片大码女人| 亚洲最色的网站| 久久激情五月婷婷| 不卡在线视频中文字幕| 精品污污网站免费看| 日韩欧美亚洲另类制服综合在线| 日本一区二区三区电影| 亚洲一区免费视频| 国产一区二区三区免费| 91福利社在线观看| 亚洲精品在线电影| 亚洲欧美色一区| 国产在线视频不卡二| 一本大道av伊人久久综合| 91精品福利在线一区二区三区 | 懂色av一区二区三区免费观看| 欧美中文字幕一二三区视频| 日韩无一区二区| 亚洲精品va在线观看| 国产精品亚洲一区二区三区在线| 欧美影视一区在线| 欧美激情在线免费观看| 蜜桃av噜噜一区| 欧美午夜精品理论片a级按摩|