How to load our device drivers 如何装载我们的设备驱动

原创 2006年05月18日 10:12:00

安装驱动有很多种方法 INF/ 直接写注册表,也可以直接自己编写装载程序来完成

这里有一个装载驱动的类,使用非常方便。

Introduction

When you develop device drivers you always need to make two projects: first, the device driver and second the application to load and test it. This wrapper class, TDriver, can help you in the second one. Furthermore I developed an application example that you can use to load any driver you indicate.

Background

Windows allows loading drivers at runtime using the Service Control Manager. Yes, the Service Control Manager in Windows not only can be used to load and manage services. You can use it with device drivers as you use it to load/unload/start/stop windows services.

If you want to send/receive data to the device driver loaded, to allow this, you have to get a handle to the driver. For this purpose you can use the function createFile, and pass the driver name as the file name. You can see Windows is so abstract in this aspect.

Using the code

Using the TDriver Class is so easy. Here is the class definition and the explanation follows:

 

class TDriver

{

public:

    TDriver(void);    //constructor

    ~TDriver(void);      //destructor

 

    //functions to initialized the driver variables

    DWORD InitDriver(LPCTSTR name, LPCTSTR path, LPCTSTR dosName=NULL);

    DWORD InitDriver(LPCTSTR path);

 

 

    //functions to load and unload drivers.

    //If start = TRUE, the driver will be started.

    DWORD LoadDriver(BOOL start = TRUE);

    DWORD LoadDriver(LPCTSTR name, LPCTSTR path,

    LPCTSTR dosName=NULL, BOOL start=TRUE);

    DWORD LoadDriver(LPCTSTR path, BOOL start=TRUE);

 

    //if forceClearData == TRUE, will remove

    //variables although we cant remove driver "service"

    DWORD UnloadDriver(BOOL forceClearData = FALSE);

   

    //functions to start and stop, driver "service"

    DWORD StartDriver(void);

    DWORD StopDriver(void);

 

    //if true, the driver havent been removed at finish

    void SetRemovable(BOOL value);

 

 

    //funtion to return class status

    BOOL IsInitialized();

    BOOL IsStarted();

    BOOL IsLoaded();

 

 

    //function to get driver handle

    HANDLE GetDriverHandle(void);

 

    //funtions to make IO operation with driver

    DWORD WriteIo(DWORD code, PVOID buffer, DWORD count);

    DWORD ReadIo(DWORD code, PVOID buffer, DWORD count);

    DWORD RawIo(DWORD code, PVOID inBuffer,

        DWORD inCount, PVOID outBuffer, DWORD outCount);

   

private:

    HANDLE driverHandle;    //driver handle

   

    LPTSTR driverName;        //driver name

    LPTSTR driverPath;        //driver disk path

    LPTSTR driverDosName; //driver's dos name, to link with it

 

    BOOL initialized; //variables to store the status of this class

    BOOL started;

    BOOL loaded;

    BOOL removable;

 

    //get a handle to the driver

    DWORD OpenDevice(void);   

};

The methods you can use in this class are:
InitDriver(...)

This function is used to initialize the parameters of the driver such as: driver name, driver path and driver dos name. If you only know the driver path, the funtion tries to get the rest of the parameters.

LoadDriver(..)

You can use this function after you call InitDriver, when you use only one parameter. If start is FALSE, we need to call StartDriver function after, to start it. The other two functions, first initialize the driver and then load it as the first function.

UnloadDriver(BOOL forceClearData = FALSE)

This function stops the driver and deregister it in Windows Service Manager. If a problem occurred (while stopping or removing the driver), the class data associated with it(driver name, driver path...) will not be free unless you pass the TRUE value in forceClearData.

StartDriver()

You can use this function to start the driver "service".

StopDriver()

Use this function to stop the driver "service"

SetRemovable(BOOL value)

If you set the parameter removable to FALSE, in the unload process, the class will not deregister the driver in Windows Service Manager. This parameter is set automatically to FALSE if the driver was loaded by another application.

IsInitialized();
BOOL IsLoaded();
BOOL IsStarted()

The above are functions to ask the driver about its status.

GetDriverHandle()

You must use this function if you can access to the driver handle directly.

WriteIo(DWORD code, PVOID buffer, DWORD count)

Function to send data to the driver. You must indicate the IOCTL code.

ReadIo(DWORD code, PVOID buffer, DWORD count)

Function to receive data from the driver. You must indicate the IOCTL code. The data will be received in buffer with a maximum length of count.

RawIo(DWORD code, PVOID inBuffer, 
    DWORD inCount, PVOID outBuffer, DWORD outCount)

You decide what to do, read, write or both.

They are all functions exported by the class to applications. However to make a simple application that manage drivers we need use only two functions. For example, I developed a program to show the functionality of the TDriver class, that will load/unload any driver you introduce (see screenshot article). The code for this purpose is the next:

if(driver.LoadDriver(m_driverPath, true) == DRV_SUCCESS)
{
    //.....
}

//.....

if(driver.UnloadDriver() == DRV_SUCCESS)
{
    //.....
}

As you can see that with two lines you can load and unload a driver, making life easy for all :P.

相关文章推荐

Linux 2.6内核配置说明(10----Device Drivers设备驱动程序)

Generic Driver Options 驱动程序通用选项 Select only drivers that don't need compile-time external firmw...

《Linux Device Drivers》第一章 设备驱动程序简介——note

设备驱动程序的作用驱动程序的编写实际上都可以分成两部分 需要提供什么功能(机制)如何使用这些功能(策略) 不带策略的驱动程序包括一些典型的特征 同时支持同步和异步操作驱动程序能够被多次打开充分利用...

《Linux Device Drivers》第三章 字符设备驱动程序——note

主设备号和次设备号 那些名称被称为特殊文件、设备文件,或者简单称之为文件系统树的节点,它们通常位于/dev目录通常而言,主设备号标识设备对应的驱动程序一个主设备号对应一个驱动程序设备编号的内部表达 ...

linux内核Device Drivers设备驱动程序

Device Drivers 设备驱动程序 Generic Driver Options 驱动程序通用选项  Select only driversthat don't need compil...

《Linux Device Drivers》第十六章 块设备驱动程序——note

简介 一个块设备驱动程序主要通过传输固定大小的随机数据来访问设备Linux内核视块设备为与字符设备相异的基本设备类型Linux块设备驱动程序接口使得块设备可以发挥其最大的功效,但是其复杂程序又是编程...

Writing Linux LCD drivers—深入分析framebuffer设备驱动的结构

Writing Linux LCD drivers ——本文深入地分析了framebuffer设备驱动的结构 作者:JimSheng Writing Linux LCD drivers ...

音频设备驱动代码单独存放于sound/目录而不在drivers/目录中

今天阅读 drivers/Kconfig 文件时,发现在 "Device Drivers" 这个菜单下的配置项除了音频设备 其它配置项都是在 drivers/ 目录。音频设备的所有代码都位于与 dri...

Writing Linux LCD drivers—深入分析framebuffer设备驱动的结构

http://hi.baidu.com/excellentderek/blog/item/2e1d2003233e2f703812bb2d.htmlWriting Linux LCD drivers ...
  • ztguang
  • ztguang
  • 2016年03月30日 10:13
  • 258
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:How to load our device drivers 如何装载我们的设备驱动
举报原因:
原因补充:

(最多只允许输入30个字)