將自己踏入BIOS領域中所學習到的知識做一些心得整理,像是Legacy BIOS、EFI BIOS、Windows Driver...etc. ※版權與智慧財產權聲明:保留所有法律權利。我在寫文章時如果有引用到其他人的地方我會盡量說明參考出處,如果有遺漏的地方請告訴我,我會馬上註明! 而轉貼我的文章時也請您註明出處!
星期三, 6月 30, 2010
EFI_SOURCE
而加入$(EFI_SOURCE)跟沒有加入的差別在哪裡?
答案就是:
有加 $(EFI_SOURCE) 就會是絕對位置
沒加 $(EFI_SOURCE) 就會是相對位置
星期二, 6月 01, 2010
星期四, 5月 20, 2010
Unicode 字元查詢
而有一些特殊字元顯示在畫面上時可能會需要做一些修改,此時如果能知道那個字元的形狀,修改起來就更方便。
這邊就介紹一下我常用的網站,用來查詢 Unicode 字元的地方:
http://www.fileformat.info/info/unicode/char/search.htm?q=U%2B25ba&preview=entity
這個網站可以方便你搜尋你要的字元,你只要在Unicode Character Search的地方的Query輸入你想要的搜尋字元 (格式: U + Unicode) ,例如我要查詢0x25BA這個字元我就輸入:
按下Search 後,就會在下面的地方出現相關的資訊,如下圖所示:
你可以看到我查詢的字元是一個"右箭頭"........ 很方便吧! ^^
星期四, 4月 29, 2010
申請美簽~
因為有點小複雜,所以把一些同事跟我自己填資料的心得分享一下:
1.先到AIT美國在臺協會網站填寫預約申請,預約面試日期
http://www.ait.org.tw/zh/visa/niv/#application
a. DS-156(非移民簽證申請表): 線上填寫申請表跟一般申請表
b. 男性還需要多填一份:DS-157 (非移民簽證申請表補充說明) 申請表
2.外交部網站可以方便你查詢護照外文姓名拼音對照表
(一般護照拼音最好跟信用卡英文姓名一樣,以避免國外刷卡問題)
http://www.boca.gov.tw/ct.asp?xitem=1608&ctnode=193
3.男性還要多填一份 DS-157表格,而這份表格內需要填的資料中有些比較特別:
a.會有兵種的兵階資訊,可以從下面網站查詢:
http://en.wikipedia.org/wiki/Military_of_the_Republic_of_China
陸軍:ARMY 海軍:Navy 空軍Air Force 憲兵隊:Military Police
b.國中/高中/大學/研究所資訊可以直接用google去查到你的母校的網站,一般都會有英文版
如果沒有英文版的網頁,那你就要靠下面的郵局網站來幫你轉換學校的中文地址:
http://www.post.gov.tw/post/internet/f_searchzone/index.jsp?ID=190103
4.以下是我們同事申辦美簽的經驗分享:
a. 早上8:00的預約的話就是AM8:00進去,如果護照沒帶的話AM10:30前警衛都會放你進去。
不然就要在網路上重新登記,就不能在當天辦好。也就是說只能改天再來。
b. 進去時候警衛會叫你把手機與名片(證件)拿在手上,他會幫你放在置物櫃保管,並給你號碼牌。等下出來的時候可以憑號碼牌跟警衛領回手機。之後會通過X光機,身上的金屬物品(皮帶,手錶)最好放在袋子中。然後袋子要過像海關一樣的X光機。人就過人要走的X光機。領回袋子後就可以走進去排隊。
c.會檢查文件(DS-156 男生要加填DS-157)是不是齊全。像我就是照片貼太上面,沒有延著虛線貼。有點擋到條碼部分。所以那邊的服務人員會幫我重貼,他身上有膠水。我只要照著他們吩咐排隊,坐在椅子上等待。等到我要辦手續的時候,他自然會幫我處理。那邊也有電視,會撥按指紋與下面幾個流程的說明。可以坐在椅子上看要怎麼樣給他們刷條碼,自己要按指紋。
d.家人最好走在一起,因為有些手續家人要一起辦。
e.然後進到面談那關! 面試通過後,遞給你快遞單然後出去填資料。送件地址我就填公司地址。那邊有快遞公司的人會幫你服務。單子填完交給他就好。然後人就可以到外面憑號碼牌領回自己的手機。就可以回去等快遞把我的護照寄來了。 (錢等快遞到的時候再付錢)
我面試日期在下星期,希望也能順利拿到美簽啦~
星期四, 4月 22, 2010
Cx State
先說說Cx State 在BIOS端是怎麼跟CPU還有ASL code甚至是SetupMenu串再一起的.
首先,一般BIOS會在SetupMenu中建立出一些item來控制Cx State的Enable/Disable,這部分會因為各家BIOS在SetupMenu上的做法不同而有所不同,但是你只要知道一個東西! 就是一定會有一個地方儲存好SetupMenu上選項內的設定值. (Ex: CMOS/EFI Variable...)
接著,在PPM 的相關 Reference code那邊 (一般都是Ixxel的CPU的PPM reference code)會去參考SetupMenu內的設定值來組態CPU內部的MSR暫存器,至於他是如何得到SetupMenu的設定值又會因為不同的BIOS而有所不同,像是EFI就可能透過Policy來得到,所以要有人把SetupMenu的值放進去Policy內,這樣子Reference code才能參考SetupMenu的選項來組態MSR!
當這邊在一般組態MSR時,他會一邊修改Acpi Table! 例如你想關閉C2/C3,大家都知道去ACPI Table把值改成>100 或是 > 1001就可以了,所以這邊的Reference code會去參考你的SetupMenu的設定值來決定要不要修改ACPI Table內那個回報給OS的值!
其他的部分有牽扯到ASL code的部分我可能就不明說了,請大家搜尋CFGD這個值,看看他在哪邊被放進,然後ASL code為什麼要判斷他! 追個一遍就清楚了^^Y
星期三, 4月 07, 2010
星期六, 4月 03, 2010
DirectX v.s VGA driver
結果在執行的時候,卻發現他跳出了一個錯誤訊息:
File=dxvideo.cpp,Line=649,Code=80004001
原本以為是VGA driver的問題,所以花了很多時間去找了最新版的Nvidia driver重新安裝,
然後再去抓了DirectX for XP SP3的更新檔來安裝! 但是結果還是沒辦法進入遊戲之中!
因此秉持著研究的精神,先去研究了一下這個網路遊戲需要的解析度,發現這個2D網路遊戲
神州Online 是預設 640 x 480 x 16 的解析度,而網路上相關的討論是說去修改遊戲目錄內的
Online.ini:
[SYSTEM]
Width = 800
Height = 600
Fullscreen = 0
Switchscreen = 1
把他強制設定成800 x 600這樣子就可以進入遊戲,然後不要全螢幕(Fullscreen = 0) ,
而Switchscreen =1是用來設定這款遊戲能不能用Alt+Enter 來切換視窗化!
雖然這樣子可以進入遊戲 ,但是畫面就是變成視窗化那樣子! 玩起來總是感覺怪怪的!
因此很不死心的繼續追問題~在google大神找了很久之後發現可以利用Dxdiag這個工具來檢
查一下你的系統的DirectX有沒有甚麼問題!
因此我就選了開始->執行->鍵入dxdiag,然後就看到測試的視窗出現了!

