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

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

?? port.c

?? FreeRTOS V4.2.1,增加了AVR32 UC3 和 LPC2368 的支持
?? C
字號:
/*    FreeRTOS V4.1.1 - Copyright (C) 2003-2006 Richard Barry.    MCF5235 Port - Copyright (C) 2006 Christian Walter.    This file is part of the FreeRTOS distribution.    FreeRTOS 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 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; 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, 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.

	Also see http://www.SafeRTOS.com for an IEC 61508 compliant version along
	with commercial development and support options.    ****************************************************************************/#include <stdlib.h>#include "FreeRTOS.h"#include "FreeRTOSConfig.h"#include "task.h"/* ------------------------ Types ----------------------------------------- */typedef volatile unsigned long vuint32;typedef volatile unsigned short vuint16;typedef volatile unsigned char vuint8;/* ------------------------ Defines --------------------------------------- */#define portVECTOR_TABLE                __RAMVEC#define portVECTOR_SYSCALL              ( 32 + portTRAP_YIELD )#define portVECTOR_TIMER                ( 64 + 36 )#define MCF_PIT_PRESCALER               512UL#define MCF_PIT_TIMER_TICKS             ( FSYS_2 / MCF_PIT_PRESCALER )#define MCF_PIT_MODULUS_REGISTER(freq)  ( MCF_PIT_TIMER_TICKS / ( freq ) - 1UL)#define MCF_PIT_PMR0                    ( *( vuint16 * )( void * )( &__IPSBAR[ 0x150002 ] ) )#define MCF_PIT_PCSR0                   ( *( vuint16 * )( void * )( &__IPSBAR[ 0x150000 ] ) )#define MCF_PIT_PCSR_PRE(x)             ( ( ( x ) & 0x000F ) << 8 )#define MCF_PIT_PCSR_EN                 ( 0x0001 )#define MCF_PIT_PCSR_RLD                ( 0x0002 )#define MCF_PIT_PCSR_PIF                ( 0x0004 )#define MCF_PIT_PCSR_PIE                ( 0x0008 )#define MCF_PIT_PCSR_OVW                ( 0x0010 )#define MCF_INTC0_ICR36                 ( *( vuint8 * )( void * )( &__IPSBAR[ 0x000C64 ] ) )#define MCF_INTC0_IMRH                  ( *( vuint32 * )( void * )( &__IPSBAR[ 0x000C08 ] ) )#define MCF_INTC0_IMRH_INT_MASK36       ( 0x00000010 )#define MCF_INTC0_IMRH_MASKALL          ( 0x00000001 )#define MCF_INTC0_ICRn_IP(x)            ( ( ( x ) & 0x07 ) << 0 )#define MCF_INTC0_ICRn_IL(x)            ( ( ( x ) & 0x07 ) << 3 )#define portNO_CRITICAL_NESTING         ( ( unsigned portLONG ) 0 )#define portINITIAL_CRITICAL_NESTING    ( ( unsigned portLONG ) 10 )/* ------------------------ Static variables ------------------------------ */volatile unsigned portLONG              ulCriticalNesting = portINITIAL_CRITICAL_NESTING;/* ------------------------ Static functions ------------------------------ */#if configUSE_PREEMPTION == 0static void prvPortPreemptiveTick ( void ) __attribute__ ((interrupt_handler));#elsestatic void prvPortPreemptiveTick ( void );#endif/* ------------------------ Start implementation -------------------------- */portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE * pxTopOfStack, pdTASK_CODE pxCode,                       void *pvParameters ){    /* Place the parameter on the stack in the expected location. */    *pxTopOfStack = ( portSTACK_TYPE ) pvParameters;    pxTopOfStack--;    /* Place dummy return address on stack. Tasks should never terminate so     * we can set this to anything. */    *pxTopOfStack = ( portSTACK_TYPE ) 0;    pxTopOfStack--;    /* Create a Motorola Coldfire exception stack frame. First comes the return     * address. */    *pxTopOfStack = ( portSTACK_TYPE ) pxCode;    pxTopOfStack--;    /* Format, fault-status, vector number for exception stack frame. Task     * run in supervisor mode. */    *pxTopOfStack = 0x40002000UL | ( portVECTOR_SYSCALL + 32 ) << 18;    pxTopOfStack--;    /* Set the initial critical section nesting counter to zero. This value     * is used to restore the value of ulCriticalNesting. */    *pxTopOfStack = 0;    *pxTopOfStack--;    *pxTopOfStack = ( portSTACK_TYPE ) 0xA6;    /* A6 / FP */    pxTopOfStack--;    *pxTopOfStack = ( portSTACK_TYPE ) 0xA5;    /* A5 */    pxTopOfStack--;    *pxTopOfStack = ( portSTACK_TYPE ) 0xA4;    /* A4 */    pxTopOfStack--;    *pxTopOfStack = ( portSTACK_TYPE ) 0xA3;    /* A3 */    pxTopOfStack--;    *pxTopOfStack = ( portSTACK_TYPE ) 0xA2;    /* A2 */    pxTopOfStack--;    *pxTopOfStack = ( portSTACK_TYPE ) 0xA1;    /* A1 */    pxTopOfStack--;    *pxTopOfStack = ( portSTACK_TYPE ) 0xA0;    /* A0 */    pxTopOfStack--;    *pxTopOfStack = ( portSTACK_TYPE ) 0xD7;    /* D7 */    pxTopOfStack--;    *pxTopOfStack = ( portSTACK_TYPE ) 0xD6;    /* D6 */    pxTopOfStack--;    *pxTopOfStack = ( portSTACK_TYPE ) 0xD5;    /* D5 */    pxTopOfStack--;    *pxTopOfStack = ( portSTACK_TYPE ) 0xD4;    /* D4 */    pxTopOfStack--;    *pxTopOfStack = ( portSTACK_TYPE ) 0xD3;    /* D3 */    pxTopOfStack--;    *pxTopOfStack = ( portSTACK_TYPE ) 0xD2;    /* D2 */    pxTopOfStack--;    *pxTopOfStack = ( portSTACK_TYPE ) 0xD1;    /* D1 */    pxTopOfStack--;    *pxTopOfStack = ( portSTACK_TYPE ) 0xD0;    /* D0 */    return pxTopOfStack;}/* * Called by portYIELD() or taskYIELD() to manually force a context switch. */static voidprvPortYield( void ){    asm volatile ( "move.w  #0x2700, %sr\n\t" );#if _GCC_USES_FP == 1    asm volatile ( "unlk %fp\n\t" );#endif     /* Perform the context switch.  First save the context of the current task. */    portSAVE_CONTEXT(  );    /* Find the highest priority task that is ready to run. */    vTaskSwitchContext(  );    /* Restore the context of the new task. */    portRESTORE_CONTEXT(  );}#if configUSE_PREEMPTION == 0/* * The ISR used for the scheduler tick depends on whether the cooperative or * the preemptive scheduler is being used. */static voidprvPortPreemptiveTick ( void ){    /* The cooperative scheduler requires a normal IRQ service routine to     * simply increment the system tick.     */    vTaskIncrementTick(  );    MCF_PIT_PCSR0 |= MCF_PIT_PCSR_PIF;}#elsestatic voidprvPortPreemptiveTick( void ){    asm volatile ( "move.w  #0x2700, %sr\n\t" );#if _GCC_USES_FP == 1    asm volatile ( "unlk %fp\n\t" );#endif    portSAVE_CONTEXT(  );    MCF_PIT_PCSR0 |= MCF_PIT_PCSR_PIF;    vTaskIncrementTick(  );    vTaskSwitchContext(  );    portRESTORE_CONTEXT(  );}#endifvoidvPortEnterCritical(){    /* FIXME: We should store the old IPL here - How are we supposed to do     * this.     */    ( void )portSET_IPL( portIPL_MAX );    /* Now interrupts are disabled ulCriticalNesting can be accessed     * directly.  Increment ulCriticalNesting to keep a count of how many times     * portENTER_CRITICAL() has been called. */    ulCriticalNesting++;}voidvPortExitCritical(){    if( ulCriticalNesting > portNO_CRITICAL_NESTING )    {        /* Decrement the nesting count as we are leaving a critical section. */        ulCriticalNesting--;        /* If the nesting level has reached zero then interrupts should be        re-enabled. */        if( ulCriticalNesting == portNO_CRITICAL_NESTING )        {            ( void )portSET_IPL( 0 );        }    }}portBASE_TYPExPortStartScheduler( void ){    extern void     ( *portVECTOR_TABLE[  ] ) (  );    /* Add entry in vector table for yield system call. */    portVECTOR_TABLE[ portVECTOR_SYSCALL ] = prvPortYield;    /* Add entry in vector table for periodic timer. */    portVECTOR_TABLE[ portVECTOR_TIMER ] = prvPortPreemptiveTick;    /* Configure the timer for the system clock. */    if ( configTICK_RATE_HZ > 0)    {        /* Configure prescaler */        MCF_PIT_PCSR0 = MCF_PIT_PCSR_PRE( 0x9 ) | MCF_PIT_PCSR_RLD | MCF_PIT_PCSR_OVW;        /* Initialize the periodic timer interrupt. */        MCF_PIT_PMR0 = MCF_PIT_MODULUS_REGISTER( configTICK_RATE_HZ );        /* Configure interrupt priority and level and unmask interrupt. */        MCF_INTC0_ICR36 = MCF_INTC0_ICRn_IL( 0x1 ) | MCF_INTC0_ICRn_IP( 0x1 );        MCF_INTC0_IMRH &= ~( MCF_INTC0_IMRH_INT_MASK36 | MCF_INTC0_IMRH_MASKALL );        /* Enable interrupts */        MCF_PIT_PCSR0 |= MCF_PIT_PCSR_PIE | MCF_PIT_PCSR_EN | MCF_PIT_PCSR_PIF;    }    /* Restore the context of the first task that is going to run. */    portRESTORE_CONTEXT(  );    /* Should not get here. */    return pdTRUE;}voidvPortEndScheduler( void ){}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本丶国产丶欧美色综合| 国产精品无人区| 亚洲与欧洲av电影| 99国产精品久| 亚洲综合久久久| 亚洲综合一区二区精品导航| 亚洲天堂精品视频| 欧美电影在哪看比较好| 麻豆精品一二三| 久久精品人人爽人人爽| 日本精品一级二级| 色婷婷久久综合| 国内不卡的二区三区中文字幕| 久久久久久久久伊人| 精品污污网站免费看| 国产一区二区免费在线| 亚洲一区二区三区中文字幕| 亚洲电影一区二区三区| 欧美精品在线视频| 欧美一区二区三区人| 91色婷婷久久久久合中文| 国产在线精品一区二区不卡了 | 国产乱码精品一区二区三区忘忧草 | 国产激情一区二区三区四区| 一区二区三区在线不卡| 久久久久久久av麻豆果冻| 国产女人aaa级久久久级| 日韩免费高清电影| 欧美午夜精品一区二区三区| 国产精品亚洲第一区在线暖暖韩国 | 亚洲一级片在线观看| 日韩国产欧美在线观看| 亚洲综合清纯丝袜自拍| 蜜臀a∨国产成人精品| 国产乱对白刺激视频不卡| 91美女片黄在线| 欧美xxxxxxxx| 91精品国产综合久久香蕉麻豆| 99精品热视频| 欧美一级专区免费大片| 亚洲视频在线一区观看| 久久精品国产亚洲a| 蜜桃视频在线一区| av午夜一区麻豆| 成人免费视频免费观看| 国产激情视频一区二区在线观看| 色欧美乱欧美15图片| 久久色在线视频| 国产日韩在线不卡| 日本亚洲一区二区| 一道本成人在线| 国产欧美日韩在线| 久久91精品国产91久久小草 | 日韩精品一区二| 一区二区三区蜜桃| 成人黄色a**站在线观看| 成人h精品动漫一区二区三区| 欧美伊人久久大香线蕉综合69| 国产日韩欧美一区二区三区乱码| 亚洲国产视频一区| 91香蕉国产在线观看软件| 久久美女高清视频| 美女一区二区视频| 欧美日韩亚洲高清一区二区| 国产精品第一页第二页第三页| 亚洲天堂网中文字| 成人精品电影在线观看| 久久精品视频在线看| 韩国av一区二区三区在线观看| 欧美吞精做爰啪啪高潮| 亚洲一区二区视频在线| 日本韩国视频一区二区| 亚洲精品欧美综合四区| 美女在线一区二区| 91精品国产综合久久久久| 亚洲成人免费观看| 欧美日韩情趣电影| 午夜激情一区二区| 国产福利一区二区三区在线视频| 日韩视频免费直播| 亚洲欧洲日产国码二区| 婷婷中文字幕综合| 日韩一区二区三区在线视频| 男女男精品网站| 91丨porny丨首页| 亚洲精品免费看| 欧美性受xxxx| 丝袜诱惑亚洲看片| bt欧美亚洲午夜电影天堂| 国产精品久久午夜夜伦鲁鲁| 成人激情电影免费在线观看| 综合自拍亚洲综合图不卡区| 91影视在线播放| 亚洲成人久久影院| 日韩视频不卡中文| 国产一区二区成人久久免费影院| 久久久亚洲午夜电影| 不卡影院免费观看| 亚洲一区在线视频观看| 8x福利精品第一导航| 国产在线播放一区二区三区 | 成人18视频在线播放| 亚洲视频网在线直播| 欧美日韩亚洲综合在线 | 日韩高清不卡在线| 精品嫩草影院久久| av一区二区三区黑人| 亚洲国产日韩a在线播放性色| 欧美精品 日韩| 成人永久免费视频| 亚洲国产欧美日韩另类综合| 日韩欧美国产高清| 成人aaaa免费全部观看| 天堂久久久久va久久久久| 久久久综合视频| 欧美怡红院视频| 国v精品久久久网| 久久久三级国产网站| 成人在线综合网站| 一区二区三区欧美亚洲| 欧美日韩免费一区二区三区| 2021国产精品久久精品| 91丝袜呻吟高潮美腿白嫩在线观看| 午夜精品福利在线| 国产精品美日韩| 日韩一区二区电影网| 成人国产免费视频| 奇米精品一区二区三区在线观看一 | 日韩欧美一级特黄在线播放| www..com久久爱| 国产一区二区在线视频| 午夜国产不卡在线观看视频| 国产精品久久久久精k8 | 久久久国际精品| 欧美一区二区在线看| 99久久国产综合色|国产精品| 男人的天堂久久精品| 亚洲一区在线观看视频| 国产精品视频你懂的| 日韩美一区二区三区| 欧美日韩国产综合草草| 亚洲精品乱码久久久久久久久 | 亚洲成av人片| 亚洲国产电影在线观看| 风流少妇一区二区| 国产一区二区网址| 激情五月婷婷综合| 精品亚洲porn| 粉嫩久久99精品久久久久久夜| 极品美女销魂一区二区三区免费| 亚洲欧美综合另类在线卡通| 不卡的电视剧免费网站有什么| 精品一区二区三区在线观看国产| 亚洲电影欧美电影有声小说| 亚洲精选视频在线| 亚洲欧美视频在线观看| 91香蕉国产在线观看软件| 成人午夜私人影院| 国产成a人亚洲| 国产成人av电影| 成人免费视频网站在线观看| 成人一二三区视频| 成人黄色777网| 91视频com| 欧美日韩高清一区| 欧美一区二区视频免费观看| 337p亚洲精品色噜噜狠狠| 91精品啪在线观看国产60岁| 欧美一区二区在线不卡| 日韩一级免费一区| 精品sm在线观看| 欧美日免费三级在线| 91精品国产综合久久久蜜臀粉嫩 | 国产精品日产欧美久久久久| 亚洲国产经典视频| 亚洲三级电影全部在线观看高清| 一区二区三区自拍| 日本午夜一区二区| 国产精品一区免费视频| 成人成人成人在线视频| 欧美在线观看一区| 成人av网址在线观看| 色网站国产精品| 欧美日韩成人一区二区| 日韩欧美国产一区在线观看| 欧美高清在线精品一区| 亚洲综合在线视频| 韩国欧美国产一区| 91免费看片在线观看| 欧美精品少妇一区二区三区| 精品成人免费观看| 亚洲精品国久久99热| 麻豆国产精品一区二区三区 | 国产精品一级片在线观看| 99久久久国产精品免费蜜臀| 7777精品伊人久久久大香线蕉超级流畅 | 亚洲乱码中文字幕| 狠狠色狠狠色综合| 欧美性色欧美a在线播放| 久久色在线视频|