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

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

?? portmacro.h

?? MCS-51的一個Free小型操作系統,在KeilC中下編譯工作
?? H
字號:
/*
	FreeRTOS.org V4.1.3 - Copyright (C) 2003-2006 Richard Barry.

	This file is part of the FreeRTOS.org distribution.

	FreeRTOS.org 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.

	FreeRTOS.org 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 FreeRTOS.org; if not, write to the Free Software
	Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA

	A special exception to the GPL can be applied should you wish to distribute
	a combined work that includes FreeRTOS.org, without being obliged to provide
	the source code for any proprietary components.  See the licensing section 
	of http://www.FreeRTOS.org for full details of how and when the exception
	can be applied.

	***************************************************************************
	See http://www.FreeRTOS.org for documentation, latest information, license 
	and contact details.  Please ensure to read the configuration and relevant 
	port sections of the online documentation.
	***************************************************************************
*/


#ifndef PORTMACRO_H
#define PORTMACRO_H

/*-----------------------------------------------------------
 * Port specific definitions.  
 *
 * The settings in this file configure FreeRTOS correctly for the
 * given hardware and compiler.
 *
 * These settings should not be altered.
 *-----------------------------------------------------------
 */

/* Type definitions. */
#define portCHAR		char
#define portFLOAT		float
#define portDOUBLE		double
#define portLONG		long
#define portSHORT		short
#define portSTACK_TYPE	unsigned portLONG
#define portBASE_TYPE	portLONG

#if( configUSE_16_BIT_TICKS == 1 )
	typedef unsigned portSHORT portTickType;
	#define portMAX_DELAY ( portTickType ) 0xffff
#else
	typedef unsigned portLONG portTickType;
	#define portMAX_DELAY ( portTickType ) 0xffffffff
#endif
/*-----------------------------------------------------------*/	

/* Hardware specifics. */
#define portSTACK_GROWTH			( -1 )
#define portTICK_RATE_MS			( ( portTickType ) 1000 / configTICK_RATE_HZ )		
#define portBYTE_ALIGNMENT			4
/*-----------------------------------------------------------*/	

