00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00036 #include "mouse.h"
00037 #include <usb/debug.h>
00038 #include <usb/dev/poll.h>
00039 #include <errno.h>
00040 #include <str_error.h>
00041
00047 static int usbmouse_add_device(usb_device_t *dev)
00048 {
00049 int rc = usb_mouse_create(dev);
00050 if (rc != EOK) {
00051 usb_log_error("Failed to initialize device driver: %s.\n",
00052 str_error(rc));
00053 return rc;
00054 }
00055
00056 usb_log_debug("Polling pipe at endpoint %d.\n",
00057 dev->pipes[0].pipe->endpoint_no);
00058
00059 rc = usb_device_auto_poll(dev, 0,
00060 usb_mouse_polling_callback, dev->pipes[0].pipe->max_packet_size,
00061 usb_mouse_polling_ended_callback, dev->driver_data);
00062
00063 if (rc != EOK) {
00064 usb_log_error("Failed to start polling fibril: %s.\n",
00065 str_error(rc));
00066 return rc;
00067 }
00068
00069 usb_log_info("controlling new mouse (handle %" PRIun ").\n",
00070 dev->ddf_dev->handle);
00071
00072 return EOK;
00073 }
00074
00076 static usb_driver_ops_t mouse_driver_ops = {
00077 .add_device = usbmouse_add_device,
00078 };
00079
00080 static usb_endpoint_description_t *endpoints[] = {
00081 &poll_endpoint_description,
00082 NULL
00083 };
00084
00086 static usb_driver_t mouse_driver = {
00087 .name = NAME,
00088 .ops = &mouse_driver_ops,
00089 .endpoints = endpoints
00090 };
00091
00092 int main(int argc, char *argv[])
00093 {
00094 usb_log_enable(USB_LOG_LEVEL_DEFAULT, NAME);
00095
00096 return usb_driver_main(&mouse_driver);
00097 }
00098