Fixed bug in RNDISEthernet and DualCDC demos not using the correct USB_ControlRequest...
[pub/USBasp.git] / Demos / Host / MouseHost / MouseHost.c
index dd7ff73..3c858a8 100644 (file)
  \r
 #include "MouseHost.h"\r
 \r
-/* Project Tags, for reading out using the ButtLoad project */\r
-BUTTLOADTAG(ProjName,    "LUFA Mouse Host App");\r
-BUTTLOADTAG(BuildTime,   __TIME__);\r
-BUTTLOADTAG(BuildDate,   __DATE__);\r
-BUTTLOADTAG(LUFAVersion, "LUFA V" LUFA_VERSION_STRING);\r
-\r
 /* Scheduler Task List */\r
 TASK_LIST\r
 {\r
-       { Task: USB_USBTask          , TaskStatus: TASK_STOP },\r
-       { Task: USB_Mouse_Host       , TaskStatus: TASK_STOP },\r
+       { .Task = USB_USBTask          , .TaskStatus = TASK_STOP },\r
+       { .Task = USB_Mouse_Host       , .TaskStatus = TASK_STOP },\r
 };\r
 \r
 \r
@@ -75,7 +69,7 @@ int main(void)
        /* Initialize USB Subsystem */\r
        USB_Init();\r
 \r
-       /* Startup message */\r
+       /* Start-up message */\r
        puts_P(PSTR(ESC_RESET ESC_BG_WHITE ESC_INVERSE_ON ESC_ERASE_DISPLAY\r
               "Mouse Host Demo running.\r\n" ESC_INVERSE_OFF));\r
                   \r
@@ -132,7 +126,7 @@ EVENT_HANDLER(USB_HostError)
        for(;;);\r
 }\r
 \r
-/** Event handler for the USB_DeviceEnumerationFailed event. This indicates that a problem occured while\r
+/** Event handler for the USB_DeviceEnumerationFailed event. This indicates that a problem occurred while\r
  *  enumerating an attached USB device.\r
  */\r
 EVENT_HANDLER(USB_DeviceEnumerationFailed)\r
@@ -188,49 +182,53 @@ void ReadNextReport(void)
        Pipe_SelectPipe(MOUSE_DATAPIPE);        \r
 \r
        #if !defined(INTERRUPT_DATA_PIPE)\r
-       /* Unfreeze mouse data pipe */\r
+       /* Unfreeze keyboard data pipe */\r
        Pipe_Unfreeze();\r
        #endif\r
 \r
-       /* Ensure pipe contains data and is ready to be read before continuing */\r
-       if (!(Pipe_ReadWriteAllowed()))\r
+       /* Check to see if a packet has been received */\r
+       if (!(Pipe_IsINReceived()))\r
        {\r
                #if !defined(INTERRUPT_DATA_PIPE)\r
-               /* Refreeze mouse data pipe */\r
+               /* Refreeze HID data IN pipe */\r
                Pipe_Freeze();\r
                #endif\r
-\r
+                       \r
                return;\r
        }\r
 \r
-       /* Read in mouse report data */\r
-       Pipe_Read_Stream_LE(&MouseReport, sizeof(MouseReport));                         \r
-               \r
-       /* Clear the IN endpoint, ready for next data packet */\r
-       Pipe_ClearCurrentBank();\r
+       /* Ensure pipe contains data before trying to read from it */\r
+       if (Pipe_IsReadWriteAllowed())\r
+       {\r
+               /* Read in mouse report data */\r
+               Pipe_Read_Stream_LE(&MouseReport, sizeof(MouseReport));                         \r
+\r
+               /* Alter status LEDs according to mouse X movement */\r
+               if (MouseReport.X > 0)\r
+                 LEDMask |= LEDS_LED1;\r
+               else if (MouseReport.X < 0)\r
+                 LEDMask |= LEDS_LED2;\r
+                       \r
+               /* Alter status LEDs according to mouse Y movement */\r
+               if (MouseReport.Y > 0)\r
+                 LEDMask |= LEDS_LED3;\r
+               else if (MouseReport.Y < 0)\r
+                 LEDMask |= LEDS_LED4;\r
+\r
+               /* Alter status LEDs according to mouse button position */\r
+               if (MouseReport.Button)\r
+                 LEDMask  = LEDS_ALL_LEDS;\r
                \r
-       /* Alter status LEDs according to mouse X movement */\r
-       if (MouseReport.X > 0)\r
-         LEDMask |= LEDS_LED1;\r
-       else if (MouseReport.X < 0)\r
-         LEDMask |= LEDS_LED2;\r
+               LEDs_SetAllLEDs(LEDMask);\r
                \r
-       /* Alter status LEDs according to mouse Y movement */\r
-       if (MouseReport.Y > 0)\r
-         LEDMask |= LEDS_LED3;\r
-       else if (MouseReport.Y < 0)\r
-         LEDMask |= LEDS_LED4;\r
-\r
-       /* Alter status LEDs according to mouse button position */\r
-       if (MouseReport.Button)\r
-         LEDMask  = LEDS_ALL_LEDS;\r
-       \r
-       LEDs_SetAllLEDs(LEDMask);\r
-       \r
-       /* Print mouse report data through the serial port */\r
-       printf_P(PSTR("dX:%2d dY:%2d Button:%d\r\n"), MouseReport.X,\r
-                                                                                                 MouseReport.Y,\r
-                                                                                                 MouseReport.Button);\r
+               /* Print mouse report data through the serial port */\r
+               printf_P(PSTR("dX:%2d dY:%2d Button:%d\r\n"), MouseReport.X,\r
+                                                                                                         MouseReport.Y,\r
+                                                                                                         MouseReport.Button);\r
+       }\r
+\r
+       /* Clear the IN endpoint, ready for next data packet */\r
+       Pipe_ClearIN();\r
 \r
        #if !defined(INTERRUPT_DATA_PIPE)\r
        /* Refreeze mouse data pipe */\r
