青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

唐吉訶德

  C++博客 :: 首頁 :: 聯系 :: 聚合  :: 管理
  5 Posts :: 75 Stories :: 3 Comments :: 0 Trackbacks

常用鏈接

留言簿(2)

我參與的團隊

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

Windows Embedded CE 6.0的中斷處理過程主要分為兩部分:

  •  中斷服務例程(ISR):處于內核中的低級處理程序,中斷發生時首先被調用。
  • 中斷服務線程(IST):處于驅動或者應用中的中斷處理線程,由系統調度,完成大部分的中斷處理工作。

ISR的實現在OALOEM適配層)中,它只處理最低級的中斷響應,通常是獲取IRQSYSINTR并設置MCU內部的中斷控制寄存器。中斷處理的主要部分在驅動或者應用的中斷處理線程中。中斷處理線程與其他普通線程一樣,使用同一個線程優先級管理系統。ISRIST之間通過事件對象進行同步。IST中創建一個事件對象,并使用函數WaitForSingleObject()等待該事件被觸發。ISR中通知內核觸發相應的事件對象。Windows Embedded CE 6.0的中斷處理的過程如下圖所示。

                      Windows Embedded CE 6.0的中斷處理過程

  在其他的一些嵌入式操作系統中,在介紹中斷處理時經常會提到一個中斷向量表的概念,如uC/OS。當中斷發生時它會進入IRQ的處理程序,并根據IRQ的值跳轉到事先分配好的中斷向量表相應的中斷處理函數中。但在WinCE中實際上并不存在中斷向量表的概念,而只有一個異常向量表,對應于MCU的幾種運行模式。WinCE的中斷處理對應于兩個異常IRQHandlerFIQHandler,通常我們使用的是IRQHandler。當外部中斷產生時,系統執行IRQHandler(),IRQHandler()中調用OEMInterruptHandler()獲取IRQ對應的SYSINTR,然后根據SYSINTR調用函數OEMNotifyIntrOccurs()觸發與SYSINTR關聯的事件,最后由IST完成主要的中斷處理工作。這種中斷處理機制在一定程度上影響了系統的實時性,但提高了IST的靈活性。有關WinCE系統實時性分析,將在另外一篇中描述。

     下面結合C:\WINCE600\PLATFORM\DEVICEEMULATOR\SRC\DRIVERSPWRBUTTON驅動進行分析。該驅動也是一個流驅動,所以可以用驅動調試助手進行動態加載和卸載,但需要對代碼進行相應的修改,否則會出問題。

    首先看PBT_Init()函數,代碼如下:


DWORD
PBT_Init(DWORD dwContext)
{
    DWORD   IDPowerButtonThread;
    DWORD   IDResetButtonThread;
    HMODULE hmCore;

    
//
    
// 從CORE Library中獲取電源管理器"SetSystemPowerState"的函數指針/
    pfnSetSystemPowerState = NULL;

    hmCore 
= (HMODULE) LoadLibrary(_T("coredll.dll"));

    
if(hmCore != NULL)
    
{
        pfnSetSystemPowerState 
= (PFN_SetSystemPowerState) GetProcAddress(hmCore, _T("SetSystemPowerState"));

        
if(pfnSetSystemPowerState == NULL)
        
{
            FreeLibrary(hmCore);
        }

    }


    
//初始化相關的虛擬內存地址
    InitializeAddresses();

    
// 創建POWER Button的IST和RESET Button的IST
    ResetButtonIntrThreadHandle = CreateThread(00, (LPTHREAD_START_ROUTINE) ResetButtonIntrThread, 00&IDResetButtonThread);
    
if (ResetButtonIntrThreadHandle == 0)
    
{
        RETAILMSG(
1, (TEXT("PBT: CreateThread() Fail\r\n")));
    }

    PowerButtonIntrThreadHandle 
= CreateThread(00, (LPTHREAD_START_ROUTINE) PowerButtonIntrThread, 00&IDPowerButtonThread);
    
if (PowerButtonIntrThreadHandle == 0)
    
{
        RETAILMSG(
1, (TEXT("PBT: CreateThread() Fail\r\n")));
    }


    
return (dwContext);
}

      RESET ButtonISTPOWER ButtonIST基本一致,所以這里只分析POWER ButtonIST,代碼如下。      


