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

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

?? emos_cpu.c

?? emos是一個新的類似于ucos的內核
?? C
?? 第 1 頁 / 共 2 頁
字號:
/****************************************************************************
 *
 * (c) Copyright 2001,2008, EMB system, All Rights Reserved.
 * THIS IS UNPUBLISHED PROPRIETARY SOURCE CODE OF EMB SYSTEM, INC.
 * The copyright notice above does not evidence any actual or intended
 * publication of such source code. 
 *
 *  Subsystem:   EMOS 
 *  File:        emos_cpu.c
 *  Author:      zenf zhao
 *  Description: this file include different CPU specific features to be supported
 *
 ****************************************************************************/

#include "emos_core.h" 
#include "emos_cpu.h"

uint8  gEmosTickDosCtr=0;      





#ifdef EMOS_CPU_X86_BCC_MODE
#include "..\cpux86\os_cpu_X86.c"
#endif






/*keep this section code as the last section of emos_cpu.c*/
#ifdef EMOS_CPU_MINGW_MODE 
#include <windows.h>

/*#include "..\cpum86\emos_cpumgw.c"*/
#define    ALLOW_CS_RECURSION    /* allow recursion of critical sections*/
#define    SET_AFFINITY_MASK     /* must be used for miltiprocessor systems*/
#define    EMOS_CPU_TRACE        /* allow print trace messages*/
#define    WIN_MM_TICK           /* Enabling WIN_MM_TICK will cause the uC/OS-II port to use the high resolution Multimedia  */
#define    WIN_MM_MIN_RES (1) 

DWORD WINAPI emosCtxSwW32( LPVOID lpParameter );
DWORD WINAPI emosTickW32 ( LPVOID lpParameter );
DWORD WINAPI emosTaskW32 ( LPVOID lpParameter );

uint32              gEmosTerminateTickW32     = 0;
uint32              gEmosTerminateCtxSwW32    = 0;
uint32              gEmosTerminateTickCtrlW32 = 0;
HANDLE              gEmosTick32Handle;
HANDLE              gEmosCtxSwW32Event;
HANDLE              gEmosCtxSwW32Handle;

#ifdef WIN_MM_TICK
HANDLE              gEmosTickEventHandle;
DWORD               gEmosTickTimer;
TIMECAPS            gEmosTimeCap;
#endif

CRITICAL_SECTION    gEmosCriticalSection;
HANDLE              gEmosSemaphore;

EMOS_EMU_STK*       SS_SP;

#ifdef ALLOW_CS_RECURSION
    DWORD           gThreadID = 0;
    int             gRecursion = 0;
#endif


/**********************************************************************************************************
*  OS INITIALIZATION HOOK
* (BEGINNING)
* Description: This function is called by OSInit() at the beginning of OSInit().
* Arguments  : none
* Note(s)    : 1) Interrupts should be disabled during this call.
**********************************************************************************************************/
void emosInitHookBegin(void)
{
#ifdef USE_CRITICAL_SECTION
    InitializeCriticalSection(&gEmosCriticalSection);
#else
    gEmosSemaphore = CreateSemaphore( NULL, 1, 1, NULL );
#endif
}

/*********************************************************************************************************
* OS INITIALIZATION HOOK(END)
* Description: This function is called by OSInit() at the end of OSInit().
* Arguments  : none
* Note(s)    : 1) Interrupts should be disabled during this call.
**********************************************************************************************************/
void emosInitHookEnd(void) {}

/*********************************************************************************************************
* EMOS_INIT_CRITICAL()
* Initialize code necessary for WIN32 implementation 
* of ENTER and EXIT CRITICAL routines.
**********************************************************************************************************/
void EMOS_INIT_CRITICAL()
{
#ifdef USE_CRITICAL_SECTION
    InitializeCriticalSection(&gEmosCriticalSection);
#endif
}

/********************************************************************************************************
* EMOS_ENTER_CRITICAL()
* Defines the beginning of a critical section of code.
*********************************************************************************************************/
void EMOS_ENTER_CRITICAL()
{
#ifdef USE_CRITICAL_SECTION
    EnterCriticalSection(&gEmosCriticalSection);
#else

#ifdef ALLOW_CS_RECURSION

    if( WaitForSingleObject(gEmosSemaphore, 0 ) == WAIT_TIMEOUT )
    {
        if( GetCurrentThreadId() != gThreadID )
        {
        	WaitForSingleObject( gEmosSemaphore, INFINITE );
        }
    }
    
    gThreadID = GetCurrentThreadId();
    ++gRecursion;

#else
    WaitForSingleObject(gEmosSemaphore, INFINITE );
#endif
#endif
}

