projects
/
pub
/
USBasp.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Collapse configuration descriptor size retrieval and size testing into a single if...
[pub/USBasp.git]
/
Demos
/
Device
/
LowLevel
/
Mouse
/
Mouse.c
diff --git
a/Demos/Device/LowLevel/Mouse/Mouse.c
b/Demos/Device/LowLevel/Mouse/Mouse.c
index
4221536
..
d15f688
100644
(file)
--- a/
Demos/Device/LowLevel/Mouse/Mouse.c
+++ b/
Demos/Device/LowLevel/Mouse/Mouse.c
@@
-119,13
+119,16
@@
void EVENT_USB_Disconnect(void)
*/
\r
void EVENT_USB_ConfigurationChanged(void)
\r
{
\r
*/
\r
void EVENT_USB_ConfigurationChanged(void)
\r
{
\r
- /* Setup Mouse Report Endpoint */
\r
- Endpoint_ConfigureEndpoint(MOUSE_EPNUM, EP_TYPE_INTERRUPT,
\r
- ENDPOINT_DIR_IN, MOUSE_EPSIZE,
\r
- ENDPOINT_BANK_SINGLE);
\r
-
\r
/* Indicate USB connected and ready */
\r
LEDs_SetAllLEDs(LEDMASK_USB_READY);
\r
/* Indicate USB connected and ready */
\r
LEDs_SetAllLEDs(LEDMASK_USB_READY);
\r
+
\r
+ /* Setup Mouse Report Endpoint */
\r
+ if (!(Endpoint_ConfigureEndpoint(MOUSE_EPNUM, EP_TYPE_INTERRUPT,
\r
+ ENDPOINT_DIR_IN, MOUSE_EPSIZE,
\r
+ ENDPOINT_BANK_SINGLE)))
\r
+ {
\r
+ LEDs_SetAllLEDs(LEDMASK_USB_ERROR);
\r
+ }
\r
}
\r
\r
/** Event handler for the USB_UnhandledControlPacket event. This is used to catch standard and class specific
\r
}
\r
\r
/** Event handler for the USB_UnhandledControlPacket event. This is used to catch standard and class specific
\r
@@
-169,9
+172,7
@@
void EVENT_USB_UnhandledControlPacket(void)
/* Send the flag to the host */
\r
Endpoint_ClearIN();
\r
\r
/* Send the flag to the host */
\r
Endpoint_ClearIN();
\r
\r
- /* Acknowledge status stage */
\r
- while (!(Endpoint_IsOUTReceived()));
\r
- Endpoint_ClearOUT();
\r
+ Endpoint_ClearStatusStage();
\r
}
\r
\r
break;
\r
}
\r
\r
break;
\r
@@
-183,9
+184,7
@@
void EVENT_USB_UnhandledControlPacket(void)
/* Set or clear the flag depending on what the host indicates that the current Protocol should be */
\r
UsingReportProtocol = (USB_ControlRequest.wValue != 0);
\r
\r
/* Set or clear the flag depending on what the host indicates that the current Protocol should be */
\r
UsingReportProtocol = (USB_ControlRequest.wValue != 0);
\r
\r
- /* Acknowledge status stage */
\r
- while (!(Endpoint_IsINReady()));
\r
- Endpoint_ClearIN();
\r
+ Endpoint_ClearStatusStage();
\r
}
\r
\r
break;
\r
}
\r
\r
break;
\r
@@
-194,12
+193,10
@@
void EVENT_USB_UnhandledControlPacket(void)
{
\r
Endpoint_ClearSETUP();
\r
\r
{
\r
Endpoint_ClearSETUP();
\r
\r
- /* Get idle period in MSB */
\r
- IdleCount = (
USB_ControlRequest.wValue >> 8
);
\r
+ /* Get idle period in MSB
, must multiply by 4 to get the duration in milliseconds
*/
\r
+ IdleCount = (
(USB_ControlRequest.wValue & 0xFF00) >> 6
);
\r
\r
\r
- /* Acknowledge status stage */
\r
- while (!(Endpoint_IsINReady()));
\r
- Endpoint_ClearIN();
\r
+ Endpoint_ClearStatusStage();
\r
}
\r
\r
break;
\r
}
\r
\r
break;
\r
@@
-208,15
+205,13
@@
void EVENT_USB_UnhandledControlPacket(void)
{
\r
Endpoint_ClearSETUP();
\r
\r
{
\r
Endpoint_ClearSETUP();
\r
\r
- /* Write the current idle duration to the host */
\r
- Endpoint_Write_Byte(IdleCount);
\r
+ /* Write the current idle duration to the host
, must be divided by 4 before sent to host
*/
\r
+ Endpoint_Write_Byte(IdleCount
>> 2
);
\r
\r
/* Send the flag to the host */
\r
Endpoint_ClearIN();
\r
\r
\r
/* Send the flag to the host */
\r
Endpoint_ClearIN();
\r
\r
- /* Acknowledge status stage */
\r
- while (!(Endpoint_IsOUTReceived()));
\r
- Endpoint_ClearOUT();
\r
+ Endpoint_ClearStatusStage();
\r
}
\r
\r
break;
\r
}
\r
\r
break;
\r
@@
-235,7
+230,7
@@
ISR(TIMER0_COMPA_vect, ISR_BLOCK)
\r
/** Fills the given HID report data structure with the next HID report to send to the host.
\r
*
\r
\r
/** Fills the given HID report data structure with the next HID report to send to the host.
\r
*
\r
- * \param ReportData Pointer to a HID report data structure to be filled
\r
+ * \param
[out]
ReportData Pointer to a HID report data structure to be filled
\r
*/
\r
void CreateMouseReport(USB_MouseReport_Data_t* ReportData)
\r
{
\r
*/
\r
void CreateMouseReport(USB_MouseReport_Data_t* ReportData)
\r
{
\r
@@
-286,8
+281,8
@@
void SendNextReport(void)
/* Check if the idle period is set and has elapsed */
\r
if ((IdleCount != HID_IDLE_CHANGESONLY) && (!(IdleMSRemaining)))
\r
{
\r
/* Check if the idle period is set and has elapsed */
\r
if ((IdleCount != HID_IDLE_CHANGESONLY) && (!(IdleMSRemaining)))
\r
{
\r
- /* Reset the idle time remaining counter
, must multiply by 4 to get the duration in milliseconds
*/
\r
- IdleMSRemaining =
(IdleCount << 2)
;
\r
+ /* Reset the idle time remaining counter */
\r
+ IdleMSRemaining =
IdleCount
;
\r
\r
/* Idle period is set and has elapsed, must send a report to the host */
\r
SendReport = true;
\r
\r
/* Idle period is set and has elapsed, must send a report to the host */
\r
SendReport = true;
\r
@@
-310,10
+305,10
@@
void SendNextReport(void)
/** Task to manage HID report generation and transmission to the host, when in report mode. */
\r
void Mouse_Task(void)
\r
{
\r
/** Task to manage HID report generation and transmission to the host, when in report mode. */
\r
void Mouse_Task(void)
\r
{
\r
- /*
Check if the USB system is connected to a host
*/
\r
- if (USB_
IsConnect
ed)
\r
- {
\r
- /* Send the next mouse report to the host */
\r
- SendNextReport();
\r
- }
\r
+ /*
Device must be connected and configured for the task to run
*/
\r
+ if (USB_
DeviceState != DEVICE_STATE_Configur
ed)
\r
+ return;
\r
+
\r
+ /* Send the next mouse report to the host */
\r
+ SendNextReport();
\r
}
\r
}
\r