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

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

?? qpribmapalib.s

?? vxworks的源代碼
?? S
字號:
/* qPriBMapALib.s - optimized bit mapped priority queue internals *//* Copyright 1984-2000 Wind River Systems, Inc. */	.data	.globl	_copyright_wind_river	.long	_copyright_wind_river/*modification history--------------------01f,28mar00,hk   added .type directive to function names.01e,17mar00,zl   made use of alignment macro _ALIGN_TEXT01d,29jul96,hk   changed to use 'mova', added DEBUG_LOCAL_SYMBOLS option.		 changed 'jsr' to _qPriBMapRemove in _qPriBMapGet to 'bsr'.01c,19may95,hk   worked around 'mova' alignment problem.01b,01may95,hk   optimized.01a,23apr95,hk   written based on mc68k-01m.*//*DESCRIPTIONThis module contains internals to the VxWorks kernel.These routines have been coded in assembler because they have been optimizedfor performance.INTERNALThe C code versions of these routines can be found in qPriBMapLib.c.*/#define _ASMLANGUAGE#include "vxWorks.h"#include "asm.h"#include "qPriNode.h"#if defined(PORTABLE)#define qPriBMapALib_PORTABLE#endif#ifndef qPriBMapALib_PORTABLE#define	BMAP_LIST_ARRAY		36	/* globals */#undef	DEBUG_LOCAL_SYMBOLS	.globl	_qPriBMapPut	.globl	_qPriBMapGet	.globl	_qPriBMapRemove#ifdef	DEBUG_LOCAL_SYMBOLS	.globl	qPriBMapPut1	.globl	qPriBMapPut2	.globl	qPriBMapPut3	.globl	qPriBMapGet1	.globl	dllRemove1	.globl	dllRemove2	.globl	clearMaps	.globl	qPriBMapNoMeta	.globl	qPriBMapMswLsb	.globl	qPriBMapLsw	.globl	qPriBMapLswLsb	.globl	qPriBMapGetHigh	.globl	qPriBMapDExit	.globl	qPriBitTable	.globl	FfsMsbTbl#endif	/* DEBUG_LOCAL_SYMBOLS */	.text/********************************************************************************* qPriBMapPut - insert the specified TCB into the ready queue** This routine inserts a node into a priority bit mapped queue.  The insertion* is based on the specified priority key which is constrained to the range* 0 to 255.  The highest priority is zero.* void qPriBMapPut*     (*     Q_PRI_BMAP_HEAD	*pQPriBMapHead,*     Q_PRI_NODE	*pQPriNode,*     ULONG		key*     )* INTERNAL:*                      +-- Q_PRI_BMAP_HEAD -----+*    pQPriBMapHead --->| Q_PRI_NODE *highNode   |   +-- BMAP_LIST -------------+*                      | BMAP_LIST  *pBMapList ---->| UINT32  metaBMap         |*                      | UINT        nPriority  |   | UINT8   bMap [32]        |*                      +------------------------+   | DL_LIST listArray [256] -+*                                                   |  | DL_NODE *head         |*                  +---- Q_PRI_NODE -----+          |  | DL_NODE *tail         |*    pQPriNode --->| DL_NODE node -------+          +--+-----------------------+*               +0 |  | dlnode *next     |*               +4 |  | dlnode *previous |*                  |  +------------------+*               +8 | ULONG   key         |*                  +---------------------+*/	.align	_ALIGN_TEXT	.type	_qPriBMapPut,@function					/* r4: pQPriBMapHead           */					/* r5: pQPriNode               */_qPriBMapPut:				/* r6: key                     */	mov.l	@r4,r7			/* r7: pQPriBMapHead->highNode */	mov.l	r6,@(Q_PRI_NODE_KEY,r5)	/* pQPriNode->key = key        */	tst	r7,r7	bt	qPriBMapPut1	mov.l	@(Q_PRI_NODE_KEY,r7),r0	/* r0: pQPriBMapHead->highNode->key */	cmp/hi	r6,r0	bf	qPriBMapPut2qPriBMapPut1:	mov.l	r5,@r4			/* pQPriBMapHead->highNode = pQPriNode*/qPriBMapPut2:	mov.l	@(4,r4),r4		/* r4: pQPriBMapHead->pBMapList *//* LOCAL void qPriBMapSet (BMAP_LIST *pBMapList, int priority) * *		r7:	(priority & 0x7) *		r6:	priority ('key' in outer level) *		r4:	pBMapList, &pBMapList->metaBMap *		r3:	(priority >> 3) *		r0:	&qPriBitTable */		not	r6,r3		extu.b	r3,r3		/* r3: priority = 255 - priority */		mov	#0x7,r7		and	r3,r7		/* r7: (priority & 0x7)          */		shlr	r3		shlr2	r3		/* r3: (priority >> 3)           */		mova	qPriBitTable,r0	/* (qPriBitTable must be long aligned)*/		mov	r3,r1		shll2	r1		mov.l	@(r0,r1),r2	/* r2: (1 << (priority >> 3))    */		mov.l	@r4,r1		/* r1: pBMapList->metaBMap       */		or	r2,r1		mov.l	r1,@r4		shll2	r7		mov.l	@(r0,r7),r2	/* r2: (1 << (priority & 0x7))   */		add	r4,r3		mov.b	@(4,r3),r0;	/* r0: pBMapList->bMap [priority >> 3]*/	shll r6		or	r2,r0		mov.b	r0,@(4,r3)	shll2	r6	add	#BMAP_LIST_ARRAY,r6	add	r6,r4		/*r4:&pQPriBMapHead->pBMapList->listArray[key]*//* * void dllAdd (pList, pNode) */		mov.l	@(4,r4),r1	/* r1: pPrev = pList->tail */		mov	#0,r0		/* r0: NULL                */		mov.l	r5,@(4,r4)	/* pList->tail     = pNode */		mov.l	r0,@r5		/* pNode->next     = NULL  */		mov.l	r1,@(4,r5)	/* pNode->previous = pPrev */		tst	r1,r1		/* (pPrev == NULL) ?       */		bt	qPriBMapPut3		mov	r1,r4qPriBMapPut3:	rts;	mov.l	r5,@r4		/* pList->head     = pNode *//********************************************************************************* qPriBMapGet - remove and return first node in priority bit-mapped queue** This routine removes and returns the first node in a priority bit-mapped* queue.  If the queue is empty, NULL is returned.* Q_PRI_NODE *qPriBMapGet*     (*     Q_PRI_BMAP_HEAD *pQPriBMapHead*     )* RETURN: Pointer to first queue node in queue head, or NULL if queue is empty.* INTERNAL:*	r5:	pQPriNode*	r4:	pQPriBMapHead*/#define	QPRIBMAPREMOVE_NOT_CLOBBER_R5	.align	_ALIGN_TEXT	.type	_qPriBMapGet,@function_qPriBMapGet:	mov.l	@r4,r5;	tst	r5,r5	bt	qPriBMapGet1		/* if highNode is NULL we're done */#ifdef	QPRIBMAPREMOVE_NOT_CLOBBER_R5	sts.l	pr,@-sp	bsr	_qPriBMapRemove;	/* r4: pQPriBMapHead, r5: pQPriNode */	nop	lds.l	@sp+,pr#else	/* QPRIBMAPREMOVE_NOT_CLOBBER_R5 */	mov.l	r8,@-sp	sts.l	pr,@-sp	bsr	_qPriBMapRemove;	/* r4: pQPriBMapHead, r5: pQPriNode */	mov	r5,r8			/* save pQPriNode */	mov	r8,r0			/* r0: pQPriNode */	lds.l	@sp+,pr	rts;	mov.l	@sp+,r8#endif	/* QPRIBMAPREMOVE_NOT_CLOBBER_R5 */qPriBMapGet1:	rts;	mov	r5,r0			/* r0: pQPriNode *//********************************************************************************* qPriBMapRemove - remove a node from a priority bit mapped queue** This routine removes a node from the specified bit mapped queue.* STATUS qPriBMapRemove*     (*     Q_PRI_BMAP_HEAD *pQPriBMapHead;*     Q_PRI_NODE      *pQPriNode;*     )* RETURN: OK, always.* INTERNAL:*                      +-- Q_PRI_BMAP_HEAD -----+*    pQPriBMapHead --->| Q_PRI_NODE *highNode   |   +-- BMAP_LIST -------------+*                      | BMAP_LIST  *pBMapList ---->| UINT32  metaBMap         |*                      | UINT        nPriority  |   | UINT8   bMap [32]        |*                      +------------------------+   | DL_LIST listArray [256] -+*                                                   |  | DL_NODE *head         |*                  +---- Q_PRI_NODE -----+          |  | DL_NODE *tail         |*    pQPriNode --->| DL_NODE node -------+          +--+-----------------------+*                  |  | dlnode *next     |*                  |  | dlnode *previous |*                  |  +------------------+*                  | ULONG   key         |*                  +---------------------+*/	.align	_ALIGN_TEXT	.type	_qPriBMapRemove,@function					/* r4: pQPriBMapHead            */_qPriBMapRemove:			/* r5: pQPriNode                */	mov.l	@(Q_PRI_NODE_KEY,r5),r7	/* r7: pQPriNode->key           */	mov.l	@(4,r4),r0		/* r0: pQPriBMapHead->pBMapList */	mov	r7,r6	shll	r6	shll2	r6			/*     key*8 indexes listArray[256] */	add	#BMAP_LIST_ARRAY,r6	/*     add offset to listArray[0]   */	add	r0,r6			/* r6: &pQPriBMapHead->pBMapList    */					/*	->listArray[pQPriNode->key] *//*		    r6     r5 * void dllRemove (pList, pNode) * * (same)	r7:			(pQPriNode->key) * (same)	r6:	pList		(&listArray[pQPriNode->key]) * (same)	r5:	pNode		(pQPriNode) * (same)	r4:			(pQPriBMapHead) * (clobber)	r3: * (clobber)	r2: * (clobber)	r1: * (clobber)	r0: */		mov	r6,r3		mov.l	@(4,r5),r1	/* r1: pNode->previous        */		mov.l	@r5,r0		/* r0: pNode->next            */		mov	r1,r2		tst	r1,r1		/* (pNode->previous == NULL)? */		bf	dllRemove1	/* r1: pNode->previous        */		mov	r3,r1		/* r1: pList                  */dllRemove1:	mov.l	r0,@r1		tst	r0,r0		/* (pNode->next == NULL)?     */		bt	dllRemove2		mov	r0,r3dllRemove2:	mov.l	r2,@(4,r3)	mov.l	@r6,r0;			/* r0: pList->head              */	mov.l	@(4,r4),r3		/* r3: pQPriBMapHead->pBMapList */	tst	r0,r0			/* If (pList->head == NULL)         */	bt	clearMaps		/*     then we clear maps           */	mov.l	@r4,r1			/* r1: pQPriBMapHead->highNode  */	cmp/eq	r1,r5			/* If not deleting highest priority */	bf	qPriBMapDExit		/*     then we are done             */	bra	qPriBMapDExit;	mov.l	r0,@r4			/* update the highest priority task */clearMaps:/*			 r3          r7 * void qPriBMapClear (pBMapList, priority) * * (clobber)	r7:	(priority & 0x7) * (clobber)	r6:	(priority >> 3) * (same)	r5: * (same)	r4: * (same)	r3:	pBMapList, &pBMapList->metaBMap * (clobber)	r2: * (clobber)	r1: * (clobber)	r0:	&qPriBitTable */		not	r7,r6		extu.b	r6,r6		/* r6: priority = 255 - priority */		mov	#7,r7		and	r6,r7		/* r7: (priority & 0x7) */		shlr	r6		shlr2	r6		/* r6: (priority >> 3) */		mova	qPriBitTable,r0	/* (qPriBitTable must be long aligned)*/		shll2	r7		mov.l	@(r0,r7),r1	/* r1: (1 << (priority & 0x7)) */		mov	r3,r2		add	r6,r2		mov.b	@(4,r2),r0	/* r0: pBMapList->bMap [priority >> 3]*/		not	r1,r1		and	r1,r0		mov.b	r0,@(4,r2)		tst	#0xff,r0		bf	qPriBMapNoMeta		mova	qPriBitTable,r0	/* (qPriBitTable must be long aligned)*/		shll2	r6		mov.l	@(r0,r6),r1	/* r1: (1 << (priority >> 3)) */		mov.l	@r3,r0		/* r0: pBMapList->metaBMap */		not	r1,r1		and	r1,r0		mov.l	r0,@r3qPriBMapNoMeta:	mov.l	@r4,r1	cmp/eq	r1,r5			/* have we deleted highest priority? */	bf	qPriBMapDExit		/* If not, then we are done          *//*			r3 * int qPriBMapHigh (pBMapList) * * (clobber)	r7: * (clobber)	r6: * (same)	r5:	(pQPriNode) * (same)	r4:	(pQPriBMapHead) * (same)	r3:	 pBMapList * (clobber)	r2:	 * (clobber)	r1: * (clobber)	r0: */		mov.l	@r3,r6			/* r6: pBMapList->metaBMap */		mov.l	FfsMsbTbl,r0		/* lookup table address in r0 */		mov	r6,r1		shlr16	r1		tst	r1,r1		bt	qPriBMapLsw		mov	r1,r2			/* 0x????xxxx */		shlr8	r1		tst	r1,r1		bt	qPriBMapMswLsb		mov.b	@(r0,r1),r7		/* 0x??xxxxxx */		bra	qPriBMapGetHigh;		add	#24,r7qPriBMapMswLsb:		mov.b	@(r0,r2),r7		/* 0x00??xxxx */		bra	qPriBMapGetHigh;		add	#16,r7qPriBMapLsw:		mov	r6,r1			/* 0x0000???? */		shlr8	r1		tst	r1,r1		bt	qPriBMapLswLsb		mov.b	@(r0,r1),r7		/* 0x0000??xx */		bra	qPriBMapGetHigh;		add	#8,r7qPriBMapLswLsb:		mov.b	@(r0,r6),r7		/* 0x000000?? */qPriBMapGetHigh:		mov	r0,r2			/* r2: _ffsMsbTbl */		mov	r3,r1			/* r3: pBMapList */		add	r7,r1			/* r7: highBits */		mov.b	@(4,r1),r0		shll	r7		extu.b	r0,r0			/* r0: bMap[highBits] */		mov.b	@(r0,r2),r6		/* r6: lowBits */		shll2	r7			/* r7: (highBits << 3) */		or	r6,r7	/* r7: (((highBits << 3) | lowBits) & 0xff) */		not	r7,r7		extu.b	r7,r0			/* r0: 255 - r7 *//* qPriBMapNewHigh: */	shll	r0	shll2	r0			/* scale r0 by sizeof (DL_HEAD) 8 */	add	r3,r0	mov.l	@(BMAP_LIST_ARRAY,r0),r0	mov.l	r0,@r4			/* put highest task into highNode */qPriBMapDExit:	rts;	mov	#0,r0			/* return OK *//* r0 r1 r2 r3 r4 r5 r6 r7 r8 r9 r10 r11 r12 r13 r14 sp pr jsr JSR */		.align	2		.type	qPriBitTable,@objectqPriBitTable:	.long	0x00000001, 0x00000002, 0x00000004, 0x00000008		.long	0x00000010, 0x00000020, 0x00000040, 0x00000080		.long	0x00000100, 0x00000200, 0x00000400, 0x00000800		.long	0x00001000, 0x00002000, 0x00004000, 0x00008000		.long	0x00010000, 0x00020000, 0x00040000, 0x00080000		.long	0x00100000, 0x00200000, 0x00400000, 0x00800000		.long	0x01000000, 0x02000000, 0x04000000, 0x08000000		.long	0x10000000, 0x20000000, 0x40000000, 0x80000000FfsMsbTbl:	.long	_ffsMsbTbl#endif	/* !qPriBMapALib_PORTABLE */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一区二区日韩电影| 欧美日本在线一区| 91精品免费在线| 中文字幕欧美日韩一区| 免费美女久久99| 一本一道久久a久久精品 | 三级亚洲高清视频| 9色porny自拍视频一区二区| 51精品视频一区二区三区| 中文字幕在线观看一区| 国产一区二区视频在线播放| 欧美日韩亚洲高清一区二区| 国产精品高潮呻吟久久| 极品尤物av久久免费看| 91精品福利在线一区二区三区| 成人免费在线播放视频| 国产不卡在线一区| 国产亚洲欧美一级| 麻豆成人91精品二区三区| 欧美日韩国产综合久久| 亚洲激情五月婷婷| 91在线视频官网| 国产精品嫩草久久久久| 国产伦精品一区二区三区免费| 欧美一区二区网站| 日韩av电影天堂| 欧美日韩在线亚洲一区蜜芽| 一区二区三区四区精品在线视频| 成人黄色免费短视频| 国产精品网曝门| 99精品国产99久久久久久白柏 | 国产 日韩 欧美大片| 亚洲精品在线电影| 国内精品伊人久久久久av影院 | 韩国三级中文字幕hd久久精品| 91麻豆精品国产91久久久久久| 亚洲成av人片在线观看| 欧美午夜视频网站| 奇米综合一区二区三区精品视频| 在线播放一区二区三区| 午夜精品一区二区三区电影天堂 | av亚洲产国偷v产偷v自拍| 国产精品免费网站在线观看| 成人性生交大片免费| 午夜精品视频在线观看| 欧美日韩亚洲综合| 日本亚洲免费观看| 久久久久国产一区二区三区四区| 国产一区91精品张津瑜| 久久精品无码一区二区三区| 99久久久精品| 丝袜亚洲另类欧美综合| 日韩精品一区二区三区中文精品| 国产麻豆一精品一av一免费| 国产精品美女久久久久aⅴ| 91成人看片片| 精品一区二区三区欧美| 国产精品欧美综合在线| 欧美天堂一区二区三区| 精品一区二区三区香蕉蜜桃| 国产精品久久久久久久久快鸭| 一本到一区二区三区| 青青草伊人久久| 日韩一区欧美一区| 在线不卡免费欧美| 成人高清av在线| 日韩中文字幕av电影| 国产婷婷精品av在线| 欧美三级日韩三级| 国产91丝袜在线播放| 一区二区三区美女| 国产欧美综合色| 538在线一区二区精品国产| 国产91精品一区二区麻豆亚洲| 亚洲精品成人悠悠色影视| 日韩三级在线观看| 色激情天天射综合网| 国精品**一区二区三区在线蜜桃| 亚洲精品乱码久久久久| 久久久激情视频| 欧美久久婷婷综合色| 国产成人久久精品77777最新版本| 亚洲国产日韩av| 亚洲人xxxx| 国产偷国产偷精品高清尤物| 欧美三级电影在线看| 成人动漫av在线| 国产美女主播视频一区| 日韩av电影一区| 亚洲国产成人av| 日韩一区欧美小说| 久久久久久黄色| 欧美群妇大交群中文字幕| 波多野结衣一区二区三区| 激情综合色播激情啊| 日韩高清一区二区| 午夜精品一区在线观看| 亚洲欧美另类久久久精品| 国产欧美一区二区精品婷婷| 日韩欧美国产午夜精品| 欧美美女网站色| 欧美日韩黄色影视| 欧美性大战xxxxx久久久| 91在线云播放| a美女胸又www黄视频久久| 国产伦精一区二区三区| 麻豆国产欧美一区二区三区| 日日夜夜精品视频天天综合网| 亚洲制服丝袜av| 一区二区成人在线| 亚洲高清免费在线| 一区二区三区在线观看欧美| 亚洲视频1区2区| 亚洲黄色小视频| 一区二区三区四区不卡在线| 中文字幕一区二区在线观看| 国产丝袜美腿一区二区三区| 久久亚洲二区三区| 久久精品免视看| 国产日韩av一区| 亚洲视频免费在线观看| 亚洲老妇xxxxxx| 午夜欧美2019年伦理| 午夜影视日本亚洲欧洲精品| 香蕉久久夜色精品国产使用方法| 亚洲成人精品一区二区| 午夜久久电影网| 精品一区二区三区免费视频| 经典三级在线一区| 国产成人一级电影| 色综合天天视频在线观看| 欧美色倩网站大全免费| 日韩视频一区二区在线观看| 精品国产人成亚洲区| 国产亚洲一本大道中文在线| 国产精品无遮挡| 亚洲与欧洲av电影| 免费观看在线色综合| 国产精品538一区二区在线| 成人av网在线| 欧美日韩国产电影| 欧美精品一区二区三区四区 | 日韩一区二区在线观看视频播放| 欧美r级电影在线观看| 国产亚洲精品福利| 亚洲影院在线观看| 久久精品国产精品亚洲红杏| 成人免费黄色大片| 欧美麻豆精品久久久久久| 久久免费偷拍视频| 亚洲综合精品久久| 国产成人午夜精品5599| 色综合久久88色综合天天6| 日韩亚洲欧美高清| 亚洲另类春色国产| 国产一区二区女| 欧美日韩国产a| 中文字幕乱码日本亚洲一区二区| 亚洲一区在线免费观看| 国产精品一区二区久激情瑜伽 | 亚洲一区二区视频在线观看| 秋霞av亚洲一区二区三| 波多野结衣中文一区| 日韩三级免费观看| 亚洲一区在线观看视频| 国产一区二区三区在线观看免费视频| 色偷偷一区二区三区| 国产肉丝袜一区二区| 免费欧美日韩国产三级电影| 色综合一区二区三区| 国产三级精品三级在线专区| 蜜桃一区二区三区四区| 在线视频你懂得一区二区三区| 久久久久高清精品| 久久成人久久爱| 欧美日韩你懂得| 亚洲激情图片小说视频| 懂色av中文字幕一区二区三区| 日韩一区二区在线看| 亚洲成人自拍一区| 欧美性欧美巨大黑白大战| 国产精品成人一区二区三区夜夜夜| 蜜臀av一区二区在线免费观看| 欧美三级日韩三级| 亚洲国产日韩a在线播放性色| 99国产精品久久久久| 国产精品狼人久久影院观看方式| 国产一区二区三区久久久| 亚洲妇熟xx妇色黄| 成人精品国产一区二区4080| 精品久久一区二区| 久久国产剧场电影| 欧美一区二区黄| 日本va欧美va瓶| 这里只有精品99re| 午夜影院久久久| 欧美精品在线观看一区二区| 亚洲国产精品天堂| 3d动漫精品啪啪一区二区竹菊| 亚洲成av人片www|