從畫面上可以看到我的顯示晶片是Quadro NVS 140M,然後你可以點選【測試DirectDraw】或是【測試Direct3D】,我是先選了【測試DirectDraw】。
然後就看到了下面的地方出現了:
DirectDraw test results: Failure at step 17 (SetDisplayMode to 640x480x16): HRESULT = 0x80004001 (Not implemented)
Direct3D 7 test results: Failure at step 39 (SetDisplayMode to 640x480x16): HRESULT = 0x80004001 (Not implemented)
啥米? 我的螢幕解析度不支援640 x 480??! 所以我就看了一下我的螢幕解析度的支援!
還真的不能使用640 x 480,最小只到800 x 600 ,難怪我的遊戲一直會出現dxvideo.cpp 有問題!
因為根本就沒辦法切過去640 x 480!
而知道的問題的原因之後,就開始針對Quadro NVS 140M來找解決方案!然後就找到了一個網站跟他所提到的工具可以解決這個顯示晶片不支援640x480的方法:
http://werdna1222coldcodes.blogspot.com/2010/02/directdraw-init-failed.html
於是在使用了這個RivaTuner的方式自己增加了一個640x480x16的解析度之後,再重新開機!
開機完重新執行dxdiag跟我的網路遊戲,結果問題真的就解決了耶!
所以結論就是: 太好的VGA,會讓你沒辦法玩舊款遊戲! 但是想玩遊戲,就只好多認真點學些
東西! 希望這篇文章能夠幫助一些人可以多玩一些遊戲啦~ 呵呵!
星期二, 3月 23, 2010
64 bit 組合語言
1.多了一些64 bit暫存器
r8,r9,r10,r11,r12,r13,r14,r15
2.暫存器長度變成64 bit
rax,rbx,rcx,rdx,rsi,rdi,rsp,rbp
3.堆疊操作指令要對應64 bit暫存器
ex: (Push, pop, call, ret, enter, and leave) push eax;這是非法的
push rax;這是合法的
4.RIP變成合法化來存取資料
mov,rax,qword ptr [rip+300];以前IP只能當成程式記數器,現在可以參與資料獲取 也因此在64 bit下,DS/ES/SS/CS變的很沒有意義了!
5.Calling Conventions (呼叫慣例)變成Callee(被呼叫者)不需要清除Stack,這是Caller呼叫者的工作
EX:
Function(arg1,arg2,arg3,arg4,arg5) ,假設arg1~4都是整數,他們分別會被放進去對應的暫存器
RCX: 1st integer arg
RDX: 2nd integer arg
R8: 3rd integer arg
R9: 4th integer arg
arg5才會被放進去Stack,但是這個stack會先幫這幾個arg預留空間,
所以第5個參數會是放在 rsp+0x20的地方!
這個概念跟我們以前32 bit觀念不同,他並不是__cdecl/ __stdcall/ __fastcall
所以從下面的範例中可以看到呼叫者會去清除stack:
The stack must be kept 16-byte aligned. Since the "call" instruction
pushes an 8-byte return address, this means that every non-leaf
function is going to adjust the stack by a value of the form 16n+8 in
order to restore 16-byte alignment.
ex:
void SomeFunction(int a, int b, int c, int d, int e);
void CallThatFunction()
{
SomeFunction(1, 2, 3, 4, 5);
SomeFunction(6, 7, 8, 9, 10);
}
On entry to CallThatFunction, the stack looks like this:
| xxxxxxx0 | .. rest of stack .. | |
| xxxxxxx8 | return address | <- RSP |
Due to the presence of the return address, the stack is misaligned. CallThatFunction sets up its stack frame, which might go like this:
sub rsp, 0x28
Notice that the local stack frame size is 16n+8, so that the result is a realigned stack.
| xxxxxxx0 | .. rest of stack .. | |
| xxxxxxx8 | return address | |
| xxxxxxx0 | (arg5) | |
| xxxxxxx8 | (arg4 spill) | |
| xxxxxxx0 | (arg3 spill) | |
| xxxxxxx8 | (arg2 spill) | |
| xxxxxxx0 | (arg1 spill) <- RSP |
Now we can set up for the first call:
mov dword ptr [rsp+0x20], 5 ; output parameter 5
mov r9d, 4 ; output parameter 4
mov r8d, 3 ; output parameter 3
mov rdx, 2 ; output parameter 2
mov rcx, 1 ; output parameter 1
call SomeFunction ; Go Speed Racer!
When SomeFunction returns, the stack is not cleaned, so it still looks like it did above. To issue the second call, then, we just shove the new values into the space we already reserved:
mov dword ptr [rsp+0x20], 10 ; output parameter 5CallThatFunction is now finished and can clean its stack and return.
mov r9d, 9 ; output parameter 4
mov r8d, 8 ; output parameter 3
mov rdx, 7 ; output parameter 2
mov rcx, 6 ; output parameter 1
call SomeFunction ; Go Speed Racer!
add rsp, 0x28
ret
Notice that you see very few "push" instructions in amd64 code, since the paradigm is for the caller to reserve parameter space and keep re-using it.
這種呼叫慣例比較像是結合了__cdecl/ __fastcall 的特性:__cdecl : 在被呼叫者(Callee) return後,由呼叫者(Caller)清除堆疊
__fastcall : 32bit時是將最左邊兩個參數會放在ecx跟edx ,而64 bit 這邊是放在rcx,rdx,r8,r9
Reference
http://blogs.msdn.com/oldnewthing/archive/2004/01/14/58579.aspx
星期六, 3月 13, 2010
安裝VB6的問題
這先就提供你一個方式可以解決這個問題.
首先你先建立一個批次檔,例如叫做VB6Setup.bat
然後輸入下面的這些內容:
@ECHO OFF
set VB6FOLDER=F:\vb6
del %temp%\*.* /y
%VB6FOLDER%\SETUP\ACMSETUP.EXE /T VB98ENT.STF /S %VB6FOLDER% /n "" /o "" /k "0000000000" /b 1
那個VB6FOLDER的路徑你可以設定成你的VB6放置的位置
例如你是放在光碟機,你就可以寫成set VB6FOLDER=E:
然後執行這個批次檔,然後你就會看到開始安裝的畫面了!
星期三, 3月 03, 2010
有趣的Code-BootOption 的建立
雖然很搞不清楚他為什麼要這樣做,但是一般情況下不可能只有SimpleFileSystem存在!
所以應該是要防呆吧! 怕哪一天真的有Hanlde上面只掛SimpleFileSystem而沒有BlkIo.
這種Hanlde他還是會幫他建立出一個BootOption!
gBS->LocateHandleBuffer (
...
&gEfiSimpleFileSystemProtocolGuid,
...
);
for (Index = 0; Index < NumberFileSystemHandles; Index++) {
Status = gBS->HandleProtocol (
...
&gEfiBlockIoProtocolGuid,
(VOID **) &BlkIo
);
if (!EFI_ERROR (Status)) {
continue; //這邊會Skip
}
...
}
星期日, 2月 28, 2010
C語言複習3
問題一: 底下的這個做法的概念
int a;
*&a=30;
Ans:
int a; 可以看成 _A WORD ?
&a 可以看成 LEA BX,_A
* 可以看成 MOV 東西到某個記憶體,所以*&a=30 等同於MOV [BX],30
其實他是等同於a=30,但是這樣子寫會跑更慢!code更大!
問題二:
*200 = 30;
Ans:
這樣子寫是非法的,因為雖然a 在記憶體200的位址,但是你不知道a是多大
所以你要告訴Compiler要一次搬兩個byte. 所以(int *) 等同於word ptr.
*(int *)200=30;
用組語來看會類似 mov word ptr [200],30
其中word ptr是假指令,用來一次搬兩個BYTE
[200] 代表記憶體位址200
星期一, 2月 22, 2010
C語言複習2
&& 是邏輯運算
& 是AND運算
EX: 當 x=1,y=2
if(x&&y) 這邊會是1&&2=TRUE
if(x&y) 這邊會是1&2 = 0 = FALSE
2.條件式判斷
Expression1?Expression2:Expression3
EX: 當x>3 成立時,會執行x=1
XXX= x > 3?1:0
他等同於:
if(x>3)
XXX=1
else
XXX=0
3.逗號語法
Expression1,Expression2,Expression3,....ExpressionN
if( x+1,y+2,z<=3)
k=1
else
k=0
他會依序執行將 X+1,Y+2,直到遇到判斷式Z<=3時才會跳出if()
簡單說就是當Z<=3成立時(TRUE),會得到K=1,雖然沒有人會這樣子寫,但是可以這樣子用!
一般比較常看到的寫法會是:
while(ch=getch(),ch=='a')
{
...
}
4.陣列
array[i]等同於*(array+i)
C語言複習
EX1:
{
int i; //只在括號內有效
}
EX2:
static int i; //只在本文件內有效
EX3:
extern int i; //不管幾個文件中都只有一個實體i;
//他等同於你在File Scope(你在寫#include的那個區塊)中宣告int i;
//只是為了可讀性所以加入extern 這個關鍵字,不加也是可以!
2.for/while/do..while/break/continue
while(Expression)
Statement