static DWORD
PowerButtonIntrThread(PVOID pArg)
{
    
//初始化中斷寄存器,使能相應的中斷
    EnablePowerButtonInterrupt();

    
//創建一個事件
    PwrButtonIntrEvent = CreateEvent(NULL, FALSE, FALSE, NULL);

    
//
    
// 根據IRQ獲取一個SYSINTR
    
//
    if (!KernelIoControl(IOCTL_HAL_REQUEST_SYSINTR, &PwrButtonIrq, sizeof PwrButtonIrq, &PwrButtonSysIntr, sizeof PwrButtonSysIntr, NULL))
    
{
        RETAILMSG(
1, (TEXT("PBT: Error! Failed to request sysintr value for power button interrupt.\r\n")));
        
return(0);
    }

    
    
//關聯SYSINTR和之前創建的事件
    if (!(InterruptInitialize(PwrButtonSysIntr, PwrButtonIntrEvent, 00)))
    
{
        RETAILMSG(
1, (TEXT("ERROR: PwrButton: Interrupt initialize failed.\r\n")));
    }


    
//POWER Button按下的處理程序
    for (;;)
    
{
        WaitForSingleObject(PwrButtonIntrEvent, INFINITE);
        
        
if (PowerButtonIsPushed()) //確認按鍵確實被按下,消除抖動
        {
            Sleep(
200);         //延遲200ms,排除長按的情況
            if (!PowerButtonIsPushed())    //按鍵被有效釋放
            {
                
//
                
//關閉系統 
                
//
                if(pfnSetSystemPowerState != NULL)
                
{
                    RETAILMSG(
1,(TEXT("PBT: Signalling power manager to suspend\r\n")));
                    pfnSetSystemPowerState(NULL, POWER_STATE_SUSPEND, POWER_FORCE);
                }
 else {
                    RETAILMSG(
1,(TEXT("PBT: Suspending by calling PowerOffSystem\r\n")));
                    PowerOffSystem();
                }

                
//
                
//結束當前線程的時間片
                Sleep(0);
            }

            
else
                RETAILMSG(
1,(TEXT("PBT: Button held too long (ignored)\r\n")));
        }

        
else
            RETAILMSG(
1,(TEXT("PBT: Feeble button press or noise triggered it (ignored)\r\n")));

        InterruptDone(PwrButtonSysIntr);
    }

}

    以上代碼結構清晰,不再贅述。但這樣編譯出來的驅動是不能通過驅動調試助手動態加載的,必須進行相應的修改才行。主要原因是沒有善始善終,分配的系統邏輯中斷沒有釋放,系統邏輯中斷與事件的關聯也沒有取消。實驗現象是,能通過驅動調試助手加載卸載,但中斷并不能正常工作了。下面介紹一下解決這個問題的辦法。

  首先定義一個全局變量g_bThreadExit初始化為FALSE。IST修改后的代碼如下:


static DWORD
PowerButtonIntrThread(PVOID pArg)
{
//初始化中斷寄存器,使能相應的中斷
    EnablePowerButtonInterrupt();

    
//創建一個事件
    PwrButtonIntrEvent = CreateEvent(NULL, FALSE, FALSE, NULL);

    
//
    
// 根據IRQ獲取一個SYSINTR
    
//
    if (!KernelIoControl(IOCTL_HAL_REQUEST_SYSINTR, &PwrButtonIrq, sizeof PwrButtonIrq, &PwrButtonSysIntr, sizeof PwrButtonSysIntr, NULL))
    
{
        RETAILMSG(
1, (TEXT("PBT: Error! Failed to request sysintr value for power button interrupt.\r\n")));
        
return(0);
    }

    
    
//關聯SYSINTR和之前創建的事件
    if (!(InterruptInitialize(PwrButtonSysIntr, PwrButtonIntrEvent, 00)))
    
{
        RETAILMSG(
1, (TEXT("ERROR: PwrButton: Interrupt initialize failed.\r\n")));
    }

    
    
// POWER Button按下的處理程序
    for (;;)
    
{
        WaitForSingleObject(PwrButtonIntrEvent, INFINITE);
                
        
if(g_bThreadExit)
        
{
            
break;    
        }


        
if (PowerButtonIsPushed())     //確認按鍵確實被按下,消除抖動
        {
            Sleep(
200);         //延遲ms,排除長按的情況
            if (!PowerButtonIsPushed())    //按鍵被有效釋放
            {
                
//
                
//關閉系統
                
//
                if(pfnSetSystemPowerState != NULL)
                
{
                    RETAILMSG(
1,(TEXT("PBT: Signalling power manager to suspend\r\n")));
                    pfnSetSystemPowerState(NULL, POWER_STATE_SUSPEND, POWER_FORCE);
                }
 else {
                    RETAILMSG(
1,(TEXT("PBT: Suspending by calling PowerOffSystem\r\n")));
                    PowerOffSystem();
                }

                
//
                
//結束當前線程的時間片
                
//
                Sleep(0);
            }

            
else
                RETAILMSG(
1,(TEXT("PBT: Button held too long (ignored)\r\n")));
        }

        
else
            RETAILMSG(
1,(TEXT("PBT: Feeble button press or noise triggered it (ignored)\r\n")));

        InterruptDone(PwrButtonSysIntr);
    }

    
    
//取消IRQ與SYSINTR之間的關聯
    KernelIoControl(IOCTL_HAL_RELEASE_SYSINTR,&PwrButtonSysIntr, sizeof(UINT32),NULL,0, NULL);
    
    
//取消Event與PwrButtonSysIntr之間的關聯
    InterruptDisable(PwrButtonSysIntr);

    CloseHandle(PwrButtonIntrEvent);
    
    RETAILMSG(
1, (TEXT("PowerButtonIntrThread Exit.\r\n")));
    
return 0;
}

  PBT_Deinit()修改后的代碼如下:


