带有驱动程序的c语言程序,关于驱动程序的有关问题

关于驱动程序的问题

刚刚接触到驱动程序,需要写一个键盘过滤的驱动,遇到一些问题,希望各位大侠帮忙解答一下.

驱动程序启动之后,附加到所有的键盘设备之上,然后,监测键盘输入

如果,键盘被拔出,再插入,这个时候,就监测不到输入了.

我添加了AddDevice例程,希望当键盘插入的时候,可以在这里面,重新附加,但是,这个例程却一直都没有

响应过.但是,拔出的时候,可以收到一个PNP的IRP,在里面,可以处理拔出操作

1.AddDevice需要满足什么条件才能响应?

2.在我写的驱动中,要实时监测键盘的插拔,能实现吗?

下面是一部分代码

NTSTATUS DriverEntry(

IN PDRIVER_OBJECT DriverObject,

IN PUNICODE_STRING RegistryPath

)

{

ULONG i;

NTSTATUS status;

KdPrint (("c2p.SYS: entering DriverEntry\n"));

// 填写所有的分发函数的指针

for (i = 0; i 

{

DriverObject->MajorFunction[i] = c2pDispatchGeneral;

}

DriverObject->DriverExtension->AddDevice = MyAddDevice;

// 单独的填写一个Read分发函数。因为要的过滤就是读取来的按键信息

// 其他的都不重要。这个分发函数单独写。

DriverObject->MajorFunction[IRP_MJ_READ] = c2pDispatchRead;

// 单独的填写一个IRP_MJ_POWER函数。这是因为这类请求中间要调用

// 一个PoCallDriver和一个PoStartNextPowerIrp,比较特殊。

DriverObject->MajorFunction [IRP_MJ_POWER] = c2pPower;

// 我们想知道什么时候一个我们绑定过的设备被卸载了(比如从机器上

// 被拔掉了?)所以专门写一个PNP(即插即用)分发函数

DriverObject->MajorFunction [IRP_MJ_PNP] = c2pPnP;

// 卸载函数。

DriverObject->DriverUnload = c2pUnload;

gDriverObject = DriverObject;

// 绑定所有键盘设备f

status = c2pAttachDevices(DriverObject, RegistryPath);

return status;

}

DRIVER_ADD_DEVICE MyAddDevice;

NTSTATUS MyAddDevice(IN PDRIVER_OBJECT DriverObject, IN PDEVICE_OBJECT pPhysicalDevice)

{

KdPrint(("In MYAddDevice"));

NTSTATUSstatus= STATUS_SUCCESS;

PDEVICE_OBJECT  pFilterDevice= NULL;

PDEVICE_OBJECTpLowerDevice= NULL;

// 创建过滤设备

/*IoCreateDevice(

IN DriverObject,

IN sizeof(C2P_DEV_EXT),

IN NULL,

IN pTargetDeviceObject->DeviceType,

IN pTargetDeviceObject->Characteristics,

IN FALSE,

OUT &pFilterDeviceObject

);*/

status = IoCreateDevice(DriverObject,sizeof(C2P_DEV_EXT),NULL,

pPhysicalDevice->DeviceType, pPhysicalDevice->Characteristics, FALSE, &pFilterDevice);

if(!NT_SUCCESS(status))

{

KdPrint(("-----Fail ==> KeyFilter::CY_KeyFilte::AddDevice->IoCreateDevice(%d)",status));

return status;

}

C2P_DEV_EXT *pDevExt = (C2P_DEV_EXT *)pFilterDevice->DeviceExtension;

pDevExt->NodeSize = sizeof(C2P_DEV_EXT);

pDevExt->pFilterDeviceObject = pFilterDevice;

pLowerDevice = IoAttachDeviceToDeviceStack(pFilterDevice, pPhysicalDevice);// 绑定

if(!pLowerDevice)

{

KdPrint(("-----Fail ==> KeyFilter::CY_KeyFilte::AddDevice->IoAttachDeviceToDeviceStack(%d)",status));

return STATUS_UNSUCCESSFUL;

}

pFilterDevice->Flags |= pLowerDevice->Flags & (DO_BUFFERED_IO | DO_DIRECT_IO | DO_POWER_PAGABLE) ;

pFilterDevice->Flags &= ~DO_DEVICE_INITIALIZING;

pDevExt->LowerDeviceObject = pLowerDevice;

pDevExt->TargetDeviceObject = pPhysicalDevice;

return status;

}

NTSTATUS c2pPnP(

IN PDEVICE_OBJECT DeviceObject,

IN PIRP Irp

)

{

KdPrint(("PNP in\n"));

PC2P_DEV_EXT devExt;

PIO_STACK_LOCATION irpStack;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,关于89C52RC单片机驱动WS2812B灯带的程序,这是一个涉及到硬件层面的具体实现,需要编写底层的驱动代码。 以下是一份C语言的代码示例,可能并非适用于所有硬件配置,需要根据具体情况做相应的变更: ``` #include <reg52.h> // 引入89C52RC单片机头文件 #define uchar unsigned char // 定义无符号字符类型 #define uint unsigned int // 定义无符号整型 #define LED_PIN P1_0 // LED控制引脚 // 定义颜色宏 #define BLACK 0x00 // 黑色 #define RED 0xFF0000 // 红色 #define GREEN 0x00FF00 // 绿色 #define BLUE 0x0000FF // 蓝色 // 定义灯带字节长度 #define LED_NUM 10 // 假设有10个LED灯 // 定义灯带缓存数组 uchar led_buffer[LED_NUM * 3]; // 每个LED灯需要3个字节,所以缓存数组长度为LED_NUM * 3 // 延时函数 void delay_ms(uint time) { uint i,j; for(i=0;i<time;i++) for(j=0;j<120;j++); } // 发送一个字节的数据到灯带 void ws2812b_send_byte(uchar data) { uchar i; for (i = 0; i < 8; i++) { if (data & 0x80) { LED_PIN = 1; delay_ms(0.6); LED_PIN = 0; delay_ms(0.3); } else { LED_PIN = 1; delay_ms(0.3); LED_PIN = 0; delay_ms(0.6); } data <<= 1; } } // 发送一个颜色数据到灯带 void ws2812b_send_color(uint color) { ws2812b_send_byte(color >> 16 & 0xFF); // 发送红色数据 ws2812b_send_byte(color >> 8 & 0xFF); // 发送绿色数据 ws2812b_send_byte(color & 0xFF); // 发送蓝色数据 } // 发送整个灯带的数据 void ws2812b_send_buffer() { uchar i, j; for (i = 0; i < LED_NUM; i++) { for (j = 0; j < 3; j++) { ws2812b_send_byte(led_buffer[i * 3 + j]); } } } // 初始化灯带 void ws2812b_init() { uchar i; for (i = 0; i < LED_NUM; i++) { led_buffer[i * 3] = 0; led_buffer[i * 3 + 1] = 0; led_buffer[i * 3 + 2] = 0; } ws2812b_send_buffer(); } // 通过索引设置某一个LED灯的颜色 void set_led_color(uchar index, uint color) { led_buffer[index * 3] = color >> 16 & 0xFF; // 设置红色数据 led_buffer[index * 3 + 1] = color >> 8 & 0xFF; // 设置绿色数据 led_buffer[index * 3 + 2] = color & 0xFF; // 设置蓝色数据 } // 主函数 void main() { ws2812b_init(); // 初始化灯带 set_led_color(0, RED); // 设置第1个LED灯为红色 set_led_color(1, GREEN); // 设置第2个LED灯为绿色 set_led_color(2, BLUE); // 设置第3个LED灯为蓝色 ws2812b_send_buffer(); // 发送整个灯带的数据 while(1); } ``` 希望以上代码能够帮助到你,如果需要更多的帮助,请随时联系我。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值