/* Task utilities. */
#define portRESTORE_CONTEXT()																			\
{																										\
extern volatile unsigned portLONG ulCriticalNesting;													\
extern volatile void * volatile pxCurrentTCB;															\
																										\
	__asm{ LDR		R1, =pxCurrentTCB };/* Set the LR to the task stack.  The location was ... */		\
	__asm{ LDR		R0, [R1]		};	/* ... stored in pxCurrentTCB. */								\
	__asm{ LDR		LR, [R0]		};																	\
																										\
	__asm{ LDR		R0, =ulCriticalNesting }; /* The critical nesting depth is the first item on ... */	\
	__asm{ LDMFD	LR!, {R1 }		}  /* ... the stack.  Load it into the ulCriticalNesting var. */	\
	__asm{ STR		R1, [R0]		}																	\
																										\
	__asm{ LDMFD	LR!, {R0}		}; /* Get the SPSR from the stack. */								\
	__asm{ MSR		SPSR_CXSF, R0	};																	\
																										\
	__asm{ LDMFD	LR, {R0-R14}^	}; /* Restore all system mode registers for the task. */			\
	__asm{ NOP						};																	\
																										\
	__asm{ LDR		LR, [LR, #+60]	}; /* Restore the return address. */								\
																										\
									   /* And return - correcting the offset in the LR to obtain ... */ \
	__asm{ SUBS	PC, LR, #4			}; /* ... the correct address. */									\
}
/*----------------------------------------------------------*/

#define portSAVE_CONTEXT()																				\
{																										\
extern volatile unsigned portLONG ulCriticalNesting;													\
extern volatile void * volatile pxCurrentTCB;															\
																										\
	__asm{ STMDB 	SP!, {R0}		};	/* Store R0 first as we need to use it.						*/	\
																										\
	__asm{ STMDB	SP,{SP}^		}; /* Set R0 to point to the task stack pointer.				*/	\
	__asm{ NOP						};																	\
	__asm{ SUB		SP, SP, #4		};																	\
	__asm{ LDMIA	SP!,{R0}		};																	\
																										\																	
	__asm{ STMDB	R0!, {LR}		}; /* Push the return address onto the stack.					*/	\
	__asm{ MOV		LR, R0			}; /* Now we have saved LR we can use it instead of R0.			*/	\
	__asm{ LDMIA	SP!, {R0}		}; /* Pop R0 so we can save it onto the system mode stack.		*/	\
																										\
	__asm{ STMDB	LR,{R0-LR}^		}; /* Push all the system mode registers onto the task stack.	*/	\
	__asm{ NOP						};																	\
	__asm{ SUB		LR, LR, #60		};																	\
																										\
	__asm{ MRS		R0, SPSR		}; /* Push the SPSR onto the task stack.						*/	\
	__asm{ STMDB	LR!, {R0}		};																	\
																										\
	__asm{ LDR		R0, =ulCriticalNesting };															\
	__asm{ LDR		R0, [R0]		};																	\
	__asm{ STMDB	LR!, {R0}		};																	\
																										\
	__asm{ LDR		R0, =pxCurrentTCB };/* Store the new top of stack for the task.					*/	\
	__asm{ LDR		R1, [R0]		};																	\
	__asm{ STR		LR, [R1]		};																	\
}

/*-----------------------------------------------------------
 * ISR entry and exit macros.  These are only required if a task switch
 * is required from an ISR.
 *----------------------------------------------------------*/

#define portENTER_SWITCHING_ISR()										\
		portSAVE_CONTEXT();												\
		{

#define portEXIT_SWITCHING_ISR( SwitchRequired )						\
		/* If a switch is required then we just need to call */			\
		/* vTaskSwitchContext() as the context has already been */		\
		/* saved. */													\
		if( SwitchRequired )											\
		{																\
			vTaskSwitchContext();										\
		}																\
	}																	\
	/* Restore the context of which ever task is now the highest */		\
	/* priority that is ready to run. */								\
	portRESTORE_CONTEXT();


/* Yield the processor - force a context switch. */
#define portYIELD()					__asm{ SWI 0 };	
/*-----------------------------------------------------------*/	

/* Critical section management. */

/*-----------------------------------------------------------
 * Interrupt control macros.
 *
 * The interrupt management utilities can only be called from ARM mode.  When
 * KEIL_THUMB_INTERWORK is defined the utilities are defined as functions in 
 * portISR.c to ensure a switch to ARM mode.  When KEIL_THUMB_INTERWORK is not 
 * defined then the utilities are defined as macros here - as per other ports.
 *----------------------------------------------------------*/

#ifdef KEIL_THUMB_INTERWORK

	extern void vPortDisableInterruptsFromThumb( void ) __task;
	extern void vPortEnableInterruptsFromThumb( void ) __task;

	#define portDISABLE_INTERRUPTS()	vPortDisableInterruptsFromThumb()
	#define portENABLE_INTERRUPTS()		vPortEnableInterruptsFromThumb()

#else

	/*-----------------------------------------------------------*/

	#define portDISABLE_INTERRUPTS()														\
		__asm{ STMDB	SP!, {R0}		};	/* Push R0.									*/	\
		__asm{ MRS		R0, CPSR		};	/* Get CPSR.								*/	\
		__asm{ ORR		R0, R0, #0xC0	};	/* Disable IRQ, FIQ.						*/	\
		__asm{ MSR		CPSR_CXSF, R0	};	/* Write back modified value.				*/	\
		__asm{ LDMIA	SP!, {R0}		}	/* Pop R0.									*/
			
	#define portENABLE_INTERRUPTS()															\
		__asm{ STMDB	SP!, {R0}		};	/* Push R0.									*/	\
		__asm{ MRS		R0, CPSR		};	/* Get CPSR.								*/	\
		__asm{ BIC		R0, R0, #0xC0	};	/* Enable IRQ, FIQ.							*/	\
		__asm{ MSR		CPSR_CXSF, R0	};	/* Write back modified value.				*/	\
		__asm{ LDMIA	SP!, {R0}		}	/* Pop R0. */

#endif /* KEIL_THUMB_INTERWORK */

/*-----------------------------------------------------------
 * Critical section control
 *
 * The code generated by the Keil compiler does not maintain separate
 * stack and frame pointers. The portENTER_CRITICAL macro cannot therefore
 * use the stack as per other ports.  Instead a variable is used to keep
 * track of the critical section nesting.  This necessitates the use of a 
 * function in place of the macro.
 *----------------------------------------------------------*/

extern void vPortEnterCritical( void );
extern void vPortExitCritical( void );

#define portENTER_CRITICAL()		vPortEnterCritical();
#define portEXIT_CRITICAL()			vPortExitCritical();
/*-----------------------------------------------------------*/	

/* Compiler specifics. */
#define inline
#define register
#define portNOP()	__asm{ NOP }
/*-----------------------------------------------------------*/	

/* Task function macros as described on the FreeRTOS.org WEB site. */
#define portTASK_FUNCTION_PROTO( vFunction, pvParameters )	void vFunction( void *pvParameters ) __task
#define portTASK_FUNCTION( vFunction, pvParameters )	void vFunction( void *pvParameters )

#endif /* PORTMACRO_H */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲成人激情自拍| 91.com在线观看| 欧洲国内综合视频| 不卡的av网站| 色老头久久综合| 久久精品人人做人人综合| 亚洲卡通动漫在线| 美女视频黄a大片欧美| 97aⅴ精品视频一二三区| 精品区一区二区| 亚洲精品视频自拍| www..com久久爱| 久久影院电视剧免费观看| 天天综合网 天天综合色| caoporn国产一区二区| 久久久电影一区二区三区| 日日欢夜夜爽一区| 欧美日韩一区国产| 国产精品青草久久| 国产mv日韩mv欧美| 久久只精品国产| 琪琪久久久久日韩精品| 欧美日韩电影一区| 午夜精品福利一区二区蜜股av | 91精品国产乱| 亚洲精品国产品国语在线app| 国产一区二区三区在线观看免费| 91精品国产综合久久蜜臀| 午夜精品一区二区三区三上悠亚| 91麻豆国产福利精品| 亚洲欧洲av在线| 9色porny自拍视频一区二区| 精品久久人人做人人爰| 麻豆精品久久久| 亚洲精品在线免费播放| 狠狠色丁香久久婷婷综| 精品毛片乱码1区2区3区 | 亚洲天堂中文字幕| av在线不卡免费看| 亚洲精品乱码久久久久久黑人| youjizz久久| 成人欧美一区二区三区视频网页| fc2成人免费人成在线观看播放| 亚洲国产精品ⅴa在线观看| 成人黄页在线观看| 有坂深雪av一区二区精品| 色噜噜狠狠成人中文综合| 亚洲在线一区二区三区| 欧美人xxxx| 韩国av一区二区三区| 欧美国产日韩在线观看| 91麻豆免费视频| 亚洲成av人片一区二区| 在线综合+亚洲+欧美中文字幕| 久久精品国产网站| 国产精品天美传媒| 日本道在线观看一区二区| 亚洲成人高清在线| 久久一区二区三区四区| 成人天堂资源www在线| 亚洲精品日日夜夜| 欧美一区在线视频| 懂色av噜噜一区二区三区av| 亚洲美女在线一区| 日韩写真欧美这视频| 丁香六月综合激情| 亚洲成人精品影院| 国产欧美日韩麻豆91| 色视频成人在线观看免| 美女视频网站久久| 综合中文字幕亚洲| 日韩精品一区二| 色播五月激情综合网| 久久精品国产免费| 亚洲精选在线视频| 久久久噜噜噜久噜久久综合| 在线视频欧美精品| 国产精品综合视频| 亚洲国产视频一区| 中日韩av电影| 91精品久久久久久久91蜜桃| 成人国产免费视频| 精品中文字幕一区二区小辣椒| 日韩美女精品在线| 欧美成人bangbros| 欧美精品久久一区二区三区| 丁香婷婷综合激情五月色| 日韩高清不卡一区二区三区| 亚洲素人一区二区| 国产视频视频一区| 日韩欧美一级二级三级| 欧美三日本三级三级在线播放| 国产高清亚洲一区| 久久99久久久久| 亚洲第一狼人社区| 亚洲乱码日产精品bd| 国产蜜臀av在线一区二区三区| 在线不卡中文字幕| 欧美日韩在线播| 一本久久精品一区二区| 国产成人啪午夜精品网站男同| 日韩精品五月天| 亚洲五码中文字幕| 亚洲精品久久嫩草网站秘色| 国产精品久久久久久久久搜平片| 精品成人佐山爱一区二区| 日韩一区二区三区在线观看| 欧美日韩精品综合在线| 欧美色倩网站大全免费| 91国偷自产一区二区使用方法| 成人av在线影院| 成人美女视频在线观看| 国产精品一区在线| 国精产品一区一区三区mba桃花| 久久精品国产亚洲aⅴ| 蜜桃av一区二区三区| 美女视频黄久久| 久久se精品一区精品二区| 麻豆精品视频在线观看| 国内成人精品2018免费看| 精品一区二区三区不卡| 国产精品一品二品| 成人在线一区二区三区| 白白色 亚洲乱淫| 色国产综合视频| 欧美日韩精品一二三区| 日韩一区二区三区三四区视频在线观看 | 亚洲一区二区四区蜜桃| 亚洲成人精品一区二区| 日本不卡视频一二三区| 国产自产2019最新不卡| 国产精品1区2区3区| 成人av网站免费观看| 色综合天天综合色综合av| 日本高清成人免费播放| 欧美丰满一区二区免费视频| 日韩免费观看高清完整版在线观看| 日韩精品在线看片z| 欧美韩国日本一区| 亚洲欧美激情插| 日本中文字幕不卡| 国产成人亚洲精品青草天美| 91伊人久久大香线蕉| 欧美日本在线视频| 久久综合久久综合久久综合| 中文字幕一区二区三区不卡 | 欧美经典一区二区三区| 国产精品久久久久精k8 | 欧美精品在线视频| 久久久欧美精品sm网站| 夜夜亚洲天天久久| 狠狠色狠狠色综合| 97精品久久久午夜一区二区三区| 欧美日韩国产不卡| 国产精品美日韩| 日本不卡在线视频| www.亚洲国产| 日韩精品一区在线| 亚洲免费三区一区二区| 九色综合国产一区二区三区| 日本久久一区二区三区| 久久亚洲春色中文字幕久久久| 一区二区三区视频在线看| 国产麻豆成人精品| 欧美乱妇15p| 中文字幕一区二区三区四区| 美女爽到高潮91| 欧美日韩日本视频| 中文字幕亚洲综合久久菠萝蜜| 免费观看一级特黄欧美大片| 91在线播放网址| 国产精品美女久久久久久久久久久 | 蜜桃一区二区三区在线观看| 99精品欧美一区二区蜜桃免费 | 欧美三区免费完整视频在线观看| 久久天堂av综合合色蜜桃网| 亚洲激情在线播放| 国产成人小视频| 久久久无码精品亚洲日韩按摩| 日日夜夜一区二区| 精品婷婷伊人一区三区三| 国产精品网站在线播放| 国产中文字幕一区| 日韩一区二区免费高清| 午夜欧美大尺度福利影院在线看| 99精品久久99久久久久| 国产欧美久久久精品影院| 青青草国产成人av片免费| 在线电影国产精品| 日韩精品免费专区| 欧美色网一区二区| 亚洲一区二区三区在线播放| 91浏览器在线视频| 一区二区三区欧美| 91国产免费看| 亚洲国产综合人成综合网站| 色婷婷久久一区二区三区麻豆| 亚洲美腿欧美偷拍| 在线观看日韩电影| 亚洲第一在线综合网站|