BOOL
PBT_Deinit(DWORD dwContext)
{
    RETAILMSG(
1, (TEXT("PBT: PBT_Deinit()\r\n")));
    
//設置退出線程的標志
g_bThreadExit = TRUE;
    
//模擬一個中斷事件
SetInterruptEvent(PwrButtonSysIntr);
    
//延遲500ms,確保IST退出
Sleep(500);

    
return (TRUE);
}

  經過以上修改,該中斷驅動程序就可以通過驅動調試助手動態加載和卸載,并能正常工作了。另外,在模擬器中由于沒有外部中斷按鍵,可以通過創建一個特定名稱的事件與中斷關聯,并在另外一個應用或者驅動中設置該事件以模擬一個外部中斷按鍵的觸發,這種方法也可以在實際平臺中根據需要使用。示例代碼如下:


//打開與中斷關聯的事件
gIntrEvent = CreateEvent(NULL, FALSE, FALSE, _T("PBTINTR"));
//設置該事件,模擬一個中斷的觸發
SetEvent(gIntrEvent);
IST中創建與中斷關聯的事件代碼修改如下:
PwrButtonIntrEvent 
= CreateEvent(NULL, FALSE, FALSE, _T("PBTINTR"));

  總的來說,WinCE中斷處理過程結構清晰,方便開發人員靈活設計IST。在使用驅動調試助手調試有關中斷的驅動程序時,需要善始善終,否則會出現中斷不能正常工作的情況。