for(Expression1;Expression2;Expression3)
Statement

do{
Statement
}while(Expression)
星期一, 10月 19, 2009
InsertList
1.EFI中都是喜歡使用雙向鏈結串列(doubly linked list)
在雙向鏈結串列中的節點(Node)至少有2個欄位,一個為向後結欄 (BackLink) ,另一個為向前鏈結欄 ( ForwardLink ) 。其必要的宣告為:
typedef struct node *node_ptr ;
typedef struct node {
node_ptr Flink ;
node_ptr Blink ;
} ;
2.插入鏈結串列可以從頭插入或是從尾插入兩種,底下是圖示來表示這兩種差別。
InsertHeadList();
InsertTailList();

這些鏈結的運用在EFI中隨處可見,所以在這邊留下筆記來紀錄一下學習心得!
星期五, 10月 09, 2009
NMAKE (1)
而為了測試NMAKE.EXE 的使用方式,所以自己就會去做一些小實驗來了解一些東西,然後順便把他紀錄下來。
底下是我為了想知道$** 跟$@ 是代表什麼用意時所做的一些實驗,因為是初學者,所以各位看官就別取笑小弟我的土法煉鋼法喔~
1.準備test.mak,其內容如下:
SOURCE_FILE_NAME = test.mak
DEST_DIR = c:\maktest
BASE_NAME = test
$(DEST_DIR)\$(BASE_NAME).bin : $(SOURCE_FILE_NAME)
echo $**
echo $@
copy $** $@
all: $(BIN_DIR)\$(BASE_NAME).bin
2.進入NAMKE環境,鍵入:
C:\maktest\>NMAKE /F test.mak
3.結果
echo test.mak
test.mak
echo c:\maktest\test.bin
c:\maktest\test.bin
copy test.mak c:\maktest\test.bin
1 file(s) copied.
C:\maktest>
4.結論
可以看的到$** 是代表$(SOURCE_FILE_NAME)
而$@ 看起來是代表$(DEST_DIR)\$(BASE_NAME).bin
所以copy $** $@ 等同於 copy test.mak c:\maktest\test.bin
從makefile寫法來看:
$**應該就是[dependency]
$@ 應該就是[target]
[target]: [dependency] [dependency]
[TAB][rule] <--要注意,寫rule之前要加tab.
[TAB][rule]
星期二, 10月 06, 2009
星期四, 6月 18, 2009
Visual C++ 編譯器選項
因為怕微軟更新網站資料就消失了,因此在這邊記錄選項的部分內容,如果有興趣了解更多的人可以到經由連結到微軟網站得到更多詳細的訊息:
| 選項 | 用途 |
|---|---|
| 指定回應檔。 | |
| 列出編譯器選項。 | |
| 指定一個要搜尋的目錄,以解析傳遞給 #using 指示詞的檔案參考。 | |
| 啟用程式碼分析 | |
| 在程式碼產生時使用 SSE 或 SSE2 指令 (僅適用於 x86)。 | |
| 增加 .obj 檔中可定址區段的數目 | |
| 在前置處理過程中保留註解。 | |
| 編譯而不連結。 | |
| 產生輸出檔案,以便在 Common Language Runtime 上執行。 | |
| 定義常數和巨集。 | |
| 將文件註解處理成 XML 檔案 | |
| 複製前置處理器輸出至標準輸出。 | |
| 指定例外處理模型。 | |
| 複製前置處理器輸出至標準輸出。 | |
| 讓您直接提供內部編譯器錯誤 (ICE) 資訊給 Visual C++ 團隊 | |
| 設定堆疊大小。 | |
| 產生已為特定 x64 架構最佳化的程式碼,或為 AMD64 和 延伸記憶體 64 技術 (Extended Memory 64 Technology, EM64T) 架構中微架構特性最佳化的程式碼 | |
| 建立清單檔。 | |
| 設定清單檔名稱。 | |
| 顯示在診斷測試中傳遞給 cl.exe 的原始程式檔完整路徑 | |
| 重新命名程式資料庫檔案。 | |
| 重新命名可執行檔。 | |
| 前置處理指定的包含檔。 | |
| 建立對應檔 (Mapfile)。 | |
| 建立目的檔。 | |
| 指定浮點行為 | |
| 指定先行編譯標頭檔的名稱。 | |
| 產生瀏覽器檔案。 | |
| 強制使用某一檔名,就如同它已傳遞給 #using 指示詞一樣。 | |
| 將插入的程式碼與原始程式檔合併。 | |
| 為 Itanium 處理器執行最佳化。只有 IPF 跨平台編譯器或 IPF 原生編譯器才有提供。 | |
| 為 Itanium2 處理器最佳化 (預設值為 /G1 與 /G2 之間),只有 IPF 跨平台編譯器或 IPF 原生編譯器才有提供。 | |
| 對 Windows 應用程式進行程式碼最佳化。 | |
| 使用 __cdecl 呼叫慣例 (僅適用於 x86)。 | |
| 啟動堆疊探查。 | |
| 啟用字串共用。 | |
| 呼叫攔截 (Hook) 函式 _pexit。 | |
| 呼叫攔截 (Hook) 函式 _penter。 | |
| 啟用整個程式最佳化。 | |
| 啟用最少重建。 | |
| 啟用執行階段型別資訊 (RTTI)。 | |
| 使用 __fastcall 呼叫慣例 (僅適用於 x86)。 | |
| 緩衝處理安全性檢查。 | |
| 控制堆疊探查。 | |
| 對使用靜態執行緒區域儲存區配置的資料支援 Fiber 安全性。 | |
| 啟用同步例外處理。 | |
| 啟用函式階層連結。 | |
| 與 /RTC1 相同。/RTC (執行階段錯誤檢查) | |
| 使用 __stdcall 呼叫慣例 (僅適用於 x86)。 | |
| 限制外部 (公用) 名稱的長度。 | |
| 列出編譯器選項。 | |
| 在函式進入時,強制暫存器中所傳遞的參數寫入至堆疊上的位置。這個編譯器選項只適用於 x64 編譯器 (原生和跨平台編譯) | |
| 建立可線上修補的影像 | |
| 搜尋包含檔的目錄。 | |
| 變更預設 char 型別。 | |
| 建立動態連結程式庫。 | |
| 建立偵錯動態連結程式庫。 | |
| 傳遞指定的選項給 LINK。 | |
| 建立 MSIL 模組 | |
| 使用 MSVCRT.lib 建立多執行緒 DLL。 | |
| 使用 MSVCRTD.lib 建立偵錯多執行緒 DLL。 | |
| 使用 LIBCMT.lib 建立多執行緒可執行檔。 | |
| 使用 LIBCMTD.lib 建立偵錯多執行緒可執行檔。 | |
| 隱藏登入程式的啟始資訊。 | |
| 建立小型程式碼。 | |
| 建立快速程式碼。 | |
| 控制內嵌展開。 | |
| 停用最佳化。 | |
| 使用全域最佳化。 | |
| 產生內建函式。 | |
| 在原始程式碼中啟用 #pragma omp | |
| 偏好小的程式碼。 | |
| 偏好快的程式碼。 | |
| 使用最大最佳化 (/Ob2gity /Gs)。 | |
| 省略框架指標 (僅適用於 x86)。 | |
| 在必須從浮點型別轉換為整數型別時,抑制 _ftol (僅適用於 x86)。 | |
| 根據 B CPU 逐步偵錯的 errata,不會產生指令順序,而導致意外結果(僅適用於 IPF)。 | |
| 根據 C CPU 逐步偵錯的 errata,不會產生指令順序,而導致意外結果(僅適用於 IPF)。 | |
| 不要使用上層 96 浮點暫存器(僅適用於 IPF)。 | |
| 產生影像加上與位置有關的程式碼 (僅適用於 IPF) | |
| 為不在執行階段建立函式的程式增強效能(僅適用於 IPF)。 | |
| 將前置處理器輸出寫入檔案。 | |
| 啟用執行階段錯誤檢查。 | |
| 在編譯時顯示包含檔清單。 | |
| 指定 C 原始程式檔。 | |
| 指定 C++ 原始程式檔。 | |
| 移除某個預先定義巨集。 | |
| 移除所有預先定義巨集。 | |
| 設定版本字串。 | |
| 抑制或啟用隱藏的 vtordisp 類別成員。 | |
| 對指向成員的指標使用最佳基底。 | |
| 對指向成員的指標使用完整一般性。 | |
| 宣告多重繼承。 | |
| 宣告單一繼承。 | |
| 宣告虛擬繼承。 | |
| 設定警告層級。 | |
| 停用所有警告。 | |
| 啟用所有警告,包括預設停用的警告。 | |
| 從命令列編譯 C++ 原始程式碼時啟用一行錯誤和警告訊息診斷。 | |
| 偵測 64 位元可移植性問題。 | |
| 忽略標準 Include 目錄。 | |
| 忽略目前組建中所有其他先行編譯標頭編譯器選項。 | |
| 建立先行編譯標頭檔。 | |
| 將完整的偵錯資訊置於所有目的檔中。 | |
| 在建立偵錯程式庫時插入一個 PCH 參考 | |
| 在建置時使用先行編譯標頭檔。 | |
| 產生 C 7.0 相容的偵錯資訊。 | |
| 停用語言擴充功能。 | |
| 指定 /Ze 下的標準行為。/Za、/Ze (停用語言擴充功能) | |
| 啟用語言擴充功能。 | |
| 產生函式原型。 | |
| 將偵錯資訊包括在與「編輯後繼續」相容的程式資料庫中。 | |
| 產生完整偵錯資訊。 | |
| 從 .obj 檔案移除預設程式庫名稱 (僅適用於 x86)。 | |
| 指定先行編譯標頭的記憶體配置上限。 | |
| 封裝結構成員。 | |
| 僅檢查語法。 | |
| 產生可偵錯最佳化程式碼,只有 IPF 跨平台編譯器或 IPF 原生編譯器才有提供 |
Reference
星期日, 5月 17, 2009
Intel EFI Specs資訊
怕自己忘記去哪下載!
所以就留下筆記記錄一下!
這些都是Intel 所提供的相關文件,有興趣的可以去Intel網站抓。
ftp://download.intel.com/technology/framework/docs
ftp://download.intel.com/technology/framework/docsReference
www.intel.com
星期三, 5月 13, 2009
AfterG3 bit
狀態1 : S0/S1/S3 電源有問題,重新上電
1=保持S5
0=啟動
狀態2 : S4 電源有問題,重新上電
1=保持S4
0=啟動
狀態3 : S5 電源有問題,重新上電
1=保持S5
0=啟動