@@ -250,16 +248,19 @@ TASK(USB_Mouse_Host)
        {\r
                case HOST_STATE_Addressed:\r
                        /* Standard request to set the device configuration to configuration 1 */\r
-                       USB_HostRequest = (USB_Host_Request_Header_t)\r
+                       USB_ControlRequest = (USB_Request_Header_t)\r
                                {\r
-                                       bmRequestType: (REQDIR_HOSTTODEVICE | REQTYPE_STANDARD | REQREC_DEVICE),\r
-                                       bRequest:      REQ_SetConfiguration,\r
-                                       wValue:        1,\r
-                                       wIndex:        0,\r
-                                       wLength:       0,\r
+                                       .bmRequestType = (REQDIR_HOSTTODEVICE | REQTYPE_STANDARD | REQREC_DEVICE),\r
+                                       .bRequest      = REQ_SetConfiguration,\r
+                                       .wValue        = 1,\r
+                                       .wIndex        = 0,\r
+                                       .wLength       = 0,\r
                                };\r
 \r
-                       /* Send the request, display error and wait for device detatch if request fails */\r
+                       /* Select the control pipe for the request transfer */\r
+                       Pipe_SelectPipe(PIPE_CONTROLPIPE);\r
+\r
+                       /* Send the request, display error and wait for device detach if request fails */\r
                        if ((ErrorCode = USB_Host_SendControlRequest(NULL)) != HOST_SENDCONTROL_Successful)\r
                        {\r
                                puts_P(PSTR("Control Error (Set Configuration).\r\n"));\r
@@ -297,16 +298,19 @@ TASK(USB_Mouse_Host)
                        }\r
                \r
                        /* HID class request to set the mouse protocol to the Boot Protocol */\r
-                       USB_HostRequest = (USB_Host_Request_Header_t)\r
+                       USB_ControlRequest = (USB_Request_Header_t)\r
                                {\r
-                                       bmRequestType: (REQDIR_HOSTTODEVICE | REQTYPE_CLASS | REQREC_INTERFACE),\r
-                                       bRequest:      REQ_SetProtocol,\r
-                                       wValue:        0,\r
-                                       wIndex:        0,\r
-                                       wLength:       0,\r
+                                       .bmRequestType = (REQDIR_HOSTTODEVICE | REQTYPE_CLASS | REQREC_INTERFACE),\r
+                                       .bRequest      = REQ_SetProtocol,\r
+                                       .wValue        = 0,\r
+                                       .wIndex        = 0,\r
+                                       .wLength       = 0,\r
                                };\r
 \r
-                       /* Send the request, display error and wait for device detatch if request fails */\r
+                       /* Select the control pipe for the request transfer */\r
+                       Pipe_SelectPipe(PIPE_CONTROLPIPE);\r
+\r
+                       /* Send the request, display error and wait for device detach if request fails */\r
                        if ((ErrorCode = USB_Host_SendControlRequest(NULL)) != HOST_SENDCONTROL_Successful)\r
                        {\r
                                puts_P(PSTR("Control Error (Set Protocol).\r\n"));\r