/*********************************************************************************************************
* EMOS_EXIT_CRITICAL()
* Defines the end of a critical section of code.
**********************************************************************************************************/

void EMOS_EXIT_CRITICAL()
{
#ifdef USE_CRITICAL_SECTION
    LeaveCriticalSection(&gEmosCriticalSection);
#else
#ifdef ALLOW_CS_RECURSION

    if( gRecursion > 0 ) 
    {
        if(--gRecursion == 0 )
        {
            gThreadID = 0;
            ReleaseSemaphore(gEmosSemaphore, 1, NULL );
        }
    }
    else 
    {
#ifdef EMOS_CPU_TRACE
    EMOS_Printf("Error: EMOS_EXIT_CRITICAL\\n");
#endif
    }

#else
    ReleaseSemaphore(gEmosSemaphore, 1, NULL );
#endif
#endif
}

/*********************************************************************************************************
* INITIALIZE A TASK'S STACK
* Description: This function is called by either OSTaskCreate() or OSTaskCreateExt() to initialize the
*              stack frame of the task being created.  This function is highly processor specific.
* Arguments  : task          is a pointer to the task code
*              pdata         is a pointer to a user supplied data area that will be passed to the task
*                            when the task first executes.
*              ptos          is a pointer to the top of stack.  It is assumed that 'ptos' points to
*                            a 'free' entry on the task stack.  If EMOS_STK_GROWTH is set to 1 then 
*                            'ptos' will contain the HIGHEST valid address of the stack.  Similarly, if
*                            EMOS_STK_GROWTH is set to 0, the 'ptos' will contains the LOWEST valid address
*                            of the stack.
*              opt           specifies options that can be used to alter the behavior of OSTaskStkInit().
*                            (see uCEMOS_II.H for EMOS_TASK_OPT_???).
* Returns    : Always returns the location of the new top-of-stack' once the processor registers have
*              been placed on the stack in the proper order.
* Note(s)    : Interrupts are enabled when your task starts executing. You can change this by setting the
*              PSW to 0x0002 instead.  In this case, interrupts would be disabled upon task startup.  The
*              application code would be responsible for enabling interrupts at the beginning of the task
*              code.  You will need to modify OSTaskIdle() and OSTaskStat() so that they enable 
*              interrupts.  Failure to do this will make your system crash!
**********************************************************************************************************/

void *emosTaskStkInit (void (*task)(void *pd), void *pdata, void *ptos, uint16 opt)
{
    EMOS_EMU_STK* stk = NULL;

    stk             = (EMOS_EMU_STK *)((char*)ptos-sizeof(EMOS_EMU_STK));   /* Load stack pointer*/
    stk->pData      = pdata;
    stk->opt        = opt;
    stk->task       = task;
    stk->handle     = NULL;
    stk->id         = 0;
    stk->exit       = 0;

    return ((void *)stk);
}


#if EMOS_CPU_HOOKS_EN
/*********************************************************************************************************
* TASK CREATION HOOK
* Description: This function is called when a task is created.
* Arguments  : ptcb   is a pointer to the task control block of the task being created.
* Note(s)    : 1) Interrupts are disabled during this call.
**********************************************************************************************************/
void emosTCBInitHook(EMOS_TCB_T *ptcb)
{
    EMOS_EMU_STK  *stack;
    
    stack = (EMOS_EMU_STK*) ptcb->osTCBStkPtr;
    stack->handle = CreateThread( NULL, 0, emosTaskW32, ptcb, CREATE_SUSPENDED, &stack->id );
    
    #ifdef SET_AFFINITY_MASK
    if( SetThreadAffinityMask( stack->handle, 1 ) == 0 ) 
	{	
        #ifdef EMOS_CPU_TRACE
        EMOS_Printf("Error: SetThreadAffinityMask\n");
        #endif
    }
    #endif
}

void emosTaskCreateHook (EMOS_TCB_T *ptcb)
{
	/*TaskCreateHook call by EMOS Core Source TaskCreate(),
	 so it invoke the TCBInitHook to create the thread*/
	emosTCBInitHook(ptcb);
}