posted on 2011-03-01 10:55 心羽 閱讀(762) 評論(0)  編輯 收藏 引用 所屬分類: wince
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美日韩视频专区在线播放| 日韩天堂在线视频| 欧美一区二区三区精品电影| 亚洲精品视频免费在线观看| 亚洲第一区在线| 免费欧美电影| 欧美激情一区二区久久久| 美女露胸一区二区三区| 玖玖玖国产精品| 欧美大色视频| 亚洲精品一区中文| 午夜伦理片一区| 久久综合狠狠| 欧美日韩成人一区二区| 国产精品久久久一本精品| 国产视频一区免费看| 一区三区视频| 一区二区三欧美| 欧美一区二区视频网站| 久久嫩草精品久久久精品| 免费在线看一区| 日韩一级在线| 久久精品国产一区二区三| 欧美激情a∨在线视频播放| 国产精品成人久久久久| 国产日韩亚洲欧美综合| 亚洲激情电影在线| 亚洲综合首页| 久久亚洲精品欧美| 亚洲精品在线三区| 久久gogo国模啪啪人体图| 欧美激情第8页| 国外视频精品毛片| 亚洲一区二区三区四区五区午夜| 久久综合色8888| 一区二区欧美在线| 美国十次了思思久久精品导航| 国产精品sss| 亚洲国产精品激情在线观看| 午夜久久一区| 亚洲精品无人区| 久久视频免费观看| 国产日韩欧美中文| 亚洲欧美一区二区三区久久 | 午夜欧美不卡精品aaaaa| 久久久久久黄| 欧美1区视频| 欧美在线影院| 欧美一区二区三区喷汁尤物| 亚洲激情电影中文字幕| 久久福利影视| 国产情人综合久久777777| 亚洲午夜在线观看视频在线| 欧美激情小视频| 久久久最新网址| 一区二区亚洲精品国产| 久久人人九九| 久久精品人人做人人综合| 国产欧美日韩另类视频免费观看| 亚洲图中文字幕| 夜夜嗨av色一区二区不卡| 欧美精品麻豆| 日韩午夜av电影| 日韩一级在线观看| 国产精品国产自产拍高清av王其 | 狠狠色丁香婷婷综合影院| 欧美一区免费视频| 欧美一区午夜精品| 一区二区三区在线免费视频| 久久一区亚洲| 蜜臀av国产精品久久久久| 亚洲福利专区| 91久久综合亚洲鲁鲁五月天| 欧美日韩国产综合久久| 亚洲制服av| 亚洲欧美在线免费| 一区二区在线不卡| 亚洲国产精品久久久| 欧美日韩成人综合| 午夜精品在线观看| 欧美自拍偷拍午夜视频| 在线免费观看视频一区| 亚洲国产成人午夜在线一区| 欧美黄色aa电影| 欧美一区二区三区免费观看视频| 欧美一级久久久久久久大片| 亚洲丶国产丶欧美一区二区三区 | 亚洲二区视频| 欧美日韩一区在线观看| 欧美在线日韩在线| 欧美成人精品在线播放| 亚洲影院色在线观看免费| 欧美一区二区三区四区视频| 亚洲国产天堂久久综合网| 一区二区国产日产| 精品电影一区| 亚洲一区二区三区精品动漫| 激情欧美一区二区三区在线观看| 亚洲高清激情| 国产精品自拍三区| 亚洲人成欧美中文字幕| 国产亚洲精品美女| 亚洲毛片一区| 亚洲高清不卡一区| 亚洲女爱视频在线| 在线观看福利一区| 黄色精品一区二区| 亚洲欧美国产日韩天堂区| 欧美专区日韩专区| 一本到12不卡视频在线dvd| 性做久久久久久免费观看欧美| 亚洲国产日韩在线| 小辣椒精品导航| 亚洲天堂av在线免费| 美女露胸一区二区三区| 欧美一区国产二区| 欧美精品一区二区在线播放| 久久久国产91| 国产精品蜜臀在线观看| 亚洲人成在线播放| 亚洲区欧美区| 噜噜噜91成人网| 久久一区国产| 国产一区二区三区久久久| 一区二区三区视频在线看| 日韩视频一区二区三区| 暖暖成人免费视频| 欧美91视频| 亚洲福利视频三区| 久久综合国产精品| 老巨人导航500精品| 国内外成人免费激情在线视频网站| 一本大道久久精品懂色aⅴ| 亚洲精品久久久久久下一站 | 欧美国产一区二区在线观看| 免费日韩精品中文字幕视频在线| 国产区在线观看成人精品| 亚洲一本视频| 翔田千里一区二区| 欧美日韩一区二区三区免费| 亚洲精品一区二区三区在线观看| 91久久久久久久久| 欧美精品精品一区| 亚洲精品国产视频| 亚洲五月六月| 国产精品视频一区二区高潮| 亚洲一区视频在线观看视频| 亚洲欧美在线aaa| 国产欧美丝祙| 久久久久久电影| 亚洲国产第一| 亚洲无玛一区| 国产亚洲一区二区三区| 久久久噜久噜久久综合| 欧美成人一区二区三区在线观看| 亚洲国产一区二区精品专区| 欧美激情视频网站| 一本色道久久综合狠狠躁篇的优点 | 久久综合久久综合久久综合| 欧美大片免费| 亚洲精品永久免费精品| 欧美日韩一区二区三区四区在线观看 | 欧美一区二区免费观在线| 亚洲激情黄色| 欧美性事在线| 亚洲欧洲av一区二区| 久久婷婷激情| 亚洲精品久久久久| 国产精品久久久久av| 欧美一区二区在线免费播放| 欧美成人中文字幕| av成人免费在线| 国产视频久久久久| 免费成人av在线| 亚洲影院免费| 欧美激情黄色片| 午夜免费在线观看精品视频| 国产最新精品精品你懂的| 免费欧美在线| 亚洲综合导航| 91久久亚洲| 久久精品国产成人| 99精品热6080yy久久 | 亚洲理论在线| 国产午夜亚洲精品理论片色戒| 欧美国产高潮xxxx1819| 欧美一区二区精品久久911| 亚洲另类一区二区| 久久综合久久综合这里只有精品| 日韩一级免费| 亚洲国产成人91精品| 国产视频欧美视频| 国产精品毛片一区二区三区| 欧美国产日韩一区二区在线观看| 欧美一区二区在线播放| 一二三区精品| 亚洲精品久久久久中文字幕欢迎你| 久久综合久久综合九色| 性欧美大战久久久久久久久| 亚洲最新视频在线播放|