SCI VS SMI

來源:互聯網
上載者:User

SCI與SMI的區別與聯絡

SMI: System Management Interrupt,系統管理中斷,進入SMM的方法,包含(但不限於)電源管理功能,對OS透明的;

                    SMI pin觸發後,CPU進入SMM Mode,轉去執行BIOS中的SMI Handler。

                    SMI pin--> CPU SMM Mode --> BIOS routine

SCI: System Control Interrupt,系統控制中斷,是ACPI定義的,專用於ACPI電源管理的一個IRQ,需要OS支援的。

                    SCI pin觸發後,CPU去執行某個放在中斷描述表(IDT)中的程式,一般都是指向某個驅動程式(ACPI.sys),ACPI driver會通知相關的驅動程式(ACPI EC Driver),然後跟EC BIOS取得一個代碼,而這個代碼就是ASL code中的Qxx Number,接著OS會去執行相應的ASL Code,一般都是Method(Qxx)。

                   SCI pin --> OS Acpi Driver --> ASL Code (Q event) --> ? (看BIOS Spec需求)

聯絡:都可以用於電源管理功能
區別:SMI是CPU層級的,ACPI和非ACPI模式下都可以用;SCI是OS層級的,只有在ACPI模式才可以用。

 
SCI只能在ACPI的OS下發出來,如果在DOS下能觸發的中斷,那肯定不是SCI,那可能是SMI。SMI同樣可以在OS下發出來。在進入ACPI的OS後,Bios把CPU的控制權交給OS,SMI還是可以發出來的。SMI大部分由硬體來issue,也可以發soft SMI,一般是在port 0B2h下command,然後在SMI Handle中加入對cmd的動作即可。

 

SCI_INT

FADT的Offset46為SCI_INT field。

它記錄了在PIC Mode下,SCI串連到8259的哪個pin(通常都是IRQ9);在APIC Mode下,它記錄了SCI interrupt的Global System interrupt number。

如果在PIC Mode下SCI串連到IRQ9,而在APIC Mode下IRQ9串連到INTIN11,則在FADT中SCI_INT為9, MADT中interrupt resource override entry mapping 將IRQ9 mapping到INTIN11。

 

如何把SCI_INT從IRQ9改成IRQ11?

三個地方要改:

1. SCI IRQ Select(D31:F0:R44h bit[2:0])由000h(IRQ9)改成010h(IRQ11)

2. FADT中SCI_INT 由9改成11

3. MADT中interrupt resource override entry, Source 0x09; GSI:由0x09改成0x0B

 

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.