/*********************************************************************************************************
* TASK DELETION HOOK
* Description: This function is called when a task is deleted.
* Arguments  : ptcb   is a pointer to the task control block of the task being deleted.
* Note(s)    : 1) Interrupts are disabled during this call.
**********************************************************************************************************/

void emosTaskDelHook (EMOS_TCB_T *ptcb)
{
    EMOS_EMU_STK* stack;
    
    stack = (EMOS_EMU_STK*) ptcb->osTCBStkPtr;

    if(!(stack->exit))
    {
        SuspendThread(stack->handle);
        CloseHandle(stack->handle);
    }
}

/*********************************************************************************************************
* TASK SWITCH HOOK
* Description: This function is called when a task switch is performed.  This allows you to perform other
*              operations during a context switch.
* Arguments  : none
* Note(s)    : 1) Interrupts are disabled during this call.
*              2) It is assumed that the global pointer 'OSTCBHighRdy' points to the TCB of the task that
*                 will be 'switched in' (i.e. the highest priority task) and, 'OSTCBCur' points to the 
*                 task being switched out (i.e. the preempted task).
**********************************************************************************************************/

void emosTaskSwHook (void)
{
}

/*********************************************************************************************************
* STATISTIC TASK HOOK
* Description: This function is called every second by uC/OS-II's statistics task.  This allows your 
*              application to add functionality to the statistics task.
* Arguments  : none
**********************************************************************************************************/
void emosTaskStatHook (void)
{
}

/*********************************************************************************************************
*                                               TICK HOOK
* Description: This function is called every tick.
* Arguments  : none
* Note(s)    : 1) Interrupts may or may not be ENABLED during this call.
**********************************************************************************************************/
void emosTimeTickHook (void)
{
}

