usb驱动(3)

usbmouse_as_key.c

/*
 * drivers\hid\usbhid\usbmouse.c
 */
#include <linux/kernel.h>
#include <linux/slab.h>
#include <linux/module.h>
#include <linux/init.h>
#include <linux/usb/input.h>
#include <linux/hid.h>
static struct input_dev *uk_dev;
static char *usb_buf;
static dma_addr_t usb_buf_phys;
static int len;
static struct urb *uk_urb;
static struct usb_device_id usbmouse_as_key_id_table [] = {
 { USB_INTERFACE_INFO(USB_INTERFACE_CLASS_HID, USB_INTERFACE_SUBCLASS_BOOT,
  USB_INTERFACE_PROTOCOL_MOUSE) },
 //{USB_DEVICE(0x1234,0x5678)},
 { } /* Terminating entry */
};
static void usbmouse_as_key_irq(struct urb *urb)
{
 int i;
 static int cnt = 0;
 printk("data cnt %d: ", ++cnt);
 for (i = 0; i < len; i++)
 {
  printk("%02x ", usb_buf[i]);
 }
 printk("\n");
 /* 重新提交urb */
 usb_submit_urb(uk_urb, GFP_KERNEL);
}
static int usbmouse_as_key_probe(struct usb_interface *intf, const struct usb_device_id *id)
{
 struct usb_device *dev = interface_to_usbdev(intf);
 struct usb_host_interface *interface;
 struct usb_endpoint_descriptor *endpoint;
 int pipe;
 interface = intf->cur_altsetting;
 endpoint = &interface->endpoint[0].desc;
 /* a. 分配一个input_dev */
 uk_dev = input_allocate_device();
 /* b. 设置 */
 /* b.1 能产生哪类事件 */
 set_bit(EV_KEY, uk_dev->evbit);
 set_bit(EV_REP, uk_dev->evbit);
 /* b.2 能产生哪些事件 */
 set_bit(KEY_L, uk_dev->keybit);
 set_bit(KEY_S, uk_dev->keybit);
 set_bit(KEY_ENTER, uk_dev->keybit);
 /* c. 注册 */
 input_register_device(uk_dev);
 /* d. 硬件相关操作 */
 /* 数据传输3要素: 源,目的,长度 */
 /* 源: USB设备的某个端点 */
 pipe = usb_rcvintpipe(dev, endpoint->bEndpointAddress);
 /* 长度: */
 len = endpoint->wMaxPacketSize;
 /* 目的: */
 usb_buf = usb_buffer_alloc(dev, len, GFP_ATOMIC, &usb_buf_phys);
 /* 使用"3要素" */
 /* 分配usb request block */
 uk_urb = usb_alloc_urb(0, GFP_KERNEL);
 /* 使用"3要素设置urb" */
 usb_fill_int_urb(uk_urb, dev, pipe, usb_buf, len, usbmouse_as_key_irq, NULL, endpoint->bInterval);
 uk_urb->transfer_dma = usb_buf_phys;
 uk_urb->transfer_flags |= URB_NO_TRANSFER_DMA_MAP;
 /* 使用URB */
 usb_submit_urb(uk_urb, GFP_KERNEL);
 return 0;
}
static void usbmouse_as_key_disconnect(struct usb_interface *intf)
{
 struct usb_device *dev = interface_to_usbdev(intf);
 //printk("disconnect usbmouse!\n");
 usb_kill_urb(uk_urb);
 usb_free_urb(uk_urb);
 usb_buffer_free(dev, len, usb_buf, usb_buf_phys);
 input_unregister_device(uk_dev);
 input_free_device(uk_dev);
}
/* 1. 分配/设置usb_driver */
static struct usb_driver usbmouse_as_key_driver = {
 .name  = "usbmouse_as_key_",
 .probe  = usbmouse_as_key_probe,
 .disconnect = usbmouse_as_key_disconnect,
 .id_table = usbmouse_as_key_id_table,
};
static int usbmouse_as_key_init(void)
{
 /* 2. 注册 */
 usb_register(&usbmouse_as_key_driver);
 return 0;
}
static void usbmouse_as_key_exit(void)
{
 usb_deregister(&usbmouse_as_key_driver); 
}
module_init(usbmouse_as_key_init);
module_exit(usbmouse_as_key_exit);
MODULE_LICENSE("GPL");
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值