跳到主要內容

發表文章

目前顯示的是 8月, 2021的文章

如何讀寫SMBus

在介紹如何讀寫SMBus之前,首先我們必須先知道什麼是SMBUS? SMBus (System Managemnet Bus,系統管理匯流排) 簡單來說是有兩條訊號線 (SMBCLK/SMBDATA) 所組成一個匯流排,讓系統上一些低速裝置進行互相溝通的管道,如EC或感測裝置等。簡單舉個例子,當系統上想得知某個掛在SMBus匯流排下的溫度感測器他的溫度變化時,首先我們必須得知感測裝置的位置(Slave Address),由Host透過SMBus通道對溫度感測器進行回傳溫度的命令,當感測器得到命令後,再將溫度回傳給Host。 RW讀取SMBUS 1.取得SMBus Base Address,根據Spec可在Offset 20h - 23h取得,此範例IO Base = 0xF040。 2.選擇IO Space方式,輸入IO Base: 0xF040,根據Spec我們主要讀寫區域為Offset 00h - 07h。 3.Byte Read - SMB_BASE + 0x00h (HST_STS)寫入0xFE,清除暫存器狀態,以確保SMBus不為忙碌狀態 - SMB_BASE + 0x04h (XMIT_SLVA)寫入0xA1 (裝置的Slave Address) 注意!!此處以Memory裝置為範例,所以Slave Address = 0xA1,而BIT0 = 1為讀取,反之則為寫入。 - SMB_BASE + 0x03h (HST_CMD)寫入0x00 ,此處主要寫入要讀取的Offset,先以0x00為範例 - SMB_BASE + 0x02h (HST_CNT)寫入0x48,開始執行讀取。Bit6代表開始執行,Bit2-4為選擇讀取的方式 - SMB_BASE + 0x05h (HST_D0),讀取Byte資料顯示於此 4.Word Read -重複Byte Read步驟1-3 - SMB_BASE + 0x02h (HST_CNT)寫入0x4C,開始執行讀取。Bit6代表開始執行,Bit2-4為選擇讀取的方式 - SMB_BASE + 0x05h (HST_D0) / SMB_BASE + 0x06h (HST_D1),讀取Word資料顯示於此 5.Block Read -重複Byte Read步驟1-3 - SMB_BASE + 0x02h (HST_CNT)寫

輕鬆建立EDK2編譯環境 - 20210819_EzBuildEDK2

下載 : 20210819_EzBuildEDK2.ZIP 相關工具 注意:(Tool無須下載,已放置於下載檔案內tool資料夾) 1. edk2-stable-202011 2. vs_community__676215966.1629204554 3. python-3.8.0-amd64 4. nasm-2.13.02-win64 5. iasl-win-20210730 使用說明 1. 下載EzBuildEDK2,並解壓Workspace到C:\ 2. 安裝VS2019 C++  3. 安裝Python3.8 4. 開始 > 程式集 > VS2019 >執行Developer Command Prompt for VS 2019 > 進入Workspace資料夾 5. 執行setvar.bat,用來設置環境變數 6. 執行edksetup.bat 7. 執行build

架設EDK2+VS2019編譯環境

1.下載軟體 - EDK2 edk2-stable-202011 or Newest - VS2019 C++ - python 3.8 - NASM http://www.nasm.us/ - ASL https://acpica.org/downloads/binary-tools - BaseTools/Source/C/BrotliCompress/brotli - MdeModulePkg/Library/BrotliCustomDecompressLib/brotli - CryptoPkg/Library/OpensslLib/openssl 2.建立資料夾(C:\Workspace) - 將edk2-stable-202011.zip內容解壓到C:\Workspace\ - 解壓brotli至BaseTools/Source/C/BrotliCompress/brotli - 解壓brotli至MdeModulePkg/Library/BrotliCustomDecompressLib/brotli - 解壓openssl至CryptoPkg/Library/OpensslLib/openssl 3.安裝VS2019 4.安裝Python3.8 5. 解壓NASM及IASL到 C:\Workspace\NASM\及 C:\Workspace\IASL\ 注意:NASM及IASL資料夾請自行建立 6.開始 > 程式集 > VS2019 >執行Developer Command Prompt for VS 2019 >  進入Workspace資料夾 8.環境設定 - set NASM_PREFIX=C:\Workspace\NASM\ - set IASL_PREFIX=C:\Workspace\IASL\ - set WORKSPACE=C:\Workspace\ - set PACKAGES_PATH=C:\Workspace\ 9.執行edksetup.bat 10.進入C:\Workspace\Confg\,修改target.txt - ACTIVE_PLATFORM = EmulatorPkg/EmulatorPkg.dsc - TARGET = RELEASE - TARGET_ARCH = X64 - TOOL_C