/*********************************************************************************************************
* TASK IDLE HOOK

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
狠狠狠色丁香婷婷综合激情 | 成人免费av在线| 蜜臀av国产精品久久久久| 视频一区在线播放| 日本va欧美va精品发布| 免费久久99精品国产| 捆绑调教美女网站视频一区| 久久精品免费观看| 国产一区二区主播在线| 国产成人精品亚洲午夜麻豆| 成人自拍视频在线| 一本色道久久综合亚洲91| 欧美视频日韩视频在线观看| 91精品国产日韩91久久久久久| 91麻豆精品91久久久久久清纯 | 久久久综合九色合综国产精品| 亚洲精品一区二区精华| 欧美国产日韩一二三区| **性色生活片久久毛片| 亚洲一区二区影院| 久久er99精品| 91丨九色丨尤物| 欧美日韩国产在线观看| 久久你懂得1024| 亚洲欧美国产高清| 免费在线观看不卡| 大尺度一区二区| 欧美性大战久久久久久久蜜臀| 日韩一区二区麻豆国产| 久久精品在线免费观看| 一区二区三区在线免费播放| 日本91福利区| 色综合久久久久久久久久久| 91精品欧美一区二区三区综合在| 久久人人超碰精品| 午夜日韩在线观看| 成人免费视频视频| 91精品国产综合久久精品性色| 久久这里只有精品6| 一区二区三区在线不卡| 久久福利视频一区二区| av亚洲产国偷v产偷v自拍| 欧美日韩高清一区二区不卡 | 91麻豆高清视频| 精品久久久久久无| 亚洲va欧美va人人爽午夜| 成人精品国产一区二区4080| 日韩一区二区三区免费观看| 亚洲精选一二三| 成人黄动漫网站免费app| 欧美一区日韩一区| 一区二区三区在线视频免费观看| 国产伦精一区二区三区| 日韩欧美视频在线| 首页综合国产亚洲丝袜| 99久久国产综合精品女不卡 | 成人av网址在线观看| 欧美变态凌虐bdsm| 欧美aⅴ一区二区三区视频| 色屁屁一区二区| 国产精品白丝在线| 国产精品影视网| 欧美sm美女调教| 日本亚洲一区二区| 91 com成人网| 日韩和欧美一区二区| 欧美日韩国产首页在线观看| 亚洲综合图片区| 色婷婷综合激情| 一区二区三区资源| 91黄色小视频| 亚洲国产乱码最新视频| 91国产免费看| 亚洲国产另类av| 国产精品一区二区果冻传媒| 久久精品一二三| 国产精品综合二区| 国产精品久久三| 99免费精品视频| 最新成人av在线| 在线观看欧美日本| 亚洲国产精品天堂| 制服丝袜激情欧洲亚洲| 日本午夜精品一区二区三区电影| 91精品国产一区二区人妖| 久久精品国产99国产| 久久久久88色偷偷免费| 成人app在线观看| 亚洲一区中文在线| 欧美精品亚洲一区二区在线播放| 免费日本视频一区| 精品国产91乱码一区二区三区 | 亚洲精品日韩专区silk| 色综合久久久久久久| 午夜精品一区在线观看| 精品剧情v国产在线观看在线| 国产专区综合网| 国产精品国产自产拍在线| 欧美性做爰猛烈叫床潮| 久久疯狂做爰流白浆xx| 亚洲欧洲韩国日本视频| 欧美久久婷婷综合色| 久久国产精品72免费观看| 国产视频一区二区在线| 色综合久久综合网欧美综合网| 午夜激情综合网| 久久综合九色综合97婷婷女人| 99精品视频在线播放观看| 日韩国产欧美一区二区三区| 国产亚洲欧美一级| 欧美视频中文字幕| 国产精品 日产精品 欧美精品| 亚洲一区二区三区三| 久久网这里都是精品| 91久久精品午夜一区二区| 国产一区二区按摩在线观看| 亚洲美女精品一区| 久久久三级国产网站| 欧美日韩精品三区| 成人午夜视频网站| 免费成人av在线| 有坂深雪av一区二区精品| 2021国产精品久久精品 | 久久99日本精品| 一区二区视频免费在线观看| 精品国产乱码久久久久久免费| 色综合久久久久综合体桃花网| 国产精品综合一区二区| 日本欧美一区二区三区乱码| 中文字幕综合网| 久久精品一区二区三区不卡牛牛 | 亚洲少妇30p| 久久久精品综合| 日韩欧美第一区| 在线电影一区二区三区| 色94色欧美sute亚洲线路一ni| 成人性生交大合| 国产一区视频网站| 久久精品国产亚洲一区二区三区 | 日韩一区二区三区免费看| 在线观看国产一区二区| 一本大道久久精品懂色aⅴ| 成人av网在线| www.欧美亚洲| 国产91精品精华液一区二区三区| 精品一区二区三区蜜桃| 美女高潮久久久| 男女视频一区二区| 老汉av免费一区二区三区 | 国产99久久精品| 国产一区在线观看麻豆| 极品少妇xxxx精品少妇偷拍| 免费成人在线网站| 狠狠网亚洲精品| 国产成人在线免费| 成人av资源网站| 91蜜桃网址入口| 91久久一区二区| 欧美精品乱码久久久久久| 欧美理论片在线| 精品少妇一区二区三区日产乱码| 日韩一区二区视频| 久久久噜噜噜久久人人看 | 欧美一区二区视频在线观看2020 | 国产成人综合亚洲91猫咪| 成人免费毛片嘿嘿连载视频| 成人综合激情网| 日本乱人伦aⅴ精品| 欧美四级电影网| 欧美变态tickle挠乳网站| 国产日韩一级二级三级| 亚洲免费看黄网站| 秋霞电影网一区二区| 国精品**一区二区三区在线蜜桃| 国产成人综合亚洲网站| 91丨porny丨首页| 欧美一区二区在线看| 国产亚洲欧美日韩日本| 一区二区三区蜜桃| 极品少妇一区二区三区精品视频| 岛国一区二区三区| 欧美日韩亚洲不卡| 国产午夜精品一区二区三区嫩草| 亚洲色图欧美激情| 亚洲香蕉伊在人在线观| 国产一区二区三区电影在线观看| 99精品在线免费| 91精品国产91久久综合桃花| 国产日韩综合av| 日韩激情一二三区| 99re热这里只有精品视频| 欧美一区二区视频在线观看| 国产精品久久久久久亚洲伦 | 亚洲制服丝袜av| 国产一区二区三区香蕉| 欧美日韩激情一区二区三区| 欧美激情一区二区在线| 蜜臀久久99精品久久久画质超高清 | 欧美xxxx在线观看| 亚洲视频中文字幕|