forked from mfulz_github/qmk_firmware
Move Dataflash operational checking code out from SCSI.c into the DataflashManager.c in the Device mode Mass Storage demos.
This commit is contained in:
parent
242303c160
commit
576f40f5ae
|
@ -490,3 +490,36 @@ void DataflashManager_ResetDataflashProtections(void)
|
||||||
/* Deselect current dataflash chip */
|
/* Deselect current dataflash chip */
|
||||||
Dataflash_DeselectChip();
|
Dataflash_DeselectChip();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** Performs a simple test on the attached Dataflash IC(s) to ensure that they are working.
|
||||||
|
*
|
||||||
|
* \return Boolean true if all media chips are working, false otherwise
|
||||||
|
*/
|
||||||
|
bool DataflashManager_CheckDataflashOperation(void)
|
||||||
|
{
|
||||||
|
uint8_t ReturnByte;
|
||||||
|
|
||||||
|
/* Test first Dataflash IC is present and responding to commands */
|
||||||
|
Dataflash_SelectChip(DATAFLASH_CHIP1);
|
||||||
|
Dataflash_SendByte(DF_CMD_READMANUFACTURERDEVICEINFO);
|
||||||
|
ReturnByte = Dataflash_ReceiveByte();
|
||||||
|
Dataflash_DeselectChip();
|
||||||
|
|
||||||
|
/* If returned data is invalid, fail the command */
|
||||||
|
if (ReturnByte != DF_MANUFACTURER_ATMEL)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
#if (DATAFLASH_TOTALCHIPS == 2)
|
||||||
|
/* Test second Dataflash IC is present and responding to commands */
|
||||||
|
Dataflash_SelectChip(DATAFLASH_CHIP2);
|
||||||
|
Dataflash_SendByte(DF_CMD_READMANUFACTURERDEVICEINFO);
|
||||||
|
ReturnByte = Dataflash_ReceiveByte();
|
||||||
|
Dataflash_DeselectChip();
|
||||||
|
|
||||||
|
/* If returned data is invalid, fail the command */
|
||||||
|
if (ReturnByte != DF_MANUFACTURER_ATMEL)
|
||||||
|
return false;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
|
@ -73,5 +73,6 @@
|
||||||
void DataflashManager_ReadBlocks_RAM(const uint32_t BlockAddress, uint16_t TotalBlocks,
|
void DataflashManager_ReadBlocks_RAM(const uint32_t BlockAddress, uint16_t TotalBlocks,
|
||||||
uint8_t* BufferPtr) ATTR_NON_NULL_PTR_ARG(3);
|
uint8_t* BufferPtr) ATTR_NON_NULL_PTR_ARG(3);
|
||||||
void DataflashManager_ResetDataflashProtections(void);
|
void DataflashManager_ResetDataflashProtections(void);
|
||||||
|
bool DataflashManager_CheckDataflashOperation(void);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -237,8 +237,6 @@ static bool SCSI_Command_Read_Capacity_10(USB_ClassInfo_MS_Device_t* MSInterface
|
||||||
*/
|
*/
|
||||||
static bool SCSI_Command_Send_Diagnostic(USB_ClassInfo_MS_Device_t* MSInterfaceInfo)
|
static bool SCSI_Command_Send_Diagnostic(USB_ClassInfo_MS_Device_t* MSInterfaceInfo)
|
||||||
{
|
{
|
||||||
uint8_t ReturnByte;
|
|
||||||
|
|
||||||
/* Check to see if the SELF TEST bit is not set */
|
/* Check to see if the SELF TEST bit is not set */
|
||||||
if (!(MSInterfaceInfo->State.CommandBlock.SCSICommandData[1] & (1 << 2)))
|
if (!(MSInterfaceInfo->State.CommandBlock.SCSICommandData[1] & (1 << 2)))
|
||||||
{
|
{
|
||||||
|
@ -250,14 +248,8 @@ static bool SCSI_Command_Send_Diagnostic(USB_ClassInfo_MS_Device_t* MSInterfaceI
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Test first Dataflash IC is present and responding to commands */
|
/* Check to see if all attached Dataflash ICs are functional */
|
||||||
Dataflash_SelectChip(DATAFLASH_CHIP1);
|
if (!(DataflashManager_CheckDataflashOperation()))
|
||||||
Dataflash_SendByte(DF_CMD_READMANUFACTURERDEVICEINFO);
|
|
||||||
ReturnByte = Dataflash_ReceiveByte();
|
|
||||||
Dataflash_DeselectChip();
|
|
||||||
|
|
||||||
/* If returned data is invalid, fail the command */
|
|
||||||
if (ReturnByte != DF_MANUFACTURER_ATMEL)
|
|
||||||
{
|
{
|
||||||
/* Update SENSE key with a hardware error condition and return command fail */
|
/* Update SENSE key with a hardware error condition and return command fail */
|
||||||
SCSI_SET_SENSE(SCSI_SENSE_KEY_HARDWARE_ERROR,
|
SCSI_SET_SENSE(SCSI_SENSE_KEY_HARDWARE_ERROR,
|
||||||
|
@ -266,25 +258,6 @@ static bool SCSI_Command_Send_Diagnostic(USB_ClassInfo_MS_Device_t* MSInterfaceI
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if (DATAFLASH_TOTALCHIPS == 2)
|
|
||||||
/* Test second Dataflash IC is present and responding to commands */
|
|
||||||
Dataflash_SelectChip(DATAFLASH_CHIP2);
|
|
||||||
Dataflash_SendByte(DF_CMD_READMANUFACTURERDEVICEINFO);
|
|
||||||
ReturnByte = Dataflash_ReceiveByte();
|
|
||||||
Dataflash_DeselectChip();
|
|
||||||
|
|
||||||
/* If returned data is invalid, fail the command */
|
|
||||||
if (ReturnByte != DF_MANUFACTURER_ATMEL)
|
|
||||||
{
|
|
||||||
/* Update SENSE key with a hardware error condition and return command fail */
|
|
||||||
SCSI_SET_SENSE(SCSI_SENSE_KEY_HARDWARE_ERROR,
|
|
||||||
SCSI_ASENSE_NO_ADDITIONAL_INFORMATION,
|
|
||||||
SCSI_ASENSEQ_NO_QUALIFIER);
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Succeed the command and update the bytes transferred counter */
|
/* Succeed the command and update the bytes transferred counter */
|
||||||
MSInterfaceInfo->State.CommandBlock.DataTransferLength = 0;
|
MSInterfaceInfo->State.CommandBlock.DataTransferLength = 0;
|
||||||
|
|
|
@ -488,3 +488,36 @@ void DataflashManager_ResetDataflashProtections(void)
|
||||||
/* Deselect current dataflash chip */
|
/* Deselect current dataflash chip */
|
||||||
Dataflash_DeselectChip();
|
Dataflash_DeselectChip();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** Performs a simple test on the attached Dataflash IC(s) to ensure that they are working.
|
||||||
|
*
|
||||||
|
* \return Boolean true if all media chips are working, false otherwise
|
||||||
|
*/
|
||||||
|
bool DataflashManager_CheckDataflashOperation(void)
|
||||||
|
{
|
||||||
|
uint8_t ReturnByte;
|
||||||
|
|
||||||
|
/* Test first Dataflash IC is present and responding to commands */
|
||||||
|
Dataflash_SelectChip(DATAFLASH_CHIP1);
|
||||||
|
Dataflash_SendByte(DF_CMD_READMANUFACTURERDEVICEINFO);
|
||||||
|
ReturnByte = Dataflash_ReceiveByte();
|
||||||
|
Dataflash_DeselectChip();
|
||||||
|
|
||||||
|
/* If returned data is invalid, fail the command */
|
||||||
|
if (ReturnByte != DF_MANUFACTURER_ATMEL)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
#if (DATAFLASH_TOTALCHIPS == 2)
|
||||||
|
/* Test second Dataflash IC is present and responding to commands */
|
||||||
|
Dataflash_SelectChip(DATAFLASH_CHIP2);
|
||||||
|
Dataflash_SendByte(DF_CMD_READMANUFACTURERDEVICEINFO);
|
||||||
|
ReturnByte = Dataflash_ReceiveByte();
|
||||||
|
Dataflash_DeselectChip();
|
||||||
|
|
||||||
|
/* If returned data is invalid, fail the command */
|
||||||
|
if (ReturnByte != DF_MANUFACTURER_ATMEL)
|
||||||
|
return false;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
|
@ -71,5 +71,6 @@
|
||||||
void DataflashManager_ReadBlocks_RAM(const uint32_t BlockAddress, uint16_t TotalBlocks,
|
void DataflashManager_ReadBlocks_RAM(const uint32_t BlockAddress, uint16_t TotalBlocks,
|
||||||
uint8_t* BufferPtr) ATTR_NON_NULL_PTR_ARG(3);
|
uint8_t* BufferPtr) ATTR_NON_NULL_PTR_ARG(3);
|
||||||
void DataflashManager_ResetDataflashProtections(void);
|
void DataflashManager_ResetDataflashProtections(void);
|
||||||
|
bool DataflashManager_CheckDataflashOperation(void);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -239,12 +239,12 @@ static bool SCSI_Command_Read_Capacity_10(void)
|
||||||
* board, and indicates if they are present and functioning correctly. Only the Self-Test portion of the diagnostic command is
|
* board, and indicates if they are present and functioning correctly. Only the Self-Test portion of the diagnostic command is
|
||||||
* supported.
|
* supported.
|
||||||
*
|
*
|
||||||
|
* \param[in] MSInterfaceInfo Pointer to the Mass Storage class interface structure that the command is associated with
|
||||||
|
*
|
||||||
* \return Boolean true if the command completed successfully, false otherwise.
|
* \return Boolean true if the command completed successfully, false otherwise.
|
||||||
*/
|
*/
|
||||||
static bool SCSI_Command_Send_Diagnostic(void)
|
static bool SCSI_Command_Send_Diagnostic(void)
|
||||||
{
|
{
|
||||||
uint8_t ReturnByte;
|
|
||||||
|
|
||||||
/* Check to see if the SELF TEST bit is not set */
|
/* Check to see if the SELF TEST bit is not set */
|
||||||
if (!(CommandBlock.SCSICommandData[1] & (1 << 2)))
|
if (!(CommandBlock.SCSICommandData[1] & (1 << 2)))
|
||||||
{
|
{
|
||||||
|
@ -256,14 +256,8 @@ static bool SCSI_Command_Send_Diagnostic(void)
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Test first Dataflash IC is present and responding to commands */
|
/* Check to see if all attached Dataflash ICs are functional */
|
||||||
Dataflash_SelectChip(DATAFLASH_CHIP1);
|
if (!(DataflashManager_CheckDataflashOperation()))
|
||||||
Dataflash_SendByte(DF_CMD_READMANUFACTURERDEVICEINFO);
|
|
||||||
ReturnByte = Dataflash_ReceiveByte();
|
|
||||||
Dataflash_DeselectChip();
|
|
||||||
|
|
||||||
/* If returned data is invalid, fail the command */
|
|
||||||
if (ReturnByte != DF_MANUFACTURER_ATMEL)
|
|
||||||
{
|
{
|
||||||
/* Update SENSE key with a hardware error condition and return command fail */
|
/* Update SENSE key with a hardware error condition and return command fail */
|
||||||
SCSI_SET_SENSE(SCSI_SENSE_KEY_HARDWARE_ERROR,
|
SCSI_SET_SENSE(SCSI_SENSE_KEY_HARDWARE_ERROR,
|
||||||
|
@ -272,25 +266,6 @@ static bool SCSI_Command_Send_Diagnostic(void)
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if (DATAFLASH_TOTALCHIPS == 2)
|
|
||||||
/* Test second Dataflash IC is present and responding to commands */
|
|
||||||
Dataflash_SelectChip(DATAFLASH_CHIP2);
|
|
||||||
Dataflash_SendByte(DF_CMD_READMANUFACTURERDEVICEINFO);
|
|
||||||
ReturnByte = Dataflash_ReceiveByte();
|
|
||||||
Dataflash_DeselectChip();
|
|
||||||
|
|
||||||
/* If returned data is invalid, fail the command */
|
|
||||||
if (ReturnByte != DF_MANUFACTURER_ATMEL)
|
|
||||||
{
|
|
||||||
/* Update SENSE key with a hardware error condition and return command fail */
|
|
||||||
SCSI_SET_SENSE(SCSI_SENSE_KEY_HARDWARE_ERROR,
|
|
||||||
SCSI_ASENSE_NO_ADDITIONAL_INFORMATION,
|
|
||||||
SCSI_ASENSEQ_NO_QUALIFIER);
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Succeed the command and update the bytes transferred counter */
|
/* Succeed the command and update the bytes transferred counter */
|
||||||
CommandBlock.DataTransferLength = 0;
|
CommandBlock.DataTransferLength = 0;
|
||||||
|
|
|
@ -21,6 +21,7 @@
|
||||||
* - Add detailed overviews of how each demo works
|
* - Add detailed overviews of how each demo works
|
||||||
* - Master LUFA include file rather than per-module includes
|
* - Master LUFA include file rather than per-module includes
|
||||||
* - Change makefiles to allow for absolute LUFA location to be used
|
* - Change makefiles to allow for absolute LUFA location to be used
|
||||||
|
* - Abstract out the physical media from the Mass Storage device demos
|
||||||
* - Make new demos
|
* - Make new demos
|
||||||
* -# Multiple-report HID device
|
* -# Multiple-report HID device
|
||||||
* -# Dual Role Mouse Host/Keyboard Device
|
* -# Dual Role Mouse Host/Keyboard Device
|
||||||
|
|
Loading…
Reference in New Issue