Windows CE陷阱調度機制
本文引用地址:http://butianyuan.cn/article/151560.htm
①硬件設備向Kernel發(fā)送中斷異常的代碼,如果檢測到這個中斷異常,就會被Kernel層的異常處理所截獲。然后,中斷服務調度程序會調用OAL例程中的OEMInterruptDisable函數,這個函數會通知硬件在處理完這一中斷前關閉特殊的中斷,但其它的中斷仍然處于開放狀態(tài),中斷服務例程ISR會被調用來決定如何處理這一中斷。
②Kernel接收到ISR的返回值可得知如何處理這一中斷。它的響應結果之一是忽略掉這一中斷不作處理(SYSINTR_NOP),或另一結果是準備執(zhí)行IST。然后,Kernel引發(fā)中斷服務調度程序去喚醒中斷服務線程。IST是常規(guī)的Win32線程,一旦啟動后,它會創(chuàng)建必要的EVENT,然后等待該EVENT被激發(fā)。中斷服務調度通過調用PulseEvent函數來激發(fā)EVENT,從而喚醒IST線程運行。當喚醒以后,IST會對中斷進行處理。
③當IST處理完成后,還需要調用InterruptDone函數通知Kernel。Kernel則調用OEMInterruptDone函數完成此次中斷的處理過程。最后,OAL例程通知硬件設備重新啟用中斷。
(2)中斷處理涉及的幾個常用函數
Windows CE在處理中斷時會涉及到兩類函數的使用,第一類是供OAL調用的ISR函數,例如HookInterrupt函數在OEMInit函數中被調用以關聯IRQ和ISR,UnhookInterrupt函數用來終止IRQ和ISR的關聯。第二類是供驅動程序調用的IST函數,例如InterruptInitialize函數用來將EVENT對象和邏輯中斷號關聯并允許中斷,InterruptDone函數用來通知中斷處理的結束,InterruptDisable函數被驅動程序調用以關閉中斷同時取消被InterruptInitialize初始化的EVENT對象。
ISR函數屬于OAL層,它將CPU寄存器中的數據移動到內存緩沖區(qū)中,但是它不能做更多的工作,其中一個原因是它不能訪問用戶態(tài)的存儲區(qū),它要把這些工作交給IST來完成。ISR函數做的另一項工作是進行物理中斷號和邏輯中斷號的映射。經過ISR后,就能把這一物理中斷轉換成Windows CE標準的SYSINTR_KEYBOARD邏輯中斷。Kernel會根據這個邏輯中斷值找到對應的EVENT,從而喚醒IST。
最后,需要提醒一下的是,常常有一些開發(fā)人員習慣拖延或忽視陷阱調度的編寫。因為輕視陷阱調度這一壞習慣是如此常見,它甚至已經影響到了Windows CE系統(tǒng)的研發(fā)。因此,建議從開始時就應該著手進行陷阱調度研發(fā)和計劃,應該投入大精力把陷阱調度的策略融合到嵌入式產品中。
評論