在Windows Embedded中獲取設備ID
在WinCE下獲取設備ID(Device ID)并不困難,只要簡單地調(diào)用KernelIoControl即可.不過至于能否獲得設備ID,并且獲得的ID屬于什么類型,則關系到驅(qū)動層的實現(xiàn).而設備ID的實現(xiàn),在不同的平臺有不同,比如在夏普的LH71404的開發(fā)板中,設備ID位于platform.c中.不過本文目的不關注如何設置或編寫設備ID,而僅僅是通過函數(shù)調(diào)用獲得該設備ID而已.
首先我們來看看設備ID在WinCE下的定義:
- typedef struct _DEVICE_ID {
- DWORD dwSize;
- DWORD dwPresetIDOffset;
- DWORD dwPresetIDBytes;
- DWORD dwPlatformIDOffset;
- DWORD dwPlatformIDBytes;
- } DEVICE_ID, *PDEVICE_ID;
結(jié)構(gòu)清晰明了,而我們所要關注的僅僅是這兩個字段:dwPlatformIDOffset和dwPlatformIDBytes.
現(xiàn)在假設我們有一個平臺,該平臺的設備ID為一個字符串:"MyDeviceId",那么我們可以通過下面一個簡單的例子獲得該設備ID:
- char szBuf[MAX_PATH] = {0};
- DEVICE_ID devID = {0};
- GetDeviceID((BYTE *)szBuf,MAX_PATH,&devID);
- char szDeviceID[MAX_PATH] = {0};
- strcpy(szDeviceID,szBuf + devID.dwPlatformIDOffset);
此時szDeviceID中存儲的字符串就是"MyDeviceId".
代碼中的GetDeviceID是自己寫的一個獲取ID函數(shù),該代碼如下:
- DWORD GetDeviceID(BYTE *pOutBuf,DWORD dwBufSize,DEVICE_ID *pDeviceID)
- {
- DWORD dwRead = 0;
- if(KernelIoControl(IOCTL_HAL_GET_DEVICEID, NULL, 0, pOutBuf, dwBufSize, &dwRead) == FALSE)
- {
- return 0;
- }
- pDeviceID = (PDEVICE_ID)pOutBuf;
- return dwRead;
- }
pOutBuf是傳入的存儲緩沖區(qū),dwBufSize是緩沖區(qū)大小,pDeviceID是接受設備ID的結(jié)構(gòu)信息,函數(shù)返回值是讀取的字節(jié)數(shù),當為0的時候,很可能是函數(shù)讀設備ID失敗.調(diào)用方法很簡單,可參考上文的例子.
代碼中出現(xiàn)的IOCTL_HAL_GET_DEVICEID是WinCE下定義的宏,專注于獲取設備ID,該宏的定義如下:
- #define IOCTL_HAL_GET_DEVICEID CTL_CODE(FILE_DEVICE_HAL, 21, METHOD_BUFFERED, FILE_ANY_ACCESS)
最后需要說的是,要使該段代碼工作正常,尚且需要包含該頭文件:Pkfuncs.h。
【編輯推薦】