图解WinCE6.0下的内核驱动和用户驱动

301 篇文章 0 订阅

作者:SUKHOI27SMK

转自:http://blog.csdn.net/sukhoi27smk/article/details/8201766


在《WinCE驱动程序的分类》中曾提到,WinCE6.0的流驱动既可以加载到内核态也可以加载到用户态。下面通过一组图片简单说明一下这两种驱动的关系。

      首先编写一个流驱动WCEDrv,代码如下。

代码
复制代码
#include  < windows.h >

extern   " C "
BOOL WINAPI DllMain(HANDLE hinstDLL, DWORD dwReason, LPVOID lpvReserved)
{
    UNREFERENCED_PARAMETER(lpvReserved);

    
switch (dwReason) {
    
case  DLL_PROCESS_ATTACH:
        DisableThreadLibraryCalls((HMODULE) hinstDLL);
        
break ;
    
case  DLL_PROCESS_DETACH:
        
break ;
    };
    
return  TRUE;
}


extern   " C "
DWORD Init(LPCTSTR pContext, DWORD dwBusContext)
{
    RETAILMSG(
1 ,(_T( " Init(%s, %x) " ),pContext,dwBusContext));
    
    PBYTE pBuffer 
=   new  BYTE[ 4096 * 1024 ];     
    RETAILMSG(
1 ,(TEXT( " pBuffer(%x)\r\n " ),pBuffer));

    
return   (DWORD)pBuffer;
}


extern   " C "
BOOL Deinit(DWORD hDeviceContext)
{
    RETAILMSG(
1 ,(_T( " Deinit(%x)\r\n " ),hDeviceContext));
    
    PBYTE pBuffer 
=  (PBYTE)hDeviceContext;
    
if  (pBuffer)
    {
        delete[] pBuffer;
    }    

    
return  TRUE;
}


extern   " C "
void  PowerUp(DWORD hDeviceContext)
{
}

extern   " C "
void  PowerDown(DWORD hDeviceContext)
{
}

extern   " C "
DWORD Open(DWORD hDeviceContext, DWORD AccessCode, DWORD ShareMode)
{
    RETAILMSG(
1 ,(_T( " Open(%x, 0x%x, 0x%x)\r\n " ),hDeviceContext, AccessCode, ShareMode));

    
return  hDeviceContext;
}

extern   " C "
BOOL Close(DWORD hOpenContext)
{
    RETAILMSG(
1 ,(_T( " Close(%x)\r\n " ),hOpenContext));

    
return  TRUE;
}

extern   " C "
BOOL IOControl(DWORD hOpenContext, DWORD dwCode, PBYTE pBufIn, DWORD dwLenIn
               , PBYTE pBufOut, DWORD dwLenOut, PDWORD pdwActualOut)
{
    UNREFERENCED_PARAMETER(hOpenContext);
    UNREFERENCED_PARAMETER(dwCode);
    UNREFERENCED_PARAMETER(pBufIn);
    UNREFERENCED_PARAMETER(dwLenIn);
    UNREFERENCED_PARAMETER(pBufOut);
    UNREFERENCED_PARAMETER(dwLenOut);
    UNREFERENCED_PARAMETER(pdwActualOut);

    SetLastError(ERROR_INVALID_FUNCTION);
    
return  FALSE;
}

extern   " C "
DWORD Read(DWORD hOpenContext, LPVOID pBuffer, DWORD Count)
{
    RETAILMSG(
1 ,(_T( " Read(%x, %x, 0x%x)\r\n " ),hOpenContext, pBuffer, Count));

    
return  TRUE;
}

extern   " C "
DWORD Write(DWORD hOpenContext, LPCVOID pBuffer, DWORD Count)
{
    RETAILMSG(
1 ,(_T( " Write(%x, %x, 0x%x)\r\n " ),hOpenContext, pBuffer, Count));

    
return  TRUE;
}

extern   " C "
DWORD Seek(DWORD hOpenContext, 
long  Amount, WORD Type)
{
    UNREFERENCED_PARAMETER(hOpenContext);
    UNREFERENCED_PARAMETER(Amount);
    UNREFERENCED_PARAMETER(Type);

    SetLastError(ERROR_NOT_SUPPORTED);
    
return   - 1 ;
}
复制代码

       其对应的注册表文件内容如下。

注册表
复制代码
[HKEY_LOCAL_MACHINE\Drivers\WCEDrv1]
    
" Prefix " = " AAA "
    
" Dll " = " WCEDrv.dll "
    
" Index " = dword: 1
    
" Flags " = dword: 8         ; DEVFLAGS_NAKEDENTRIES
    
" Order " = dword: 0

[HKEY_LOCAL_MACHINE\Drivers\WCEDrv2]
    
" Prefix " = " BBB "
    
" Dll " = " WCEDrv.dll "
    
" Index " = dword: 1
    
" Flags " = dword: 8         ; DEVFLAGS_NAKEDENTRIES
    
" Order " = dword: 0

[HKEY_LOCAL_MACHINE\Drivers\WCEDrv3]
    
" Prefix " = " CCC "
    
" Dll " = " WCEDrv.dll "
    
" Index " = dword: 1
    
" Flags " = dword: 18     ; DEVFLAGS_LOAD_AS_USERPROC  |  DEVFLAGS_NAKEDENTRIES
    
" Order " = dword: 0

[HKEY_LOCAL_MACHINE\Drivers\WCEDrv4]
    
" Prefix " = " DDD "
    
" Dll " = " WCEDrv.dll "
    
" Index " = dword: 1
    
" Flags " = dword: 18     ; DEVFLAGS_LOAD_AS_USERPROC  |  DEVFLAGS_NAKEDENTRIES
    
" Order " = dword: 0
复制代码

       通过驱动调试助手动态加载该驱动,在加载时,根据注册表中的设置,分别加载两个到内核空间和用户空间。

      image

                                   通过驱动调试助手导入注册表文件

      image

                                    用户态和内核态分别加载两个,共加载四个驱动

      image

                                 加载驱动过程时的串口打印

      image

                加载驱动成功后,HKEY_LOCAL_MACHINE\Drivers\Active下内核驱动对应的键

      image 

                     加载驱动成功后,HKEY_LOCAL_MACHINE\Drivers\Active下用户驱动对应的键      image

                          通过远程堆查看器,查看内存的分配情况

      image

                      通过远程进程查看器 ,查看wcedrv.dll加载为内核态驱动 

      image

                          通过远程进程查看器,查看wcedrv.dll加载为用户态驱动1

      image

                      通过远程进程查看器,查看wcedrv.dll加载为用户态驱动2

      WCEDRV的源代码下载地址:http://files.cnblogs.com/we-hjb/WCEDrv.rar


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值