/*\r
LUFA Library\r
- Copyright (C) Dean Camera, 2009.\r
+ Copyright (C) Dean Camera, 2010.\r
\r
dean [at] fourwalledcubicle [dot] com\r
www.fourwalledcubicle.com\r
*/\r
\r
/*\r
- Copyright 2009 Dean Camera (dean [at] fourwalledcubicle [dot] com)\r
-\r
- Permission to use, copy, modify, and distribute this software\r
- and its documentation for any purpose and without fee is hereby\r
- granted, provided that the above copyright notice appear in all\r
- copies and that both that the copyright notice and this\r
- permission notice and warranty disclaimer appear in supporting\r
- documentation, and that the name of the author not be used in\r
- advertising or publicity pertaining to distribution of the\r
+ Copyright 2010 Dean Camera (dean [at] fourwalledcubicle [dot] com)\r
+\r
+ Permission to use, copy, modify, distribute, and sell this \r
+ software and its documentation for any purpose is hereby granted\r
+ without fee, provided that the above copyright notice appear in \r
+ all copies and that both that the copyright notice and this\r
+ permission notice and warranty disclaimer appear in supporting \r
+ documentation, and that the name of the author not be used in \r
+ advertising or publicity pertaining to distribution of the \r
software without specific, written prior permission.\r
\r
The author disclaim all warranties with regard to this\r
.Config =\r
{\r
.DataINPipeNumber = 1,\r
+ .DataINPipeDoubleBank = false,\r
+ \r
.DataOUTPipeNumber = 2,\r
+ .DataOUTPipeDoubleBank = false,\r
},\r
};\r
\r
\r
/** Main program entry point. This routine configures the hardware required by the application, then\r
- * starts the scheduler to run the application tasks.\r
+ * enters a loop to run the application tasks in sequence.\r
*/\r
int main(void)\r
{\r
uint16_t ConfigDescriptorSize;\r
uint8_t ConfigDescriptorData[512];\r
\r
- if ((USB_GetDeviceConfigDescriptor(1, &ConfigDescriptorSize, NULL) != HOST_SENDCONTROL_Successful) ||\r
- (ConfigDescriptorSize > sizeof(ConfigDescriptorData)) ||\r
- (USB_GetDeviceConfigDescriptor(1, &ConfigDescriptorSize, ConfigDescriptorData)))\r
+ if (USB_Host_GetDeviceConfigDescriptor(1, &ConfigDescriptorSize, ConfigDescriptorData,\r
+ sizeof(ConfigDescriptorData)) != HOST_GETCONFIG_Successful)\r
{\r
printf("Error Retrieving Configuration Descriptor.\r\n");\r
LEDs_SetAllLEDs(LEDMASK_USB_ERROR);\r
}\r
\r
if (MS_Host_ConfigurePipes(&FlashDisk_MS_Interface,\r
- ConfigDescriptorSize, ConfigDescriptorData) != MS_ENUMERROR_NoError)\r
+ ConfigDescriptorSize, ConfigDescriptorData) != MS_ENUMERROR_NoError)\r
{\r
- printf("Attached Device Not a Valid Mouse.\r\n");\r
+ printf("Attached Device Not a Valid Mass Storage Device.\r\n");\r
LEDs_SetAllLEDs(LEDMASK_USB_ERROR);\r
USB_HostState = HOST_STATE_WaitForDeviceRemoval;\r
break;\r
break;\r
}\r
\r
- printf("Mouse Enumerated.\r\n");\r
+ printf("Mass Storage Device Enumerated.\r\n");\r
USB_HostState = HOST_STATE_Configured;\r
break;\r
case HOST_STATE_Configured:\r
break;\r
}\r
\r
+ printf("Total LUNs: %d - Using first LUN in device.\r\n", (MaxLUNIndex + 1));\r
+ \r
if (MS_Host_ResetMSInterface(&FlashDisk_MS_Interface))\r
{\r
printf("Error resetting Mass Storage interface.\r\n");\r
}\r
\r
SCSI_Inquiry_Response_t InquiryData;\r
- if (MS_Host_GetInquiryData(&FlashDisk_MS_Interface, &InquiryData))\r
+ if (MS_Host_GetInquiryData(&FlashDisk_MS_Interface, 0, &InquiryData))\r
{\r
- printf("Error retreiving device Inquiry data.\r\n");\r
+ printf("Error retrieving device Inquiry data.\r\n");\r
LEDs_SetAllLEDs(LEDMASK_USB_ERROR);\r
USB_HostState = HOST_STATE_WaitForDeviceRemoval;\r
break; \r
printf("Vendor \"%.8s\", Product \"%.16s\"\r\n", InquiryData.VendorID, InquiryData.ProductID);\r
\r
printf("Waiting until ready...\r\n");\r
- bool DeviceReady;\r
\r
- do\r
+ for (;;)\r
{\r
- if (MS_Host_TestUnitReady(&FlashDisk_MS_Interface, 0, &DeviceReady))\r
+ uint8_t ErrorCode = MS_Host_TestUnitReady(&FlashDisk_MS_Interface, 0);\r
+ \r
+ if (!(ErrorCode))\r
+ break;\r
+\r
+ /* Check if an error other than a logical command error (device busy) received */\r
+ if (ErrorCode != MS_ERROR_LOGICAL_CMD_FAILED)\r
{\r
printf("Error waiting for device to be ready.\r\n");\r
LEDs_SetAllLEDs(LEDMASK_USB_ERROR);\r
break;\r
}\r
}\r
- while (!(DeviceReady));\r
\r
printf("Retrieving Capacity... ");\r
\r